feat: персональные AI модели, оптимизация задач, фильтрация словаря

- Добавлена поддержка персональных AI моделей для каждого пользователя
- Оптимизация создания заданий: батч-запрос к AI вместо N запросов
- Фильтрация слов по языку изучения (source_lang) в словаре
- Удалены неиспользуемые колонки examples и category из vocabulary
- Миграции для ai_model_id и удаления колонок

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
2025-12-08 16:43:08 +03:00
parent 6138af4e63
commit 16a7df0343
13 changed files with 507 additions and 142 deletions

View File

@@ -0,0 +1,28 @@
"""Remove examples and category columns from vocabulary
Revision ID: 20251208_rm_examples_category
Revises: 20251208_ai_models
Create Date: 2024-12-08
"""
from typing import Sequence, Union
from alembic import op
import sqlalchemy as sa
# revision identifiers, used by Alembic.
revision: str = '20251208_rm_examples_category'
down_revision: Union[str, None] = '20251208_ai_models'
branch_labels: Union[str, Sequence[str], None] = None
depends_on: Union[str, Sequence[str], None] = None
def upgrade() -> None:
op.drop_column('vocabulary', 'examples')
op.drop_column('vocabulary', 'category')
def downgrade() -> None:
op.add_column('vocabulary', sa.Column('category', sa.String(length=100), nullable=True))
op.add_column('vocabulary', sa.Column('examples', sa.JSON(), nullable=True))

View File

@@ -0,0 +1,26 @@
"""Add ai_model_id to users
Revision ID: 20251208_user_ai_model
Revises: 20251208_rm_examples_category
Create Date: 2024-12-08
"""
from typing import Sequence, Union
from alembic import op
import sqlalchemy as sa
# revision identifiers, used by Alembic.
revision: str = '20251208_user_ai_model'
down_revision: Union[str, None] = '20251208_rm_examples_category'
branch_labels: Union[str, Sequence[str], None] = None
depends_on: Union[str, Sequence[str], None] = None
def upgrade() -> None:
op.add_column('users', sa.Column('ai_model_id', sa.Integer(), nullable=True))
def downgrade() -> None:
op.drop_column('users', 'ai_model_id')