64 lines
2.0 KiB
Python
64 lines
2.0 KiB
Python
from typing import List, Any
|
|
|
|
from fastapi import APIRouter, Depends
|
|
from sqlalchemy.orm import Session
|
|
|
|
from app import schemas
|
|
from app.chain.media import MediaChain
|
|
from app.core.metainfo import MetaInfo
|
|
from app.core.security import verify_token
|
|
from app.db import get_db
|
|
from app.db.mediaserver_oper import MediaServerOper
|
|
|
|
router = APIRouter()
|
|
|
|
|
|
@router.get("/recognize", summary="识别媒体信息", response_model=schemas.Context)
|
|
def recognize(title: str,
|
|
subtitle: str = None,
|
|
_: schemas.TokenPayload = Depends(verify_token)) -> Any:
|
|
"""
|
|
根据标题、副标题识别媒体信息
|
|
"""
|
|
# 识别媒体信息
|
|
context = MediaChain().recognize_by_title(title=title, subtitle=subtitle)
|
|
if context:
|
|
return context.to_dict()
|
|
return schemas.Context()
|
|
|
|
|
|
@router.get("/search", summary="搜索媒体信息", response_model=List[schemas.MediaInfo])
|
|
def search_by_title(title: str,
|
|
page: int = 1,
|
|
count: int = 8,
|
|
_: schemas.TokenPayload = Depends(verify_token)) -> Any:
|
|
"""
|
|
模糊搜索媒体信息列表
|
|
"""
|
|
_, medias = MediaChain().search(title=title)
|
|
if medias:
|
|
return [media.to_dict() for media in medias[(page - 1) * count: page * count]]
|
|
return []
|
|
|
|
|
|
@router.get("/exists", summary="本地是否存在", response_model=schemas.Response)
|
|
def exists(title: str = None,
|
|
year: int = None,
|
|
mtype: str = None,
|
|
tmdbid: int = None,
|
|
season: int = None,
|
|
db: Session = Depends(get_db),
|
|
_: schemas.TokenPayload = Depends(verify_token)) -> Any:
|
|
"""
|
|
判断本地是否存在
|
|
"""
|
|
meta = MetaInfo(title)
|
|
if not season:
|
|
season = meta.begin_season
|
|
exist = MediaServerOper(db).exists(
|
|
title=meta.name, year=year, mtype=mtype, tmdbid=tmdbid, season=season
|
|
)
|
|
return schemas.Response(success=True if exist else False, data={
|
|
"item": exist or {}
|
|
})
|