ASP.NET Razor website for https://wotdn.nightmare.haus

134 lines
4.0 KiB

3 years ago
using System;
using System.Text;
using System.Linq;
using System.Collections.Generic;
using MySql.Data.MySqlClient;
using System.Security.Cryptography;
using Microsoft.AspNetCore.Mvc.RazorPages;
using Microsoft.Extensions.Logging;
namespace NightmareCoreWeb2.Pages
{
public class AccountModel : PageModel
{
3 years ago
public string UserEmail { get; set; }
3 years ago
public string UserPassword { get; set; }
3 years ago
public string CharacterListType { get; set; }
3 years ago
public string AuthToken { get; set; }
3 years ago
public string Username { get; set; }
public bool IsGM { get; set; }
3 years ago
public bool IsAuthenticated = false;
3 years ago
public Account UserAccount { get; set; }
3 years ago
public List<Character> OnlineCharacters = new List<Character>();
3 years ago
public List<GMTicket> Tickets = new List<GMTicket>();
3 years ago
private readonly ILogger<AccountModel> _logger;
private MySqlConnection conn;
public AccountModel(ILogger<AccountModel> logger)
{
3 years ago
3 years ago
conn = new MySqlConnection(Program.connStr);
3 years ago
_logger = logger;
}
public void OnGetCharacterAction(int guid, int action)
{
OnGet();
3 years ago
if (!IsAuthenticated)
{
return;
}
Character c = new Character(guid);
foreach (Character test in this.UserAccount.Characters)
{
if (test.guid == c.guid)
{
if ((c.AtLogin & Character.AtLoginOptions.AT_LOGIN_FIRST) == 0)
{
c.AtLogin |= (Character.AtLoginOptions)action;
}
c.SetAtLogin();
}
}
}
3 years ago
public void OnGet()
{
ViewData["Title"] = "Login";
3 years ago
if (Request.Cookies.Count() > 1)
3 years ago
{
3 years ago
try
{
3 years ago
this.UserAccount = new Account(Request.Cookies["Username"]);
byte[] auth = Convert.FromBase64String(Request.Cookies["AuthToken"]);
this.Username = this.UserAccount.Username;
if (!this.UserAccount.AuthenticateAccount(auth))
{
3 years ago
Console.WriteLine($"Failed to authenticate {this.UserAccount.Username}");
Response.Cookies.Delete("Username");
Response.Cookies.Delete("AuthToken");
}
else
{
3 years ago
this.IsAuthenticated = true;
}
3 years ago
SetupAccount(this.UserAccount.Username);
}
catch (Exception e)
{
Console.WriteLine(e);
}
3 years ago
}
3 years ago
}
public void SetupAccount(string Username)
{
Account a = new Account(Username);
UserAccount = a;
OnlineCharacters = a.Characters;
foreach (var access in a.Access)
{
if (access.RealmID == -1 && access.RealmID >= 1)
3 years ago
{
this.IsGM = true;
this.Tickets = GMTicket.GetAllTickets();
3 years ago
}
}
ViewData["Title"] = a.Username;
CharacterListType = $"{a.Username}'s Characters";
3 years ago
this.UserAccount = a;
3 years ago
}
3 years ago
3 years ago
public void OnPostLogin()
{
UserEmail = Request.Form["UserEmail"];
UserPassword = Request.Form["UserPassword"];
3 years ago
try
{
Username = UserEmail.Substring(0, UserEmail.IndexOf("@"));
}
catch (Exception)
{
Username = UserEmail;
}
3 years ago
Account a = new Account(Username);
if (a.AuthenticateAccount(UserPassword))
{
Response.Cookies.Append("Username", Username);
3 years ago
Response.Cookies.Append("AuthToken", Convert.ToBase64String(a.Verifier));
Response.Redirect("/Account");
3 years ago
}
3 years ago
}
3 years ago
3 years ago
}
}