Exemplo n.º 1
0
        private static void CheckNameExistance(Client.AuthClient client, AuthPackets.Packet packet)
        {
            string Name = Encoding.ASCII.GetString(packet.buffer, 6, 12).Replace(Encoding.ASCII.GetString(new byte[] { 0x0 }), "");

            client.Send(new AuthPackets.Packet(AuthPackets.Packet.PacketType.S2C_CheckNameExsitance, new byte[4] {
                (byte)(Database.EntityTable.NameExists(Name) ? 0x2 : 0x0), 0x0, 0x0, 0x0
            }));
        }
Exemplo n.º 2
0
        public static async Task Main()
        {
            var client = new Client.AuthClient("https://localhost:5001/");

            var result = await client.AuthenticateAsync("eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6Ik5UVXpSVVUxUmtZNVJUSTNNamN6TUVaRk4wRkJRME0zUkRNeFJFUXdRVFZGUlVZd1JEazVSUSJ9.eyJpc3MiOiJodHRwczovL2F1dGguY2xpY2tpcS5jby51ay8iLCJzdWIiOiJhdXRoMHw1ZGNiZDkyOWI3NjI1MjBlNDgwYzcxMmYiLCJhdWQiOlsiaHR0cHM6Ly9jbHVzdGVyLnN0YWdlLmNsaWNraXEuaW8iLCJodHRwczovL2NsaWNraXEuZXUuYXV0aDAuY29tL3VzZXJpbmZvIl0sImlhdCI6MTYwNDE2Nzg3NywiZXhwIjoxNjA0MTc1MDc3LCJhenAiOiJxVmtJdXVXWGpFNkMxTTRFd1RwYlpxVTRVM2pqZmRIMiIsInNjb3BlIjoib3BlbmlkIHByb2ZpbGUgZW1haWwifQ.r3xOOHPoilYV9MAYtQhZ-HfHv7uAlMcPYktdsiR1UXINKALZFMWOGyMSDgYy-zwkKjepPCV2U5UfdHOoea5EjqTc24m_PDs47Bo7KSDHJ7igJPhfvfvwHTg-kmzeWWXhj8K-ywB_dfkCeZEfS3dy0zg_aJprJOh8LJtmA5kpa_qbBNcBme9QN6II05PzSbBDaBegG6uBDo08LoodcHrIX5DjTVruadLwj_xr0hfiLEcRFhNGBe714QGg9qTu97mavYIp0s_V0p1EmMK2UKHtFnCWpv3zvecV-SDPOKw9U692lROHKSgeNjmOrTgFuN7xQXT8Fq2Ma3rouixVW85vJQ");

            Console.WriteLine(result.Name);
            Console.ReadKey();
        }
Exemplo n.º 3
0
        private static void CreateAccount(Client.AuthClient client, AuthPackets.Packet packet)
        {
            string Name = Encoding.ASCII.GetString(packet.buffer, 6, 12).Replace(Encoding.ASCII.GetString(new byte[] { 0x0 }), "");

            if (!Database.EntityTable.NameExists(Name) && Database.EntityTable.CreateEntity(client, Name))
            {
                client.Send(new AuthPackets.Packet(AuthPackets.Packet.PacketType.S2C_CreateAccount, new byte[4]));
            }
        }
Exemplo n.º 4
0
 private static void TryEnterServer(Client.AuthClient client)
 {
     System.Threading.Thread thread = new System.Threading.Thread(delegate()
     {
         System.Threading.Thread.Sleep(Constants.timeToAutomaticallyEnterServer * 1000);
         client.Send(new AuthPackets.Packet(AuthPackets.Packet.PacketType.S2C_TryEnter, new byte[0]));
     });
     thread.Start();
 }
