summaryrefslogtreecommitdiff
path: root/src/net/ea
diff options
context:
space:
mode:
Diffstat (limited to 'src/net/ea')
-rw-r--r--src/net/ea/loginhandler.cpp170
-rw-r--r--src/net/ea/loginhandler.h15
-rw-r--r--src/net/ea/loginrecv.cpp180
-rw-r--r--src/net/ea/loginrecv.h55
4 files changed, 263 insertions, 157 deletions
diff --git a/src/net/ea/loginhandler.cpp b/src/net/ea/loginhandler.cpp
index e967b76b6..0958434f0 100644
--- a/src/net/ea/loginhandler.cpp
+++ b/src/net/ea/loginhandler.cpp
@@ -37,6 +37,7 @@
#include "net/logindata.h"
#include "net/messagein.h"
+#include "net/ea/loginrecv.h"
#include "net/ea/token.h"
#include "debug.h"
@@ -44,30 +45,24 @@
namespace Ea
{
-std::string LoginHandler::mUpdateHost;
-Worlds LoginHandler::mWorlds;
-Token LoginHandler::mToken;
-bool LoginHandler::mVersionResponse = false;
-bool LoginHandler::mRegistrationEnabled = true;
-
LoginHandler::LoginHandler() :
Net::LoginHandler()
{
- mVersionResponse = false;
- mRegistrationEnabled = true;
- mUpdateHost.clear();
- mWorlds.clear();
- mToken.clear();
+ LoginRecv::mVersionResponse = false;
+ LoginRecv::mRegistrationEnabled = true;
+ LoginRecv::mUpdateHost.clear();
+ LoginRecv::mWorlds.clear();
+ LoginRecv::mToken.clear();
}
LoginHandler::~LoginHandler()
{
- delete_all(mWorlds);
+ delete_all(LoginRecv::mWorlds);
}
bool LoginHandler::isRegistrationEnabled() const
{
- return mRegistrationEnabled;
+ return LoginRecv::mRegistrationEnabled;
}
void LoginHandler::getRegistrationDetails() const
@@ -88,17 +83,25 @@ void LoginHandler::loginAccount(LoginData *const loginData1) const
void LoginHandler::chooseServer(const unsigned int server,
const bool persistentIp) const
{
- if (static_cast<size_t>(server) >= mWorlds.size() || !mWorlds[server])
+ if (static_cast<size_t>(server) >= LoginRecv::mWorlds.size() ||
+ !LoginRecv::mWorlds[server])
+ {
return;
+ }
ServerInfo *const charServer = getCharServer();
if (charServer)
{
if (config.getBoolValue("usePersistentIP") || persistentIp)
+ {
charServer->hostname = settings.serverName;
+ }
else
- charServer->hostname = ipToString(mWorlds[server]->address);
- charServer->port = mWorlds[server]->port;
+ {
+ charServer->hostname = ipToString(
+ LoginRecv::mWorlds[server]->address);
+ }
+ charServer->port = LoginRecv::mWorlds[server]->port;
}
client->setState(STATE_UPDATE);
@@ -131,137 +134,13 @@ void LoginHandler::registerAccount(const LoginData *const loginData1) const
const Worlds &LoginHandler::getWorlds() const
{
- return mWorlds;
+ return LoginRecv::mWorlds;
}
void LoginHandler::clearWorlds()
{
- delete_all(mWorlds);
- mWorlds.clear();
-}
-
-void LoginHandler::processUpdateHost(Net::MessageIn &msg)
-{
- const int len = msg.readInt16("len") - 4;
- mUpdateHost = msg.readString(len, "update host");
-
- if (!checkPath(mUpdateHost))
- {
- mUpdateHost.clear();
- logger->log1("Warning: incorrect update server name");
- }
- loginData.updateHost = mUpdateHost;
-
- logger->log("Received update host \"%s\" from login server.",
- mUpdateHost.c_str());
-}
-
-void LoginHandler::processLoginData(Net::MessageIn &msg)
-{
- msg.readInt16("len");
-
- loginHandler->clearWorlds();
-
- const int worldCount = (msg.getLength() - 47) / 32;
-
- mToken.session_ID1 = msg.readInt32("session id1");
- mToken.account_ID = msg.readBeingId("accound id");
- mToken.session_ID2 = msg.readInt32("session id2");
- msg.readInt32("old ip");
- loginData.lastLogin = msg.readString(24, "last login");
- msg.readInt16("unused");
-
- // reserve bits for future usage
- mToken.sex = Being::intToGender(static_cast<uint8_t>(
- msg.readUInt8("gender") & 3U));
-
- for (int i = 0; i < worldCount; i++)
- {
- WorldInfo *const world = new WorldInfo;
-
- world->address = msg.readInt32("ip address");
- world->port = msg.readInt16("port");
- world->name = msg.readString(20, "name");
- world->online_users = msg.readInt16("online number");
- config.setValue("updatehost", mUpdateHost);
- world->updateHost = mUpdateHost;
- msg.readInt16("maintenance");
- msg.readInt16("new");
-
- logger->log("Network: Server: %s (%s:%d)", world->name.c_str(),
- ipToString(world->address), world->port);
-
- mWorlds.push_back(world);
- }
- client->setState(STATE_WORLD_SELECT);
-}
-
-void LoginHandler::processLoginError(Net::MessageIn &msg)
-{
- const uint8_t code = msg.readUInt8("error");
- logger->log("Login::error code: %u", static_cast<unsigned int>(code));
- std::string date = msg.readString(20, "date");
-
- switch (code)
- {
- case 0:
- // TRANSLATORS: error message
- errorMessage = _("Unregistered ID.");
- break;
- case 1:
- // TRANSLATORS: error message
- errorMessage = _("Wrong password.");
- LoginDialog::savedPassword.clear();
- break;
- case 2:
- // TRANSLATORS: error message
- errorMessage = _("Account expired.");
- break;
- case 3:
- // TRANSLATORS: error message
- errorMessage = _("Rejected from server.");
- break;
- case 4:
- // TRANSLATORS: error message
- errorMessage = _("You have been permanently banned from "
- "the game. Please contact the GM team.");
- break;
- case 5:
- // TRANSLATORS: error message
- errorMessage = _("Client too old.");
- break;
- case 6:
- // TRANSLATORS: error message
- errorMessage = strprintf(_("You have been temporarily "
- "banned from the game until %s.\nPlease contact the GM "
- "team via the forums."), date.c_str());
- break;
- case 7:
- // TRANSLATORS: error message
- errorMessage = _("Server overpopulated.");
- break;
- case 9:
- // TRANSLATORS: error message
- errorMessage = _("This user name is already taken.");
- break;
- case 10:
- // TRANSLATORS: error message
- errorMessage = _("Wrong name.");
- break;
- case 11:
- // TRANSLATORS: error message
- errorMessage = _("Incorrect email.");
- break;
- case 99:
- // TRANSLATORS: error message
- errorMessage = _("Username permanently erased.");
- break;
- default:
- // TRANSLATORS: error message
- errorMessage = _("Unknown error.");
- break;
- }
- client->setState(STATE_ERROR);
+ delete_all(LoginRecv::mWorlds);
+ LoginRecv::mWorlds.clear();
}
void LoginHandler::loginOrRegister(LoginData *const data) const
@@ -302,4 +181,9 @@ void LoginHandler::unregisterAccount(const std::string &username A_UNUSED,
{
}
+const Token &LoginHandler::getToken() const
+{
+ return LoginRecv::mToken;
+}
+
} // namespace Ea
diff --git a/src/net/ea/loginhandler.h b/src/net/ea/loginhandler.h
index 96a228b07..9dc559dab 100644
--- a/src/net/ea/loginhandler.h
+++ b/src/net/ea/loginhandler.h
@@ -70,8 +70,7 @@ class LoginHandler notfinal : public Net::LoginHandler
virtual ServerInfo *getCharServer() const A_WARN_UNUSED = 0;
- const Token &getToken() const A_WARN_UNUSED
- { return mToken; }
+ const Token &getToken() const A_WARN_UNUSED;
void logout() const override final;
@@ -86,21 +85,9 @@ class LoginHandler notfinal : public Net::LoginHandler
protected:
LoginHandler();
- static void processUpdateHost(Net::MessageIn &msg);
-
- static void processLoginData(Net::MessageIn &msg);
-
- static void processLoginError(Net::MessageIn &msg);
-
virtual void sendLoginRegister(const std::string &username,
const std::string &password,
const std::string &email) const = 0;
-
- static std::string mUpdateHost;
- static Worlds mWorlds;
- static Token mToken;
- static bool mVersionResponse;
- static bool mRegistrationEnabled;
};
} // namespace Ea
diff --git a/src/net/ea/loginrecv.cpp b/src/net/ea/loginrecv.cpp
new file mode 100644
index 000000000..e3430bac8
--- /dev/null
+++ b/src/net/ea/loginrecv.cpp
@@ -0,0 +1,180 @@
+/*
+ * The ManaPlus Client
+ * Copyright (C) 2004-2009 The Mana World Development Team
+ * Copyright (C) 2009-2010 The Mana Developers
+ * Copyright (C) 2011-2015 The ManaPlus Developers
+ *
+ * This file is part of The ManaPlus Client.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "net/ea/loginrecv.h"
+
+#include "client.h"
+#include "configuration.h"
+#include "settings.h"
+
+#include "being/being.h"
+
+#include "gui/windows/logindialog.h"
+
+#include "utils/dtor.h"
+#include "utils/gettext.h"
+#include "utils/paths.h"
+
+#include "net/logindata.h"
+#include "net/messagein.h"
+
+#include "net/ea/token.h"
+
+#include "debug.h"
+
+namespace Ea
+{
+
+namespace LoginRecv
+{
+ std::string mUpdateHost;
+ Worlds mWorlds;
+ Token mToken;
+ bool mVersionResponse = false;
+ bool mRegistrationEnabled = true;
+} // namespace LoginRecv
+
+void LoginRecv::processUpdateHost(Net::MessageIn &msg)
+{
+ const int len = msg.readInt16("len") - 4;
+ mUpdateHost = msg.readString(len, "update host");
+
+ if (!checkPath(mUpdateHost))
+ {
+ mUpdateHost.clear();
+ logger->log1("Warning: incorrect update server name");
+ }
+ loginData.updateHost = mUpdateHost;
+
+ logger->log("Received update host \"%s\" from login server.",
+ mUpdateHost.c_str());
+}
+
+void LoginRecv::processLoginData(Net::MessageIn &msg)
+{
+ msg.readInt16("len");
+
+ loginHandler->clearWorlds();
+
+ const int worldCount = (msg.getLength() - 47) / 32;
+
+ mToken.session_ID1 = msg.readInt32("session id1");
+ mToken.account_ID = msg.readBeingId("accound id");
+ mToken.session_ID2 = msg.readInt32("session id2");
+ msg.readInt32("old ip");
+ loginData.lastLogin = msg.readString(24, "last login");
+ msg.readInt16("unused");
+
+ // reserve bits for future usage
+ mToken.sex = Being::intToGender(static_cast<uint8_t>(
+ msg.readUInt8("gender") & 3U));
+
+ for (int i = 0; i < worldCount; i++)
+ {
+ WorldInfo *const world = new WorldInfo;
+
+ world->address = msg.readInt32("ip address");
+ world->port = msg.readInt16("port");
+ world->name = msg.readString(20, "name");
+ world->online_users = msg.readInt16("online number");
+ config.setValue("updatehost", mUpdateHost);
+ world->updateHost = mUpdateHost;
+ msg.readInt16("maintenance");
+ msg.readInt16("new");
+
+ logger->log("Network: Server: %s (%s:%d)", world->name.c_str(),
+ ipToString(world->address), world->port);
+
+ mWorlds.push_back(world);
+ }
+ client->setState(STATE_WORLD_SELECT);
+}
+
+void LoginRecv::processLoginError(Net::MessageIn &msg)
+{
+ const uint8_t code = msg.readUInt8("error");
+ logger->log("Login::error code: %u", static_cast<unsigned int>(code));
+ std::string date = msg.readString(20, "date");
+
+ switch (code)
+ {
+ case 0:
+ // TRANSLATORS: error message
+ errorMessage = _("Unregistered ID.");
+ break;
+ case 1:
+ // TRANSLATORS: error message
+ errorMessage = _("Wrong password.");
+ LoginDialog::savedPassword.clear();
+ break;
+ case 2:
+ // TRANSLATORS: error message
+ errorMessage = _("Account expired.");
+ break;
+ case 3:
+ // TRANSLATORS: error message
+ errorMessage = _("Rejected from server.");
+ break;
+ case 4:
+ // TRANSLATORS: error message
+ errorMessage = _("You have been permanently banned from "
+ "the game. Please contact the GM team.");
+ break;
+ case 5:
+ // TRANSLATORS: error message
+ errorMessage = _("Client too old.");
+ break;
+ case 6:
+ // TRANSLATORS: error message
+ errorMessage = strprintf(_("You have been temporarily "
+ "banned from the game until %s.\nPlease contact the GM "
+ "team via the forums."), date.c_str());
+ break;
+ case 7:
+ // TRANSLATORS: error message
+ errorMessage = _("Server overpopulated.");
+ break;
+ case 9:
+ // TRANSLATORS: error message
+ errorMessage = _("This user name is already taken.");
+ break;
+ case 10:
+ // TRANSLATORS: error message
+ errorMessage = _("Wrong name.");
+ break;
+ case 11:
+ // TRANSLATORS: error message
+ errorMessage = _("Incorrect email.");
+ break;
+ case 99:
+ // TRANSLATORS: error message
+ errorMessage = _("Username permanently erased.");
+ break;
+ default:
+ // TRANSLATORS: error message
+ errorMessage = _("Unknown error.");
+ break;
+ }
+ client->setState(STATE_ERROR);
+}
+
+} // namespace Ea
diff --git a/src/net/ea/loginrecv.h b/src/net/ea/loginrecv.h
new file mode 100644
index 000000000..07e2f14bf
--- /dev/null
+++ b/src/net/ea/loginrecv.h
@@ -0,0 +1,55 @@
+/*
+ * The ManaPlus Client
+ * Copyright (C) 2004-2009 The Mana World Development Team
+ * Copyright (C) 2009-2010 The Mana Developers
+ * Copyright (C) 2011-2015 The ManaPlus Developers
+ *
+ * This file is part of The ManaPlus Client.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef NET_EA_LOGINRECV_H
+#define NET_EA_LOGINRECV_H
+
+#include "net/loginhandler.h"
+
+#include "net/registrationoptions.h"
+
+class LoginData;
+
+struct Token;
+
+namespace Net
+{
+ class MessageIn;
+}
+
+namespace Ea
+{
+ namespace LoginRecv
+ {
+ extern std::string mUpdateHost;
+ extern Worlds mWorlds;
+ extern Token mToken;
+ extern bool mVersionResponse;
+ extern bool mRegistrationEnabled;
+
+ void processUpdateHost(Net::MessageIn &msg);
+ void processLoginData(Net::MessageIn &msg);
+ void processLoginError(Net::MessageIn &msg);
+ } // namespace LoginRecv
+} // namespace Ea
+
+#endif // NET_EA_LOGINRECV_H