2026-02-08 11:57:57 +01:00
|
|
|
using System.ComponentModel.DataAnnotations;
|
|
|
|
|
using System.ComponentModel.DataAnnotations.Schema;
|
2026-02-15 19:06:09 +01:00
|
|
|
using IdentityShroud.Core.Security;
|
2026-02-08 11:57:57 +01:00
|
|
|
|
2026-02-06 19:58:01 +01:00
|
|
|
namespace IdentityShroud.Core.Model;
|
|
|
|
|
|
2026-02-08 11:57:57 +01:00
|
|
|
[Table("realm")]
|
2026-02-06 19:58:01 +01:00
|
|
|
public class Realm
|
|
|
|
|
{
|
2026-02-08 11:57:57 +01:00
|
|
|
|
2026-02-06 19:58:01 +01:00
|
|
|
public Guid Id { get; set; }
|
2026-02-08 11:57:57 +01:00
|
|
|
/// <summary>
|
|
|
|
|
/// Note this is part of the url we should encourage users to keep it short but we do not want to limit them too much
|
|
|
|
|
/// </summary>
|
|
|
|
|
[MaxLength(40)]
|
2026-02-06 19:58:01 +01:00
|
|
|
public string Slug { get; set; } = "";
|
2026-02-08 11:57:57 +01:00
|
|
|
|
|
|
|
|
[MaxLength(128)]
|
|
|
|
|
public string Name { get; set; } = "";
|
|
|
|
|
public List<Client> Clients { get; init; } = [];
|
|
|
|
|
|
2026-02-27 17:57:42 +00:00
|
|
|
public List<RealmKey> Keys { get; init; } = [];
|
|
|
|
|
|
|
|
|
|
public List<RealmDek> Deks { get; init; } = [];
|
2026-02-15 19:06:09 +01:00
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Can be overriden per client
|
|
|
|
|
/// </summary>
|
|
|
|
|
public string DefaultSignatureAlgorithm { get; set; } = JsonWebAlgorithm.RS256;
|
2026-02-27 17:57:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Table("realm_dek")]
|
|
|
|
|
public record RealmDek
|
|
|
|
|
{
|
|
|
|
|
public required DekId Id { get; init; }
|
|
|
|
|
public required bool Active { get; set; }
|
|
|
|
|
public required string Algorithm { get; init; }
|
|
|
|
|
public required EncryptedDek KeyData { get; init; }
|
|
|
|
|
public required Guid RealmId { get; init; }
|
2026-02-15 19:06:09 +01:00
|
|
|
}
|