Browse Source

Cleaning

master
Gregory Rudolph 3 years ago
parent
commit
b29a6bee3c
Signed by: rudi
GPG Key ID: EF64F3CBD1A1EBDD
  1. 50
      Account.cs

50
Account.cs

@ -1,8 +1,6 @@
using System; using System;
using System.Numerics;
using System.Collections.Generic; using System.Collections.Generic;
using MySql.Data.MySqlClient; using MySql.Data.MySqlClient;
using System.Globalization;
namespace NightmareCoreWeb2 namespace NightmareCoreWeb2
{ {
@ -10,7 +8,7 @@ namespace NightmareCoreWeb2
public class Account public class Account
{ {
public UInt32 Id { get; set; } public UInt32 Id { get; set; }
public bool IsGM {get; set;} public bool IsGM { get; set; }
public string Username { get; set; } public string Username { get; set; }
public string Email { get; set; } public string Email { get; set; }
public string LastIP { get; set; } public string LastIP { get; set; }
@ -19,7 +17,7 @@ namespace NightmareCoreWeb2
public List<Character> Characters { get; set; } public List<Character> Characters { get; set; }
public List<AccountAccess> Access { get; set; } public List<AccountAccess> Access { get; set; }
public Account(int id) public Account(int id)
{ {
MySqlConnection conn = new MySqlConnection(Program.connStr); MySqlConnection conn = new MySqlConnection(Program.connStr);
@ -125,25 +123,6 @@ namespace NightmareCoreWeb2
conn.Close(); conn.Close();
} }
public bool AuthenticateWithToken(string token)
{
MySqlConnection conn = new MySqlConnection(Program.connStr);
conn.Open();
string sql = "select token from tokens.active_tokens where email=@email";
MySqlCommand cmd = new MySqlCommand(sql, conn);
cmd.Parameters.AddWithValue("email", this.Email);
MySqlDataReader rdr = cmd.ExecuteReader();
string dbToken = "";
while (rdr.Read())
{
try
{
dbToken = rdr.GetString(0);
}
catch (Exception) { }
}
return token.Equals(dbToken);
}
public bool AuthenticateAccount(string password) public bool AuthenticateAccount(string password)
{ {
MySqlConnection conn = new MySqlConnection(Program.connStr); MySqlConnection conn = new MySqlConnection(Program.connStr);
@ -170,20 +149,21 @@ namespace NightmareCoreWeb2
{ {
return verifier.Compare(this.Verifier); return verifier.Compare(this.Verifier);
} }
public void ChangePassword(string NewPassword) { public void ChangePassword(string NewPassword)
{
MySqlConnection conn = new MySqlConnection(Program.connStr); MySqlConnection conn = new MySqlConnection(Program.connStr);
conn.Open(); conn.Open();
byte[] salt = new byte[32]; byte[] salt = new byte[32];
byte[] verifier = new byte[32]; byte[] verifier = new byte[32];
(salt, verifier) = Framework.Cryptography.SRP6.MakeRegistrationData(this.Username, NewPassword); (salt, verifier) = Framework.Cryptography.SRP6.MakeRegistrationData(this.Username, NewPassword);
string sql = "UPDATE auth.account SET salt=@salt, verifier=@verifier where username=@username"; string sql = "UPDATE auth.account SET salt=@salt, verifier=@verifier where username=@username";
MySqlCommand cmd = new MySqlCommand(sql, conn); MySqlCommand cmd = new MySqlCommand(sql, conn);
cmd.Parameters.AddWithValue("username", Username); cmd.Parameters.AddWithValue("username", Username);
cmd.Parameters.AddWithValue("salt", salt); cmd.Parameters.AddWithValue("salt", salt);
cmd.Parameters.AddWithValue("verifier", verifier); cmd.Parameters.AddWithValue("verifier", verifier);
cmd.ExecuteNonQuery(); cmd.ExecuteNonQuery();
conn.Close(); conn.Close();
} }
} }

Loading…
Cancel
Save