mirror of
https://github.com/StepanovPlaton/torrent_backend.git
synced 2026-04-03 12:20:38 +04:00
57 lines
2.4 KiB
Python
57 lines
2.4 KiB
Python
from sqlalchemy.ext.asyncio import AsyncSession
|
|
from fastapi import APIRouter, Depends, HTTPException, status
|
|
|
|
from database import *
|
|
from file_handler import *
|
|
from routes.auth import get_user
|
|
|
|
movies_router = APIRouter(prefix="/movies", tags=["Movies"])
|
|
|
|
|
|
@movies_router.get("/{movie_id}", response_model=Movie)
|
|
async def get_movie(movie_id: int, db_session: AsyncSession = Depends(Database.get_session)):
|
|
return await MoviesCRUD.get(db_session, movie_id)
|
|
|
|
|
|
@movies_router.get("", response_model=list[MovieCard])
|
|
async def get_movies_cards(db_session: AsyncSession = Depends(Database.get_session)):
|
|
return await MoviesCRUD.get_all(db_session)
|
|
|
|
|
|
@movies_router.post("", response_model=Movie)
|
|
async def add_movie(movie: MovieCreate,
|
|
user: User = Depends(get_user),
|
|
db_session: AsyncSession = Depends(Database.get_session)):
|
|
return await MoviesCRUD.add(db_session, movie, user.id)
|
|
|
|
|
|
@movies_router.put("/{movie_id}", response_model=Movie)
|
|
async def edit_movie(movie_id: int,
|
|
movie: MovieCreate,
|
|
user: User = Depends(get_user),
|
|
db_session: AsyncSession = Depends(Database.get_session)):
|
|
movie_db = await MoviesCRUD.get(db_session, movie_id)
|
|
if (movie_db is None):
|
|
raise HTTPException(status.HTTP_404_NOT_FOUND,
|
|
detail=f"Movie with id={movie_id} not found")
|
|
if (user.id != movie_db.owner_id):
|
|
raise HTTPException(status.HTTP_401_UNAUTHORIZED,
|
|
detail=f"Movie can only be edited "
|
|
"by the owner (creator)")
|
|
return await MoviesCRUD.change(db_session, movie_id, movie)
|
|
|
|
|
|
@movies_router.delete("/{movie_id}", response_model=Movie)
|
|
async def delete_movie(movie_id: int,
|
|
user: User = Depends(get_user),
|
|
db_session: AsyncSession = Depends(Database.get_session)):
|
|
movie_db = await MoviesCRUD.get(db_session, movie_id)
|
|
if (movie_db is None):
|
|
raise HTTPException(status.HTTP_404_NOT_FOUND,
|
|
detail=f"Movie with id={movie_id} not found")
|
|
if (user.id != movie_db.owner_id):
|
|
raise HTTPException(status.HTTP_401_UNAUTHORIZED,
|
|
detail=f"Movie can only be deleted "
|
|
"by the owner (creator)")
|
|
return await MoviesCRUD.delete(db_session, movie_id)
|