Exemplo n.º 5
0
Arquivo: Mains.cs Projeto: iodz37/Iodz
 static void AuthServer_OnClientConnect(ClientWrapper obj)
 {
     Client.AuthClient authState;
     obj.Connector           = (authState = new Client.AuthClient(obj));
     authState.Cryptographer = new Network.Cryptography.AuthCryptography();
     Network.AuthPackets.PasswordCryptographySeed pcs = new PasswordCryptographySeed();
     pcs.Seed = Kernel.Random.Next();
     authState.PasswordSeed = pcs.Seed;
     authState.Send(pcs);
 }
Exemplo n.º 6
0
        public static Enums.AccountStatus Authenticate(Client.AuthClient client, string Account, string Password)
        {
            try
            {
                using (var sql = new SqlHandler(Program.Config.ReadString("AuthConnectionString")))
                {
                    using (var cmd = new SqlCommandBuilder(sql, SqlCommandType.SELECT, true))
                    {
                        cmd.AddWhereValue("AccountName", Account);
                        cmd.AddWhereValue("AccountPassword", Password);

                        cmd.Finish("DB_Accounts");
                    }

                    if (!sql.Read())
                    {
                        return(Enums.AccountStatus.Invalid_AccountID_Or_Password);
                    }
                    client.DatabaseUID = sql.ReadInt32("AccountID");
                    client.Server      = sql.ReadByte("AccountServer");
                    client.Account     = Account;
                    client.Password    = Password;
                    using (var sql2 = new SqlHandler(Program.Config.ReadString("AuthConnectionString")))
                    {
                        using (var cmd2 = new SqlCommandBuilder(sql2, SqlCommandType.UPDATE, true))
                        {
                            cmd2.AddWhereValue("AccountID", client.DatabaseUID);
                            if (sql.ReadBoolean("AccountBanned"))
                            {
                                DateTime banexpire = sql.ReadDateTime("AccountBanExpire");
                                if (DateTime.Now < banexpire)
                                {
                                    return(Enums.AccountStatus.Account_Banned);
                                }

                                cmd2.AddUpdateValue("AccountBanned", false);
                            }

                            cmd2.AddUpdateValue("AccountLastLoginIP", client.NetworkClient.IP);
                            cmd2.Finish("DB_Accounts");
                        }
                        sql2.Execute();
                    }
                }
                return(Enums.AccountStatus.Ready);
            }
            catch (Exception e)
            {
                Console.WriteLine(e.ToString());
                return(Enums.AccountStatus.Datebase_Error);
            }
        }
Exemplo n.º 7
0
 private static void SendServers(Client.AuthClient client)
 {
     System.IO.MemoryStream memory = new System.IO.MemoryStream();
     System.IO.BinaryWriter writer = new System.IO.BinaryWriter(memory);
     #region Character Info
     writer.Write(client.Account.EntityID > 0 ? 0 : 6);
     if (client.Account.EntityID > 0)
     {
         writer.Write(Encoding.ASCII.GetBytes(client.Account.Name));
         writer.Write(new byte[16 - client.Account.Name.Length]);
     }
     else
     {
         memory.Position += 16;
     }
     writer.Write(client.Account.EntityID);
     writer.Write((ushort)0);
     writer.Write(client.Account.Rank);
     writer.Write(client.Account.TotalKills);
     writer.Write(client.Account.TotalDeaths);
     writer.Write(0u);
     writer.Write(StringToBytes("2D 3E F7 D5 CF 18 F7 3F"));
     writer.Write((ulong)Program.Servers.Length);
     #endregion
     #region Servers
     for (int i = 0; i < Program.Servers.Length; i++)
     {
         var Server = Program.Servers[i];
         writer.Write((ushort)(Server.serverType));
         writer.Write(Server.NoLimit);
         writer.Write(Server.MinRank);
         writer.Write(Server.MaxRank);
         memory.Position += 16;
         writer.Write((ushort)(i + 1));
         writer.Write(Encoding.ASCII.GetBytes(Server.Name));
         writer.Write(new byte[34 - Server.Name.Length]);
         writer.Write(Server.Port);
         writer.Write(Server.IPBytes);
         writer.Write(100u);
         writer.Write((ulong)((double)Kernel.GamePool.Values.Where(x => x.Account.Server == Server).Count() / (double)Server.MaxPlayers * 100d));//FF FF FF FF Should be Maintanance
     }
     #endregion
     memory.Position = 0;
     byte[] answer = new byte[memory.Length];
     memory.Read(answer, 0, answer.Length);
     writer.Close();
     memory.Close();
     client.Send(new AuthPackets.Packet(AuthPackets.Packet.PacketType.S2C_GetServers, answer));
     TryEnterServer(client);
 }
