# app/api/v1/vendor/__init__.py """ Vendor API router aggregation. This module aggregates all vendor-related JSON API endpoints. IMPORTANT: - This router is for JSON API endpoints only - HTML page routes are mounted separately in main.py at /vendor/* - Do NOT include pages.router here - it causes route conflicts """ from fastapi import APIRouter # Import all sub-routers (JSON API only) from . import ( analytics, auth, content_pages, customers, dashboard, info, inventory, letzshop, marketplace, media, notifications, orders, payments, products, profile, settings, team, ) # Create vendor router router = APIRouter() # ============================================================================ # JSON API ROUTES ONLY # ============================================================================ # These routes return JSON and are mounted at /api/v1/vendor/* # IMPORTANT: Specific routes MUST be registered BEFORE catch-all routes # The info.router has GET /{vendor_code} which catches everything, # so it must be registered LAST # Authentication (no prefix, specific routes like /auth/login) router.include_router(auth.router, tags=["vendor-auth"]) # Vendor management (with prefixes: /dashboard/*, /profile/*, /settings/*) router.include_router(dashboard.router, tags=["vendor-dashboard"]) router.include_router(profile.router, tags=["vendor-profile"]) router.include_router(settings.router, tags=["vendor-settings"]) # Business operations (with prefixes: /products/*, /orders/*, etc.) router.include_router(products.router, tags=["vendor-products"]) router.include_router(orders.router, tags=["vendor-orders"]) router.include_router(customers.router, tags=["vendor-customers"]) router.include_router(team.router, tags=["vendor-team"]) router.include_router(inventory.router, tags=["vendor-inventory"]) router.include_router(marketplace.router, tags=["vendor-marketplace"]) router.include_router(letzshop.router, tags=["vendor-letzshop"]) # Services (with prefixes: /payments/*, /media/*, etc.) router.include_router(payments.router, tags=["vendor-payments"]) router.include_router(media.router, tags=["vendor-media"]) router.include_router(notifications.router, tags=["vendor-notifications"]) router.include_router(analytics.router, tags=["vendor-analytics"]) # Content pages management router.include_router( content_pages.router, prefix="/{vendor_code}/content-pages", tags=["vendor-content-pages"], ) # Vendor info endpoint - MUST BE LAST! Has catch-all GET /{vendor_code} router.include_router(info.router, tags=["vendor-info"]) __all__ = ["router"]