gpt4 book ai didi

ruby-on-rails - 付款失败后阻止用户使用 SaaS 应用程序的最佳方法是什么

转载 作者:太空宇宙 更新时间:2023-11-03 16:13:15 24 4
gpt4 key购买 nike

我正在使用 Ruby on Rails 开发 SaaS 应用程序。每个用户都必须订阅一个特定的计划才能开始使用该应用程序。这一步是使用 Stripe 完成的

问题是如果自动支付订阅失败(他更换信用卡等),我不知道如何阻止该用户使用我的应用程序。我正在考虑使用用户模型中的一列将此用户标记为非事件状态并阻止他登录。但这并不像我预期的那样工作,因为我希望此用户能够登录但他必须更新他的订阅继续。

顺便说一下,我在 Rails 上看到很多 SaaS 示例,例如 https://github.com/RailsApps/rails-stripe-membership-saashttps://github.com/railscasts/289-paypal-recurring-billing但似乎他们不会在发生故障时处理来自提供商(Stripe 或 Paypal)的回发。

请让我知道您的想法以及你们如何在类似项目中处理这个问题。

提前致谢

最佳答案

Stripe 会定期为您从卡中扣款。您的应用程序不负责为已订阅您的服务的用户产生新费用。

来自 the docs

Stripe makes handling failed payments easy. Stripe can automatically retry a recurring payment after it fails, and can automatically cancel the customer's subscription if it repeatedly fails. How long to wait, and how many times to retry, can be easily set in your account settings.

我可能会在我的 User 模型上跟踪一个 :subscription_active bool 值或类似值。当用户登录时,您可以检查 API 以查看用户订阅的状态。 <强> API docs 关于响应中订阅的状态有这样的说法(强调我自己的):

Possible values are trialing, active, past_due, canceled, or unpaid. A subscription still in its trial period is trialing and moves to active when the trial period is over. When payment to renew the subscription fails, the subscription becomes past_due. After Stripe has exhausted all payment retry attempts, the subscription ends up with a status of either canceled or unpaid depending on your retry settings. Note that when a subscription has a status of unpaid, any future invoices will not be attempted until the customer’s card details are updated.

如果响应返回为上述粗体状态之一,请将用户的 :subscription_active 标记为 false。在需要有条件地为用户启用应用程序功能的任何地方检查 user.subscription_active?

关于ruby-on-rails - 付款失败后阻止用户使用 SaaS 应用程序的最佳方法是什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18085777/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com