diff options
author | Aki <please@ignore.pl> | 2022-04-01 21:23:39 +0200 |
---|---|---|
committer | Aki <please@ignore.pl> | 2022-04-01 21:23:39 +0200 |
commit | 3c487c5cd69c53d6fea948643c0a76df03516605 (patch) | |
tree | 72730c7b8b26a5ef8fc9a987ec4c16129efd5aac /StarsEx/NetClientConfig.cpp | |
parent | 8f353abd0bfe18baddd8a8250ab7c4f2d1c83a6e (diff) | |
download | starshatter-3c487c5cd69c53d6fea948643c0a76df03516605.zip starshatter-3c487c5cd69c53d6fea948643c0a76df03516605.tar.gz starshatter-3c487c5cd69c53d6fea948643c0a76df03516605.tar.bz2 |
Moved Stars45 to StarsEx
Diffstat (limited to 'StarsEx/NetClientConfig.cpp')
-rw-r--r-- | StarsEx/NetClientConfig.cpp | 331 |
1 files changed, 331 insertions, 0 deletions
diff --git a/StarsEx/NetClientConfig.cpp b/StarsEx/NetClientConfig.cpp new file mode 100644 index 0000000..2fd4d1b --- /dev/null +++ b/StarsEx/NetClientConfig.cpp @@ -0,0 +1,331 @@ +/* Starshatter: The Open Source Project + Copyright (c) 2021-2022, Starshatter: The Open Source Project Contributors + Copyright (c) 2011-2012, Starshatter OpenSource Distribution Contributors + Copyright (c) 1997-2006, Destroyer Studios LLC. + + AUTHOR: John DiCamillo + +*/ + + +#include "NetClientConfig.h" +#include "NetLobbyClient.h" +#include "NetBrokerClient.h" + +#include "NetLayer.h" +#include "NetAddr.h" +#include "NetHost.h" + +#include "Token.h" +#include "Game.h" +#include "DataLoader.h" +#include "ParseUtil.h" + +// +--------------------------------------------------------------------+ + +NetClientConfig* NetClientConfig::instance = 0; + +// +--------------------------------------------------------------------+ + +NetClientConfig::NetClientConfig() +: server_index(-1), host_request(false), conn(0) +{ + instance = this; + Load(); +} + +NetClientConfig::~NetClientConfig() +{ + Logout(); + + instance = 0; + servers.destroy(); +} + +// +--------------------------------------------------------------------+ + +void +NetClientConfig::Initialize() +{ + if (!instance) + instance = new NetClientConfig(); +} + +void +NetClientConfig::Close() +{ + delete instance; + instance = 0; +} + +// +--------------------------------------------------------------------+ + +void +NetClientConfig::AddServer(const char* name, const char* addr, WORD port, const char* pass, bool save) +{ + if (!addr || !*addr || port < 1024 || port > 48000) + return; + + char buffer[1024]; + if (name && *name) + strcpy_s(buffer, name); + else + sprintf_s(buffer, "%s:%d", addr, port); + + NetServerInfo* server = new NetServerInfo; + server->name = buffer; + server->hostname = addr; + server->addr = NetAddr(addr, port); + server->port = port; + server->password = pass; + server->save = save; + + if (server->addr.IPAddr() == 0) { + Print("NetClientConfig::AddServer(%s, %s, %d) failed to resolve IP Addr\n", + name, addr, port); + } + + servers.append(server); +} + +void +NetClientConfig::DelServer(int index) +{ + if (index >= 0 && index < servers.size()) { + delete servers.removeIndex(index); + } +} + +// +--------------------------------------------------------------------+ + +NetServerInfo* +NetClientConfig::GetServerInfo(int n) +{ + if (n >= 0 && n < servers.size()) + return servers.at(n); + + return 0; +} + +// +--------------------------------------------------------------------+ + +NetServerInfo* +NetClientConfig::GetSelectedServer() +{ + if (server_index >= 0 && server_index < servers.size()) + return servers.at(server_index); + + return 0; +} + +// +--------------------------------------------------------------------+ + +void +NetClientConfig::Download() +{ + Load(); + + List<NetServerInfo> list; + if (NetBrokerClient::GameList("Starshatter", list)) { + servers.append(list); + } +} + +// +--------------------------------------------------------------------+ + +void +NetClientConfig::Load() +{ + server_index = -1; + + // read the config file: + BYTE* block = 0; + int blocklen = 0; + + char filename[64]; + strcpy_s(filename, "client.cfg"); + + FILE* f; + ::fopen_s(&f, filename, "rb"); + + if (f) { + ::fseek(f, 0, SEEK_END); + blocklen = ftell(f); + ::fseek(f, 0, SEEK_SET); + + block = new BYTE[blocklen+1]; + block[blocklen] = 0; + + ::fread(block, blocklen, 1, f); + ::fclose(f); + } + + if (blocklen == 0) + return; + + servers.destroy(); + + Parser parser(new BlockReader((const char*) block, blocklen)); + Term* term = parser.ParseTerm(); + + if (!term) { + Print("ERROR: could not parse '%s'.\n", filename); + return; + } + else { + TermText* file_type = term->isText(); + if (!file_type || file_type->value() != "CLIENT_CONFIG") { + Print("WARNING: invalid '%s' file. Using defaults\n", filename); + return; + } + } + + do { + delete term; + + term = parser.ParseTerm(); + + if (term) { + TermDef* def = term->isDef(); + if (def) { + if (def->name()->value() == "server") { + if (!def->term() || !def->term()->isStruct()) { + Print("WARNING: server struct missing in '%s'\n", filename); + } + else { + TermStruct* val = def->term()->isStruct(); + + Text name; + Text addr; + Text pass; + int port; + + for (int i = 0; i < val->elements()->size(); i++) { + TermDef* pdef = val->elements()->at(i)->isDef(); + if (pdef) { + if (pdef->name()->value() == "name") + GetDefText(name, pdef, filename); + else if (pdef->name()->value() == "addr") + GetDefText(addr, pdef, filename); + else if (pdef->name()->value() == "pass") + GetDefText(pass, pdef, filename); + else if (pdef->name()->value() == "port") + GetDefNumber(port, pdef, filename); + } + } + + AddServer(name, addr, (WORD) port, pass, true); + } + } + else { + Print("WARNING: unknown label '%s' in '%s'\n", + def->name()->value().data(), filename); + } + } + } + } + while (term); + + delete [] block; +} + +// +--------------------------------------------------------------------+ + +void +NetClientConfig::Save() +{ + FILE* f; + fopen_s(&f, "client.cfg", "wb"); + if (f) { + fprintf(f, "CLIENT_CONFIG\n\n"); + + ListIter<NetServerInfo> iter = servers; + while (++iter) { + NetServerInfo* server = iter.value(); + + if (server->save) { + int port = (int) server->port; + fprintf(f, "server: {\n"); + fprintf(f, " name: \"%s\",\n", (const char*) server->name); + fprintf(f, " addr: \"%s\",\n", (const char*) server->hostname); + fprintf(f, " port: %d,\n", port); + + if (server->password.length()) + fprintf(f, " pass: \"%s\",\n", (const char*) server->password); + + fprintf(f, "}\n\n"); + } + } + + fclose(f); + } +} + +// +--------------------------------------------------------------------+ + +void +NetClientConfig::CreateConnection() +{ + NetServerInfo* s = GetSelectedServer(); + + if (s) { + NetAddr addr = s->addr; + + if (conn) { + if (conn->GetServerAddr().IPAddr() != addr.IPAddr() || + conn->GetServerAddr().Port() != addr.Port()) { + conn->Logout(); + DropConnection(); + } + } + + if (addr.IPAddr() && addr.Port() && !conn) { + conn = new NetLobbyClient; // (addr); + } + } + + else if (conn) { + conn->Logout(); + DropConnection(); + } +} + +NetLobbyClient* +NetClientConfig::GetConnection() +{ + return conn; +} + +bool +NetClientConfig::Login() +{ + bool result = false; + + if (!conn) + CreateConnection(); + + if (conn) + result = conn->Login(host_request); + + return result; +} + +bool +NetClientConfig::Logout() +{ + bool result = false; + + if (conn) { + result = conn->Logout(); + DropConnection(); + } + + return result; +} + +void +NetClientConfig::DropConnection() +{ + delete conn; + conn = 0; +} |