Files
orion/app/modules/cms/__init__.py
Samir Boulahtit ec4ec045fc feat: complete CMS as fully autonomous self-contained module
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>
2026-01-26 22:42:46 +01:00

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"]