diff options
author | Jared Adams <jaxad0127@gmail.com> | 2009-01-28 15:16:12 +0000 |
---|---|---|
committer | Jared Adams <jaxad0127@gmail.com> | 2009-01-28 15:17:03 +0000 |
commit | 61707d27740d0e429d8533606789f1e829752b0f (patch) | |
tree | 71af12bcb38dcaf5182f72b0d9f52df3f471f43b /src/net/charserverhandler.cpp | |
parent | c3ac08bc7629b69ece1a7a44e4d224b95ea51f27 (diff) | |
download | mana-61707d27740d0e429d8533606789f1e829752b0f.tar.gz mana-61707d27740d0e429d8533606789f1e829752b0f.tar.bz2 mana-61707d27740d0e429d8533606789f1e829752b0f.tar.xz mana-61707d27740d0e429d8533606789f1e829752b0f.zip |
Fix handling of packet 0x81
Diffstat (limited to 'src/net/charserverhandler.cpp')
-rw-r--r-- | src/net/charserverhandler.cpp | 50 |
1 files changed, 29 insertions, 21 deletions
diff --git a/src/net/charserverhandler.cpp b/src/net/charserverhandler.cpp index cfa52c38..f00615d7 100644 --- a/src/net/charserverhandler.cpp +++ b/src/net/charserverhandler.cpp @@ -38,6 +38,7 @@ CharServerHandler::CharServerHandler(): mCharCreateDialog(0) { static const Uint16 _messages[] = { + SMSG_CONNECTION_PROBLEM, 0x006b, 0x006c, 0x006d, @@ -45,7 +46,6 @@ CharServerHandler::CharServerHandler(): 0x006f, 0x0070, 0x0071, - 0x0081, 0 }; handledMessages = _messages; @@ -53,13 +53,40 @@ CharServerHandler::CharServerHandler(): void CharServerHandler::handleMessage(MessageIn *msg) { - int slot; + int slot, code; LocalPlayer *tempPlayer; logger->log("CharServerHandler: Packet ID: %x, Length: %d", msg->getId(), msg->getLength()); switch (msg->getId()) { + case SMSG_CONNECTION_PROBLEM: + code = msg->readInt8(); + logger->log("Connection problem: %i", code); + + switch (code) { + case 0: + errorMessage = "Authentication failed"; + break; + case 1: + errorMessage = "Map server(s) offline"; + break; + case 2: + errorMessage = "This account is already logged in"; + break; + case 3: + errorMessage = "Speed hack detected"; + break; + case 8: + errorMessage = "Duplicated login"; + break; + default: + errorMessage = "Unknown connection error"; + break; + } + state = ERROR_STATE; + break; + case 0x006b: // Skip length word and an additional mysterious 20 bytes msg->skip(2 + 20); @@ -154,25 +181,6 @@ void CharServerHandler::handleMessage(MessageIn *msg) mCharInfo->select(slot); state = CONNECTING_STATE; break; - - case 0x0081: - switch (msg->readInt8()) { - case 1: - errorMessage = "Map server offline"; - break; - case 3: - errorMessage = "Speed hack detected"; - break; - case 8: - errorMessage = "Duplicated login"; - break; - default: - errorMessage = "Unknown error with 0x0081"; - break; - } - mCharInfo->unlock(); - state = ERROR_STATE; - break; } } |