diff options
Diffstat (limited to 'src/net/ea')
-rw-r--r-- | src/net/ea/loginhandler.cpp | 170 | ||||
-rw-r--r-- | src/net/ea/loginhandler.h | 15 | ||||
-rw-r--r-- | src/net/ea/loginrecv.cpp | 180 | ||||
-rw-r--r-- | src/net/ea/loginrecv.h | 55 |
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 |