mirror of
https://github.com/chylex/Minecraft-Phantom-Panel.git
synced 2025-07-24 00:59:05 +02:00
71 lines
2.8 KiB
C#
71 lines
2.8 KiB
C#
using System.Collections.Immutable;
|
|
using Microsoft.EntityFrameworkCore;
|
|
using Phantom.Common.Data.Web.Users;
|
|
using Phantom.Controller.Database;
|
|
using Phantom.Controller.Database.Entities;
|
|
using Phantom.Utils.Collections;
|
|
using Phantom.Utils.Logging;
|
|
using Serilog;
|
|
|
|
namespace Phantom.Controller.Services.Users;
|
|
|
|
sealed class PermissionManager {
|
|
private static readonly ILogger Logger = PhantomLogger.Create<PermissionManager>();
|
|
|
|
private readonly IDbContextProvider dbProvider;
|
|
|
|
public PermissionManager(IDbContextProvider dbProvider) {
|
|
this.dbProvider = dbProvider;
|
|
}
|
|
|
|
public async Task Initialize() {
|
|
Logger.Information("Adding default permissions to database.");
|
|
|
|
await using var ctx = dbProvider.Eager();
|
|
|
|
var existingPermissionIds = await ctx.Permissions.Select(static p => p.Id).AsAsyncEnumerable().ToImmutableSetAsync();
|
|
var missingPermissionIds = GetMissingPermissionsOrdered(Permission.All, existingPermissionIds);
|
|
if (!missingPermissionIds.IsEmpty) {
|
|
Logger.Information("Adding default permissions: {Permissions}", string.Join(", ", missingPermissionIds));
|
|
|
|
foreach (var permissionId in missingPermissionIds) {
|
|
ctx.Permissions.Add(new PermissionEntity(permissionId));
|
|
}
|
|
|
|
await ctx.SaveChangesAsync();
|
|
}
|
|
}
|
|
|
|
public async Task<PermissionSet> FetchPermissionsForAllUsers(Guid userId) {
|
|
await using var ctx = dbProvider.Eager();
|
|
|
|
var userPermissions = ctx.UserPermissions
|
|
.Where(up => up.UserGuid == userId)
|
|
.Select(static up => up.PermissionId);
|
|
|
|
var rolePermissions = ctx.UserRoles
|
|
.Where(ur => ur.UserGuid == userId)
|
|
.Join(ctx.RolePermissions, static ur => ur.RoleGuid, static rp => rp.RoleGuid, static (ur, rp) => rp.PermissionId);
|
|
|
|
return new PermissionSet(await userPermissions.Union(rolePermissions).AsAsyncEnumerable().ToImmutableSetAsync());
|
|
}
|
|
|
|
public async Task<PermissionSet> FetchPermissionsForUserId(Guid userId) {
|
|
await using var ctx = dbProvider.Eager();
|
|
|
|
var userPermissions = ctx.UserPermissions
|
|
.Where(up => up.UserGuid == userId)
|
|
.Select(static up => up.PermissionId);
|
|
|
|
var rolePermissions = ctx.UserRoles
|
|
.Where(ur => ur.UserGuid == userId)
|
|
.Join(ctx.RolePermissions, static ur => ur.RoleGuid, static rp => rp.RoleGuid, static (ur, rp) => rp.PermissionId);
|
|
|
|
return new PermissionSet(await userPermissions.Union(rolePermissions).AsAsyncEnumerable().ToImmutableSetAsync());
|
|
}
|
|
|
|
public static ImmutableArray<string> GetMissingPermissionsOrdered(IEnumerable<Permission> allPermissions, ImmutableHashSet<string> existingPermissionIds) {
|
|
return allPermissions.Select(static permission => permission.Id).Except(existingPermissionIds).Order().ToImmutableArray();
|
|
}
|
|
}
|