public static void On_SMSG_CHAR_ENUM(ref Packets.PacketClass Packet) { Console.WriteLine("[{0}][World] Received Character List.", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss")); byte NumChars = Packet.GetInt8(); if (NumChars > 0) { for (byte i = 1, loopTo = NumChars; i <= loopTo; i++) { ulong GUID = Packet.GetUInt64(); string Name = Packet.GetString(); byte Race = Packet.GetInt8(); byte Classe = Packet.GetInt8(); byte Gender = Packet.GetInt8(); byte Skin = Packet.GetInt8(); byte Face = Packet.GetInt8(); byte HairStyle = Packet.GetInt8(); byte HairColor = Packet.GetInt8(); byte FacialHair = Packet.GetInt8(); byte Level = Packet.GetInt8(); int Zone = Packet.GetInt32(); int Map = Packet.GetInt32(); float PosX = Packet.GetFloat(); float PosY = Packet.GetFloat(); float PosZ = Packet.GetFloat(); uint GuildID = Packet.GetUInt32(); uint PlayerState = Packet.GetUInt32(); byte RestState = Packet.GetInt8(); uint PetInfoID = Packet.GetUInt32(); uint PetLevel = Packet.GetUInt32(); uint PetFamilyID = Packet.GetUInt32(); Console.WriteLine("[{0}][World] Logging in with character [{1}].", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss"), Name); Worldserver.CharacterGUID = GUID; var Response = new Packets.PacketClass(OPCODES.CMSG_PLAYER_LOGIN); Response.AddUInt64(GUID); Worldserver.Send(Response); Response.Dispose(); break; // Skip the equipment Packet.Offset += 20 * 9; } } else { Console.WriteLine("[{0}][World] No characters found.", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss")); } }
public static void On_SMSG_MESSAGECHAT(ref Packets.PacketClass Packet) { ChatMsg msgType = (ChatMsg)Packet.GetInt8(); LANGUAGES msgLanguage = (LANGUAGES)Packet.GetInt32(); switch (msgType) { case ChatMsg.CHAT_MSG_WHISPER: { ulong SenderGuid = (ulong)Packet.GetInt64(); int ByteCount = Packet.GetInt32(); string Message = Packet.GetString(); byte ChatFlag = Packet.GetInt8(); Console.WriteLine("Answer: " + Message); break; } } }
public static void OnData(byte[] Buffer) { var Packet = new Packets.PacketClass(ref Buffer, true); switch (Packet.OpCode) { case CMD_AUTH_LOGON_CHALLENGE: { Console.WriteLine("[{0}][Realm] Received Logon Challenged.", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss")); switch (Buffer[1]) { case 0: // No error { Console.WriteLine("[{0}][Realm] Challenge Success.", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss")); Packet.Offset = 3; ServerB = Packet.GetByteArray(32); byte G_len = Packet.GetInt8(); G = Packet.GetByteArray(G_len); byte N_len = Packet.GetInt8(); N = Packet.GetByteArray(N_len); Salt = Packet.GetByteArray(32); CrcSalt = Packet.GetByteArray(16); CalculateProof(); Thread.Sleep(100); var LogonProof = new Packets.PacketClass(CMD_AUTH_LOGON_PROOF); LogonProof.AddByteArray(PublicA); LogonProof.AddByteArray(M1); LogonProof.AddByteArray(CrcHash); LogonProof.AddInt8(0); // Added in 1.12.x client branch? Security Flags (&H0...&H4)? SendR(LogonProof); LogonProof.Dispose(); break; } case 4: case 5: // Bad user { Console.WriteLine("[{0}][Realm] Bad account information, the account did not exist.", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss")); Connection.Close(); break; } case 9: // Bad version { Console.WriteLine("[{0}][Realm] Bad client version (the server does not allow our version).", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss")); Connection.Close(); break; } default: { Console.WriteLine("[{0}][Realm] Unknown challenge error [{1}].", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss"), Buffer[1]); Connection.Close(); break; } } break; } case CMD_AUTH_LOGON_PROOF: { Console.WriteLine("[{0}][Realm] Received Logon Proof.", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss")); switch (Buffer[1]) { case 0: // No error { Console.WriteLine("[{0}][Realm] Proof Success.", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss")); var RealmList = new Packets.PacketClass(CMD_AUTH_REALMLIST); RealmList.AddInt32(0); SendR(RealmList); RealmList.Dispose(); break; } case 4: case 5: // Bad user { Console.WriteLine("[{0}][Realm] Bad account information, your password was incorrect.", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss")); Connection.Close(); break; } case 9: // Bad version { Console.WriteLine("[{0}][Realm] Bad client version (the crc files are either too old or to new for this server).", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss")); Connection.Close(); break; } default: { Console.WriteLine("[{0}][Realm] Unknown proof error [{1}].", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss"), Buffer[1]); Connection.Close(); break; } } break; } case CMD_AUTH_REALMLIST: { Console.WriteLine("[{0}][Realm] Received Realm List.", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss")); Packet.Offset = 7; int RealmCount = Packet.GetInt8(); if (RealmCount > 0) { for (int i = 1, loopTo = RealmCount; i <= loopTo; i++) { byte RealmType = Packet.GetInt8(); byte RealmLocked = Packet.GetInt8(); byte Unk1 = Packet.GetInt8(); byte Unk2 = Packet.GetInt8(); byte RealmStatus = Packet.GetInt8(); string RealmName = Packet.GetString(); string RealmIP = Packet.GetString(); float RealmPopulation = Packet.GetFloat(); byte RealmCharacters = Packet.GetInt8(); byte RealmTimezone = Packet.GetInt8(); byte Unk3 = Packet.GetInt8(); Console.WriteLine("[{0}][Realm] Connecting to realm [{1}][{2}].", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss"), RealmName, RealmIP); if (Strings.InStr(RealmIP, ":") > 0) { var SplitIP = Strings.Split(RealmIP, ":"); if (SplitIP.Length == 2) { if (Information.IsNumeric(SplitIP[1])) { Worldserver.ConnectToServer(SplitIP[0], Conversions.ToInteger(SplitIP[1])); } else { Console.WriteLine("[{0}][Realm] Invalid IP in realmlist [{1}].", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss"), RealmIP); } } else { Console.WriteLine("[{0}][Realm] Invalid IP in realmlist [{1}].", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss"), RealmIP); } } else { Console.WriteLine("[{0}][Realm] Invalid IP in realmlist [{1}].", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss"), RealmIP); } break; } } else { Console.WriteLine("[{0}][Realm] No realms were found.", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss")); } break; } default: { Console.WriteLine("[{0}][Realm] Unknown opcode [{1}].", Strings.Format(DateAndTime.TimeOfDay, "HH:mm:ss"), Packet.OpCode); break; } } }