This commit is contained in:
2026-02-08 23:07:50 +00:00
commit 95a9bcd24d
32 changed files with 1415 additions and 0 deletions

58
app/database.py Executable file
View File

@@ -0,0 +1,58 @@
from peewee import *
from pathlib import Path
# Garante pasta de dados
data_dir = Path('/app/data')
data_dir.mkdir(parents=True, exist_ok=True)
db = SqliteDatabase(str(data_dir / 'cleiflow.db'))
class BaseModel(Model):
class Meta:
database = db
class AppConfig(BaseModel):
key = CharField(unique=True)
value = TextField()
@classmethod
def get_val(cls, key, default=''):
try:
return cls.get(cls.key == key).value
except:
return default
@classmethod
def set_val(cls, key, value):
cls.replace(key=key, value=value).execute()
class Category(BaseModel):
name = CharField(unique=True)
target_path = CharField()
match_keywords = CharField(null=True) # Ex: movie, film
# NOVO CAMPO: Tipo de conteúdo (movie, series, mixed)
content_type = CharField(default='mixed')
class FFmpegProfile(BaseModel):
name = CharField()
video_codec = CharField(default='h264_vaapi')
preset = CharField(default='medium')
crf = IntegerField(default=23)
audio_langs = CharField(default='por,eng,jpn')
subtitle_langs = CharField(default='por')
is_active = BooleanField(default=False)
def init_db():
db.connect()
db.create_tables([AppConfig, Category, FFmpegProfile], safe=True)
# Migração segura para adicionar coluna se não existir
try:
db.execute_sql('ALTER TABLE category ADD COLUMN content_type VARCHAR DEFAULT "mixed"')
except: pass # Já existe
# Perfil padrão se não existir
if FFmpegProfile.select().count() == 0:
FFmpegProfile.create(name="Padrão VAAPI (Intel)", video_codec="h264_vaapi", is_active=True)
db.close()