🏦 Stripe Payments
888
Let's see how you can setup Stripe in WeWeb so that your web-app users can make payments.
Installing the Plugin
To add the Stripe Plugin to your WeWeb project, go to the "Plugins" > "Extensions" menu:
data:image/s3,"s3://crabby-images/ae702/ae702a329eae247acaf44f21272078e0a1f46bf4" alt=""
Once you have added the Stripe Extension, you will be invited to set it up with your production API keys:
data:image/s3,"s3://crabby-images/d66db/d66dbe7f5c216b4b256b146c6e72cc104e95a512" alt=""
🔥 Pro Tip 🔥
If you want to work with test data in Stripe, you can also add test API keys. Better be safe than sorry! 😅
Once you have set up the Extension, you will have access to the payment form Element.
The Payment Form
To display a Stripe payment form on your web app, you'll need to add a Form Container with a submit button on the Canvas:
data:image/s3,"s3://crabby-images/70220/702201305d523b4f713cc8dcbb2076d31c9ab3d8" alt=""
Then, you'll want to remove the Input so you're only left with the "Button" Element and add the "Stripe - Payment" Element inside the Form Container you added above:
data:image/s3,"s3://crabby-images/47a27/47a27985dd02b702bcb9c59de33077c93f1960b8" alt=""
In the Stripe payment element's "Settings", you'll need a client secret.
To get a client secret, we first need to create a client intent.
We do this by creating a Workflow that triggers on page load.
In the first step, we create a payment intent, decide which payment methods the client can use and which Stripe products they can purchase (the "Price ID" will come from your Stripe account):
data:image/s3,"s3://crabby-images/9738e/9738ec631fa5e5ea960949b62068a6b0b5656dc6" alt=""
We will then test Action 1 because we need to bind its result in Action 2.
In step two, we setup a "Change variable value" Action to update a `payment_intent_client_secret` Variable (type Query) with the result of the previous Action:
data:image/s3,"s3://crabby-images/0d026/0d0261fbbfc3d38492e6df7e42d98ddf490e0e0b" alt=""
🔥 Pro Tip 🔥
The query Variable must be named `payment_intent_client_secret` in WeWeb because that's the name of the query string Stripe will pass when creating the client secret. If you choose a different name in WeWeb, we want be able to recognize the query string provided by Stripe.
Once our Workflow on Page is complete, we will go back to our "Stripe - Payment" Element and bind the `payment_intent_client_secret` Variable to the Client secret Setting:
data:image/s3,"s3://crabby-images/256c4/256c4db595beb5426c122289a4c30d824e7c5a2b" alt=""
Finally, we will setup a Workflow to confirm the payment action and redirect the user to a Checkout page when they submit the payment form:
data:image/s3,"s3://crabby-images/fe1a8/fe1a80714fac01d29611de8879b8baf1701d82d2" alt=""
And fake a payment to trigger the Workflow and go to the checkout page:
data:image/s3,"s3://crabby-images/94f1a/94f1a46d1beb9e3038cc3ee20a95d6c248e8e25c" alt=""
🔥 Pro Tip 🔥
In order to move forward with the tutorial, you will need to fake a payment intent with a fake card. Read more about simulating payments in the Stripe documentation.
The Checkout Page
On the checkout page, we'll create a Workflow that triggers on page to retrieve the user's payment intent:
Action 1: Retrieve the payment intent
We will add the "Retrieve payment intent" Action and bind this to the `payment_intent_client_secret` Variable we created earlier
It will look something like this:
data:image/s3,"s3://crabby-images/509cc/509cc9e9031929be7851227ec957292f5d2d5353" alt=""
If you've named your Variable correctly and faked a payment with a fake Stripe card, you should be able to see the the `payment_intent_client_secret` query string in the URL, which is retrieved by WeWeb in the `payment_intent_client_secret` Variable:
data:image/s3,"s3://crabby-images/5232a/5232a09c051937b361024f63fffcd96f63a3b285" alt=""
Action 2: Store the payment intent
After testing Action 1, we will create an Action 2 to store the payment intent in a Variable of type Object.
We will choose a "Change variable value" Action and bind it to the result of the previous Action in the Workflow:
data:image/s3,"s3://crabby-images/008d8/008d8ce0dd7bc8ddc99b6ddb2f67ff13fb97a194" alt=""
Again, we need to test this Action if we want to update the Variable.
Then, we could use the information from the Variable to style the Checkout page.
For example:
data:image/s3,"s3://crabby-images/a404c/a404c6aabe581d8f8fca24750c903678eed8e9e1" alt=""