mirror of
https://github.com/bitwarden/server.git
synced 2025-04-05 05:00:19 -05:00
[PM-17540]Do not grant re-subscriptions trial period (#5327)
* Remove trial for restarted subscription Signed-off-by: Cy Okeke <cokeke@bitwarden.com> * Resolve the pr comment on initial change Signed-off-by: Cy Okeke <cokeke@bitwarden.com> * Resolve the issue of not saving payment method * Refactor the taxinfo mapping Signed-off-by: Cy Okeke <cokeke@bitwarden.com> --------- Signed-off-by: Cy Okeke <cokeke@bitwarden.com>
This commit is contained in:
parent
af07dffa6f
commit
cc211647d7
@ -2,6 +2,7 @@
|
|||||||
using Bit.Api.AdminConsole.Models.Request.Organizations;
|
using Bit.Api.AdminConsole.Models.Request.Organizations;
|
||||||
using Bit.Api.Billing.Models.Requests;
|
using Bit.Api.Billing.Models.Requests;
|
||||||
using Bit.Api.Billing.Models.Responses;
|
using Bit.Api.Billing.Models.Responses;
|
||||||
|
using Bit.Core.Billing.Models;
|
||||||
using Bit.Core.Billing.Models.Sales;
|
using Bit.Core.Billing.Models.Sales;
|
||||||
using Bit.Core.Billing.Services;
|
using Bit.Core.Billing.Services;
|
||||||
using Bit.Core.Context;
|
using Bit.Core.Context;
|
||||||
@ -17,7 +18,6 @@ namespace Bit.Api.Billing.Controllers;
|
|||||||
[Authorize("Application")]
|
[Authorize("Application")]
|
||||||
public class OrganizationBillingController(
|
public class OrganizationBillingController(
|
||||||
ICurrentContext currentContext,
|
ICurrentContext currentContext,
|
||||||
IFeatureService featureService,
|
|
||||||
IOrganizationBillingService organizationBillingService,
|
IOrganizationBillingService organizationBillingService,
|
||||||
IOrganizationRepository organizationRepository,
|
IOrganizationRepository organizationRepository,
|
||||||
IPaymentService paymentService,
|
IPaymentService paymentService,
|
||||||
@ -282,7 +282,15 @@ public class OrganizationBillingController(
|
|||||||
var plan = StaticStore.GetPlan(model.PlanType);
|
var plan = StaticStore.GetPlan(model.PlanType);
|
||||||
sale.Organization.PlanType = plan.Type;
|
sale.Organization.PlanType = plan.Type;
|
||||||
sale.Organization.Plan = plan.Name;
|
sale.Organization.Plan = plan.Name;
|
||||||
|
sale.SubscriptionSetup.SkipTrial = true;
|
||||||
await organizationBillingService.Finalize(sale);
|
await organizationBillingService.Finalize(sale);
|
||||||
|
var org = await organizationRepository.GetByIdAsync(organizationId);
|
||||||
|
if (organizationSignup.PaymentMethodType != null)
|
||||||
|
{
|
||||||
|
var paymentSource = new TokenizedPaymentSource(organizationSignup.PaymentMethodType.Value, organizationSignup.PaymentToken);
|
||||||
|
var taxInformation = TaxInformation.From(organizationSignup.TaxInfo);
|
||||||
|
await organizationBillingService.UpdatePaymentMethod(org, paymentSource, taxInformation);
|
||||||
|
}
|
||||||
|
|
||||||
return TypedResults.Ok();
|
return TypedResults.Ok();
|
||||||
}
|
}
|
||||||
|
@ -9,6 +9,7 @@ public class SubscriptionSetup
|
|||||||
public required Plan Plan { get; set; }
|
public required Plan Plan { get; set; }
|
||||||
public required PasswordManager PasswordManagerOptions { get; set; }
|
public required PasswordManager PasswordManagerOptions { get; set; }
|
||||||
public SecretsManager? SecretsManagerOptions { get; set; }
|
public SecretsManager? SecretsManagerOptions { get; set; }
|
||||||
|
public bool SkipTrial = false;
|
||||||
|
|
||||||
public class PasswordManager
|
public class PasswordManager
|
||||||
{
|
{
|
||||||
|
@ -379,7 +379,7 @@ public class OrganizationBillingService(
|
|||||||
["organizationId"] = organizationId.ToString()
|
["organizationId"] = organizationId.ToString()
|
||||||
},
|
},
|
||||||
OffSession = true,
|
OffSession = true,
|
||||||
TrialPeriodDays = plan.TrialPeriodDays
|
TrialPeriodDays = subscriptionSetup.SkipTrial ? 0 : plan.TrialPeriodDays
|
||||||
};
|
};
|
||||||
|
|
||||||
return await stripeAdapter.SubscriptionCreateAsync(subscriptionCreateOptions);
|
return await stripeAdapter.SubscriptionCreateAsync(subscriptionCreateOptions);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user