"""Add skill table Revision ID: a1b2c3d4e5f6 Revises: f1e2d3c4b5a6 Create Date: 2026-02-11 09:30:00.000000 """ from typing import Sequence, Union from alembic import op import sqlalchemy as sa from open_webui.migrations.util import get_existing_tables revision: str = "a1b2c3d4e5f6" down_revision: Union[str, None] = "f1e2d3c4b5a6" branch_labels: Union[str, Sequence[str], None] = None depends_on: Union[str, Sequence[str], None] = None def upgrade() -> None: existing_tables = set(get_existing_tables()) if "skill" not in existing_tables: op.create_table( "skill", sa.Column("id", sa.String(), nullable=False, primary_key=True), sa.Column("user_id", sa.String(), nullable=False), sa.Column("name", sa.Text(), nullable=False, unique=True), sa.Column("description", sa.Text(), nullable=True), sa.Column("content", sa.Text(), nullable=False), sa.Column("meta", sa.JSON(), nullable=True), sa.Column("is_active", sa.Boolean(), nullable=False), sa.Column("updated_at", sa.BigInteger(), nullable=False), sa.Column("created_at", sa.BigInteger(), nullable=False), ) op.create_index("idx_skill_user_id", "skill", ["user_id"]) op.create_index("idx_skill_updated_at", "skill", ["updated_at"]) def downgrade() -> None: op.drop_index("idx_skill_updated_at", table_name="skill") op.drop_index("idx_skill_user_id", table_name="skill") op.drop_table("skill")