Remove top-level import of cms_module from app/modules/cms/__init__.py to break circular import chain: models.database -> model discovery -> cms.models -> cms.__init__ -> cms.definition -> app.modules.base -> models.database (partial) Replace with lazy get_cms_module() getter function. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
47 lines
1.3 KiB
Python
47 lines
1.3 KiB
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
|
|
"""
|
|
|
|
# NOTE: Do NOT import cms_module at top level to avoid circular import.
|
|
# The circular import chain is:
|
|
# models.database -> model discovery -> app.modules.cms.models
|
|
# -> app.modules.cms.__init__ -> cms_module -> app.modules.base
|
|
# -> models.database.admin_menu_config (partial)
|
|
#
|
|
# Use lazy import instead:
|
|
# from app.modules.cms.definition import cms_module
|
|
|
|
|
|
def get_cms_module():
|
|
"""Lazy getter for cms_module to avoid circular imports."""
|
|
from app.modules.cms.definition import cms_module
|
|
return cms_module
|
|
|
|
|
|
__all__ = ["get_cms_module"]
|