mirror of
https://github.com/bitwarden/server.git
synced 2025-04-06 05:28:15 -05:00
[Reset Password] Enrollment API, Service, and Model updates (#1245)
* [Reset Password] Enrollment API, Service and Model updates * Added conditional check for calling User's ID
This commit is contained in:
parent
339292f536
commit
296e3d881d
@ -180,6 +180,13 @@ namespace Bit.Api.Controllers
|
|||||||
var loggedInUserId = _userService.GetProperUserId(User);
|
var loggedInUserId = _userService.GetProperUserId(User);
|
||||||
await _organizationService.UpdateUserGroupsAsync(organizationUser, model.GroupIds.Select(g => new Guid(g)), loggedInUserId);
|
await _organizationService.UpdateUserGroupsAsync(organizationUser, model.GroupIds.Select(g => new Guid(g)), loggedInUserId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[HttpPut("{userId}/reset-password-enrollment")]
|
||||||
|
public async Task PutResetPasswordEnrollment(string orgId, string userId, [FromBody]OrganizationUserResetPasswordEnrollmentRequestModel model)
|
||||||
|
{
|
||||||
|
var callingUserId = _userService.GetProperUserId(User);
|
||||||
|
await _organizationService.UpdateUserResetPasswordEnrollmentAsync(new Guid(orgId), new Guid(userId), model.ResetPasswordKey, callingUserId);
|
||||||
|
}
|
||||||
|
|
||||||
[HttpDelete("{id}")]
|
[HttpDelete("{id}")]
|
||||||
[HttpPost("{id}/delete")]
|
[HttpPost("{id}/delete")]
|
||||||
|
@ -43,6 +43,8 @@
|
|||||||
OrganizationUser_Removed = 1503,
|
OrganizationUser_Removed = 1503,
|
||||||
OrganizationUser_UpdatedGroups = 1504,
|
OrganizationUser_UpdatedGroups = 1504,
|
||||||
OrganizationUser_UnlinkedSso = 1505,
|
OrganizationUser_UnlinkedSso = 1505,
|
||||||
|
OrganizationUser_ResetPassword_Enroll = 1506,
|
||||||
|
OrganizationUser_ResetPassword_Withdraw = 1507,
|
||||||
|
|
||||||
Organization_Updated = 1600,
|
Organization_Updated = 1600,
|
||||||
Organization_PurgedVault = 1601,
|
Organization_PurgedVault = 1601,
|
||||||
|
@ -84,4 +84,9 @@ namespace Bit.Core.Models.Api
|
|||||||
[Required]
|
[Required]
|
||||||
public IEnumerable<string> GroupIds { get; set; }
|
public IEnumerable<string> GroupIds { get; set; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public class OrganizationUserResetPasswordEnrollmentRequestModel
|
||||||
|
{
|
||||||
|
public string ResetPasswordKey { get; set; }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,6 +30,8 @@ namespace Bit.Core.Models.Api
|
|||||||
SsoBound = !string.IsNullOrWhiteSpace(organization.SsoExternalId);
|
SsoBound = !string.IsNullOrWhiteSpace(organization.SsoExternalId);
|
||||||
Identifier = organization.Identifier;
|
Identifier = organization.Identifier;
|
||||||
Permissions = CoreHelpers.LoadClassFromJsonData<Permissions>(organization.Permissions);
|
Permissions = CoreHelpers.LoadClassFromJsonData<Permissions>(organization.Permissions);
|
||||||
|
ResetPasswordKey = organization.ResetPasswordKey;
|
||||||
|
UserId = organization.UserId?.ToString();
|
||||||
}
|
}
|
||||||
|
|
||||||
public string Id { get; set; }
|
public string Id { get; set; }
|
||||||
@ -55,5 +57,7 @@ namespace Bit.Core.Models.Api
|
|||||||
public bool SsoBound { get; set; }
|
public bool SsoBound { get; set; }
|
||||||
public string Identifier { get; set; }
|
public string Identifier { get; set; }
|
||||||
public Permissions Permissions { get; set; }
|
public Permissions Permissions { get; set; }
|
||||||
|
public string ResetPasswordKey { get; set; }
|
||||||
|
public string UserId { get; set; }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -28,5 +28,6 @@ namespace Bit.Core.Models.Data
|
|||||||
public string SsoExternalId { get; set; }
|
public string SsoExternalId { get; set; }
|
||||||
public string Identifier { get; set; }
|
public string Identifier { get; set; }
|
||||||
public string Permissions { get; set; }
|
public string Permissions { get; set; }
|
||||||
|
public string ResetPasswordKey { get; set; }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -22,6 +22,7 @@ namespace Bit.Core.Models.Data
|
|||||||
public string ExternalId { get; set; }
|
public string ExternalId { get; set; }
|
||||||
public string SsoExternalId { get; set; }
|
public string SsoExternalId { get; set; }
|
||||||
public string Permissions { get; set; }
|
public string Permissions { get; set; }
|
||||||
|
public string ResetPasswordKey { get; set; }
|
||||||
|
|
||||||
public Dictionary<TwoFactorProviderType, TwoFactorProvider> GetTwoFactorProviders()
|
public Dictionary<TwoFactorProviderType, TwoFactorProvider> GetTwoFactorProviders()
|
||||||
{
|
{
|
||||||
|
@ -11,6 +11,7 @@ namespace Bit.Core.Models.Table
|
|||||||
public Guid? UserId { get; set; }
|
public Guid? UserId { get; set; }
|
||||||
public string Email { get; set; }
|
public string Email { get; set; }
|
||||||
public string Key { get; set; }
|
public string Key { get; set; }
|
||||||
|
public string ResetPasswordKey { get; set; }
|
||||||
public OrganizationUserStatusType Status { get; set; }
|
public OrganizationUserStatusType Status { get; set; }
|
||||||
public OrganizationUserType Type { get; set; }
|
public OrganizationUserType Type { get; set; }
|
||||||
public bool AccessAll { get; set; }
|
public bool AccessAll { get; set; }
|
||||||
|
@ -43,6 +43,7 @@ namespace Bit.Core.Services
|
|||||||
Task DeleteUserAsync(Guid organizationId, Guid organizationUserId, Guid? deletingUserId);
|
Task DeleteUserAsync(Guid organizationId, Guid organizationUserId, Guid? deletingUserId);
|
||||||
Task DeleteUserAsync(Guid organizationId, Guid userId);
|
Task DeleteUserAsync(Guid organizationId, Guid userId);
|
||||||
Task UpdateUserGroupsAsync(OrganizationUser organizationUser, IEnumerable<Guid> groupIds, Guid? loggedInUserId);
|
Task UpdateUserGroupsAsync(OrganizationUser organizationUser, IEnumerable<Guid> groupIds, Guid? loggedInUserId);
|
||||||
|
Task UpdateUserResetPasswordEnrollmentAsync(Guid organizationId, Guid organizationUserId, string resetPasswordKey, Guid? callingUserId);
|
||||||
Task<OrganizationLicense> GenerateLicenseAsync(Guid organizationId, Guid installationId);
|
Task<OrganizationLicense> GenerateLicenseAsync(Guid organizationId, Guid installationId);
|
||||||
Task<OrganizationLicense> GenerateLicenseAsync(Organization organization, Guid installationId,
|
Task<OrganizationLicense> GenerateLicenseAsync(Organization organization, Guid installationId,
|
||||||
int? version = null);
|
int? version = null);
|
||||||
|
@ -1378,6 +1378,24 @@ namespace Bit.Core.Services
|
|||||||
await _eventService.LogOrganizationUserEventAsync(organizationUser,
|
await _eventService.LogOrganizationUserEventAsync(organizationUser,
|
||||||
EventType.OrganizationUser_UpdatedGroups);
|
EventType.OrganizationUser_UpdatedGroups);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public async Task UpdateUserResetPasswordEnrollmentAsync(Guid organizationId, Guid organizationUserId, string resetPasswordKey, Guid? callingUserId)
|
||||||
|
{
|
||||||
|
var orgUser = await _organizationUserRepository.GetByOrganizationAsync(organizationId, organizationUserId);
|
||||||
|
if (!callingUserId.HasValue || orgUser == null || orgUser.UserId != callingUserId.Value ||
|
||||||
|
orgUser.Status != OrganizationUserStatusType.Confirmed ||
|
||||||
|
orgUser.OrganizationId != organizationId)
|
||||||
|
{
|
||||||
|
throw new BadRequestException("User not valid.");
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO - Block certain org types from using this feature?
|
||||||
|
|
||||||
|
orgUser.ResetPasswordKey = resetPasswordKey;
|
||||||
|
await _organizationUserRepository.ReplaceAsync(orgUser);
|
||||||
|
await _eventService.LogOrganizationUserEventAsync(orgUser, resetPasswordKey != null ?
|
||||||
|
EventType.OrganizationUser_ResetPassword_Enroll : EventType.OrganizationUser_ResetPassword_Withdraw);
|
||||||
|
}
|
||||||
|
|
||||||
public async Task<OrganizationLicense> GenerateLicenseAsync(Guid organizationId, Guid installationId)
|
public async Task<OrganizationLicense> GenerateLicenseAsync(Guid organizationId, Guid installationId)
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user