From 637a923e8407687896846f42a9db9fd1277bf2d9 Mon Sep 17 00:00:00 2001 From: Geometrically <18202329+Geometrically@users.noreply.github.com> Date: Sun, 18 Aug 2024 11:35:39 -0700 Subject: [PATCH] Fix empty subscriptions (#954) --- src/routes/internal/billing.rs | 21 ++++++--------------- 1 file changed, 6 insertions(+), 15 deletions(-) diff --git a/src/routes/internal/billing.rs b/src/routes/internal/billing.rs index cdb8533f..57a15956 100644 --- a/src/routes/internal/billing.rs +++ b/src/routes/internal/billing.rs @@ -771,10 +771,11 @@ pub async fn initiate_payment( intent.metadata = Some(metadata); intent.automatic_payment_methods = Some(CreatePaymentIntentAutomaticPaymentMethods { allow_redirects: None, - enabled: true, + enabled: false, }); intent.receipt_email = user.email.as_deref(); intent.setup_future_usage = Some(PaymentIntentSetupFutureUsage::OffSession); + intent.payment_method_types = Some(vec!["card".to_string(), "cashapp".to_string()]); if let PaymentRequestType::PaymentMethod { .. } = payment_request.type_ { intent.payment_method = Some(payment_method.id.clone()); @@ -1007,22 +1008,12 @@ pub async fn stripe_webhook( user_subscription.price_id = metadata.product_price.id; user_subscription.interval = interval; user_subscription.upsert(&mut transaction).await?; + + intervals.get(&interval).copied() } else { - user_subscription_item::UserSubscriptionItem { - id: subscription_id, - user_id: metadata.user.id, - price_id: metadata.product_price.id, - interval, - created: Utc::now(), - expires: Utc::now(), - last_charge: Some(Utc::now()), - status: SubscriptionStatus::PaymentFailed, - } - .upsert(&mut transaction) - .await?; + // We don't create a new subscription for a failed payment, so we return None here so no email is sent + None } - - intervals.get(&interval).copied() } else { None }