Transform CMS from a thin wrapper into a fully self-contained module with all code living within app/modules/cms/: Module Structure: - models/: ContentPage model (canonical location with dynamic discovery) - schemas/: Pydantic schemas for API validation - services/: ContentPageService business logic - exceptions/: Module-specific exceptions - routes/api/: REST API endpoints (admin, vendor, shop) - routes/pages/: HTML page routes (admin, vendor) - templates/cms/: Jinja2 templates (namespaced) - static/: JavaScript files (admin/vendor) - locales/: i18n translations (en, fr, de, lb) Key Changes: - Move ContentPage model to module with dynamic model discovery - Create Pydantic schemas package for request/response validation - Extract API routes from app/api/v1/*/ to module - Extract page routes from admin_pages.py/vendor_pages.py to module - Move static JS files to module with dedicated mount point - Update templates to use cms_static for module assets - Add module static file mounting in main.py - Delete old scattered files (no shims - hard errors on old imports) This establishes the pattern for migrating other modules to be fully autonomous and independently deployable. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
33 lines
879 B
Python
33 lines
879 B
Python
# app/modules/cms/__init__.py
|
|
"""
|
|
CMS Module - Content Management System.
|
|
|
|
This is a SELF-CONTAINED module that includes:
|
|
- Services: content_page_service (business logic)
|
|
- Models: ContentPage (database model)
|
|
- Exceptions: ContentPageNotFoundException, etc.
|
|
|
|
This module provides:
|
|
- Content pages management (three-tier: platform, vendor default, vendor override)
|
|
- Media library
|
|
- Vendor themes
|
|
- SEO tools
|
|
|
|
Routes:
|
|
- Admin: /api/v1/admin/content-pages/*
|
|
- Vendor: /api/v1/vendor/content-pages/*, /api/v1/vendor/media/*
|
|
|
|
Menu Items:
|
|
- Admin: content-pages, vendor-themes
|
|
- Vendor: content-pages, media
|
|
|
|
Usage:
|
|
from app.modules.cms.services import content_page_service
|
|
from app.modules.cms.models import ContentPage
|
|
from app.modules.cms.exceptions import ContentPageNotFoundException
|
|
"""
|
|
|
|
from app.modules.cms.definition import cms_module
|
|
|
|
__all__ = ["cms_module"]
|