public void OnUserRequestDesKey(Client client) { if (OPT.SettingExists("des.key")) { if (debug) { Output.Write(new Message() { Text = string.Format("Client [{0}] requested des.key...", client.Id) }); } string desKey = OPT.GetString("des.key"); PacketStream stream = new PacketStream(0x9999); stream.WriteString(desKey); if (OPT.GetBool("debug")) { Output.Write(new Message() { Text = string.Format("[{0}] Sent!", desKey), AddBreak = true }); } ClientManager.Instance.Send(client, stream); } else { Output.Write(new Message() { Text = "Failed to find des.key in settings!", AddBreak = true }); } }
public static void SetIO() { GUI.Instance.Invoke(new MethodInvoker(delegate { GUI.Instance.IP.Text = OPT.GetString("io.ip"); GUI.Instance.Port.Text = OPT.GetString("io.port"); GUI.Instance.Maintenance.Text = (OPT.GetBool("maintenance")) ? "ON" : "OFF"; })); }
public void OnUserRequestDesKey(Client client) { if (OPT.SettingExists("des.key")) { string desKey = OPT.GetString("des.key"); PacketStream stream = new PacketStream(0x9999); stream.WriteString(desKey); if (OPT.GetBool("debug")) { Console.WriteLine("[{0}] Sent!", desKey); } ClientManager.Instance.Send(client, stream); } else { Console.WriteLine("Failed to find des.key in settings!"); } }
public void OnValidateUser(Client client, string username, string password, string fingerprint) { if (debug) { Console.WriteLine("Client [{0}] requested login validation with the following credentials:", client.Id); Console.WriteLine("Username: {0}\nPassword: {1}\nFingerprint: {2}", username, password, fingerprint); } // Check if username / password exist using (SqlConnection sqlCon = Database.Connection) { SqlCommand sqlCmd = new SqlCommand(); sqlCmd.Connection = sqlCon; sqlCmd.CommandText = string.Format("SELECT account_id FROM dbo.{0} WHERE login_name = @name AND password = @password", OPT.GetString("db.auth.table.alias")); sqlCmd.Parameters.Add("@name", SqlDbType.NVarChar).Value = username; sqlCmd.Parameters.Add("@password", SqlDbType.NVarChar).Value = PasswordCipher.CreateHash(OPT.GetString("md5.key"), password); if (debug) { Console.Write("\t-Checking for Account..."); } object result = Database.ExecuteStatement(sqlCmd, 1); if (debug) { Console.WriteLine(((int)result > 0) ? "[FOUND]" : "[NOT FOUND]"); } if ((int)result > 0) // Account exists { int account_id = (int)result; if (debug) { Console.Write("\t-Checking Account ban status..."); } // Check if account is banned sqlCmd.CommandText = string.Format("SELECT ban FROM dbo.{0} WHERE login_name = @name AND password = @password", OPT.GetString("db.auth.table.alias")); result = Database.ExecuteStatement(sqlCmd, 1); if (debug) { Console.WriteLine(((int)result == 0) ? "[NOT BANNED]" : "[BANNED]"); } if ((int)result == 0) // Account is not banned { if (debug) { Console.Write("\t-Checking for FingerPrint..."); } // Check for fingerprint sqlCmd.CommandText = "SELECT COUNT(account_id) FROM dbo.FingerPrint WHERE account_id = @account_id"; sqlCmd.Parameters.Clear(); sqlCmd.Parameters.Add("@account_id", SqlDbType.Int).Value = account_id; result = Database.ExecuteStatement(sqlCmd, 1); if (debug) { Console.WriteLine(((int)result == 1) ? "[FOUND]" : "[NOT FOUND]"); } if ((int)result == 1) // FingerPrint exists { if (debug) { Console.Write("\t-Checking FingerPrint ban status..."); } // Check if FingerPrint is banned sqlCmd.CommandText = "SELECT ban FROM dbo.FingerPrint WHERE account_id = @account_id"; result = Database.ExecuteStatement(sqlCmd, 1); if (debug) { Console.WriteLine(((int)result == 0) ? "[NOT BANNED]" : "[BANNED]"); } if ((int)result == 0) // FingerPrint is not banned { setOTP(ref client, ref sqlCmd, account_id); } else // FingerPrint is banned { if (debug) { Console.Write("\t-Checking if FingerPrint ban is expired..."); } // Get OTP Expiration Date sqlCmd.CommandText = "SELECT expiration_date FROM dbo.FingerPrint WHERE account_id = @account_id"; sqlCmd.Parameters.Clear(); sqlCmd.Parameters.Add("@account_id", SqlDbType.Int).Value = account_id; result = Database.ExecuteStatement(sqlCmd, 1); if ((DateTime)result < DateTime.Now) // Ban is up { if (debug) { Console.WriteLine("[EXPIRED]\n\t-Updating FingerPrint ban..."); } sqlCmd.CommandText = "UPDATE dbo.FingerPrint SET ban = 0 WHERE account_id = @account_id"; result = Database.ExecuteStatement(sqlCmd, 0); if (debug) { Console.WriteLine(((int)result == 1) ? "[SUCCESS]" : "[FAIL]"); } setOTP(ref client, ref sqlCmd, account_id); } else { ClientPackets.Instance.SC_SendBanStatus(client, 1); } } } else { if (debug) { Console.Write("\t-Inserting FingerPrint: {0}...", fingerprint); } sqlCmd.CommandText = "INSERT INTO dbo.FingerPrint (account_id, finger_print, ban, expiration_date) VALUES (@account_id, @finger_print, @ban, @expiration_date)"; sqlCmd.Parameters.Clear(); sqlCmd.Parameters.Add("@account_id", SqlDbType.Int).Value = account_id; sqlCmd.Parameters.Add("@finger_print", SqlDbType.NVarChar).Value = fingerprint; sqlCmd.Parameters.Add("@ban", SqlDbType.Int).Value = 0; sqlCmd.Parameters.Add("@expiration_date", SqlDbType.DateTime).Value = new DateTime(1999, 1, 1, 12, 0, 0, 0); result = Database.ExecuteStatement(sqlCmd, 0); if (debug) { Console.WriteLine(((int)result == 1) ? "[SUCCESS]" : "[FAIL]"); } } } else { ClientPackets.Instance.SC_SendBanStatus(client, 0); } // Account is banned } else { ClientPackets.Instance.SC_SendAccountNull(client); } // Account doesn't exist } }
internal void OnUserRequestArguments(Client client) { string arguments = string.Format("/auth_ip:{0} /auth_port:{1} /locale:? country:? /use_nprotect:0 /cash /commercial_shop /allow_double_exec:{2}", OPT.GetString("auth.io.ip"), OPT.GetString("auth.io.port"), OPT.GetString("double.execute")); if (OPT.GetBool("imbc.login")) { arguments += "/imbclogin /account:? /password:?"; } ClientPackets.Instance.SC_SendArguments(client, arguments, OPT.GetInt("sframe.bypass")); }
internal void OnUserRequestArguments(Client client) { ClientPackets.Instance.SC_SendArguments(client, string.Format("/auth_ip:{0} /auth_port:{1} /locale:? /country:? /use_nprotect:0 /cash /commercial_shop /allow_double_exec:1 /imbclogin /account:? /password:?", OPT.GetString("auth.io.ip"), OPT.GetString("auth.io.port")); }