Adding payment options to your web application is easier than ever. One of the services that makes accepting payments so easy is Stripe. Here’s an example of setting up a subscription service for a node application.
You’ll want to make sure you update the action of the form they’ve supplied to
the corresponding path on your server. The form for my subscription page looks
form(method='POST' action="/subscriptions" id="payment-form").
If you’ve setup the subscription page correctly according to the Stripe documentation, then setting up the corresponding logic on your server should be easy.
You’ll want to make sure you have a place in your
userSchema to store the
Stripe customer token for your user. Here’s an example:
We can then create the corresponding route and action to handle our new form.
We’re going to use the official node library provided by Stripe to handle our
subscriptions. You can install the library with the following command:
install stripe --save.
Make sure you have a route setup to handle the form.
var subscriptions = require('./controllers/subscriptions'); app.post('/subscriptions', subscriptions.create);
On the server side, we want to tell Stripe to create a new user for a specific
plan, e-mail, and card token we’ve just received. You’ll also want to
make sure you’ve setup a subscription plan through the Stripe dashboard. Keep
in mind that Stripe doesn’t share plans between
test/production, so you’ll want
to setup one for both.
Make sure you provide your own secret API key and plan id. You’ll also want to handle saving your user and providing a response. You might also want to setup Stripe to handle sending your customers a receipt, otherwise you’ll have to handle that on your end.