Stripe integration for Django-based projects
Project description
Stripe integration for Django-based projects
This project’s target is to make the Stripe API easier to use in Django-based applications. At the moment the library supports:
charging users
Installation
Add aa_stripe to your app’s INSTALLED_APPS, and also set STRIPE_API_KEY in project settings. After all please migrate the app (./manage.py migrate aa_stripe). Add STRIPE_WEBHOOK_ENDPOINT_SECRET into your settings from stripe webhooks configuration to enable webhooks.
Add aa_stripe.api_urls into your url conf.
Usage
Creating a token for user
Use stripe.js (https://stripe.com/docs/stripe.js) to get single use token (stripe.js->createToken) and send it to API using /aa-stripe/customers to create Customer for the user. It runs:
customer = stripe.Customer.create(source=data["id"]) # data is the response dictionary from Stripe API (in front-end) token = StripeToken.objects.create(user=request.user, content=data, customer_id=customer["id"])
This endpoint requires authenticated user. In case you need diferent implementation (like one call with register) you’ll have to adjust your code.
Charging
First of all, make sure to obtain Stripe user token from the Stripe API, and then save it to aa_stripe.models.StripeToken, for example:
import stripe from aa_stripe.models import StripeToken customer = stripe.Customer.create(source=data["id"]) # data is the response dictionary from Stripe API (in front-end) token = StripeToken.objects.create(user=request.user, content=data, customer_id=customer["id"])
To charge users, create an instance of aa_stripe.models.StripeCharge model and then call the charge() method:
c = StripeCharge.objects.create(user=user, token=token, amount=500, # in cents description="Charge for stuff", # sent to Stripe comment="Comment for internal information") c.charge()
There is also a management command called charge_stripe in case you need to process all the remaining charges.
Webhooks support
All webhooks should be sent to /aa-stripe/webhooks url. Add STRIPE_WEBHOOK_ENDPOINT_SECRET to your settings to enable webhook verifications. Each received webhook is saved as StripeWebhook object in database. User need to add parsing webhooks depending on the project.
Support
Django 1.11
Python 2.7, 3.4-3.6
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for aa_stripe-0.2-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 40b6a88718c72dcc4a02d5e2684229ebe778367f63cd8c999689073700473223 |
|
MD5 | 10a7fc61201e44f94543b002fe32cce8 |
|
BLAKE2b-256 | 4bd1f64b6a5721f88fe50514b3de63f59a20748defbfbf2d38ebd0d990337496 |