Files
orion/app/modules/inventory/definition.py
Samir Boulahtit 705d336e19 feat: add self-contained structure to remaining modules
Add exceptions, models, schemas, services directories to modules:

customers:
- exceptions.py, models/, schemas/, services/

inventory:
- exceptions.py, models/, schemas/, services/

messaging:
- exceptions.py, models/, schemas/, services/

monitoring:
- exceptions.py, models/, schemas/, services/

orders:
- exceptions.py, models/, schemas/, services/

payments:
- Updated __init__.py

All modules now have the standard self-contained directory
structure ready for future migration of business logic.

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

80 lines
2.6 KiB
Python

# app/modules/inventory/definition.py
"""
Inventory module definition.
Defines the inventory module including its features, menu items,
route configurations, and self-contained module settings.
"""
from app.modules.base import ModuleDefinition
from models.database.admin_menu_config import FrontendType
def _get_admin_router():
"""Lazy import of admin router to avoid circular imports."""
from app.modules.inventory.routes.admin import admin_router
return admin_router
def _get_vendor_router():
"""Lazy import of vendor router to avoid circular imports."""
from app.modules.inventory.routes.vendor import vendor_router
return vendor_router
# Inventory module definition
inventory_module = ModuleDefinition(
code="inventory",
name="Inventory Management",
description=(
"Stock level tracking, inventory locations, low stock alerts, "
"transaction history, and bulk imports."
),
version="1.0.0",
features=[
"inventory_basic", # Basic stock tracking
"inventory_locations", # Multiple warehouse locations
"low_stock_alerts", # Automated low stock notifications
"inventory_purchase_orders", # Purchase order management
"product_management", # Product catalog CRUD
"inventory_transactions", # Stock movement history
"inventory_import", # Bulk inventory import
],
menu_items={
FrontendType.ADMIN: [
"inventory", # Platform-wide inventory view
"vendor-products", # Product catalog management
],
FrontendType.VENDOR: [
"products", # Vendor product catalog
"inventory", # Vendor inventory management
],
},
is_core=False,
# =========================================================================
# Self-Contained Module Configuration
# =========================================================================
is_self_contained=True,
services_path="app.modules.inventory.services",
models_path="app.modules.inventory.models",
schemas_path="app.modules.inventory.schemas",
exceptions_path="app.modules.inventory.exceptions",
)
def get_inventory_module_with_routers() -> ModuleDefinition:
"""
Get inventory module with routers attached.
This function attaches the routers lazily to avoid circular imports
during module initialization.
"""
inventory_module.admin_router = _get_admin_router()
inventory_module.vendor_router = _get_vendor_router()
return inventory_module
__all__ = ["inventory_module", "get_inventory_module_with_routers"]