Exemplo n.º 8
0
 private static void SendNewGUID(Client.AuthClient client)
 {
     byte[] buffer = new byte[208];
     Writer.Write(45138, 14 - 6, buffer);
     Writer.Write("pY20", 16 - 6, buffer);
     Writer.Write(44431, 22 - 6, buffer);
     Writer.Write("lY", 24 - 6, buffer);
     Writer.Write(DateTime.Now.ToString("yyyymmddhhmmss"), 26 - 6, buffer);
     Writer.Write(client.Account.Rank, 94 - 6, buffer);
     Writer.Write(client.Account.TotalKills, 98 - 6, buffer);
     Writer.Write(client.Account.TotalDeaths, 102 - 6, buffer);
     // client.Account.Identifer = Kernel.RandomString(32);
     Writer.Write(client.Account.Identifer, 106 - 6, buffer);
     client.Send(new AuthPackets.Packet(AuthPackets.Packet.PacketType.S2C_LoginToGameServer_Step1, buffer));
 }
Exemplo n.º 9
0
 /// <summary>
 /// Handling all connections.
 /// </summary>
 /// <param name="socketClient">The socket client.</param>
 public static bool Handle_Connection(SocketClient socketClient)
 {
     try
     {
         Client.AuthClient client = new Client.AuthClient(socketClient);
         using (var packet = new Packets.PasswordSeedPacket())
         {
             packet.Seed = 90011337;
             client.Send(packet);
         }
     }
     catch (Exception e)
     {
         Console.WriteLine(e.ToString());
     }
     return(true);
 }
Exemplo n.º 10
0
 /// <summary>
 /// Handling all connections.
 /// </summary>
 /// <param name="socketClient">The socket client.</param>
 public static bool Handle_Connection(SocketClient socketClient)
 {
     try
     {
         Client.AuthClient client = new Client.AuthClient(socketClient);
         using (var packet = new Packets.PasswordSeedPacket())
         {
             packet.Seed = 90011337;
             client.Send(packet);
         }
     }
     catch (Exception e)
     {
         Console.WriteLine(e.ToString());
     }
     return true;
 }
Exemplo n.º 11
0
        private static void ReturnToServers(Client.AuthClient client, AuthPackets.Packet packet)
        {
            System.IO.MemoryStream memory = new System.IO.MemoryStream();
            System.IO.BinaryWriter writer = new System.IO.BinaryWriter(memory);
            string Username = Encoding.ASCII.GetString(packet.buffer, 10, 20).Replace(Encoding.ASCII.GetString(new byte[] { 0x0 }), "");
            uint   UID      = BitConverter.ToUInt32(packet.buffer, 6);

            client.Account = Kernel.GamePool.Values.Where(i => i.Entity.UID == UID && i.Account.Username == Username).FirstOrDefault().Account;
            Kernel.AwaitingPool[client.Account.Identifer] = client.Account;
            #region Character Info
            memory.Position += 20;
            writer.Write(client.Account.EntityID);
            writer.Write((ushort)0);
            writer.Write(client.Account.Rank);
            writer.Write(client.Account.TotalKills);
            writer.Write(client.Account.TotalDeaths);
            writer.Write(0u);
            writer.Write(StringToBytes("2D 3E F7 D5 CF 18 F7 3F"));
            writer.Write((ulong)Program.Servers.Length);
            #endregion
            #region Servers
            for (int i = 0; i < Program.Servers.Length; i++)
            {
                var Server = Program.Servers[i];
                writer.Write((ushort)(Server.serverType));
                writer.Write(Server.NoLimit);
                writer.Write(Server.MinRank);
                writer.Write(Server.MaxRank);
                memory.Position += 16;
                writer.Write((ushort)(i + 1));
                writer.Write(Encoding.ASCII.GetBytes(Server.Name));
                writer.Write(new byte[34 - Server.Name.Length]);
                writer.Write(Server.Port);
                writer.Write(Server.IPBytes);
                writer.Write(100u);
                writer.Write((ulong)((double)Kernel.GamePool.Values.Where(x => x.Account.Server == Server).Count() / (double)Server.MaxPlayers * 100d));//FF FF FF FF Should be Maintanance
            }
            #endregion
            memory.Position = 0;
            byte[] answer = new byte[memory.Length];
            memory.Read(answer, 0, answer.Length);
            writer.Close();
            memory.Close();
            client.Send(new AuthPackets.Packet(AuthPackets.Packet.PacketType.S2C_GoBackForServers, answer));
        }
