| | | 1 | | using Syki.Back.Domain.Enums; |
| | | 2 | | |
| | | 3 | | namespace Syki.Back.Domain.Identity; |
| | | 4 | | |
| | | 5 | | /// <summary> |
| | | 6 | | /// SSO configuration for an institution. |
| | | 7 | | /// </summary> |
| | | 8 | | public class SsoConfiguration |
| | | 9 | | { |
| | 0 | 10 | | public int Id { get; set; } |
| | 0 | 11 | | public Guid PublicId { get; set; } |
| | 0 | 12 | | public int InstitutionId { get; set; } |
| | | 13 | | |
| | | 14 | | // Provider |
| | 0 | 15 | | public SsoProviderType ProviderType { get; set; } |
| | 0 | 16 | | public string Authority { get; set; } |
| | 0 | 17 | | public string ClientId { get; set; } |
| | 0 | 18 | | public string ClientSecret { get; set; } |
| | | 19 | | |
| | | 20 | | // Domains |
| | 0 | 21 | | public List<SsoAllowedDomain> AllowedDomains { get; set; } |
| | | 22 | | |
| | | 23 | | // Behavior |
| | 0 | 24 | | public bool IsActive { get; set; } |
| | 0 | 25 | | public bool RequireSso { get; set; } |
| | | 26 | | |
| | | 27 | | // Metadata |
| | 0 | 28 | | public DateTime CreatedAt { get; set; } |
| | 0 | 29 | | public DateTime UpdatedAt { get; set; } |
| | | 30 | | |
| | 0 | 31 | | public SsoConfiguration() { } |
| | | 32 | | |
| | 0 | 33 | | public SsoConfiguration( |
| | 0 | 34 | | int orgId, |
| | 0 | 35 | | SsoProviderType providerType, |
| | 0 | 36 | | string authority, |
| | 0 | 37 | | string clientId, |
| | 0 | 38 | | string clientSecret, |
| | 0 | 39 | | List<string> allowedDomains) |
| | | 40 | | { |
| | 0 | 41 | | InstitutionId = orgId; |
| | 0 | 42 | | PublicId = Guid.NewGuid(); |
| | 0 | 43 | | ProviderType = providerType; |
| | 0 | 44 | | Authority = authority; |
| | 0 | 45 | | ClientId = clientId; |
| | 0 | 46 | | ClientSecret = clientSecret; |
| | 0 | 47 | | IsActive = true; |
| | 0 | 48 | | RequireSso = false; |
| | 0 | 49 | | CreatedAt = DateTime.UtcNow; |
| | 0 | 50 | | UpdatedAt = CreatedAt; |
| | | 51 | | |
| | 0 | 52 | | AllowedDomains = allowedDomains |
| | 0 | 53 | | .Select(d => new SsoAllowedDomain(d)) |
| | 0 | 54 | | .ToList(); |
| | 0 | 55 | | } |
| | | 56 | | |
| | | 57 | | public void Update( |
| | | 58 | | SsoProviderType providerType, |
| | | 59 | | string authority, |
| | | 60 | | string clientId, |
| | | 61 | | string clientSecret, |
| | | 62 | | bool isActive, |
| | | 63 | | bool requireSso) |
| | | 64 | | { |
| | 0 | 65 | | ProviderType = providerType; |
| | 0 | 66 | | Authority = authority; |
| | 0 | 67 | | ClientId = clientId; |
| | 0 | 68 | | ClientSecret = clientSecret; |
| | 0 | 69 | | IsActive = isActive; |
| | 0 | 70 | | RequireSso = requireSso; |
| | 0 | 71 | | UpdatedAt = DateTime.UtcNow; |
| | 0 | 72 | | } |
| | | 73 | | } |