Files
orion/app/modules/tenancy/routes/api/store_profile.py
Samir Boulahtit 4aa6f76e46
Some checks failed
CI / validate (push) Has been cancelled
CI / dependency-scanning (push) Has been cancelled
CI / docs (push) Has been cancelled
CI / deploy (push) Has been cancelled
CI / pytest (push) Has been cancelled
CI / ruff (push) Successful in 10s
refactor(arch): move auth schemas to tenancy module and add cross-module service methods
Move all auth schemas (UserContext, UserLogin, LoginResponse, etc.) from
legacy models/schema/auth.py to app/modules/tenancy/schemas/auth.py per
MOD-019. Update 84 import sites across 14 modules. Legacy file now
re-exports for backwards compatibility.

Add missing tenancy service methods for cross-module consumers:
- merchant_service.get_merchant_by_owner_id()
- merchant_service.get_merchant_count_for_owner()
- admin_service.get_user_by_id() (public, was private-only)
- platform_service.get_active_store_count()

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-26 23:57:04 +01:00

45 lines
1.5 KiB
Python

# app/modules/tenancy/routes/api/store_profile.py
"""
Store profile management endpoints.
Store Context: Uses token_store_id from JWT token (authenticated store API pattern).
The get_current_store_api dependency guarantees token_store_id is present.
"""
import logging
from fastapi import APIRouter, Depends
from sqlalchemy.orm import Session
from app.api.deps import get_current_store_api
from app.core.database import get_db
from app.modules.tenancy.schemas.auth import UserContext
from app.modules.tenancy.schemas.store import StoreResponse, StoreUpdate
from app.modules.tenancy.services.store_service import store_service
store_profile_router = APIRouter(prefix="/profile")
logger = logging.getLogger(__name__)
@store_profile_router.get("", response_model=StoreResponse)
def get_store_profile(
current_user: UserContext = Depends(get_current_store_api),
db: Session = Depends(get_db),
):
"""Get current store profile information."""
store = store_service.get_store_by_id(db, current_user.token_store_id)
return store
@store_profile_router.put("", response_model=StoreResponse)
def update_store_profile(
store_update: StoreUpdate,
current_user: UserContext = Depends(get_current_store_api),
db: Session = Depends(get_db),
):
"""Update store profile information."""
# Service handles permission checking and raises InsufficientPermissionsException if needed
return store_service.update_store(
db, current_user.token_store_id, store_update, current_user
)