public static void Handle(ulong clientId, Packet packet, SslStream stream) { Dictionary <string, Tdf> data = Utilities.DecodePayload(packet.payload); TdfString pnam = (TdfString)data["PNAM"]; var client = ClientManager.GetClient(clientId); Log.Info(string.Format("User {0} logging in to persona {1}.", client.user.id, pnam.value)); TdfEncoder encoder = new TdfEncoder(); encoder.WriteTdf(new TdfInteger("BUID", client.persona.id)); encoder.WriteTdf(new TdfInteger("FRST", 0)); encoder.WriteTdf(new TdfString("KEY", "10c38a80_a223eb9d6c2c199db1885856a297055d")); encoder.WriteTdf(new TdfInteger("LLOG", Utilities.GetUnixTime())); encoder.WriteTdf(new TdfString("MAIL", client.user.mail)); encoder.WriteTdf(new TdfStruct("PDTL", new List <Tdf> { new TdfString("DSNM", client.persona.name), // persona display name new TdfInteger("LAST", Utilities.GetUnixTime()), // time of last persona authentication new TdfInteger("PID", 0), // persona ID new TdfInteger("STAS", 2), // ACTIVE new TdfInteger("XREF", 0), new TdfInteger("XTYP", (ulong)ExternalRefType.BLAZE_EXTERNAL_REF_TYPE_UNKNOWN) // this is actually a TdfMin })); encoder.WriteTdf(new TdfInteger("UID", clientId)); // Blaze user ID byte[] payload = encoder.Encode(); Utilities.SendPacket(new Packet { componentId = Component.AUTHENTICATION, commandId = 0x6E, errorCode = 0, msgType = MessageType.REPLY, msgNum = packet.msgNum, payload = payload, payloadSize = payload.Length }, stream); }
public static void Handle(ulong clientId, Packet packet, SslStream stream) { Dictionary <string, Tdf> data = Utilities.DecodePayload(packet.payload); TdfString etag = (TdfString)data["ETAG"]; bool onlineAccess = false; if (etag.value == "ONLINE_ACCESS") { onlineAccess = true; } var client = ClientManager.GetClient(clientId); TdfEncoder encoder = new TdfEncoder(); if (onlineAccess == false) { TdfList nlst = new TdfList("NLST", TdfBaseType.TDF_TYPE_STRUCT, new ArrayList { new List <Tdf> { new TdfString("DEVI", ""), new TdfString("GDAY", "2011-11-02T11:2Z"), new TdfString("GNAM", "BF3PC"), new TdfInteger("ID", 1234632478), new TdfInteger("ISCO", 0), new TdfInteger("PID", 0), new TdfString("PJID", "303566"), new TdfInteger("PRCA", 2), new TdfString("PRID", "DR:224766400"), new TdfInteger("STAT", 1), new TdfInteger("STRC", 0), new TdfString("TAG", "ONLINE_ACCESS"), new TdfString("TDAY", ""), new TdfInteger("TYPE", 1), new TdfInteger("UCNT", 0), new TdfInteger("VER", 0) }, new List <Tdf> { new TdfString("DEVI", ""), new TdfString("GDAY", "2011-11-02T11:2Z"), new TdfString("GNAM", "BF3PC"), new TdfInteger("ID", 1294632417), new TdfInteger("ISCO", 0), new TdfInteger("PID", 0), new TdfString("PJID", "303566"), new TdfInteger("PRCA", 2), new TdfString("PRID", "303566"), new TdfInteger("STAT", 1), new TdfInteger("STRC", 0), new TdfString("TAG", "PROJECT10_CODE_CONSUMED_LE1"), new TdfString("TDAY", ""), new TdfInteger("TYPE", 1), new TdfInteger("UCNT", 0), new TdfInteger("VER", 0) }, new List <Tdf> { new TdfString("DEVI", ""), new TdfString("GDAY", "2013-02-22T14:40Z"), new TdfString("GNAM", "BF3PC"), new TdfInteger("ID", 5674749135), new TdfInteger("ISCO", 0), new TdfInteger("PID", 0), new TdfString("PJID", "306678"), new TdfInteger("PRCA", 2), new TdfString("PRID", "OFB-EAST:50401"), new TdfInteger("STAT", 1), new TdfInteger("STRC", 0), new TdfString("TAG", "BF3:PREMIUM_ACCESS"), new TdfString("TDAY", ""), new TdfInteger("TYPE", 5), new TdfInteger("UCNT", 0), new TdfInteger("VER", 0) }, new List <Tdf> { new TdfString("DEVI", ""), new TdfString("GDAY", "2014-05-29T6:15Z"), new TdfString("GNAM", "BF3PC"), new TdfInteger("ID", 1005150961807), new TdfInteger("ISCO", 0), new TdfInteger("PID", 0), new TdfString("PJID", "305060"), new TdfInteger("PRCA", 2), new TdfString("PRID", "DR:235665900"), new TdfInteger("STAT", 2), new TdfInteger("STRC", 0), new TdfString("TAG", "ONLINE_ACCESS"), new TdfString("TDAY", ""), new TdfInteger("TYPE", 1), new TdfInteger("UCNT", 0), new TdfInteger("VER", 0) }, new List <Tdf> { new TdfString("DEVI", ""), new TdfString("GDAY", "2013-02-22T14:40Z"), new TdfString("GNAM", "BF3PC"), new TdfInteger("ID", 1002134961807), new TdfInteger("ISCO", 0), new TdfInteger("PID", 0), new TdfString("PJID", "305061"), new TdfInteger("PRCA", 2), new TdfString("PRID", "DR:235663400"), new TdfInteger("STAT", 2), new TdfInteger("STRC", 0), new TdfString("TAG", "ONLINE_ACCESS"), new TdfString("TDAY", ""), new TdfInteger("TYPE", 1), new TdfInteger("UCNT", 0), new TdfInteger("VER", 0) }, new List <Tdf> { new TdfString("DEVI", ""), new TdfString("GDAY", "2012-06-04T21:13Z"), new TdfString("GNAM", "BF3PC"), new TdfInteger("ID", 1771457489), new TdfInteger("ISCO", 0), new TdfInteger("PID", 0), new TdfString("PJID", "306678"), new TdfInteger("PRCA", 2), new TdfString("PRID", "OFB-EAST:50400"), new TdfInteger("STAT", 1), new TdfInteger("STRC", 0), new TdfString("TAG", "BF3:PREMIUM_ACCESS"), new TdfString("TDAY", ""), new TdfInteger("TYPE", 5), new TdfInteger("UCNT", 0), new TdfInteger("VER", 0) }, // DLC 1 - Back 2 Karkand new List <Tdf> { new TdfString("DEVI", ""), new TdfString("GDAY", "2012-06-04T21:13Z"), new TdfString("GNAM", "BF3PC"), new TdfInteger("ID", 1771457490), new TdfInteger("ISCO", 0), new TdfInteger("PID", 0), new TdfString("PJID", "302777"), new TdfInteger("PRCA", 2), new TdfString("PRID", "OFB-EAST:50400"), new TdfInteger("STAT", 1), new TdfInteger("STRC", 0), new TdfString("TAG", "BF3:PC:B2K_PURCHASE"), new TdfString("TDAY", ""), new TdfInteger("TYPE", 5), new TdfInteger("UCNT", 0), new TdfInteger("VER", 0) }, // DLC 2 new List <Tdf> { new TdfString("DEVI", ""), new TdfString("GDAY", "2012-06-04T21:13Z"), new TdfString("GNAM", "BF3PC"), new TdfInteger("ID", 1771457491), new TdfInteger("ISCO", 0), new TdfInteger("PID", 0), new TdfString("PJID", "302776"), new TdfInteger("PRCA", 2), new TdfString("PRID", "OFB-EAST:48215"), new TdfInteger("STAT", 1), new TdfInteger("STRC", 0), new TdfString("TAG", "BF3:PC:XPACK2_PURCHASE"), new TdfString("TDAY", ""), new TdfInteger("TYPE", 5), new TdfInteger("UCNT", 0), new TdfInteger("VER", 0) }, // DLC 3 new List <Tdf> { new TdfString("DEVI", ""), new TdfString("GDAY", "2014-02-07T20:15Z"), new TdfString("GNAM", "BF3PC"), new TdfInteger("ID", 1004743136441), new TdfInteger("ISCO", 0), new TdfInteger("PID", 0), new TdfString("PJID", "302778"), new TdfInteger("PRCA", 2), new TdfString("PRID", "OFB-EAST:51080"), new TdfInteger("STAT", 1), new TdfInteger("STRC", 0), new TdfString("TAG", "BF3:PC:XPACK3_PURCHASE"), new TdfString("TDAY", ""), new TdfInteger("TYPE", 5), new TdfInteger("UCNT", 0), new TdfInteger("VER", 0) }, // DLC 4 new List <Tdf> { new TdfString("DEVI", ""), new TdfString("GDAY", "2012-11-26T9:4Z"), new TdfString("GNAM", "BF3PC"), new TdfInteger("ID", 1000808118611), new TdfInteger("ISCO", 0), new TdfInteger("PID", 0), new TdfString("PJID", "303129"), new TdfInteger("PRCA", 2), new TdfString("PRID", "OFB-EAST:55171"), new TdfInteger("STAT", 1), new TdfInteger("STRC", 0), new TdfString("TAG", "BF3:PC:XPACK4_PURCHASE"), new TdfString("TDAY", ""), new TdfInteger("TYPE", 5), new TdfInteger("UCNT", 0), new TdfInteger("VER", 0) }, // DLC 5 new List <Tdf> { new TdfString("DEVI", ""), new TdfString("GDAY", "2013-03-07T2:21Z"), new TdfString("GNAM", "BF3PC"), new TdfInteger("ID", 1002246118611), new TdfInteger("ISCO", 0), new TdfInteger("PID", 0), new TdfString("PJID", "306409"), new TdfInteger("PRCA", 2), new TdfString("PRID", "OFB-EAST:109546437"), new TdfInteger("STAT", 1), new TdfInteger("STRC", 0), new TdfString("TAG", "BF3:PC:XPACK5_PURCHASE"), new TdfString("TDAY", ""), new TdfInteger("TYPE", 5), new TdfInteger("UCNT", 0), new TdfInteger("VER", 0) }, // COOP shortcut new List <Tdf> { new TdfString("DEVI", ""), new TdfString("GDAY", "2012-04-17T15:57Z"), new TdfString("GNAM", "BF3PC"), new TdfInteger("ID", 1684196754), new TdfInteger("ISCO", 0), new TdfInteger("PID", 0), new TdfString("PJID", "306215"), new TdfInteger("PRCA", 1), new TdfString("PRID", "OFB-EAST:48642"), new TdfInteger("STAT", 1), new TdfInteger("STRC", 0), new TdfString("TAG", "BF3:SHORTCUT:COOP"), new TdfString("TDAY", ""), new TdfInteger("TYPE", 5), new TdfInteger("UCNT", 0), new TdfInteger("VER", 0) } }); encoder.WriteTdf(new List <Tdf> { nlst }); } byte[] payload = encoder.Encode(); Utilities.SendPacket(new Packet { componentId = Component.AUTHENTICATION, commandId = 0x1D, errorCode = 0, msgType = MessageType.REPLY, msgNum = packet.msgNum, payload = payload, payloadSize = payload.Length }, stream); }
public static void Handle(ulong clientId, Packet packet) { var client = ClientManager.GetClient(clientId); Dictionary <string, Tdf> data = Utilities.DecodePayload(packet.payload); TdfMap attr = (TdfMap)data["ATTR"]; TdfString gnam = (TdfString)data["GNAM"]; TdfInteger gset = (TdfInteger)data["GSET"]; TdfList pcap = (TdfList)data["PCAP"]; TdfInteger igno = (TdfInteger)data["IGNO"]; TdfInteger pmax = (TdfInteger)data["PMAX"]; TdfInteger nres = (TdfInteger)data["NRES"]; // network topology TdfInteger ntop = (TdfInteger)data["NTOP"]; TdfInteger voip = (TdfInteger)data["VOIP"]; TdfInteger pres = (TdfInteger)data["PRES"]; // TdfMin TdfInteger qcap = (TdfInteger)data["QCAP"]; //TdfString uuid = (TdfString)data["UUID"]; TdfList hnet = (TdfList)data["HNET"]; TdfStruct exip = (TdfStruct)hnet.list[0]; TdfInteger exipIP = (TdfInteger)exip.data.Find(tdf => tdf.label == "IP"); TdfInteger exipPort = (TdfInteger)exip.data.Find(tdf => tdf.label == "PORT"); TdfStruct inip = (TdfStruct)hnet.list[1]; TdfInteger inipIP = (TdfInteger)inip.data.Find(tdf => tdf.label == "IP"); TdfInteger inipPort = (TdfInteger)inip.data.Find(tdf => tdf.label == "PORT"); // TODO: don't get gameId as result but get by clientId after creating the game /* ulong gameId = GameManager.CreateGame( * * (int)gset.value, * (int)igno.value, * (int)nres.value, * (int)ntop.value, * "714b05dc-93bc-49ac-961c-cb38b574f30a" * ); */ var level = attr.map["level"].ToString(); var gametype = attr.map["levellocation"].ToString(); var game = new Database.Game(); game.clientId = clientId; game.name = gnam.value; game.attributes = attr.map; game.capacity = pcap.list; game.level = attr.map["level"].ToString(); game.gametype = attr.map["levellocation"].ToString(); game.maxPlayers = (ushort)pmax.value; game.notResetable = (byte)nres.value; game.queueCapacity = (ushort)qcap.value; game.presenceMode = (PresenceMode)pres.value; game.state = GameState.INITIALIZING; game.networkTopology = (GameNetworkTopology)ntop.value; game.voipTopology = (VoipTopology)voip.value; Database.NetworkInfo internalNetworkInfo = new Database.NetworkInfo(); internalNetworkInfo.ip = inipIP.value; internalNetworkInfo.port = (ushort)inipPort.value; Database.NetworkInfo externalNetworkInfo = new Database.NetworkInfo(); externalNetworkInfo.ip = exipIP.value; externalNetworkInfo.port = (ushort)exipPort.value; game.internalNetworkInfo = internalNetworkInfo; game.externalNetworkInfo = externalNetworkInfo; ulong gameId = Database.CreateGame(game); TdfEncoder encoder = new TdfEncoder(); encoder.WriteTdf(new List <Tdf> { // this one is tdfmin new TdfInteger("GID", (ulong)gameId) }); byte[] payload = encoder.Encode(); Utilities.SendPacket(new Packet { componentId = Component.GAMEMANAGER, commandId = 0x1, errorCode = 0, msgType = MessageType.REPLY, msgNum = packet.msgNum, payload = payload, payloadSize = payload.Length }, client.stream); GameStateChangeNotification.Notify(gameId, game.state, client.stream); GameSetupNotification.Notify(clientId, gameId, client.stream); }
public static void Handle(ulong clientId, Packet packet, SslStream stream) { Dictionary <string, Tdf> data = Utilities.DecodePayload(packet.payload); TdfString mail = (TdfString)data["MAIL"]; TdfString pass = (TdfString)data["PASS"]; var client = ClientManager.GetClient(clientId); var user = Database.GetUser(mail.value, pass.value); if (user.id != 0) { Log.Info(string.Format("User {0} logging in with mail {1}.", user.id, user.mail)); } else { Log.Error(string.Format("Could not find user for user {0}.", user.id)); } ClientManager.SetClientUser(clientId, user); var persona = Database.GetPersona(user.personaId); if (persona.name != null) { Log.Debug(string.Format("Found persona '{0}' for user {1}.", persona.name, user.id)); } else { Log.Error(string.Format("Could not find persona for user {0}.", user.id)); } ClientManager.SetClientPersona(clientId, persona); TdfEncoder encoder = new TdfEncoder(); encoder.WriteTdf(new List <Tdf> { new TdfString("LDHT", ""), new TdfInteger("NTOS", 0), new TdfString("PCTK", "NnQWcHUvUoE4gBscrqJNMx6QzKKrVnnbaZBnD4ZY9kEzKg0cBlW0TrCWil1I8GokLs9p0h_stN5UvWYaS3IrQEK6qvjFwY59k6R_NYIKCp4"), new TdfList("PLST", TdfBaseType.TDF_TYPE_STRUCT, new ArrayList { new List <Tdf> { new TdfString("DSNM", persona.name), new TdfInteger("LAST", Utilities.GetUnixTime()), new TdfInteger("PID", persona.id), new TdfInteger("STAS", 2), // 'ACTIVE' new TdfInteger("XREF", 0), new TdfInteger("XTYP", (ulong)ExternalRefType.BLAZE_EXTERNAL_REF_TYPE_UNKNOWN) } }), new TdfString("PRIV", ""), new TdfString("SKEY", "10c38a80_a223eb9d6c2c199db1885856a297055d"), new TdfInteger("SPAM", 1), new TdfString("THST", ""), new TdfString("TSUI", ""), new TdfString("TURI", ""), new TdfInteger("UID", clientId) }); byte[] payload = encoder.Encode(); Utilities.SendPacket(new Packet { componentId = Component.AUTHENTICATION, commandId = 0x28, errorCode = 0, msgType = MessageType.REPLY, msgNum = packet.msgNum, payload = payload, payloadSize = payload.Length }, stream); }
public static void Handle(ulong clientId, Packet packet, SslStream stream) { Dictionary <string, Tdf> data = Utilities.DecodePayload(packet.payload); TdfString auth = (TdfString)data["AUTH"]; ClientManager.UpdateClientAuthToken(clientId, auth.value); TdfInteger pid = (TdfInteger)data["PID"]; var user = Database.GetUser(pid.value); if (user.mail != null) { ClientManager.SetClientUser(clientId, user); } else { Log.Warn(string.Format("Could not find user by persona ID {0}.", pid.value)); } Log.Info(string.Format("Performing silent login with persona {0} for user {1}.", pid.value, user.id)); var persona = Database.GetPersona(pid.value); if (persona.name != null) { //Log.Info(string.Format("User {0} logging in to persona {1} with auth token {2}.", user.id, persona.name, auth.value)); ClientManager.SetClientPersona(clientId, persona); } else { Log.Warn(string.Format("Could not find persona {0} for user {1}.", pid.value, user.id)); } // not sure what is this type for //TdfInteger type = (TdfInteger)data.Find(tdf => tdf.label == "TYPE"); var client = ClientManager.GetClient(clientId); TdfEncoder encoder = new TdfEncoder(); encoder.WriteTdf(new List <Tdf> { new TdfInteger("AGUP", 0), new TdfString("LDHT", ""), new TdfInteger("NTOS", 0), new TdfString("PCTK", "fa1a26c1-d934-422a-a6ba-ed92614f7d87"), new TdfString("PRIV", ""), new TdfStruct("SESS", new List <Tdf> { new TdfInteger("BUID", client.persona.id), new TdfInteger("FRST", 0), new TdfString("KEY", "some_key"), new TdfInteger("LLOG", Utilities.GetUnixTime()), new TdfString("MAIL", client.user.mail), // TODO: get mail for client new TdfStruct("PDTL", new List <Tdf> { new TdfString("DSNM", client.persona.name), // persona display name new TdfInteger("LAST", Utilities.GetUnixTime()), // time of last persona authentication new TdfInteger("PID", client.persona.id), // persona ID new TdfInteger("STAS", 0), // should be ACTIVE(2)? new TdfInteger("XREF", 0), new TdfInteger("XTYP", (ulong)ExternalRefType.BLAZE_EXTERNAL_REF_TYPE_UNKNOWN) // this is actually a TdfMin }), new TdfInteger("UID", clientId) }), new TdfInteger("SPAM", 0), new TdfString("THST", ""), new TdfString("TSUI", ""), new TdfString("TURI", "") }); byte[] payload = encoder.Encode(); Utilities.SendPacket(new Packet { componentId = Component.AUTHENTICATION, commandId = 0x32, errorCode = 0, msgType = MessageType.REPLY, msgNum = packet.msgNum, payload = payload, payloadSize = payload.Length }, stream); }
public static void Handle(ulong clientId, Packet packet, SslStream stream) { // decode payload Dictionary <string, Tdf> data = Utilities.DecodePayload(packet.payload); // read client type TdfStruct cdat = (TdfStruct)data["CDAT"]; TdfInteger type = (TdfInteger)cdat.data.Find(tdf => tdf.label == "TYPE"); TdfString svcn = (TdfString)cdat.data.Find(tdf => tdf.label == "SVCN"); TdfStruct cinf = (TdfStruct)data["CINF"]; TdfInteger loc = (TdfInteger)cinf.data.Find(tdf => tdf.label == "LOC"); // set client type ClientManager.UpdateClientType(clientId, (ClientType)type.value); ClientManager.UpdateClientLocalization(clientId, loc.value); ClientManager.UpdateClientService(clientId, svcn.value); var client = ClientManager.GetClient(clientId); TdfList cids = new TdfList("CIDS", TdfBaseType.TDF_TYPE_INTEGER, new ArrayList { //1, 25, 4, 27, 28, 6, 7, 9, 10, 11, 30720, 30721, 30722, 30723, 20, 30725, 30726, 2000 }); cids.list.AddRange((new ulong[] { 1, 25, 4, 27, 28, 6, 7, 9, 10, 11, 30720, 30721, 30722, 30723, 20, 30725, 30726, 2000 }).ToArray()); TdfEncoder encoder = new TdfEncoder(); encoder.WriteTdf(new List <Tdf> { new TdfInteger("ANON", 0), new TdfString("ASRC", "300294"), cids, new TdfString("CNGN", ""), new TdfStruct("CONF", new List <Tdf> { new TdfMap("CONF", TdfBaseType.TDF_TYPE_STRING, TdfBaseType.TDF_TYPE_STRING, new Dictionary <object, object> { { "connIdleTimeout", "90s" }, { "defaultRequestTimeout", "80s" }, { "pingPeriod", "20s" }, { "voipHeadsetUpdateRate", "1000" }, { "xlspConnectionIdleTimeout", "300" } }) }), new TdfString("INST", client.service), new TdfInteger("MINR", 0), new TdfString("NASP", "cem_ea_id"), // TODO: check if present in decoded data new TdfString("PILD", ""), new TdfString("PLAT", "pc"), // TODO: fetch from decoded data new TdfString("PTAG", ""), new TdfStruct("QOSS", new List <Tdf> { // bandwidth ping site info new TdfStruct("BWPS", new List <Tdf> { new TdfString("PSA", "127.0.0.1"), // ping site address new TdfInteger("PSP", 17502), // ping site port new TdfString("SNA", "ams") // ping site name }), new TdfInteger("LNP", 10), // number of latency probes new TdfMap("LTPS", TdfBaseType.TDF_TYPE_STRING, TdfBaseType.TDF_TYPE_STRUCT, new Dictionary <object, object> { { "ams", new List <Tdf> { new TdfString("PSA", "127.0.0.1"), // ping site address new TdfInteger("PSP", 17502), // ping site port new TdfString("SNA", "ams") // ping site name } } }), new TdfInteger("SVID", 1161889797) // service ID }), new TdfString("RSRC", "300294"), new TdfString("SVER", "Blaze 3.15.08.0 (CL# 1060080)") }); byte[] payload = encoder.Encode(); Utilities.SendPacket(new Packet { componentId = Component.UTIL, commandId = 0x7, errorCode = 0, msgType = MessageType.REPLY, msgNum = packet.msgNum, payload = payload, payloadSize = payload.Length }, stream); }