Files
server/extra/admin-api/Spacebar.UApi/Services/PermissionService.cs
T
2026-02-26 08:58:36 +01:00

41 lines
1.8 KiB
C#

using Microsoft.EntityFrameworkCore;
using Spacebar.Models.Db.Contexts;
using Spacebar.Models.Generic.Constants;
namespace Spacebar.UApi.Services;
public class PermissionService(SpacebarDbContext db) {
/// <summary>
/// Asserts that user has all the relevant guild permissions
/// </summary>
/// <param name="permission">Permissions to require</param>
/// <param name="guildId">Guild ID</param>
/// <param name="userId">Member ID</param>
/// <exception cref="InvalidOperationException">Has one or more missing permissions</exception>
public async Task AssertUserHasGuildPermission(Permissions permission, string guildId, string userId) {
var member = await db.Members
.Include(x => x.Roles)
.SingleAsync(x => x.Id == userId && x.GuildId == guildId);
if (member is null)
throw new InvalidOperationException("You are not a member of this guild.");
var permissions = member.Roles.Aggregate((Permissions)0UL, (current, role) => current | (Permissions)ulong.Parse(role.Permissions));
if (member.CommunicationDisabledUntil is not null && member.CommunicationDisabledUntil > DateTime.UtcNow) {
permissions &= Permissions.ViewChannel | Permissions.ReadMessageHistory;
}
if (!permissions.HasFlag(permission))
throw new PermissionException(Enum.GetValues<Permissions>().Where(p => !permissions.HasFlag(p) && permission.HasFlag(p)));
}
}
public class PermissionException : Exception {
public IEnumerable<Permissions> MissingPermissions { get; }
public PermissionException(IEnumerable<Permissions> missingPermissions) : base(
$"You do not have the required permissions to perform this action: {string.Join(", ", missingPermissions)}") {
MissingPermissions = missingPermissions;
}
}