Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pay-rails/pay
Payments for Ruby on Rails apps
https://github.com/pay-rails/pay
braintree engine hacktoberfest paddle pay payment-provider payments rails sca stripe subscription
Last synced: about 23 hours ago
JSON representation
Payments for Ruby on Rails apps
- Host: GitHub
- URL: https://github.com/pay-rails/pay
- Owner: pay-rails
- License: mit
- Created: 2017-02-01T19:50:52.000Z (almost 8 years ago)
- Default Branch: main
- Last Pushed: 2025-01-13T14:57:03.000Z (8 days ago)
- Last Synced: 2025-01-14T03:00:26.262Z (8 days ago)
- Topics: braintree, engine, hacktoberfest, paddle, pay, payment-provider, payments, rails, sca, stripe, subscription
- Language: Ruby
- Homepage: https://github.com/pay-rails/pay
- Size: 5.54 MB
- Stars: 2,011
- Watchers: 31
- Forks: 320
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: docs/contributing/adding_a_payment_processor.md
- Funding: .github/FUNDING.yml
- License: MIT-LICENSE
Awesome Lists containing this project
- awesome-rails-gems - pay-rails / pay
- awesome-rails-bootstrapped-br - Pay - Uma engine de pagamentos para Rails, com suporte para Stripe, Paddle, Braintree, Lemon Squeezy e Fake Processor. (🚂 **Acelere usando Rails**)
- awesome-rails-bootstrapped-br - Pay - Uma engine de pagamentos para Rails, com suporte para Stripe, Paddle, Braintree, Lemon Squeezy e Fake Processor. (🚂 **Acelere usando Rails**)
README
# 💳 Pay - Payments engine for Ruby on Rails
[![Build Status](https://github.com/pay-rails/pay/workflows/Tests/badge.svg)](https://github.com/pay-rails/pay/actions) [![Gem Version](https://badge.fury.io/rb/pay.svg)](https://badge.fury.io/rb/pay)
Pay is a payments engine for Ruby on Rails 6.0 and higher.
> [!TIP]
> Check out [Jumpstart](https://jumpstartrails.com) for Rails Starter Kit with Pay already integrated!**Upgrading?** Check the [UPGRADE](UPGRADE.md) guide for required changes and/or migration when upgrading from a previous version of Pay.
## 🧑💻 Tutorial
Want to see how Pay works? Check out our video getting started guide.
## 🏦 Payment Processors
Our supported payment processors are:
- Stripe ([SCA Compatible](https://stripe.com/docs/strong-customer-authentication) using API version `2022-11-15`)
- Paddle (SCA Compatible & supports PayPal)
- Braintree (supports PayPal)
- Lemon Squeezy (supports PayPal)
- [Fake Processor](docs/fake_processor/1_overview.md) (used for generic trials without cards, free subscriptions, testing, etc)Want to add a new payment provider? Contributions are welcome.
> We make our best attempt to standardize the different payment providers. They function differently so keep that in mind if you plan on doing more complex payments. It would be best to stick with a single payment provider in that case so you don't run into discrepancies.
## 📚 Docs
* [Installation](docs/1_installation.md)
* [Configuration](docs/2_configuration.md)
* **Usage**
* [Customers](docs/3_customers.md)
* [Payment Methods](docs/4_payment_methods.md)
* [Charges](docs/5_charges.md)
* [Subscriptions](docs/6_subscriptions.md)
* [Routes & Webhooks](docs/7_webhooks.md)
* [Customizing Pay Models](docs/8_customizing_models.md)* **Payment Processors**
* [Stripe](docs/stripe/1_overview.md)
* [Braintree](docs/braintree/1_overview.md)
* [Paddle](docs/paddle_billing/1_overview.md)
* [Lemon Squeezy](docs/lemon_squeezy/1_overview.md)
* [Fake Processor](docs/fake_processor/1_overview.md)
* [Asaas (Community)](https://github.com/PedroAugustoRamalhoDuarte/pay-asaas)
* **Marketplaces**
* [Stripe Connect](docs/marketplaces/stripe_connect.md)
* **Contributing**
* [Adding A Payment Processor](docs/contributing/adding_a_payment_processor.md)## 🙏 Contributing
If you have an issue you'd like to submit, please do so using the issue tracker in GitHub. In order for us to help you in the best way possible, please be as detailed as you can.
For those using devcontainers, if you want to test the application with different databases:
1. Uncomment the `DATABASE_URL` corresponding to the database type you wish to use in the `.devcontainer/devcontainer.json` file.
2. Rebuild the devcontainer, which will configure the application to use the selected database for your development environment.If you'd like to open a PR please make sure the following things pass:
```ruby
bin/rails db:test:prepare
bin/rails test
bundle exec standardrb
```## 📝 License
The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).