#nullable enable using LBPUnion.ProjectLighthouse.Administration; using LBPUnion.ProjectLighthouse.PlayerData.Profiles; using LBPUnion.ProjectLighthouse.Servers.Website.Pages.Layouts; using LBPUnion.ProjectLighthouse.Types; using Microsoft.AspNetCore.Mvc; using Microsoft.EntityFrameworkCore; namespace LBPUnion.ProjectLighthouse.Servers.Website.Pages.Admin; public class ModeratorBanUserPage : BaseLayout { public User? TargetedUser; public ModeratorBanUserPage(Database database) : base(database) {} public async Task OnGet([FromRoute] int id) { User? user = this.Database.UserFromWebRequest(this.Request); if (user == null || !user.IsModerator) return this.NotFound(); this.TargetedUser = await this.Database.Users.FirstOrDefaultAsync(u => u.UserId == id); if (this.TargetedUser == null) return this.NotFound(); return this.Page(); } public async Task OnPost([FromRoute] int id, string reason, string modNotes, DateTime caseExpires) { User? user = this.Database.UserFromWebRequest(this.Request); if (user == null || !user.IsModerator) return this.NotFound(); this.TargetedUser = await this.Database.Users.FirstOrDefaultAsync(u => u.UserId == id); if (this.TargetedUser == null) return this.NotFound(); this.TargetedUser.PermissionLevel = PermissionLevel.Banned; this.TargetedUser.BannedReason = reason; // invalidate all currently active gametokens this.Database.GameTokens.RemoveRange(this.Database.GameTokens.Where(t => t.UserId == this.TargetedUser.UserId)); // invalidate all currently active webtokens this.Database.WebTokens.RemoveRange(this.Database.WebTokens.Where(t => t.UserId == this.TargetedUser.UserId)); // generate & add moderation case this.Database.Add(ModerationCase.NewBanCase(user.UserId, this.TargetedUser.UserId, reason, modNotes, caseExpires)); await this.Database.SaveChangesAsync(); return this.Redirect($"/user/{this.TargetedUser.UserId}"); } }