Files
orion/app/modules/billing/__init__.py
Samir Boulahtit f79e67d199 feat: complete billing module self-containment
Migrate billing module routes to self-contained structure:

- routes/api/admin.py - Admin API endpoints
- routes/api/vendor.py - Vendor API endpoints
- routes/pages/ - Page routes (placeholder)
- models/subscription.py - Subscription model (moved)
- schemas/subscription.py - Pydantic schemas (moved)
- locales/ - Translations (en, de, fr, lu)

Removed legacy route files:
- app/modules/billing/routes/admin.py
- app/modules/billing/routes/vendor.py

Updated __init__.py files to use new structure.

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-28 22:21:32 +01:00

45 lines
1.4 KiB
Python

# app/modules/billing/__init__.py
"""
Billing Module - Subscription and payment management.
This module provides:
- Subscription tier management
- Vendor subscription CRUD
- Billing history and invoices
- Stripe integration
- Scheduled tasks for subscription lifecycle
Routes:
- Admin: /api/v1/admin/subscriptions/*
- Vendor: /api/v1/vendor/billing/*
Menu Items:
- Admin: subscription-tiers, subscriptions, billing-history
- Vendor: billing, invoices
Usage:
from app.modules.billing import billing_module
from app.modules.billing.services import subscription_service, stripe_service
from app.modules.billing.models import VendorSubscription, SubscriptionTier
from app.modules.billing.exceptions import TierLimitExceededException
"""
# Lazy imports to avoid circular dependencies
# Routers and module definition are imported on-demand
__all__ = [
"billing_module",
"get_billing_module_with_routers",
]
def __getattr__(name: str):
"""Lazy import to avoid circular dependencies."""
if name == "billing_module":
from app.modules.billing.definition import billing_module
return billing_module
elif name == "get_billing_module_with_routers":
from app.modules.billing.definition import get_billing_module_with_routers
return get_billing_module_with_routers
raise AttributeError(f"module {__name__!r} has no attribute {name!r}")