Files
tg_bot_language/migrations/versions/20251208_add_tasks_count.py
mamonov.ep eb666ec9bc feat: мульти-провайдер AI, выбор типов заданий, настройка количества
- Добавлена поддержка нескольких AI провайдеров (OpenAI, Google Gemini)
- Добавлена админ-панель (/admin) для переключения AI моделей
- Добавлен AIModelService для управления моделями в БД
- Добавлен выбор типа заданий (микс, перевод слов, подстановка, перевод предложений)
- Добавлена настройка количества заданий (5-15)
- ai_service динамически выбирает провайдера на основе активной модели
- Обработка ограничений моделей (temperature, response_format)
- Очистка markdown обёртки из ответов Gemini

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-08 15:16:24 +03:00

29 lines
832 B
Python

"""Add tasks_count field to users
Revision ID: 20251208_tasks_count
Revises: 20251207_translation_language
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_tasks_count'
down_revision: Union[str, None] = '20251207_translation_language'
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('tasks_count', sa.Integer(), nullable=True, server_default='5'))
# Установим дефолт для существующих записей
op.execute("UPDATE users SET tasks_count = 5 WHERE tasks_count IS NULL")
def downgrade() -> None:
op.drop_column('users', 'tasks_count')