mirror of
https://github.com/bitwarden/server.git
synced 2025-04-06 13:38:13 -05:00
[PM-3891] Remove the dollar threshold changes and Implement time-based threshold (#3948)
* implement time threshold Signed-off-by: Cy Okeke <cokeke@bitwarden.com> * add code to make failed payment is tried Signed-off-by: Cy Okeke <cokeke@bitwarden.com> --------- Signed-off-by: Cy Okeke <cokeke@bitwarden.com> Co-authored-by: Conner Turnbull <133619638+cturnbull-bitwarden@users.noreply.github.com>
This commit is contained in:
parent
f0b7074219
commit
48da6eba1c
@ -868,7 +868,7 @@ public class StripeController : Controller
|
|||||||
private bool UnpaidAutoChargeInvoiceForSubscriptionCycle(Invoice invoice)
|
private bool UnpaidAutoChargeInvoiceForSubscriptionCycle(Invoice invoice)
|
||||||
{
|
{
|
||||||
return invoice.AmountDue > 0 && !invoice.Paid && invoice.CollectionMethod == "charge_automatically" &&
|
return invoice.AmountDue > 0 && !invoice.Paid && invoice.CollectionMethod == "charge_automatically" &&
|
||||||
invoice.BillingReason == "subscription_cycle" && invoice.SubscriptionId != null;
|
invoice.BillingReason is "subscription_cycle" or "automatic_pending_invoice_item_invoice" && invoice.SubscriptionId != null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task<Subscription> VerifyCorrectTaxRateForCharge(Invoice invoice, Subscription subscription)
|
private async Task<Subscription> VerifyCorrectTaxRateForCharge(Invoice invoice, Subscription subscription)
|
||||||
|
@ -777,6 +777,7 @@ public class StripePaymentService : IPaymentService
|
|||||||
var chargeNow = collectionMethod == "charge_automatically";
|
var chargeNow = collectionMethod == "charge_automatically";
|
||||||
var updatedItemOptions = subscriptionUpdate.UpgradeItemsOptions(sub);
|
var updatedItemOptions = subscriptionUpdate.UpgradeItemsOptions(sub);
|
||||||
var isPm5864DollarThresholdEnabled = _featureService.IsEnabled(FeatureFlagKeys.PM5864DollarThreshold);
|
var isPm5864DollarThresholdEnabled = _featureService.IsEnabled(FeatureFlagKeys.PM5864DollarThreshold);
|
||||||
|
var isAnnualPlan = sub?.Items?.Data.FirstOrDefault()?.Plan?.Interval == "year";
|
||||||
|
|
||||||
var subUpdateOptions = new SubscriptionUpdateOptions
|
var subUpdateOptions = new SubscriptionUpdateOptions
|
||||||
{
|
{
|
||||||
@ -788,25 +789,10 @@ public class StripePaymentService : IPaymentService
|
|||||||
CollectionMethod = "send_invoice",
|
CollectionMethod = "send_invoice",
|
||||||
ProrationDate = prorationDate,
|
ProrationDate = prorationDate,
|
||||||
};
|
};
|
||||||
var immediatelyInvoice = false;
|
if (!invoiceNow && isAnnualPlan && isPm5864DollarThresholdEnabled && sub.Status.Trim() != "trialing")
|
||||||
if (!invoiceNow && isPm5864DollarThresholdEnabled && sub.Status.Trim() != "trialing")
|
|
||||||
{
|
{
|
||||||
var upcomingInvoiceWithChanges = await _stripeAdapter.InvoiceUpcomingAsync(new UpcomingInvoiceOptions
|
subUpdateOptions.PendingInvoiceItemInterval =
|
||||||
{
|
new SubscriptionPendingInvoiceItemIntervalOptions { Interval = "month" };
|
||||||
Customer = subscriber.GatewayCustomerId,
|
|
||||||
Subscription = subscriber.GatewaySubscriptionId,
|
|
||||||
SubscriptionItems = ToInvoiceSubscriptionItemOptions(updatedItemOptions),
|
|
||||||
SubscriptionProrationBehavior = Constants.CreateProrations,
|
|
||||||
SubscriptionProrationDate = prorationDate,
|
|
||||||
SubscriptionBillingCycleAnchor = SubscriptionBillingCycleAnchor.Now
|
|
||||||
});
|
|
||||||
|
|
||||||
var isAnnualPlan = sub?.Items?.Data.FirstOrDefault()?.Plan?.Interval == "year";
|
|
||||||
immediatelyInvoice = isAnnualPlan && upcomingInvoiceWithChanges.AmountRemaining >= 50000;
|
|
||||||
|
|
||||||
subUpdateOptions.BillingCycleAnchor = immediatelyInvoice
|
|
||||||
? SubscriptionBillingCycleAnchor.Now
|
|
||||||
: SubscriptionBillingCycleAnchor.Unchanged;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
var pm5766AutomaticTaxIsEnabled = _featureService.IsEnabled(FeatureFlagKeys.PM5766AutomaticTax);
|
var pm5766AutomaticTaxIsEnabled = _featureService.IsEnabled(FeatureFlagKeys.PM5766AutomaticTax);
|
||||||
@ -859,21 +845,16 @@ public class StripePaymentService : IPaymentService
|
|||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (!isPm5864DollarThresholdEnabled || immediatelyInvoice || invoiceNow)
|
if (chargeNow)
|
||||||
{
|
{
|
||||||
if (chargeNow)
|
paymentIntentClientSecret = await PayInvoiceAfterSubscriptionChangeAsync(subscriber, invoice);
|
||||||
{
|
}
|
||||||
paymentIntentClientSecret = await PayInvoiceAfterSubscriptionChangeAsync(subscriber, invoice);
|
else
|
||||||
}
|
{
|
||||||
else
|
invoice = await _stripeAdapter.InvoiceFinalizeInvoiceAsync(subResponse.LatestInvoiceId,
|
||||||
{
|
new InvoiceFinalizeOptions { AutoAdvance = false, });
|
||||||
invoice = await _stripeAdapter.InvoiceFinalizeInvoiceAsync(subResponse.LatestInvoiceId, new InvoiceFinalizeOptions
|
await _stripeAdapter.InvoiceSendInvoiceAsync(invoice.Id, new InvoiceSendOptions());
|
||||||
{
|
paymentIntentClientSecret = null;
|
||||||
AutoAdvance = false,
|
|
||||||
});
|
|
||||||
await _stripeAdapter.InvoiceSendInvoiceAsync(invoice.Id, new InvoiceSendOptions());
|
|
||||||
paymentIntentClientSecret = null;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch
|
catch
|
||||||
|
Loading…
x
Reference in New Issue
Block a user