Exemplo n.º 12
0
        /// <summary>
        /// Handling all packets received.
        /// </summary>
        /// <param name="socketClient">The socket client.</param>
        /// <param name="Packet">The packet.</param>
        public static bool Handle_Receive(SocketClient socketClient, DataPacket Packet)
        {
            try
            {
                Client.AuthClient client = socketClient.Owner as Client.AuthClient;

                switch (Packet.PacketID)
                {
                case Packets.PacketType.AuthRequestPacket1:
                case Packets.PacketType.AuthRequestPacket2:
                    Packets.AuthRequestPacket.Handle(client, Packet);
                    break;
                }
            }
            catch (Exception e)
            {
                Console.WriteLine(e.ToString());
            }
            return(true);
        }
Exemplo n.º 13
0
 private static void Login(Enums.LoginTypes type, Client.AuthClient client)
 {
     if (type == Enums.LoginTypes.NoError)
     {
         byte[] Buffer = new byte[800];
         var    packet = new AuthPackets.Packet(AuthPackets.Packet.PacketType.S2C_ValidAccount, Buffer);
         packet.buffer[8] = 2; packet.buffer[406] = 1;
         client.Send(packet);
         SendServers(client);
     }
     else
     {
         byte[] buff = new byte[1452];
         Writer.Write((byte)type, 2, buff);
         if (type == Enums.LoginTypes.Player_Already_Logged_In)
         {
             Writer.Write(client.Account.EntityID, 26, buff);
         }
         client.Send(new AuthPackets.Packet(AuthPackets.Packet.PacketType.S2C_DisplayError, buff));
     }
 }
Exemplo n.º 14
0
        public static bool CreateEntity(Client.AuthClient client, string Name)
        {
            if (Name.Length > 12)
            {
                Name = Name.Substring(0, 12);
            }
            if (Name == "")
            {
                return(false);
            }
            uint UID = NextUID;

            while (UIDExists(UID))
            {
                UID = NextUID;
            }
            while (true)
            {
                try
                {
                    using (var cmd = new MySqlCommand(MySqlCommandType.INSERT))
                        cmd.Insert("characters")
                        .Insert("Name", Name)
                        .Insert("GP", Constants.DefaultGP)
                        .Insert("UID", UID)
                        .Execute();
                    break;
                }
                catch
                {
                    UID = NextUID;
                }
            }
            client.Account.EntityID = UID;
            client.Account.Save();
            return(true);
        }
