Production-ready utilities for Django applications in the Oxiliere ecosystem
Project description
OxUtils
Production-ready utilities for Django applications in the Oxiliere ecosystem.
Features
- 🔐 JWT Authentication - RS256 with JWKS caching
- 📝 Structured Logging - JSON logs with automatic request tracking
- 🔍 Audit System - Change tracking with S3 export
- ⚙️ Celery Integration - Pre-configured task processing
- 🛠️ Django Mixins - UUID, timestamps, user tracking
- ⚡ Custom Exceptions - Standardized API errors
- 🎨 Context Processors - Site name and domain for templates
- 💱 Currency Module - Multi-source exchange rates (BCC/OXR)
- 📄 PDF Generation - WeasyPrint integration for Django
- 🏢 Multi-Tenant - PostgreSQL schema-based isolation
Installation
pip install oxutils
uv add oxutils
Quick Start
1. Configure Django Settings
# settings.py
from oxutils.conf import UTILS_APPS, AUDIT_MIDDLEWARE
INSTALLED_APPS = [
*UTILS_APPS, # structlog, auditlog, celery_results
# your apps...
]
MIDDLEWARE = [
*AUDIT_MIDDLEWARE, # RequestMiddleware, Auditlog
# your middleware...
]
2. Environment Variables
OXI_SERVICE_NAME=my-service
OXI_JWT_JWKS_URL=https://auth.example.com/.well-known/jwks.json
3. Usage Examples
# JWT Authentication
from oxutils.jwt.client import verify_token
payload = verify_token(token)
# Structured Logging
import structlog
logger = structlog.get_logger(__name__)
logger.info("user_action", user_id=user_id)
# Model Mixins
from oxutils.models.base import BaseModelMixin
class Product(BaseModelMixin): # UUID + timestamps + is_active
name = models.CharField(max_length=255)
# Custom Exceptions
from oxutils.exceptions import NotFoundException
raise NotFoundException(detail="User not found")
# Context Processors
# settings.py
TEMPLATES = [{
'OPTIONS': {
'context_processors': [
'oxutils.context.site_name_processor.site_name',
],
},
}]
# Now {{ site_name }} and {{ site_domain }} are available in templates
Documentation
Core Modules
- Settings - Configuration reference
- JWT - Authentication
- Audit - Change tracking
- Logging - Structured logs
- Mixins - Model/service mixins
- Celery - Task processing
Additional Modules
- Currency - Exchange rates management
- PDF - PDF generation with WeasyPrint
- Oxiliere - Multi-tenant architecture
Requirements
- Python 3.12+
- Django 5.0+
- PostgreSQL (recommended)
Development
git clone https://github.com/oxiliere/oxutils.git
cd oxutils
uv sync
uv run pytest # 201 tests passing, 4 skipped
Creating Migrations
To generate Django migrations for the audit module:
make migrations
# or
uv run make_migrations.py
See MIGRATIONS.md for detailed documentation.
Optional Dependencies
# Multi-tenant support
uv add oxutils[oxiliere]
# PDF generation
uv add oxutils[pdf]
# Development tools
uv add oxutils[dev]
Advanced Examples
JWT with Django Ninja
from ninja import NinjaAPI
from ninja.security import HttpBearer
from oxutils.jwt.client import verify_token
class JWTAuth(HttpBearer):
def authenticate(self, request, token):
try:
return verify_token(token)
except:
return None
api = NinjaAPI(auth=JWTAuth())
@api.get("/protected")
def protected(request):
return {"user_id": request.auth['sub']}
Audit Log Export
from oxutils.audit.export import export_logs_from_date
from datetime import datetime, timedelta
from_date = datetime.now() - timedelta(days=7)
export = export_logs_from_date(from_date=from_date)
print(f"Exported to {export.data.url}")
Currency Exchange Rates
from oxutils.currency.models import CurrencyState
# Sync rates from BCC (with OXR fallback)
state = CurrencyState.sync()
# Get latest rates
latest = CurrencyState.objects.latest()
usd_rate = latest.currencies.get(code='USD').rate
eur_rate = latest.currencies.get(code='EUR').rate
PDF Generation
from oxutils.pdf.printer import Printer
from oxutils.pdf.views import WeasyTemplateView
# Standalone PDF generation
printer = Printer(
template_name='invoice.html',
context={'invoice': invoice},
stylesheets=['css/invoice.css']
)
pdf_bytes = printer.write_pdf()
# Class-based view
class InvoicePDFView(WeasyTemplateView):
template_name = 'invoice.html'
pdf_filename = 'invoice.pdf'
pdf_stylesheets = ['css/invoice.css']
Multi-Tenant Setup
# settings.py
TENANT_MODEL = "oxiliere.Tenant"
MIDDLEWARE = [
'oxutils.oxiliere.middleware.TenantMainMiddleware', # First!
# other middleware...
]
# All requests must include X-Organization-ID header
# Data is automatically isolated per tenant schema
License
Apache 2.0 License - see LICENSE
Support
- Issues: GitHub Issues
- Email: dev@oxiliere.com
Made with ❤️ by Oxiliere
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
oxutils-0.1.21.tar.gz
(78.3 kB
view details)
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
oxutils-0.1.21-py3-none-any.whl
(120.0 kB
view details)
File details
Details for the file oxutils-0.1.21.tar.gz.
File metadata
- Download URL: oxutils-0.1.21.tar.gz
- Upload date:
- Size: 78.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.6 {"installer":{"name":"uv","version":"0.10.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Fedora Linux","version":"43","id":"","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6bc8b3b1719bd8c6df0785219f0ce25637faa1614f9412ce09befd45a10a4c06
|
|
| MD5 |
cd513375b9bccd61dc6abe4bc69d5fc1
|
|
| BLAKE2b-256 |
28008b7901fc15ab8f5931edb8834aef0305023f9eaf082dce962351f7442c53
|
File details
Details for the file oxutils-0.1.21-py3-none-any.whl.
File metadata
- Download URL: oxutils-0.1.21-py3-none-any.whl
- Upload date:
- Size: 120.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.6 {"installer":{"name":"uv","version":"0.10.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Fedora Linux","version":"43","id":"","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ee856ca5e95484367a16b8ccf5f86bf976ecf52ca52f03c1e07d56d56e90066d
|
|
| MD5 |
568344e2911764e7a5ad751f6cab3279
|
|
| BLAKE2b-256 |
75d596cf568c04a83022b4e0e59d36fff4c62382b8b563fdbdc30679fd3259fa
|