API для работы с файлами, индексация файлов и результатов распощнавания

This commit is contained in:
poturaevpetr
2025-12-24 16:05:14 +05:00
parent 4f23dc8664
commit c39b348472
31 changed files with 1739 additions and 0 deletions
+2
View File
@@ -0,0 +1,2 @@
from apiApp.services.audio_service import AudioCRUD
from apiApp.services.ai_conclusion_service import AiConclusionCRUD
+56
View File
@@ -0,0 +1,56 @@
from sqlalchemy.orm import Session
from typing import List, Optional
import os
from apiApp.database import Audio
from apiApp.schemas import AudioCreate
from apiApp.config import UPLOAD_FOLDER
import datetime
import uuid
class AiConclusionCRUD:
@staticmethod
def get_by_audio_id(db: Session, audio_id: uuid.UUID):
"""Получить заключение по audio_id"""
from apiApp.database import AiConclusion
return db.query(AiConclusion).filter(AiConclusion.audio_id == audio_id).first()
@staticmethod
def create(db: Session, audio_id: uuid.UUID, conclusion: dict = None):
"""Создать новое заключение"""
from apiApp.database import AiConclusion
db_conclusion = AiConclusion(
audio_id=audio_id,
conclusion=conclusion or {
"transcription": [],
"ai_transcription": [],
"conclusion": {}
},
index_date=datetime.datetime.utcnow()
)
db.add(db_conclusion)
db.commit()
db.refresh(db_conclusion)
return db_conclusion
@staticmethod
def update(db: Session, conclusion_id: uuid.UUID, conclusion_data: dict, end_date: bool = False):
"""Обновить заключение"""
from apiApp.database import AiConclusion
db_conclusion = db.query(AiConclusion).filter(AiConclusion.id == conclusion_id).first()
if not db_conclusion:
return None
if conclusion_data:
db_conclusion.conclusion = conclusion_data
if end_date:
db_conclusion.end_date = datetime.datetime.utcnow()
db.commit()
db.refresh(db_conclusion)
return db_conclusion
+79
View File
@@ -0,0 +1,79 @@
from sqlalchemy.orm import Session
from typing import List, Optional
import os
from apiApp.database import Audio
from apiApp.schemas import AudioCreate
from apiApp.config import UPLOAD_FOLDER
import datetime
import uuid
class AudioCRUD:
@staticmethod
def get_all(db: Session) -> List[Audio]:
"""Получить все аудиофайлы"""
return db.query(Audio).all()
@staticmethod
def get_by_id(db: Session, audio_id: uuid.UUID) -> Optional[Audio]:
"""Получить аудиофайл по ID"""
return db.query(Audio).filter(Audio.id == audio_id).first()
@staticmethod
def get_by_filename(db: Session, filename: str) -> Optional[Audio]:
"""Получить аудиофайл по имени файла"""
return db.query(Audio).filter(Audio.filename == filename).first()
@staticmethod
def create(db: Session, audio_data: AudioCreate, file_path: str, file_size: int = None) -> Audio:
"""Создать новую запись аудиофайла"""
db_audio = Audio(
filename=audio_data.filename,
file_path=file_path,
index_date=datetime.datetime.utcnow(),
file_size=file_size
)
db.add(db_audio)
db.commit()
db.refresh(db_audio)
return db_audio
@staticmethod
def update(db: Session, audio_id: uuid.UUID, audio_data: dict) -> Optional[Audio]:
"""Обновить запись аудиофайла"""
db_audio = db.query(Audio).filter(Audio.id == audio_id).first()
if not db_audio:
return None
for key, value in audio_data.items():
if hasattr(db_audio, key):
setattr(db_audio, key, value)
db.commit()
db.refresh(db_audio)
return db_audio
@staticmethod
def delete(db: Session, audio_id: uuid.UUID) -> Optional[Audio]:
"""Удалить аудиофайл"""
db_audio = db.query(Audio).filter(Audio.id == audio_id).first()
if not db_audio:
return None
# Удаление файла с диска
if db_audio.file_path and os.path.exists(db_audio.file_path):
try:
os.remove(db_audio.file_path)
except Exception as e:
print(f"Error deleting file: {e}")
db.delete(db_audio)
db.commit()
return db_audio
@staticmethod
def update_recognition_result(db: Session, audio_id: uuid.UUID, result: dict) -> Optional[Audio]:
"""Обновить результат распознавания"""
return AudioCRUD.update(db, audio_id, {"recognition_result": result})