using System.Text.Json.Serialization; using Bit.Core.Entities; using Bit.Core.Enums; using Bit.Core.Models.Api; using Bit.Core.Models.Data; using Bit.Core.Models.Data.Organizations.OrganizationUsers; using Bit.Core.Utilities; namespace Bit.Api.Models.Response.Organizations; public class OrganizationUserResponseModel : ResponseModel { public OrganizationUserResponseModel(OrganizationUser organizationUser, string obj = "organizationUser") : base(obj) { if (organizationUser == null) { throw new ArgumentNullException(nameof(organizationUser)); } Id = organizationUser.Id.ToString(); UserId = organizationUser.UserId?.ToString(); Type = organizationUser.Type; Status = organizationUser.Status; AccessAll = organizationUser.AccessAll; ExternalId = organizationUser.ExternalId; AccessSecretsManager = organizationUser.AccessSecretsManager; Permissions = CoreHelpers.LoadClassFromJsonData(organizationUser.Permissions); ResetPasswordEnrolled = !string.IsNullOrEmpty(organizationUser.ResetPasswordKey); } public OrganizationUserResponseModel(OrganizationUserUserDetails organizationUser, string obj = "organizationUser") : base(obj) { if (organizationUser == null) { throw new ArgumentNullException(nameof(organizationUser)); } Id = organizationUser.Id.ToString(); UserId = organizationUser.UserId?.ToString(); Type = organizationUser.Type; Status = organizationUser.Status; AccessAll = organizationUser.AccessAll; ExternalId = organizationUser.ExternalId; AccessSecretsManager = organizationUser.AccessSecretsManager; Permissions = CoreHelpers.LoadClassFromJsonData(organizationUser.Permissions); ResetPasswordEnrolled = !string.IsNullOrEmpty(organizationUser.ResetPasswordKey); UsesKeyConnector = organizationUser.UsesKeyConnector; HasMasterPassword = organizationUser.HasMasterPassword; } public string Id { get; set; } public string UserId { get; set; } public OrganizationUserType Type { get; set; } public OrganizationUserStatusType Status { get; set; } public bool AccessAll { get; set; } public string ExternalId { get; set; } public bool AccessSecretsManager { get; set; } public Permissions Permissions { get; set; } public bool ResetPasswordEnrolled { get; set; } public bool UsesKeyConnector { get; set; } public bool HasMasterPassword { get; set; } } public class OrganizationUserDetailsResponseModel : OrganizationUserResponseModel { public OrganizationUserDetailsResponseModel(OrganizationUser organizationUser, IEnumerable collections) : base(organizationUser, "organizationUserDetails") { Collections = collections.Select(c => new SelectionReadOnlyResponseModel(c)); } public OrganizationUserDetailsResponseModel(OrganizationUserUserDetails organizationUser, IEnumerable collections) : base(organizationUser, "organizationUserDetails") { Collections = collections.Select(c => new SelectionReadOnlyResponseModel(c)); } public IEnumerable Collections { get; set; } [JsonIgnore(Condition = JsonIgnoreCondition.WhenWritingNull)] public IEnumerable Groups { get; set; } } public class OrganizationUserUserDetailsResponseModel : OrganizationUserResponseModel { public OrganizationUserUserDetailsResponseModel(OrganizationUserUserDetails organizationUser, bool twoFactorEnabled, string obj = "organizationUserUserDetails") : base(organizationUser, obj) { if (organizationUser == null) { throw new ArgumentNullException(nameof(organizationUser)); } Name = organizationUser.Name; Email = organizationUser.Email; AvatarColor = organizationUser.AvatarColor; TwoFactorEnabled = twoFactorEnabled; SsoBound = !string.IsNullOrWhiteSpace(organizationUser.SsoExternalId); Collections = organizationUser.Collections.Select(c => new SelectionReadOnlyResponseModel(c)); Groups = organizationUser.Groups; // Prevent reset password when using key connector. ResetPasswordEnrolled = ResetPasswordEnrolled && !organizationUser.UsesKeyConnector; } public string Name { get; set; } public string Email { get; set; } public string AvatarColor { get; set; } public bool TwoFactorEnabled { get; set; } public bool SsoBound { get; set; } public IEnumerable Collections { get; set; } public IEnumerable Groups { get; set; } } public class OrganizationUserResetPasswordDetailsResponseModel : ResponseModel { public OrganizationUserResetPasswordDetailsResponseModel(OrganizationUserResetPasswordDetails orgUser, string obj = "organizationUserResetPasswordDetails") : base(obj) { if (orgUser == null) { throw new ArgumentNullException(nameof(orgUser)); } Kdf = orgUser.Kdf; KdfIterations = orgUser.KdfIterations; KdfMemory = orgUser.KdfMemory; KdfParallelism = orgUser.KdfParallelism; ResetPasswordKey = orgUser.ResetPasswordKey; EncryptedPrivateKey = orgUser.EncryptedPrivateKey; } public KdfType Kdf { get; set; } public int KdfIterations { get; set; } public int? KdfMemory { get; set; } public int? KdfParallelism { get; set; } public string ResetPasswordKey { get; set; } public string EncryptedPrivateKey { get; set; } } public class OrganizationUserPublicKeyResponseModel : ResponseModel { public OrganizationUserPublicKeyResponseModel(Guid id, Guid userId, string key, string obj = "organizationUserPublicKeyResponseModel") : base(obj) { Id = id; UserId = userId; Key = key; } public Guid Id { get; set; } public Guid UserId { get; set; } public string Key { get; set; } } public class OrganizationUserBulkResponseModel : ResponseModel { public OrganizationUserBulkResponseModel(Guid id, string error, string obj = "OrganizationBulkConfirmResponseModel") : base(obj) { Id = id; Error = error; } public Guid Id { get; set; } public string Error { get; set; } }