/* * The ManaPlus Client * Copyright (C) 2004-2009 The Mana World Development Team * Copyright (C) 2009-2010 The Mana Developers * Copyright (C) 2011-2016 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/eathena/loginhandler.h" #include "client.h" #include "net/generalhandler.h" #include "net/serverfeatures.h" #include "net/eathena/messageout.h" #include "net/eathena/network.h" #include "net/eathena/protocolout.h" #include "debug.h" extern Net::LoginHandler *loginHandler; namespace EAthena { extern ServerInfo charServer; LoginHandler::LoginHandler() : Ea::LoginHandler() { loginHandler = this; } LoginHandler::~LoginHandler() { } void LoginHandler::connect() const { if (!Network::mInstance) return; Network::mInstance->connect(mServer); if (serverFeatures->haveServerVersion()) { sendVersion(); } else { if (client->getState() != State::LOGIN) client->setState(State::LOGIN); } } bool LoginHandler::isConnected() const { if (!Network::mInstance) return false; return Network::mInstance->isConnected(); } void LoginHandler::disconnect() const { if (Network::mInstance && Network::mInstance->getServer() == mServer) Network::mInstance->disconnect(); } void LoginHandler::changePassword(const std::string &restrict oldPassword, const std::string &restrict newPassword) const { if (!serverFeatures->haveChangePassword()) return; createOutPacket(CMSG_CHAR_PASSWORD_CHANGE); outMsg.writeStringNoLog(oldPassword, 24, "old password"); outMsg.writeStringNoLog(newPassword, 24, "new password"); } void LoginHandler::sendLoginRegister(const std::string &restrict username, const std::string &restrict password, const std::string &restrict email) const { if (email.empty()) { createOutPacket(CMSG_LOGIN_REGISTER); outMsg.writeInt32(20, "client version"); outMsg.writeString(username, 24, "login"); outMsg.writeStringNoLog(password, 24, "password"); outMsg.writeInt8(0x03, "client type"); } else { createOutPacket(CMSG_LOGIN_REGISTER2); outMsg.writeString(username, 24, "login"); outMsg.writeStringNoLog(password, 24, "password"); outMsg.writeInt8(0x03, "client type"); outMsg.writeString(email, 40, "email"); } } ServerInfo *LoginHandler::getCharServer() const { return &charServer; } void LoginHandler::sendVersion() const { createOutPacket(CMSG_SERVER_VERSION_REQUEST); outMsg.writeInt32(CLIENT_PROTOCOL_VERSION, "protocol version"); outMsg.writeInt32(0, "unused"); outMsg.writeInt32(0, "unused"); outMsg.writeInt32(0, "unused"); outMsg.writeInt32(0, "unused"); generalHandler->flushSend(); } void LoginHandler::ping() const { createOutPacket(CMSG_LOGIN_PING); outMsg.writeInt32(0, "unused"); outMsg.writeInt32(0, "unused"); outMsg.writeInt32(0, "unused"); outMsg.writeInt32(0, "unused"); outMsg.writeInt32(0, "unused"); outMsg.writeInt32(0, "unused"); } } // namespace EAthena