126 lines
4.0 KiB
Python
126 lines
4.0 KiB
Python
# app/api/v1/admin.py
|
|
"""
|
|
Admin endpoints - simplified with service-level exception handling.
|
|
|
|
This module provides classes and functions for:
|
|
- User management (view, toggle status)
|
|
- Vendor management (view, verify, toggle status)
|
|
- Marketplace import job monitoring
|
|
- Admin dashboard statistics
|
|
"""
|
|
|
|
import logging
|
|
from typing import List, Optional
|
|
|
|
from fastapi import APIRouter, Depends, Query
|
|
from sqlalchemy.orm import Session
|
|
|
|
from app.api.deps import get_current_admin_user
|
|
from app.core.database import get_db
|
|
from app.services.admin_service import admin_service
|
|
from models.schemas.auth import UserResponse
|
|
from models.schemas.marketplace_import_job import MarketplaceImportJobResponse
|
|
from models.schemas.vendor import VendorListResponse
|
|
from models.database.user import User
|
|
|
|
router = APIRouter()
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
@router.get("/admin/users", response_model=List[UserResponse])
|
|
def get_all_users(
|
|
skip: int = Query(0, ge=0),
|
|
limit: int = Query(100, ge=1, le=1000),
|
|
db: Session = Depends(get_db),
|
|
current_admin: User = Depends(get_current_admin_user),
|
|
):
|
|
"""Get all users (Admin only)."""
|
|
users = admin_service.get_all_users(db=db, skip=skip, limit=limit)
|
|
return [UserResponse.model_validate(user) for user in users]
|
|
|
|
|
|
@router.put("/admin/users/{user_id}/status")
|
|
def toggle_user_status(
|
|
user_id: int,
|
|
db: Session = Depends(get_db),
|
|
current_admin: User = Depends(get_current_admin_user),
|
|
):
|
|
"""Toggle user active status (Admin only)."""
|
|
user, message = admin_service.toggle_user_status(db, user_id, current_admin.id)
|
|
return {"message": message}
|
|
|
|
|
|
@router.get("/admin/vendors", response_model=VendorListResponse)
|
|
def get_all_vendors_admin(
|
|
skip: int = Query(0, ge=0),
|
|
limit: int = Query(100, ge=1, le=1000),
|
|
db: Session = Depends(get_db),
|
|
current_admin: User = Depends(get_current_admin_user),
|
|
):
|
|
"""Get all vendors with admin view (Admin only)."""
|
|
vendors, total = admin_service.get_all_vendors(db=db, skip=skip, limit=limit)
|
|
return VendorListResponse(vendors=vendors, total=total, skip=skip, limit=limit)
|
|
|
|
|
|
@router.put("/admin/vendors/{vendor_id}/verify")
|
|
def verify_vendor(
|
|
vendor_id: int,
|
|
db: Session = Depends(get_db),
|
|
current_admin: User = Depends(get_current_admin_user),
|
|
):
|
|
"""Verify/unverify vendor (Admin only)."""
|
|
vendor, message = admin_service.verify_vendor(db, vendor_id)
|
|
return {"message": message}
|
|
|
|
|
|
@router.put("/admin/vendors/{vendor_id}/status")
|
|
def toggle_vendor_status(
|
|
vendor_id: int,
|
|
db: Session = Depends(get_db),
|
|
current_admin: User = Depends(get_current_admin_user),
|
|
):
|
|
"""Toggle vendor active status (Admin only)."""
|
|
vendor, message = admin_service.toggle_vendor_status(db, vendor_id)
|
|
return {"message": message}
|
|
|
|
|
|
@router.get(
|
|
"/admin/marketplace-import-jobs", response_model=List[MarketplaceImportJobResponse]
|
|
)
|
|
def get_all_marketplace_import_jobs(
|
|
marketplace: Optional[str] = Query(None),
|
|
vendor_name: Optional[str] = Query(None),
|
|
status: Optional[str] = Query(None),
|
|
skip: int = Query(0, ge=0),
|
|
limit: int = Query(100, ge=1, le=100),
|
|
db: Session = Depends(get_db),
|
|
current_admin: User = Depends(get_current_admin_user),
|
|
):
|
|
"""Get all marketplace import jobs (Admin only)."""
|
|
return admin_service.get_marketplace_import_jobs(
|
|
db=db,
|
|
marketplace=marketplace,
|
|
vendor_name=vendor_name,
|
|
status=status,
|
|
skip=skip,
|
|
limit=limit,
|
|
)
|
|
|
|
|
|
@router.get("/admin/stats/users")
|
|
def get_user_statistics(
|
|
db: Session = Depends(get_db),
|
|
current_admin: User = Depends(get_current_admin_user),
|
|
):
|
|
"""Get user statistics for admin dashboard (Admin only)."""
|
|
return admin_service.get_user_statistics(db)
|
|
|
|
|
|
@router.get("/admin/stats/vendors")
|
|
def get_vendor_statistics(
|
|
db: Session = Depends(get_db),
|
|
current_admin: User = Depends(get_current_admin_user),
|
|
):
|
|
"""Get vendor statistics for admin dashboard (Admin only)."""
|
|
return admin_service.get_vendor_statistics(db)
|