Exemplo n.º 15
0
        public static void UpdateAuthentication(Client.AuthClient client)
        {
            if (PlayerExists(client.DatabaseUID))
            {
                using (var sql = new SqlHandler(Program.Config.ReadString("GameConnectionString")))
                {
                    using (var cmd = new SqlCommandBuilder(sql, SqlCommandType.UPDATE, true))
                    {
                        cmd.AddWhereValue("PlayerID", client.DatabaseUID);
                        cmd.AddUpdateValue("PlayerLastEntityUID", client.EntityUID);
                        cmd.AddUpdateValue("PlayerLoginOK", true);

                        cmd.Finish("DB_Players");
                    }
                    sql.Execute();
                }
            }
            else
            {
                using (var sql = new SqlHandler(Program.Config.ReadString("GameConnectionString")))
                {
                    using (var cmd = new SqlCommandBuilder(sql, SqlCommandType.INSERT, false))
                    {
                        cmd.AddInsertValue("PlayerID", client.DatabaseUID);
                        cmd.AddInsertValue("PlayerNew", true);
                        cmd.AddInsertValue("PlayerAccount", client.Account);
                        cmd.AddInsertValue("PlayerLastEntityUID", client.EntityUID);
                        cmd.AddInsertValue("PlayerLoginOK", true);
                        cmd.AddInsertValue("PlayerServer", client.Server);

                        cmd.Finish("DB_Players");
                    }
                    sql.Execute();
                }
            }
        }
Exemplo n.º 16
0
        /// <summary>
        /// Handles the auth request packet.
        /// </summary>
        /// <param name="client">The auth client.</param>
        /// <param name="Packet">The packet.</param>
        public static void Handle(Client.AuthClient client, DataPacket Packet)
        {
            using (var auth = new AuthRequestPacket(Packet))
            {
                Enums.AccountStatus status = Database.ServerDatabase.Authenticate(client, auth.Account, auth.Password);
                client.EntityUID = (uint)ProjectX_V3_Lib.ThreadSafe.RandomGenerator.Generator.Next(1000000, 699999999);

                if (status == Enums.AccountStatus.Ready)
                {
                    try
                    {
                        Database.ServerDatabase.UpdateAuthentication(client);
                        Socket quicksock = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);

                        quicksock.Connect(new IPEndPoint(IPAddress.Parse(Program.Config.ReadString("GameIP")), Program.Config.ReadInt32("GameAuthPort")));

                        using (DataPacket packet = new DataPacket(44, 9001))
                        {
                            packet.WriteString(Program.Config.ReadString("ServerPassword"), 4);
                            packet.WriteString(client.Account, 20);
                            packet.WriteInt32(client.DatabaseUID, 36);
                            packet.WriteUInt32(client.EntityUID, 40);
                            quicksock.BeginSend(packet.Copy(), 0, 44, SocketFlags.None,
                                                new AsyncCallback((ia) =>
                            {
                                int send = quicksock.EndSend(ia);
                                if (send != 44)
                                {
                                    status           = Enums.AccountStatus.Datebase_Error;
                                    client.EntityUID = 0;
                                }
                                Console.WriteLine("Database Notified: [Account: {0}] [DUID: {1}] [EUID: {2}]", client.Account, client.DatabaseUID, client.EntityUID);
                            }), null);
                        }
                        System.Threading.Thread.Sleep(2000);
                    }
                    catch
                    {
                        status = Enums.AccountStatus.Datebase_Error;
                    }
                }

                using (var resp = new AuthResponsePacket())
                {
                    if (status == Enums.AccountStatus.Ready)
                    {
                        Console.WriteLine("Incoming login. [Account: {0}] [Password: {1}]", client.Account, client.Password);

                        resp.EntityUID = client.EntityUID;
                        resp.Port      = Program.Config.ReadUInt32("GamePort");
                        resp.IPAddress = Program.Config.ReadString("GameIP");
                    }
                    else
                    {
                        resp.EntityUID = 0;
                    }
                    resp.AccountStatus = status;
                    client.Send(resp);
                }
                System.Threading.Thread.Sleep(5000);
                client.NetworkClient.Disconnect("TIME_OUT");
            }
        }
