using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; using SharedLibraryCore; using WebfrontCore.ViewModels; using static SharedLibraryCore.Database.Models.EFClient; namespace WebfrontCore.Controllers { public class ActionController : BaseController { public IActionResult BanForm() { var info = new ActionInfo() { ActionButtonLabel = Localization["WEBFRONT_ACTION_BAN_NAME"], Name = "Ban", Inputs = new List() { new InputInfo() { Name = "Reason", Label = Localization["WEBFRONT_ACTION_LABEL_REASON"], }, new InputInfo() { Name ="Duration", Label=Localization["WEBFRONT_ACTION_LABEL_DURATION"], Type="select", Values = new Dictionary() { {"1", $"1 {Localization["GLOBAL_TIME_HOUR"]}" }, {"2", $"6 {Localization["GLOBAL_TIME_HOURS"]}" }, {"3", $"1 {Localization["GLOBAL_TIME_DAY"]}" }, {"4", $"2 {Localization["GLOBAL_TIME_DAYS"]}" }, {"5", $"1 {Localization["GLOBAL_TIME_WEEK"]}" }, {"6", $"{Localization["WEBFRONT_ACTION_SELECTION_PERMANENT"]}" }, } } }, Action = "BanAsync" }; return View("_ActionForm", info); } public async Task BanAsync(int targetId, string Reason, int Duration) { string duration = string.Empty; var loc = Utilities.CurrentLocalization.LocalizationIndex; switch (Duration) { case 1: duration = $"1{loc["GLOBAL_TIME_HOURS"][0]}"; break; case 2: duration = $"6{loc["GLOBAL_TIME_HOURS"][0]}"; break; case 3: duration = $"1{loc["GLOBAL_TIME_DAYS"][0]}"; break; case 4: duration = $"2{loc["GLOBAL_TIME_DAYS"][0]}"; break; case 5: duration = $"1{loc["GLOBAL_TIME_WEEKS"][0]}"; break; } string command = Duration == 6 ? $"!ban @{targetId} {Reason}" : $"!tempban @{targetId} {duration} {Reason}"; var server = Manager.GetServers().First(); return await Task.FromResult(RedirectToAction("ExecuteAsync", "Console", new { serverId = server.EndPoint, command })); } public IActionResult UnbanForm() { var info = new ActionInfo() { ActionButtonLabel = Localization["WEBFRONT_ACTION_UNBAN_NAME"], Name = "Unban", Inputs = new List() { new InputInfo() { Name = "Reason", Label = Localization["WEBFRONT_ACTION_LABEL_REASON"], } }, Action = "UnbanAsync" }; return View("_ActionForm", info); } public async Task UnbanAsync(int targetId, string Reason) { var server = Manager.GetServers().First(); return await Task.FromResult(RedirectToAction("ExecuteAsync", "Console", new { serverId = server.EndPoint, command = $"!unban @{targetId} {Reason}" })); } public IActionResult LoginForm() { var login = new ActionInfo() { ActionButtonLabel = Localization["WEBFRONT_ACTION_LOGIN_NAME"], Name = "Login", Inputs = new List() { new InputInfo() { Name = "clientId", Label = Localization["WEBFRONT_ACTION_LABEL_ID"] }, new InputInfo() { Name = "Password", Label = Localization["WEBFRONT_ACTION_LABEL_PASSWORD"], Type = "password", } }, Action = "LoginAsync" }; return View("_ActionForm", login); } public async Task LoginAsync(int clientId, string password) { return await Task.FromResult(RedirectToAction("LoginAsync", "Account", new { clientId, password })); } public IActionResult EditForm() { var info = new ActionInfo() { ActionButtonLabel = Localization["WEBFRONT_ACTION_LABEL_EDIT"], Name = "Edit", Inputs = new List() { new InputInfo() { Name ="level", Label=Localization["WEBFRONT_PROFILE_LEVEL"], Type="select", Values = Enum.GetValues(typeof(Permission)).OfType() .Where(p => p <= Client.Level) .Where(p => p != Permission.Banned) .Where(p => p != Permission.Flagged) .ToDictionary(p => p.ToString(), p=> p.ToLocalizedLevelName()) }, }, Action = "EditAsync" }; return View("_ActionForm", info); } public async Task EditAsync(int targetId, string level) { var server = Manager.GetServers().First(); return await Task.FromResult(RedirectToAction("ExecuteAsync", "Console", new { serverId = server.EndPoint, command = $"!setlevel @{targetId} {level}" })); } public async Task GenerateLoginTokenForm() { var info = new ActionInfo() { ActionButtonLabel = "Generate", Name = "GenerateLoginToken", Action = "GenerateLoginTokenAsync", Inputs = new List() }; return View("_ActionForm", info); } [Authorize] public string GenerateLoginTokenAsync() { var state = Manager.TokenAuthenticator.GenerateNextToken(Client.NetworkId); return string.Format(Utilities.CurrentLocalization.LocalizationIndex["COMMANDS_GENERATETOKEN_SUCCESS"], state.Token, $"{state.RemainingTime} {Utilities.CurrentLocalization.LocalizationIndex["GLOBAL_MINUTES"]}", Client.ClientId); } } }