Pegasus (version 2023.9.1 and up) includes an out-of-the-box E-Commerce/Payments demo. In a few clicks you can have a fully functional digital storefront in your application, allowing you to collect and track one-time or recurring payments with Stripe.
To see how this feature works, you can watch the following video:
First add your products in the Stripe dashboard. Be sure to add readable product names, descriptions, and images, as these will be used for the in-app store. Additionally, make sure each product includes at least one Price.
Setting up your development is similar to the process for subscriptions, but has fewer steps.
- If you haven't already, update the
STRIPE_*
variables insettings.py
or in your os environment variables to match the keys from Stripe. See this page to find your API keys. - Run
python manage.py bootstrap_ecommerce
to sync your Stripe products and prices to your local database.
Once you've done this, login and click on the e-commerce tab in the navigation, and you should see your store.
What shows up in your store is controlled by the ProductConfiguration
data model.
You can manage these objects from the Django admin (available at
http://localhost:8000/admin/ecommerce/productconfiguration/ locally).
For example, to remove a product from the store you can uncheck "is active".
The ProductConfiguration
model is also a good place to add additional information to your products.
For example, you can add additional display data there, or add a FileField
if you want purchases to grant access
to a digital download.
The Purchase
model is used to record user purchases.
A Purchase
is associated with a User
and a ProductConfiguration
and also has details of the Stripe checkout session,
date of purchase, and product/price used at the time of purchase.
The @product_required
decorator can be used to restrict access to a view based on whether or not
the logged-in user has purchased a particular product. This decorator expects a product_slug
field
in the URL / view with the slug of the ProductConfiguration
object to be checked.
If the user owns the product, they will be granted access to the view.
Additionally, if the user gets access, two additional field will be populated on the request
object:
request.product_config
will have theProductConfiguration
object.request.product_purchase
will have thePurchase
object.
If the user does not have access to the product, the decorator will redirect them back to the store homepage.
Like subscriptions, it's recommended to use webhooks to ensure you receive all updates from Stripe.
For the e-commerce store, the only required webhook is checkout.session.completed
.
Follow the subscriptions documentation to set up webhooks in development and production.