Exemplo n.º 17
0
        public static void Process(Client.AuthClient client, AuthPackets.Packet packet)
        {
            if (packet.CorrectPacket)
            {
                switch (packet.packetType)
                {
                case AuthPackets.Packet.PacketType.C2S_Login:
                    var Username    = Encoding.ASCII.GetString(packet.buffer, 16, 20).Replace(Encoding.ASCII.GetString(new byte[] { 0x0 }), "");
                    var Password    = Encoding.ASCII.GetString(packet.buffer, 37, 20).Replace(Encoding.ASCII.GetString(new byte[] { 0x0 }), "");
                    var CFArugments = Encoding.ASCII.GetString(packet.buffer, 145, 12).Replace(Encoding.ASCII.GetString(new byte[] { 0x0 }), "");
                    var MacAddress  = Encoding.ASCII.GetString(packet.buffer, 407, 12).Replace(Encoding.ASCII.GetString(new byte[] { 0x0 }), "");
                    client.Account = new Database.AccountTable(Username)
                    {
                        IP = client.Socket.IP
                    };
                    client.Account.Identifer = Encoding.ASCII.GetString(packet.buffer, 77, 32).Replace(Encoding.ASCII.GetString(new byte[] { 0x0 }), "");
                    if (client.Account.exists && client.Account.Password == Password && !Kernel.GamePool.ContainsKey(client.Account.EntityID))
                    {
                        Kernel.AwaitingPool[client.Account.Identifer] = client.Account;
                        Login(Enums.LoginTypes.NoError, client);
                    }
                    else if (client.Account.exists && client.Account.Password == Password && Kernel.GamePool.ContainsKey(client.Account.EntityID))
                    {
                        Login(Enums.LoginTypes.Player_Already_Logged_In, client);
                    }
                    else
                    {
                        Login(Enums.LoginTypes.Unknown_Username_Or_Password, client);
                    }
                    break;

                case AuthPackets.Packet.PacketType.C2S_AccountAlreadyLoggedOn:
                    if (client.Account != null)
                    {
                        var player = Kernel.GamePool.Values.Where(i => i.Account.EntityID == client.Account.EntityID).FirstOrDefault();
                        player.Disconnect();
                        packet = new AuthPackets.Packet(AuthPackets.Packet.PacketType.S2C_PlayerHasBeenLoggedOut, new byte[0]);
                        client.Send(packet);
                    }
                    break;

                case AuthPackets.Packet.PacketType.C2S_LoginToGameServer_Step1:
                    byte ServerNumber = packet.buffer[6];
                    client.Account.Server = Program.Servers[ServerNumber - 1];
                    SendNewGUID(client);
                    break;

                case AuthPackets.Packet.PacketType.C2S_LoginToGameServer_Step2:
                    while (true)
                    {
                        if (Kernel.GamePool.ContainsKey(client.Account.EntityID) && Kernel.GamePool[client.Account.EntityID].Entity.FullyLoaded)
                        {
                            var ans = new AuthPackets.Packet(AuthPackets.Packet.PacketType.S2C_LoginToGameServer_Step2, new byte[4] {
                                1, 0, 0, 0
                            });
                            client.Send(ans);
                            break;
                        }
                        else
                        {
                            System.Threading.Thread.Sleep(10);
                        }
                    }
                    break;

                case AuthPackets.Packet.PacketType.C2S_GoBackForServers:
                    ReturnToServers(client, packet);
                    break;

                case AuthPackets.Packet.PacketType.C2S_CheckNameExsitance:
                    CheckNameExistance(client, packet);
                    break;

                case AuthPackets.Packet.PacketType.C2S_CreateAccount:
                    CreateAccount(client, packet);
                    break;

                case AuthPackets.Packet.PacketType.C2S_Exit:
                    //Send a Packet To Confirm Exit
                    packet.buffer[4] = 12;
                    client.Send(packet);
                    client.Disconnect();
                    break;

                case AuthPackets.Packet.PacketType.Unknown:
                    if (Program.CaptureUnknownPackets)
                    {
                        Console.WriteLine("Unknown Packet! =>  (" + packet.buffer[3] + "-" + packet.buffer[4] + "-" + packet.buffer[5] + ")");
                    }
                    break;
                }
            }
            else
            {
                Console.WriteLine("Incorrent Packet Structure! =>  (" + packet.buffer[3] + "-" + packet.buffer[4] + "-" + packet.buffer[5] + ")");
            }
        }