Django library for multi-channel missive management (email, SMS, push, postal, etc.)
Project description
Django Missive
🚀 A complete Django library for managing multi-channel missive sending: email, SMS, WhatsApp, postal mail, and in-app notifications.
✨ Features
Main features
- 📧 Multi-channel: 14 supported types (Email, SMS, WhatsApp, Telegram, Signal, Messenger, RCS, Postal mail, LRE, Voice calls, Push notifications, Slack, Teams)
- 🔌 15+ integrated providers: SendGrid, Mailgun, Twilio, La Poste, Telegram, FCM, APN, Slack, Teams, etc.
- 📎 Flexible attachments: Local files OR external URLs (S3, Google Drive)
- 🔔 Unified webhooks: Single endpoint
/missive/webhook/{provider}/ - 📊 Full tracking: History, statuses, events
- 🎯 Recipient model: Centralized contact details (email, phone, address)
- 🔍 Built-in validation: Pre-send risk checks
- 👨💼 Complete Django admin: Management interface with validation actions
- 🔗 GenericForeignKey: Flexible link with your business models
- 📝 Reusable templates: Create missive templates
- 📊 Advanced monitoring: Services, credits, SLA and health check per provider
- 🔄 Automatic fallback: Switch to backup provider on failure
Technical architecture
- ✅ Compatible with Django 3.2+ and Python 3.9+
- ✅ Modular structure with mixins (providers/base/)
- ✅ Comprehensive unit tests (8/8 ✅)
- ✅ Exhaustive documentation (16 .md files)
- ✅ CI/CD with GitHub Actions
- ✅ Type hints and mypy
- ✅ Code formatted with Black + isort
Installation
🔧 Development mode (local project)
# Core only (Django + validation)
pip install -r requirements.txt
# Development (tests, linters)
pip install -r requirements-dev.txt
# All providers
pip install -r requirements-all.txt
📦 Production mode (future - after PyPI publication)
# Base installation
pip install django-missive
# With specific providers
pip install django-missive[email] # Email (SendGrid, Mailgun, SES)
pip install django-missive[sms] # SMS & Voice (Twilio, Vonage)
pip install django-missive[messaging] # Telegram, Signal, Messenger
pip install django-missive[push] # Push notifications (FCM, APN)
pip install django-missive[professional] # Slack, Teams
pip install django-missive[postal] # Postal, LRE
pip install django-missive[all] # All providers
Quick Start
- Add
django_pymissiveto yourINSTALLED_APPSinsettings.py:
INSTALLED_APPS = [
...
'django_pymissive',
]
- Run migrations:
python manage.py migrate django_pymissive
- Include the URLconf in your project
urls.py:
from django.urls import path, include
urlpatterns = [
...
path('missive/', include('django_pymissive.urls')), # Webhooks
]
This will create the following URLs:
/missive/webhook/{provider}/- Unified webhook for all providers
- Configure providers in
settings.py:
# Django Missive configuration
MISSIVE_PROVIDERS = {
# Providers by missive type (uses python-missive)
'EMAIL': {
'backend': 'pymissive.providers.sendgrid.SendGridProvider',
'config': {
'SENDGRID_API_KEY': os.getenv('SENDGRID_API_KEY'),
}
},
'SMS': {
'backend': 'pymissive.providers.twilio.TwilioProvider',
'config': {
'TWILIO_ACCOUNT_SID': os.getenv('TWILIO_ACCOUNT_SID'),
'TWILIO_AUTH_TOKEN': os.getenv('TWILIO_AUTH_TOKEN'),
'TWILIO_PHONE_NUMBER': '+33123456789',
}
},
'POSTAL': {
'backend': 'pymissive.providers.laposte.LaPosteProvider',
'config': {
'LAPOSTE_API_KEY': os.getenv('LAPOSTE_API_KEY'),
}
},
}
# Default email
DEFAULT_FROM_EMAIL = 'noreply@example.com'
🚀 Quick usage
Send an email
from django_pymissive.models import Missive, MissiveType, MissiveEventType
# Create an email missive
missive = Missive.objects.create(
sender=request.user,
missive_type=MissiveType.EMAIL,
recipient_email="client@example.com",
subject="Order confirmed",
body="<p>Your order #123 is confirmed</p>",
body_text="Your order #123 is confirmed",
status=MissiveEventType.PENDING,
)
# Sending can be handled via async tasks or manually
Use the model to create missives
from django_pymissive.models import Missive, MissiveType, MissiveEventType
# Create a recipient with all contact details
missive = Missive.objects.create(
sender=request.user,
missive_type=MissiveType.EMAIL,
recipient_first_name="Jean",
recipient_last_name="Dupont",
recipient_email="jean@acme.com",
recipient_phone="+33600000000",
recipient_address_line1="123 Rue de la Paix",
recipient_postal_code="75001",
recipient_city="Paris",
recipient_country="FR",
subject="Welcome",
body="<p>Hello Jean, welcome!</p>",
status=MissiveEventType.PENDING,
)
# Create an SMS with the same contact details
sms = Missive.objects.create(
sender=request.user,
missive_type=MissiveType.SMS,
recipient_phone="+33600000000",
body="Your verification code: 123456",
status=MissiveEventType.PENDING,
)
Provider monitoring (via python-missive)
from pymissive.providers.sendgrid import SendGridProvider
# Configure and verify the provider
provider = SendGridProvider(config={
'SENDGRID_API_KEY': 'your-api-key'
})
# Verify configuration
is_configured = provider.is_configured()
print(f"Provider configured: {is_configured}")
# Send a test email
result = provider.send_email(
from_email='sender@example.com',
to_email='recipient@example.com',
subject='Test',
body='<p>Test message</p>'
)
Validate and send
from django_pymissive.models import Missive, MissiveEventType
# Retrieve a missive
missive = Missive.objects.get(id=123)
# Check it is ready to be sent
if missive.status == MissiveEventType.PENDING:
# Mark as sent (actual sending is done via the configured provider)
missive.status = MissiveEventType.SENT
missive.save()
Development
Quick Start
This project includes service.py - a cross-platform development tool that works on all operating systems.
# Setup development environment
python service.py dev install-dev
# Run tests
python service.py dev test
# Format code
python service.py dev format
# Build package
python service.py dev build
Linux/macOS users can make it executable:
chmod +x service.py
./service.py dev install-dev
./service.py dev test
Available Commands
Development:
python service.py dev venv- Create virtual environmentpython service.py dev install- Install in production modepython service.py dev install-dev- Install in development mode
Testing:
python service.py dev test- Run tests with pytestpython service.py dev test-verbose- Run tests with verbose outputpython service.py dev coverage- Run tests with coverage report
Code Quality:
python service.py quality lint- Run linters (flake8, mypy)python service.py quality format- Format code (black, isort)python service.py quality check- Run all checks (lint + format check)
Building:
python service.py dev build- Build wheel and source distributionpython service.py dev clean- Remove all build artifactspython service.py dev clean-test- Remove test artifacts (htmlcov, .coverage, etc.)
Publishing:
python service.py dev upload-test- Upload to TestPyPIpython service.py dev upload- Upload to PyPIpython service.py dev release- Full release workflow
Utilities:
python service.py dev show-version- Show current versionpython service.py dev venv-clean- Recreate virtual environment
Run python service.py dev help to see all available commands.
Django Development Server
Test the library with a Django development server:
# Run migrations and create superuser (admin/admin)
python service.py dev migrate
# Start development server
python service.py dev runserver
Access the admin interface at http://127.0.0.1:8000/admin/ (login: admin/admin)
See docs/development.md for detailed development guide (if available).
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
- Fork the repository
- Create your feature branch (
git checkout -b feature/AmazingFeature) - Commit your changes (
git commit -m 'Add some AmazingFeature') - Push to the branch (
git push origin feature/AmazingFeature) - Open a Pull Request
License
This project is licensed under the MIT License - see the LICENSE file for details.
Changelog
0.1.0 (Initial Release)
- Initial release
- Basic functionality
Support
If you encounter any issues or have questions, please file an issue on the GitHub issue tracker.
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 django_pymissive-1.0.2.tar.gz.
File metadata
- Download URL: django_pymissive-1.0.2.tar.gz
- Upload date:
- Size: 93.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3bfd3a04ebf7c66fb7c0d4ed2c1d068fe0bbfdbdec7b527da0f424ce8349a3fe
|
|
| MD5 |
244e0a044e08db8d76a625b3b4a45d85
|
|
| BLAKE2b-256 |
8f9704a96f3cc6468c9d5a8e47ec40a3418acc93d4b6a9c408059d4baa4b1e5b
|
File details
Details for the file django_pymissive-1.0.2-py3-none-any.whl.
File metadata
- Download URL: django_pymissive-1.0.2-py3-none-any.whl
- Upload date:
- Size: 122.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1d13519ff933b39fec66ef74a811bfda53d7aaf1dc6dbf2abe96aead9aa8427e
|
|
| MD5 |
a22b2cb3f77329ed5f5047888b6ff5c0
|
|
| BLAKE2b-256 |
25b185402cbad965d2d5f15e08b15f8e389d059ef6e48cf46602d684c800328a
|