Payments JS API
Use our fliplet-payments
library to add payments functionality in your Fliplet apps using Stripe within minutes using a easy-to-use JS API.
Before you start, make sure you have signed up for a Stripe account on their website as it will be required in the very first steps of the integration.
Dependency name: fliplet-payments
Data models and key concepts
Adding payments to your apps has the following four requirements:
- An app is configured to use payments, including adding the required settings and secrets which are securely stored in our backend.
- You have created a Stripe account and configured the Fliplet webhook URL on their dashboard.
- A Data Source is created with a specific structure to manage the list of products you want the app users to be able to buy.
- Custom code is added in your app screen to let users buy the products and complete the checkout process using our simple JS APIs.
Configuration
To start setting up payments for your app, add fliplet-payments
to your app or screen dependencies.
1. Configure the payment settings
An app must first configure its payment settings before users are able to buy products. Configuring the app is done by making a JS API or RESTful API request including the following information:
provider
:string
- the payment provider; we currently only supportstripe
as valueproviderPublicKey
:string
- the publisheable key from StripeproviderPrivateKey
:string
- the secret key from StripeproductsDataSourceId
:number
- the ID of the Data Source listing the products your users can buy
Note: the following request must be made only once and from an authenticated Studio user. You can however call it at any time to update the configuration.
// Run this once while logged in as a Studio user
// to set up or update the configuration.
Fliplet.Payments.Configuration.update({
provider: 'stripe',
// Get these from https://dashboard.stripe.com/apikeys
providerPublicKey: 'pk_live_abcdef123456', // Publisheable key
providerPrivateKey: 'sk_live_abcdef123456', // Secret key
productsDataSourceId: 123 // ID of the products data source
}).then(function (result) {
// Configuration has been set successfully.
// Your app is almost ready to start checkout sessions.
console.log('Webhook URL to configure in Stripe', result.webhookUrl);
// result.webhookUrl must be configured on your payment provider,
// see the next section of the docs here below.
// Here's an example of what the URL looks like:
// https://api.fliplet.com/v1/billing/apps/webhook/8a85a2edc3f3a774ac06f
});
2. Configure webhooks in the payment provider
Before you start accepting payments, webhooks must be set up in your payment provider to notify Fliplet about charges made from buying products and subscriptions.
The previous JS API (Fliplet.Payments.Configuration.update
) returns a webhookUrl
in its promise callback which you should note down and add into Stripe:
- Go to the Developers > Webhooks section in Stripe
- Click
Add endpoint
- Add the value you got from
webhookUrl
in theEndpoint URL
field. The value has a format similar to this URL:https://api.fliplet.com/v1/billing/apps/webhook/8a85a2edc3f3a774ac06f
- Choose the following events to be sent:
customer.subscription.updated
customer.subscription.deleted
customer.subscription.created
Save changes to add the endpoint, then copy the value of the Signing secret
:
Finally, configure your signing secret in the Fliplet app by running the following JS API as a logged in Studio user:
// Run this once while logged in as a Studio user
// to set up or update the signing secret from Stripe.
Fliplet.Payments.Configuration.updateSigningSecret('whsec_123abc').then(function () {
// Configuration has been set successfully.
// Your app is now ready to start checkout sessions.
});
Once the webhook has been set up, you can start to configure your data source with the products you want to list.
3. Configure the products
Use the “App data” section of Fliplet Studio or the Data Sources JS APIs to manage a list of products for users to buy. Each product requires the following information:
- Name:
string
- Price:
float
- Price ID:
string
- the ID or hash as found in your payment provider
Here’s an example Data Source containing a few products:
Name | Description | Price | Price ID |
---|---|---|---|
Premium plan | A fancy premium plan | 1.00 | price_1HAuW7JNczvHKhMA2lbd8xjs |
Gold plan | A even fancier gold plan | 2.50 | price_2HAuW7sNczvfKhMA2lbd1xjx |
Once you have set up one or more products you’re ready to start accepting payments in your app.
4. Add code to initiate a checkout session
Our JS APIs allow your apps to read the list of products you have configured and then initiate a checkout process for one of your products.
You want to first read the list of products, then let the user choose one (and its quantity) and then initiate a checkout session.
These are the two JS APIs you need to use to achieve what has been described above:
Fliplet.Payments.Products.get()
- fetch the list of products you have configured in the data sourceFliplet.Payments.Checkout.create(options)
- initiate a checkout session to let the user buy a product
Moreover, although not required it is recommended that you use the following JS API to create a customer on Stripe:
Fliplet.Payments.Customers.create(options)
- create a customer (if it’s existing then it just gets returned)
Here’s a full example to help you getting started:
// Get the list of products
Fliplet.Payments.Products.get().then(function (products) {
// Create or get a customer by email
return Fliplet.Payments.Customers.create({
email: 'john@example.org'
}).then(function(customer) {
// Save customer.id if required
// Initiate a checkout session to the payment provider
return Fliplet.Payments.Checkout.create({
// Options for the payment provider.
// Refer to the Stripe documentation for the list
// of available options you can use:
// https://stripe.com/docs/api/checkout/sessions/create
mode: 'payment',
payment_method_types: ['card'],
customer: customer.id,
// Specify the list of items
// https://stripe.com/docs/api/checkout/sessions/create#create_checkout_session-line_items
line_items: [
{
price: products[0]['Price ID'],
quantity: 1
},
{
price: products[1]['Price ID'],
quantity: 2
}
]
}).then(function onCheckoutCompleted(response) {
// The checkout session has been completed.
// The user was successfully charged for the product.
// response.transactionDetails
}, function onCheckoutFailed(err) {
// The checkout session has been canceled
// or could not be completed
});
});
});
Advanced functionality
Check if payments have been configured for an app
Use the Configuration.exists()
method to check whether payments have been configured for the app:
Fliplet.Payments.Configuration.exists().then(function (isConfigured) {
if (isConfigured) {
// Payments are configured
} else {
// Payments are not configured
}
});
Customers and events
Create a customer
Use the following JS API to create a customer, or return the existing record when it already exists for the given email:
return Fliplet.Payments.Customers.create({
email: 'nvalbusa@fliplet.com'
}).then(function(customer) {
// Use customer as required
console.log(customer);
});
Retrieve the list of payment-related events for a customer
Some providers are capable of returning a list of events made for a specific customer, including a list of successfull and failed charges. You can use the following JS API to retrieve a list of all logs generated for a customer:
Fliplet.Payments.Customers.getLogs({
customer: 'cus_abcdefg123456'
}).then(function (logs) {
// Use logs here
});
This is the full list of supported input parameters:
customer
(String)limit
(Number, defaults to 100)offset
(Number, defaults to 0)where
(Query object)
return Fliplet.Payments.Customers.getLogs({
customer: 'cus_abcdefg123456',
limit: 30,
offset: 0,
where: {
type: 'payment_intent.created'
}
}).then(function (logs) {
});
Open the customer billing portal on Stripe
Use the openBillingPortal
JS API to redirect the user to the customer billing portal on Stripe. The promise will resolve once the user has returned to the app.
Fliplet.Payments.Customers.openBillingPortal({
customer: 'cus_abcdefg123456'
});