from typing import List, Any from fastapi import APIRouter, Depends, Response from app import schemas from app.chain.douban import DoubanChain from app.core.config import settings from app.core.context import MediaInfo from app.core.security import verify_token from app.schemas import MediaType from app.utils.http import RequestUtils router = APIRouter() @router.get("/img", summary="豆瓣图片代理") def douban_img(imgurl: str) -> Any: """ 豆瓣图片代理 """ if not imgurl: return None response = RequestUtils(headers={ 'Referer': "https://movie.douban.com/" }, ua=settings.USER_AGENT).get_res(url=imgurl) if response: return Response(content=response.content, media_type="image/jpeg") return None @router.get("/person/{person_id}", summary="人物详情", response_model=schemas.MediaPerson) def douban_person(person_id: int, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 根据人物ID查询人物详情 """ return DoubanChain().person_detail(person_id=person_id) @router.get("/person/credits/{person_id}", summary="人物参演作品", response_model=List[schemas.MediaInfo]) def douban_person_credits(person_id: int, page: int = 1, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 根据人物ID查询人物参演作品 """ medias = DoubanChain().person_credits(person_id=person_id, page=page) if medias: return [media.to_dict() for media in medias] return [] @router.get("/showing", summary="豆瓣正在热映", response_model=List[schemas.MediaInfo]) def movie_showing(page: int = 1, count: int = 30, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 浏览豆瓣正在热映 """ movies = DoubanChain().movie_showing(page=page, count=count) if movies: return [media.to_dict() for media in movies] return [] @router.get("/movies", summary="豆瓣电影", response_model=List[schemas.MediaInfo]) def douban_movies(sort: str = "R", tags: str = "", page: int = 1, count: int = 30, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 浏览豆瓣电影信息 """ movies = DoubanChain().douban_discover(mtype=MediaType.MOVIE, sort=sort, tags=tags, page=page, count=count) if movies: return [media.to_dict() for media in movies] return [] @router.get("/tvs", summary="豆瓣剧集", response_model=List[schemas.MediaInfo]) def douban_tvs(sort: str = "R", tags: str = "", page: int = 1, count: int = 30, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 浏览豆瓣剧集信息 """ tvs = DoubanChain().douban_discover(mtype=MediaType.TV, sort=sort, tags=tags, page=page, count=count) if tvs: return [media.to_dict() for media in tvs] return [] @router.get("/movie_top250", summary="豆瓣电影TOP250", response_model=List[schemas.MediaInfo]) def movie_top250(page: int = 1, count: int = 30, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 浏览豆瓣剧集信息 """ movies = DoubanChain().movie_top250(page=page, count=count) if movies: return [media.to_dict() for media in movies] return [] @router.get("/tv_weekly_chinese", summary="豆瓣国产剧集周榜", response_model=List[schemas.MediaInfo]) def tv_weekly_chinese(page: int = 1, count: int = 30, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 中国每周剧集口碑榜 """ tvs = DoubanChain().tv_weekly_chinese(page=page, count=count) if tvs: return [media.to_dict() for media in tvs] return [] @router.get("/tv_weekly_global", summary="豆瓣全球剧集周榜", response_model=List[schemas.MediaInfo]) def tv_weekly_global(page: int = 1, count: int = 30, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 全球每周剧集口碑榜 """ tvs = DoubanChain().tv_weekly_global(page=page, count=count) if tvs: return [media.to_dict() for media in tvs] return [] @router.get("/tv_animation", summary="豆瓣动画剧集", response_model=List[schemas.MediaInfo]) def tv_animation(page: int = 1, count: int = 30, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 热门动画剧集 """ tvs = DoubanChain().tv_animation(page=page, count=count) if tvs: return [media.to_dict() for media in tvs] return [] @router.get("/movie_hot", summary="豆瓣热门电影", response_model=List[schemas.MediaInfo]) def movie_hot(page: int = 1, count: int = 30, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 热门电影 """ movies = DoubanChain().movie_hot(page=page, count=count) if movies: return [media.to_dict() for media in movies] return [] @router.get("/tv_hot", summary="豆瓣热门电视剧", response_model=List[schemas.MediaInfo]) def tv_hot(page: int = 1, count: int = 30, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 热门电视剧 """ tvs = DoubanChain().tv_hot(page=page, count=count) if tvs: return [media.to_dict() for media in tvs] return [] @router.get("/credits/{doubanid}/{type_name}", summary="豆瓣演员阵容", response_model=List[schemas.MediaPerson]) def douban_credits(doubanid: str, type_name: str, page: int = 1, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 根据豆瓣ID查询演员阵容,type_name: 电影/电视剧 """ mediatype = MediaType(type_name) if mediatype == MediaType.MOVIE: return DoubanChain().movie_credits(doubanid=doubanid) elif mediatype == MediaType.TV: return DoubanChain().tv_credits(doubanid=doubanid) return [] @router.get("/recommend/{doubanid}/{type_name}", summary="豆瓣推荐电影/电视剧", response_model=List[schemas.MediaInfo]) def douban_recommend(doubanid: str, type_name: str, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 根据豆瓣ID查询推荐电影/电视剧,type_name: 电影/电视剧 """ mediatype = MediaType(type_name) if mediatype == MediaType.MOVIE: medias = DoubanChain().movie_recommend(doubanid=doubanid) elif mediatype == MediaType.TV: medias = DoubanChain().tv_recommend(doubanid=doubanid) else: return [] if medias: return [media.to_dict() for media in medias] return [] @router.get("/{doubanid}", summary="查询豆瓣详情", response_model=schemas.MediaInfo) def douban_info(doubanid: str, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 根据豆瓣ID查询豆瓣媒体信息 """ doubaninfo = DoubanChain().douban_info(doubanid=doubanid) if doubaninfo: return MediaInfo(douban_info=doubaninfo).to_dict() else: return schemas.MediaInfo()