mirror of
https://github.com/bitwarden/server.git
synced 2025-04-05 05:00:19 -05:00
Updated LicensingService to be a singleton again and moved IFeatureService up a frame in the call stack (#5238)
(cherry picked from commit 6771f79597fe038ecc605ad5cdd7320039d2d275)
This commit is contained in:
parent
8224f69df2
commit
4fa2995f7e
@ -15,17 +15,20 @@ public class CloudGetOrganizationLicenseQuery : ICloudGetOrganizationLicenseQuer
|
|||||||
private readonly IPaymentService _paymentService;
|
private readonly IPaymentService _paymentService;
|
||||||
private readonly ILicensingService _licensingService;
|
private readonly ILicensingService _licensingService;
|
||||||
private readonly IProviderRepository _providerRepository;
|
private readonly IProviderRepository _providerRepository;
|
||||||
|
private readonly IFeatureService _featureService;
|
||||||
|
|
||||||
public CloudGetOrganizationLicenseQuery(
|
public CloudGetOrganizationLicenseQuery(
|
||||||
IInstallationRepository installationRepository,
|
IInstallationRepository installationRepository,
|
||||||
IPaymentService paymentService,
|
IPaymentService paymentService,
|
||||||
ILicensingService licensingService,
|
ILicensingService licensingService,
|
||||||
IProviderRepository providerRepository)
|
IProviderRepository providerRepository,
|
||||||
|
IFeatureService featureService)
|
||||||
{
|
{
|
||||||
_installationRepository = installationRepository;
|
_installationRepository = installationRepository;
|
||||||
_paymentService = paymentService;
|
_paymentService = paymentService;
|
||||||
_licensingService = licensingService;
|
_licensingService = licensingService;
|
||||||
_providerRepository = providerRepository;
|
_providerRepository = providerRepository;
|
||||||
|
_featureService = featureService;
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task<OrganizationLicense> GetLicenseAsync(Organization organization, Guid installationId,
|
public async Task<OrganizationLicense> GetLicenseAsync(Organization organization, Guid installationId,
|
||||||
@ -38,11 +41,13 @@ public class CloudGetOrganizationLicenseQuery : ICloudGetOrganizationLicenseQuer
|
|||||||
}
|
}
|
||||||
|
|
||||||
var subscriptionInfo = await GetSubscriptionAsync(organization);
|
var subscriptionInfo = await GetSubscriptionAsync(organization);
|
||||||
|
var license = new OrganizationLicense(organization, subscriptionInfo, installationId, _licensingService, version);
|
||||||
return new OrganizationLicense(organization, subscriptionInfo, installationId, _licensingService, version)
|
if (_featureService.IsEnabled(FeatureFlagKeys.SelfHostLicenseRefactor))
|
||||||
{
|
{
|
||||||
Token = await _licensingService.CreateOrganizationTokenAsync(organization, installationId, subscriptionInfo)
|
license.Token = await _licensingService.CreateOrganizationTokenAsync(organization, installationId, subscriptionInfo);
|
||||||
};
|
}
|
||||||
|
|
||||||
|
return license;
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task<SubscriptionInfo> GetSubscriptionAsync(Organization organization)
|
private async Task<SubscriptionInfo> GetSubscriptionAsync(Organization organization)
|
||||||
|
@ -30,7 +30,6 @@ public class LicensingService : ILicensingService
|
|||||||
private readonly ILogger<LicensingService> _logger;
|
private readonly ILogger<LicensingService> _logger;
|
||||||
private readonly ILicenseClaimsFactory<Organization> _organizationLicenseClaimsFactory;
|
private readonly ILicenseClaimsFactory<Organization> _organizationLicenseClaimsFactory;
|
||||||
private readonly ILicenseClaimsFactory<User> _userLicenseClaimsFactory;
|
private readonly ILicenseClaimsFactory<User> _userLicenseClaimsFactory;
|
||||||
private readonly IFeatureService _featureService;
|
|
||||||
|
|
||||||
private IDictionary<Guid, DateTime> _userCheckCache = new Dictionary<Guid, DateTime>();
|
private IDictionary<Guid, DateTime> _userCheckCache = new Dictionary<Guid, DateTime>();
|
||||||
|
|
||||||
@ -42,7 +41,6 @@ public class LicensingService : ILicensingService
|
|||||||
ILogger<LicensingService> logger,
|
ILogger<LicensingService> logger,
|
||||||
IGlobalSettings globalSettings,
|
IGlobalSettings globalSettings,
|
||||||
ILicenseClaimsFactory<Organization> organizationLicenseClaimsFactory,
|
ILicenseClaimsFactory<Organization> organizationLicenseClaimsFactory,
|
||||||
IFeatureService featureService,
|
|
||||||
ILicenseClaimsFactory<User> userLicenseClaimsFactory)
|
ILicenseClaimsFactory<User> userLicenseClaimsFactory)
|
||||||
{
|
{
|
||||||
_userRepository = userRepository;
|
_userRepository = userRepository;
|
||||||
@ -51,7 +49,6 @@ public class LicensingService : ILicensingService
|
|||||||
_logger = logger;
|
_logger = logger;
|
||||||
_globalSettings = globalSettings;
|
_globalSettings = globalSettings;
|
||||||
_organizationLicenseClaimsFactory = organizationLicenseClaimsFactory;
|
_organizationLicenseClaimsFactory = organizationLicenseClaimsFactory;
|
||||||
_featureService = featureService;
|
|
||||||
_userLicenseClaimsFactory = userLicenseClaimsFactory;
|
_userLicenseClaimsFactory = userLicenseClaimsFactory;
|
||||||
|
|
||||||
var certThumbprint = environment.IsDevelopment() ?
|
var certThumbprint = environment.IsDevelopment() ?
|
||||||
@ -344,11 +341,6 @@ public class LicensingService : ILicensingService
|
|||||||
|
|
||||||
public async Task<string> CreateOrganizationTokenAsync(Organization organization, Guid installationId, SubscriptionInfo subscriptionInfo)
|
public async Task<string> CreateOrganizationTokenAsync(Organization organization, Guid installationId, SubscriptionInfo subscriptionInfo)
|
||||||
{
|
{
|
||||||
if (!_featureService.IsEnabled(FeatureFlagKeys.SelfHostLicenseRefactor))
|
|
||||||
{
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
var licenseContext = new LicenseContext
|
var licenseContext = new LicenseContext
|
||||||
{
|
{
|
||||||
InstallationId = installationId,
|
InstallationId = installationId,
|
||||||
@ -363,11 +355,6 @@ public class LicensingService : ILicensingService
|
|||||||
|
|
||||||
public async Task<string> CreateUserTokenAsync(User user, SubscriptionInfo subscriptionInfo)
|
public async Task<string> CreateUserTokenAsync(User user, SubscriptionInfo subscriptionInfo)
|
||||||
{
|
{
|
||||||
if (!_featureService.IsEnabled(FeatureFlagKeys.SelfHostLicenseRefactor))
|
|
||||||
{
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
var licenseContext = new LicenseContext { SubscriptionInfo = subscriptionInfo };
|
var licenseContext = new LicenseContext { SubscriptionInfo = subscriptionInfo };
|
||||||
var claims = await _userLicenseClaimsFactory.GenerateClaims(user, licenseContext);
|
var claims = await _userLicenseClaimsFactory.GenerateClaims(user, licenseContext);
|
||||||
var audience = $"user:{user.Id}";
|
var audience = $"user:{user.Id}";
|
||||||
|
@ -234,7 +234,7 @@ public static class ServiceCollectionExtensions
|
|||||||
services.AddScoped<IPaymentHistoryService, PaymentHistoryService>();
|
services.AddScoped<IPaymentHistoryService, PaymentHistoryService>();
|
||||||
services.AddSingleton<IStripeSyncService, StripeSyncService>();
|
services.AddSingleton<IStripeSyncService, StripeSyncService>();
|
||||||
services.AddSingleton<IMailService, HandlebarsMailService>();
|
services.AddSingleton<IMailService, HandlebarsMailService>();
|
||||||
services.AddScoped<ILicensingService, LicensingService>();
|
services.AddSingleton<ILicensingService, LicensingService>();
|
||||||
services.AddSingleton<ILookupClient>(_ =>
|
services.AddSingleton<ILookupClient>(_ =>
|
||||||
{
|
{
|
||||||
var options = new LookupClientOptions { Timeout = TimeSpan.FromSeconds(15), UseTcpOnly = true };
|
var options = new LookupClientOptions { Timeout = TimeSpan.FromSeconds(15), UseTcpOnly = true };
|
||||||
|
@ -57,6 +57,7 @@ public class CloudGetOrganizationLicenseQueryTests
|
|||||||
sutProvider.GetDependency<IInstallationRepository>().GetByIdAsync(installationId).Returns(installation);
|
sutProvider.GetDependency<IInstallationRepository>().GetByIdAsync(installationId).Returns(installation);
|
||||||
sutProvider.GetDependency<IPaymentService>().GetSubscriptionAsync(organization).Returns(subInfo);
|
sutProvider.GetDependency<IPaymentService>().GetSubscriptionAsync(organization).Returns(subInfo);
|
||||||
sutProvider.GetDependency<ILicensingService>().SignLicense(Arg.Any<ILicense>()).Returns(licenseSignature);
|
sutProvider.GetDependency<ILicensingService>().SignLicense(Arg.Any<ILicense>()).Returns(licenseSignature);
|
||||||
|
sutProvider.GetDependency<IFeatureService>().IsEnabled(FeatureFlagKeys.SelfHostLicenseRefactor).Returns(false);
|
||||||
|
|
||||||
var result = await sutProvider.Sut.GetLicenseAsync(organization, installationId);
|
var result = await sutProvider.Sut.GetLicenseAsync(organization, installationId);
|
||||||
|
|
||||||
@ -64,6 +65,27 @@ public class CloudGetOrganizationLicenseQueryTests
|
|||||||
Assert.Equal(organization.Id, result.Id);
|
Assert.Equal(organization.Id, result.Id);
|
||||||
Assert.Equal(installationId, result.InstallationId);
|
Assert.Equal(installationId, result.InstallationId);
|
||||||
Assert.Equal(licenseSignature, result.SignatureBytes);
|
Assert.Equal(licenseSignature, result.SignatureBytes);
|
||||||
|
Assert.Null(result.Token);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Theory]
|
||||||
|
[BitAutoData]
|
||||||
|
public async Task GetLicenseAsync_WhenFeatureFlagEnabled_CreatesToken(SutProvider<CloudGetOrganizationLicenseQuery> sutProvider,
|
||||||
|
Organization organization, Guid installationId, Installation installation, SubscriptionInfo subInfo,
|
||||||
|
byte[] licenseSignature, string token)
|
||||||
|
{
|
||||||
|
installation.Enabled = true;
|
||||||
|
sutProvider.GetDependency<IInstallationRepository>().GetByIdAsync(installationId).Returns(installation);
|
||||||
|
sutProvider.GetDependency<IPaymentService>().GetSubscriptionAsync(organization).Returns(subInfo);
|
||||||
|
sutProvider.GetDependency<ILicensingService>().SignLicense(Arg.Any<ILicense>()).Returns(licenseSignature);
|
||||||
|
sutProvider.GetDependency<IFeatureService>().IsEnabled(FeatureFlagKeys.SelfHostLicenseRefactor).Returns(true);
|
||||||
|
sutProvider.GetDependency<ILicensingService>()
|
||||||
|
.CreateOrganizationTokenAsync(organization, installationId, subInfo)
|
||||||
|
.Returns(token);
|
||||||
|
|
||||||
|
var result = await sutProvider.Sut.GetLicenseAsync(organization, installationId);
|
||||||
|
|
||||||
|
Assert.Equal(token, result.Token);
|
||||||
}
|
}
|
||||||
|
|
||||||
[Theory]
|
[Theory]
|
||||||
|
Loading…
x
Reference in New Issue
Block a user