A comprehensive subscription management system for Wagtail CMS
Project description
Wagtail Subscriptions
A comprehensive subscription management system for Wagtail CMS that provides everything you need to build a SaaS application with subscription billing.
Features
🚀 Complete Subscription Management
- Multiple subscription plans with flexible billing periods
- Feature-based access control
- Trial periods and plan upgrades
- Customer portal and billing management
- Multi-tenant support (auto-detects django-tenant-schemas)
💳 Payment Integration
- Stripe integration (built-in)
- Paddle support
- PayPal integration
- Extensible payment processor architecture
🎛️ Admin Dashboard
- Beautiful Wagtail-integrated admin interface
- Plan and feature management
- Customer overview and analytics
- Payment processor configuration
- Tenant-aware permissions (works in both single/multi-tenant modes)
🎨 Frontend Components
- Responsive pricing tables
- Modern UI with Tailwind CSS
- Customizable templates
- Template tags for easy integration
Quick Start
Installation
pip install wagtail-subscriptions
Settings
Add to your INSTALLED_APPS:
INSTALLED_APPS = [
# ... your apps
'wagtail_subscriptions',
]
Configure payment processors:
WAGTAIL_SUBSCRIPTIONS = {
'PAYMENT_PROCESSORS': {
'stripe': {
'public_key': 'pk_test_...',
'secret_key': 'sk_test_...',
'webhook_secret': 'whsec_...',
}
}
}
URLs
from django.urls import path, include
urlpatterns = [
# ... your URLs
path('subscriptions/', include('wagtail_subscriptions.urls')),
]
Migrate
python manage.py migrate
python manage.py setup_subscription_permissions
Usage
Create Subscription Plans
- Go to Wagtail Admin → Subscriptions → Plans
- Create your subscription plans with pricing
- Add modules and features
- Associate features with plans
Display Pricing
Use the built-in template tag:
{% load subscription_tags %}
{% price_table %}
Protect Views
from wagtail_subscriptions.permissions.decorators import subscription_required, feature_required
@subscription_required
def my_view(request):
return render(request, 'my_template.html')
@feature_required('advanced_analytics')
def analytics_view(request):
return render(request, 'analytics.html')
Check Permissions in Templates
{% load subscription_tags %}
<!-- Works in both single-tenant and multi-tenant modes -->
{% if request|has_feature:'api_access' %}
<a href="/api/">API Documentation</a>
{% endif %}
<!-- Get subscription info -->
{% subscription_info as sub_info %}
<p>Current Plan: {{ sub_info.plan }}</p>
<p>Subscriber: {{ sub_info.name }} ({{ sub_info.type }})</p>
Documentation
Models
- SubscriptionPlan: Define pricing and billing periods
- Module: Organize features into logical groups
- Feature: Individual features with quota support
- PlanFeature: Associate features with plans
- Subscription: User subscriptions and billing
- Customer: Extended customer information
Payment Processors
Stripe Setup
- Create Stripe account
- Get API keys from dashboard
- Add webhook endpoint:
/subscriptions/webhooks/stripe/ - Configure in Django settings
Paddle Setup
- Create Paddle account
- Get Vendor ID and Auth Code
- Configure webhook URL
- Add to Django settings
Template Tags
{% load subscription_tags %}
<!-- Basic pricing table -->
{% price_table %}
<!-- Custom options -->
{% price_table show_trial=False highlight_plan="pro" %}
<!-- Check feature access -->
{% if subscription|has_feature:"advanced_reports" %}
<!-- Feature content -->
{% endif %}
Management Commands
# Set up permissions
python manage.py setup_subscription_permissions
# Create sample data
python manage.py create_sample_plans
# Sync tenant plans (for multi-tenant setups)
python manage.py sync_tenant_plans
API Reference
Subscription Model Methods
subscription = request.user.subscriptions.first()
# Check feature access
subscription.has_feature_access('feature_slug')
# Get feature quota
subscription.get_feature_quota('feature_slug')
# Check if active
subscription.is_active
# Check if in trial
subscription.is_trial
Permission Mixins
from wagtail_subscriptions.permissions.mixins import (
SubscriptionRequiredMixin,
FeatureRequiredMixin
)
# Works automatically in both single-tenant and multi-tenant modes
class MyView(FeatureRequiredMixin, TemplateView):
required_feature = 'advanced_analytics'
template_name = 'my_template.html'
Contributing
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests
- Submit a pull request
License
MIT License - see LICENSE file for details.
Support
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file wagtail_subscriptions-0.1.0.tar.gz.
File metadata
- Download URL: wagtail_subscriptions-0.1.0.tar.gz
- Upload date:
- Size: 60.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
532d643054866f0ab555a37361bc6834bcf02010e4c6c7fd5af968ed33a63a32
|
|
| MD5 |
93a819f1e0a5792eae1c5a9b69ec50a1
|
|
| BLAKE2b-256 |
459199b7b1d407743ff41792fdd6b117fbe681dbbe231cb8caef3a0259704740
|
File details
Details for the file wagtail_subscriptions-0.1.0-py3-none-any.whl.
File metadata
- Download URL: wagtail_subscriptions-0.1.0-py3-none-any.whl
- Upload date:
- Size: 86.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
38522e2e525af94dad12e4a592ed7feb67b00dee887ac4872e6aebbdeddb72ef
|
|
| MD5 |
b504e57bc1813fa1918fde8a50746979
|
|
| BLAKE2b-256 |
fdb0a7c26a0bdd3d97d576d99805fc508edfc24441ea975f3ac389f19c49598e
|