mirror of
https://github.com/jxxghp/MoviePilot.git
synced 2026-03-20 03:57:30 +08:00
96 lines
2.8 KiB
Python
96 lines
2.8 KiB
Python
from typing import Optional
|
||
|
||
from sqlalchemy import Column, Integer, String, Sequence, Float, JSON
|
||
from sqlalchemy.orm import Session
|
||
|
||
from app.db import db_query, Base
|
||
|
||
|
||
class SubscribeHistory(Base):
|
||
"""
|
||
订阅历史表
|
||
"""
|
||
id = Column(Integer, Sequence('id'), primary_key=True, index=True)
|
||
# 标题
|
||
name = Column(String, nullable=False, index=True)
|
||
# 年份
|
||
year = Column(String)
|
||
# 类型
|
||
type = Column(String)
|
||
# 搜索关键字
|
||
keyword = Column(String)
|
||
tmdbid = Column(Integer, index=True)
|
||
imdbid = Column(String)
|
||
tvdbid = Column(Integer)
|
||
doubanid = Column(String, index=True)
|
||
bangumiid = Column(Integer, index=True)
|
||
mediaid = Column(String, index=True)
|
||
# 季号
|
||
season = Column(Integer)
|
||
# 海报
|
||
poster = Column(String)
|
||
# 背景图
|
||
backdrop = Column(String)
|
||
# 评分,float
|
||
vote = Column(Float)
|
||
# 简介
|
||
description = Column(String)
|
||
# 过滤规则
|
||
filter = Column(String)
|
||
# 包含
|
||
include = Column(String)
|
||
# 排除
|
||
exclude = Column(String)
|
||
# 质量
|
||
quality = Column(String)
|
||
# 分辨率
|
||
resolution = Column(String)
|
||
# 特效
|
||
effect = Column(String)
|
||
# 总集数
|
||
total_episode = Column(Integer)
|
||
# 开始集数
|
||
start_episode = Column(Integer)
|
||
# 订阅完成时间
|
||
date = Column(String)
|
||
# 订阅用户
|
||
username = Column(String)
|
||
# 订阅站点
|
||
sites = Column(JSON)
|
||
# 是否洗版
|
||
best_version = Column(Integer, default=0)
|
||
# 保存路径
|
||
save_path = Column(String)
|
||
# 是否使用 imdbid 搜索
|
||
search_imdbid = Column(Integer, default=0)
|
||
# 自定义识别词
|
||
custom_words = Column(String)
|
||
# 自定义媒体类别
|
||
media_category = Column(String)
|
||
# 过滤规则组
|
||
filter_groups = Column(JSON, default=list)
|
||
# 剧集组
|
||
episode_group = Column(String)
|
||
|
||
@staticmethod
|
||
@db_query
|
||
def list_by_type(db: Session, mtype: str, page: Optional[int] = 1, count: Optional[int] = 30):
|
||
result = db.query(SubscribeHistory).filter(
|
||
SubscribeHistory.type == mtype
|
||
).order_by(
|
||
SubscribeHistory.date.desc()
|
||
).offset((page - 1) * count).limit(count).all()
|
||
return list(result)
|
||
|
||
@staticmethod
|
||
@db_query
|
||
def exists(db: Session, tmdbid: Optional[int] = None, doubanid: Optional[str] = None, season: Optional[int] = None):
|
||
if tmdbid:
|
||
if season:
|
||
return db.query(SubscribeHistory).filter(SubscribeHistory.tmdbid == tmdbid,
|
||
SubscribeHistory.season == season).first()
|
||
return db.query(SubscribeHistory).filter(SubscribeHistory.tmdbid == tmdbid).first()
|
||
elif doubanid:
|
||
return db.query(SubscribeHistory).filter(SubscribeHistory.doubanid == doubanid).first()
|
||
return None
|