IdentityShroud/IdentityShroud.Core/Services/RealmService.cs

64 lines
1.9 KiB
C#
Raw Normal View History

using System.Security.Cryptography;
using IdentityShroud.Core.Contracts;
2026-02-08 18:00:24 +01:00
using IdentityShroud.Core.Helpers;
using IdentityShroud.Core.Messages.Realm;
using IdentityShroud.Core.Model;
using IdentityShroud.Core.Security.Keys;
using IdentityShroud.Core.Security.Keys.Rsa;
2026-02-15 07:15:11 +01:00
using Microsoft.EntityFrameworkCore;
namespace IdentityShroud.Core.Services;
2026-02-08 18:00:24 +01:00
public record RealmCreateResponse(Guid Id, string Slug, string Name);
public class RealmService(
Db db,
IKeyService keyService) : IRealmService
{
public async Task<Realm?> FindById(Guid id, CancellationToken ct = default)
{
return await db.Realms
.SingleOrDefaultAsync(r => r.Id == id, ct);
}
2026-02-15 07:15:11 +01:00
public async Task<Realm?> FindBySlug(string slug, CancellationToken ct = default)
{
return await db.Realms
.SingleOrDefaultAsync(r => r.Slug == slug, ct);
}
public async Task<Result<RealmCreateResponse>> Create(RealmCreateRequest request, CancellationToken ct = default)
{
Realm realm = new()
{
Id = request.Id ?? Guid.CreateVersion7(),
2026-02-08 18:00:24 +01:00
Slug = request.Slug ?? SlugHelper.GenerateSlug(request.Name),
Name = request.Name,
};
realm.Keys.Add(keyService.CreateKey(GetKeyPolicy(realm)));
db.Add(realm);
await db.SaveChangesAsync(ct);
2026-02-08 18:00:24 +01:00
return new RealmCreateResponse(
realm.Id, realm.Slug, realm.Name);
}
/// <summary>
/// Place holder for getting policies from the realm and falling back to sane defaults when no policies have been set.
/// </summary>
/// <param name="_"></param>
/// <returns></returns>
private KeyPolicy GetKeyPolicy(Realm _) => new RsaKeyPolicy();
public async Task LoadActiveKeys(Realm realm)
{
await db.Entry(realm).Collection(r => r.Keys)
.Query()
2026-02-20 17:35:38 +01:00
.Where(k => k.RevokedAt == null)
.LoadAsync();
}
}