2026-06-07 21:51:01 +08:00
|
|
|
"""/sources 源列表(只读,所有登录用户可看)。"""
|
|
|
|
|
from __future__ import annotations
|
|
|
|
|
|
|
|
|
|
from fastapi import APIRouter, Depends
|
|
|
|
|
from sqlalchemy import select
|
|
|
|
|
from sqlalchemy.ext.asyncio import AsyncSession
|
|
|
|
|
|
|
|
|
|
from app.core.deps import get_current_user
|
|
|
|
|
from app.database import get_session
|
|
|
|
|
from app.models.source import Source
|
|
|
|
|
from app.models.user import User
|
|
|
|
|
from app.schemas.source import SourceOut
|
|
|
|
|
|
|
|
|
|
router = APIRouter(prefix="/sources", tags=["sources"])
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@router.get("", response_model=list[SourceOut])
|
|
|
|
|
async def list_sources(
|
|
|
|
|
user: User = Depends(get_current_user), # noqa: ARG001
|
|
|
|
|
session: AsyncSession = Depends(get_session),
|
|
|
|
|
):
|
2026-06-07 23:22:56 +08:00
|
|
|
result = await session.execute(select(Source).order_by(Source.priority.desc(), Source.name))
|
|
|
|
|
rows = result.scalars()
|
2026-06-07 21:51:01 +08:00
|
|
|
return [SourceOut.model_validate(s) for s in rows]
|