update
This commit is contained in:
@@ -1,23 +1,35 @@
|
||||
from sqlalchemy.orm import Session
|
||||
|
||||
from models import Video
|
||||
from models import Profile, Video, video_profiles
|
||||
from schemas import VideoCreate
|
||||
|
||||
|
||||
def create_video(db: Session, video_data: VideoCreate) -> Video:
|
||||
video = Video(**video_data.model_dump())
|
||||
profile_id = video_data.profile_id
|
||||
data = video_data.model_dump(exclude={"profile_id"})
|
||||
video = Video(**data)
|
||||
if profile_id:
|
||||
profile = db.query(Profile).filter(Profile.id == profile_id).first()
|
||||
if profile:
|
||||
video.profiles.append(profile)
|
||||
db.add(video)
|
||||
db.commit()
|
||||
db.refresh(video)
|
||||
return video
|
||||
|
||||
|
||||
def get_all_videos(db: Session) -> list[Video]:
|
||||
return db.query(Video).order_by(Video.id.desc()).all()
|
||||
def get_all_videos(db: Session, profile_id: int | None = None) -> list[Video]:
|
||||
query = db.query(Video)
|
||||
if profile_id:
|
||||
query = query.filter(Video.profiles.any(Profile.id == profile_id))
|
||||
return query.order_by(Video.id.desc()).all()
|
||||
|
||||
|
||||
def get_downloaded_videos(db: Session) -> list[Video]:
|
||||
return db.query(Video).filter(Video.file_path.isnot(None)).order_by(Video.id.desc()).all()
|
||||
def get_downloaded_videos(db: Session, profile_id: int | None = None) -> list[Video]:
|
||||
query = db.query(Video).filter(Video.file_path.isnot(None))
|
||||
if profile_id:
|
||||
query = query.filter(Video.profiles.any(Profile.id == profile_id))
|
||||
return query.order_by(Video.id.desc()).all()
|
||||
|
||||
|
||||
def get_video(db: Session, video_id: int) -> Video | None:
|
||||
@@ -34,3 +46,7 @@ def update_file_path(db: Session, video_id: int, path: str):
|
||||
if video:
|
||||
video.file_path = path
|
||||
db.commit()
|
||||
|
||||
|
||||
def get_all_profiles(db: Session) -> list[Profile]:
|
||||
return db.query(Profile).all()
|
||||
|
||||
Reference in New Issue
Block a user