summaryrefslogtreecommitdiffhomepage
path: root/StarsEx/NetClientConfig.cpp
diff options
context:
space:
mode:
authorAki <please@ignore.pl>2022-04-01 21:23:39 +0200
committerAki <please@ignore.pl>2022-04-01 21:23:39 +0200
commit3c487c5cd69c53d6fea948643c0a76df03516605 (patch)
tree72730c7b8b26a5ef8fc9a987ec4c16129efd5aac /StarsEx/NetClientConfig.cpp
parent8f353abd0bfe18baddd8a8250ab7c4f2d1c83a6e (diff)
downloadstarshatter-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.cpp331
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;
+}