mirror of
https://github.com/bitwarden/server.git
synced 2025-04-05 05:00:19 -05:00
Families for enterprise/fix new org sponsorship after deleted sponsored org (#1740)
* Sponsorship exists only if sponsored org is not null * Replace existing sponsorship if necessary * Update src/Core/Services/Implementations/OrganizationSponsorshipService.cs Co-authored-by: Robyn MacCallum <nickersthecat@gmail.com> * Fix tests Co-authored-by: Robyn MacCallum <nickersthecat@gmail.com>
This commit is contained in:
parent
dc3d70cf3a
commit
a70564cea8
@ -98,7 +98,7 @@ namespace Bit.Core.Services
|
|||||||
|
|
||||||
var existingOrgSponsorship = await _organizationSponsorshipRepository
|
var existingOrgSponsorship = await _organizationSponsorshipRepository
|
||||||
.GetBySponsoringOrganizationUserIdAsync(sponsoringOrgUser.Id);
|
.GetBySponsoringOrganizationUserIdAsync(sponsoringOrgUser.Id);
|
||||||
if (existingOrgSponsorship != null)
|
if (existingOrgSponsorship?.SponsoredOrganizationId != null)
|
||||||
{
|
{
|
||||||
throw new BadRequestException("Can only sponsor one organization per Organization User.");
|
throw new BadRequestException("Can only sponsor one organization per Organization User.");
|
||||||
}
|
}
|
||||||
@ -113,9 +113,15 @@ namespace Bit.Core.Services
|
|||||||
CloudSponsor = true,
|
CloudSponsor = true,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if (existingOrgSponsorship != null)
|
||||||
|
{
|
||||||
|
// Replace existing invalid offer with our new sponsorship offer
|
||||||
|
sponsorship.Id = existingOrgSponsorship.Id;
|
||||||
|
}
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
sponsorship = await _organizationSponsorshipRepository.CreateAsync(sponsorship);
|
await _organizationSponsorshipRepository.UpsertAsync(sponsorship);
|
||||||
|
|
||||||
await SendSponsorshipOfferAsync(sponsorship, sponsoringUserEmail);
|
await SendSponsorshipOfferAsync(sponsorship, sponsoringUserEmail);
|
||||||
}
|
}
|
||||||
|
@ -139,7 +139,7 @@ namespace Bit.Core.Test.Services
|
|||||||
};
|
};
|
||||||
|
|
||||||
await sutProvider.GetDependency<IOrganizationSponsorshipRepository>().Received(1)
|
await sutProvider.GetDependency<IOrganizationSponsorshipRepository>().Received(1)
|
||||||
.CreateAsync(Arg.Is<OrganizationSponsorship>(s => SponsorshipValidator(s, expectedSponsorship)));
|
.UpsertAsync(Arg.Is<OrganizationSponsorship>(s => SponsorshipValidator(s, expectedSponsorship)));
|
||||||
|
|
||||||
await sutProvider.GetDependency<IMailService>().Received(1).
|
await sutProvider.GetDependency<IMailService>().Received(1).
|
||||||
SendFamiliesForEnterpriseOfferEmailAsync(sponsoredEmail, email,
|
SendFamiliesForEnterpriseOfferEmailAsync(sponsoredEmail, email,
|
||||||
@ -156,7 +156,7 @@ namespace Bit.Core.Test.Services
|
|||||||
|
|
||||||
var expectedException = new Exception();
|
var expectedException = new Exception();
|
||||||
OrganizationSponsorship createdSponsorship = null;
|
OrganizationSponsorship createdSponsorship = null;
|
||||||
sutProvider.GetDependency<IOrganizationSponsorshipRepository>().CreateAsync(default).ThrowsForAnyArgs(callInfo =>
|
sutProvider.GetDependency<IOrganizationSponsorshipRepository>().UpsertAsync(default).ThrowsForAnyArgs(callInfo =>
|
||||||
{
|
{
|
||||||
createdSponsorship = callInfo.ArgAt<OrganizationSponsorship>(0);
|
createdSponsorship = callInfo.ArgAt<OrganizationSponsorship>(0);
|
||||||
createdSponsorship.Id = Guid.NewGuid();
|
createdSponsorship.Id = Guid.NewGuid();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user