Skip to content

Latest commit

 

History

History
72 lines (48 loc) · 2.44 KB

3_customers.md

File metadata and controls

72 lines (48 loc) · 2.44 KB

Customers

Every payment processor has a Customer object that keeps track of your customers by email. Pay keeps track of these Customers with the Pay::Customer model.

Setting the Payment Processor

Before you can process payments, you need to assign a payment processor for the user.

@user.set_payment_processor :stripe
@user.set_payment_processor :braintree
@user.set_payment_processor :paddle_billing
@user.set_payment_processor :paddle_classic
@user.set_payment_processor :lemon_squeezy
@user.set_payment_processor :fake_processor, allow_fake: true

This creates a Pay::Customer record in the database that keeps track of the payment processor's ID and allows you to interact with the API to charge and subscribe this customer.

The fake_processor is restricted by default so users can't give themselves free access to your application.

Alternatively, you can set a default processor for all users.

class User < ApplicationRecord
  pay_customer default_payment_processor: :stripe
end

Payment Processor Associations

After setting the payment processor, your model will have a payment_processor they can use to create charges, subscriptions, etc.

@user.payment_processor
#=> #<Pay::Customer processor: "stripe", processor_id: "cus_1000">

This record keeps track of payment processor that is active and the ID for the customer on the API. It also is associated with all Charges, Subscriptions, and Payment Methods.

A user might switch between payment processors. For example, they might initially subscribe using Braintree, cancel after a while, and resubscribe using Stripe later on.

Pay keeps track of these with a has_many :pay_customers association.

@user.pay_customers
#=> [#<Pay::Customer>, #<Pay::Customer>]

Only one Pay::Customer can be the default which is used for payment_processor.

Retrieving a Customer object from the Payment Processor

For Paddle Billing and Lemon Squeezy, using the api_record method will create a new customer on the payment processor.

If the processor_id is already set, it will retrieve the customer from the payment processor and return the object directly from the API. Like so:

@user.payment_processor.api_record
#=> #<Stripe::Customer>
#=> #<Paddle::Customer>
#=> #<LemonSqueezy::Customer>
Paddle Classic:

It is currently not possible to retrieve a Customer object through the Paddle Classic API.

Next

See Payment Methods