using System.ComponentModel.DataAnnotations; using System.Text.Json; using Bit.Api.Models.Request.Accounts; using Bit.Core.Entities; using Bit.Core.Enums; using Bit.Core.Models.Data; using Bit.Core.Models.Data.Organizations.OrganizationUsers; using Bit.Core.Utilities; namespace Bit.Api.Models.Request.Organizations; public class OrganizationUserInviteRequestModel { [Required] [StrictEmailAddressList] public IEnumerable Emails { get; set; } [Required] public OrganizationUserType? Type { get; set; } public bool AccessAll { get; set; } public bool AccessSecretsManager { get; set; } public Permissions Permissions { get; set; } public IEnumerable Collections { get; set; } public IEnumerable Groups { get; set; } public OrganizationUserInviteData ToData() { return new OrganizationUserInviteData { Emails = Emails, Type = Type, AccessAll = AccessAll, AccessSecretsManager = AccessSecretsManager, Collections = Collections?.Select(c => c.ToSelectionReadOnly()), Groups = Groups, Permissions = Permissions, }; } } public class OrganizationUserAcceptRequestModel { [Required] public string Token { get; set; } // Used to auto-enroll in master password reset public string ResetPasswordKey { get; set; } } public class OrganizationUserConfirmRequestModel { [Required] public string Key { get; set; } } public class OrganizationUserBulkConfirmRequestModelEntry { [Required] public Guid Id { get; set; } [Required] public string Key { get; set; } } public class OrganizationUserBulkConfirmRequestModel { [Required] public IEnumerable Keys { get; set; } public Dictionary ToDictionary() { return Keys.ToDictionary(e => e.Id, e => e.Key); } } public class OrganizationUserUpdateRequestModel { [Required] public OrganizationUserType? Type { get; set; } public bool AccessAll { get; set; } public bool AccessSecretsManager { get; set; } public Permissions Permissions { get; set; } public IEnumerable Collections { get; set; } public IEnumerable Groups { get; set; } public OrganizationUser ToOrganizationUser(OrganizationUser existingUser) { existingUser.Type = Type.Value; existingUser.Permissions = JsonSerializer.Serialize(Permissions, new JsonSerializerOptions { PropertyNamingPolicy = JsonNamingPolicy.CamelCase, }); existingUser.AccessAll = AccessAll; existingUser.AccessSecretsManager = AccessSecretsManager; return existingUser; } } public class OrganizationUserUpdateGroupsRequestModel { [Required] public IEnumerable GroupIds { get; set; } } public class OrganizationUserResetPasswordEnrollmentRequestModel : SecretVerificationRequestModel { public string ResetPasswordKey { get; set; } } public class OrganizationUserBulkRequestModel { [Required] public IEnumerable Ids { get; set; } }