"""evagit_diff_and_discussion_models

Revision ID: 863542aedd2f
Revises: f65a0a6b8aeb
Create Date: 2025-06-05 09:51:47.756128

"""
from alembic import op
import sqlalchemy as sa


# revision identifiers, used by Alembic.
revision = '863542aedd2f'
down_revision = 'f65a0a6b8aeb'
branch_labels = None
depends_on = None


def upgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.create_table('cmf_evagit_discussion',
    sa.Column('id', sa.String(length=64), nullable=False),
    sa.Column('cmf_locked_at', sa.TIMESTAMP(timezone=True), nullable=True),
    sa.Column('cmf_created_at', sa.TIMESTAMP(timezone=True), nullable=False),
    sa.Column('cmf_modified_at', sa.TIMESTAMP(timezone=True), nullable=False),
    sa.Column('cmf_viewed_at', sa.TIMESTAMP(timezone=True), nullable=True),
    sa.Column('cmf_deleted', sa.Boolean(), nullable=False),
    sa.Column('cmf_version', sa.BIGINT(), nullable=True),
    sa.Column('name', sa.String(length=256), nullable=True),
    sa.Column('code', sa.String(length=64), nullable=True),
    sa.Column('system', sa.Boolean(), nullable=False),
    sa.Column('text', sa.TEXT(), nullable=True),
    sa.Column('import_original', sa.Boolean(), nullable=False),
    sa.Column('import_raw_json', sa.TEXT(), nullable=True),
    sa.Column('ext_id', sa.String(), nullable=True),
    sa.Column('cmf_archived', sa.Boolean(), nullable=False),
    sa.Column('is_favorite', sa.Boolean(), nullable=False),
    sa.Column('has_tree_nodes', sa.Boolean(), nullable=False),
    sa.Column('tree_node_is_branch', sa.Boolean(), nullable=False),
    sa.Column('tree_hidden', sa.Boolean(), nullable=False),
    sa.Column('sl_owner_lock', sa.Boolean(), nullable=False),
    sa.Column('orderno', sa.Integer(), nullable=True),
    sa.Column('perm_public', sa.Boolean(), nullable=False),
    sa.Column('perm_has_acl', sa.Boolean(), nullable=False),
    sa.Column('perm_inherit', sa.Boolean(), nullable=False),
    sa.Column('perm_parent_owner_id', sa.String(length=64), nullable=True),
    sa.Column('perm_inherit_acl_id', sa.String(length=64), nullable=True),
    sa.Column('perm_effective_acl_id', sa.String(length=64), nullable=True),
    sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True),
    sa.Column('perm_encrypt', sa.Boolean(), nullable=False),
    sa.Column('perm_encrypt_help', sa.String(length=256), nullable=True),
    sa.Column('status', sa.String(length=32), nullable=True),
    sa.Column('line_code', sa.String(length=128), nullable=False),
    sa.Column('original_position', sa.TEXT(), nullable=False),
    sa.Column('position', sa.TEXT(), nullable=False),
    sa.Column('change_position', sa.TEXT(), nullable=True),
    sa.Column('resolved_at', sa.TIMESTAMP(timezone=True), nullable=True),
    sa.Column('cmf_author_id', sa.String(length=64), nullable=True),
    sa.Column('cmf_owner_id', sa.String(length=64), nullable=True),
    sa.Column('parent_id', sa.String(length=64), nullable=True),
    sa.Column('cmf_modified_by_id', sa.String(length=64), nullable=True),
    sa.Column('cmf_locked_by_id', sa.String(length=64), nullable=True),
    sa.Column('cmf_import_id', sa.String(length=64), nullable=True),
    sa.Column('tree_parent_id', sa.String(length=64), nullable=True),
    sa.Column('root_parent_id', sa.String(length=64), nullable=True),
    sa.Column('project_id', sa.String(length=64), nullable=True),
    sa.Column('perm_acl_id', sa.String(length=64), nullable=True),
    sa.Column('perm_parent_id', sa.String(length=64), nullable=True),
    sa.Column('resolved_by_id', sa.String(length=64), nullable=True),
    sa.ForeignKeyConstraint(['cmf_import_id'], ['cmf_import.id'], ),
    sa.ForeignKeyConstraint(['perm_acl_id'], ['cmf_access_list.id'], ),
    sa.ForeignKeyConstraint(['project_id'], ['cmf_project.id'], ),
    sa.ForeignKeyConstraint(['resolved_by_id'], ['cmf_person.id'], ),
    sa.PrimaryKeyConstraint('id')
    )
    op.create_index(op.f('ix_cmf_evagit_discussion_cmf_author_id'), 'cmf_evagit_discussion', ['cmf_author_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_cmf_created_at'), 'cmf_evagit_discussion', ['cmf_created_at'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_cmf_deleted'), 'cmf_evagit_discussion', ['cmf_deleted'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_cmf_import_id'), 'cmf_evagit_discussion', ['cmf_import_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_cmf_locked_at'), 'cmf_evagit_discussion', ['cmf_locked_at'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_cmf_locked_by_id'), 'cmf_evagit_discussion', ['cmf_locked_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_cmf_modified_at'), 'cmf_evagit_discussion', ['cmf_modified_at'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_cmf_modified_by_id'), 'cmf_evagit_discussion', ['cmf_modified_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_cmf_owner_id'), 'cmf_evagit_discussion', ['cmf_owner_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_cmf_version'), 'cmf_evagit_discussion', ['cmf_version'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_cmf_viewed_at'), 'cmf_evagit_discussion', ['cmf_viewed_at'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_code'), 'cmf_evagit_discussion', ['code'], unique=True)
    op.create_index('ix_cmf_evagit_discussion_code_gin_trgm', 'cmf_evagit_discussion', ['code'], unique=False, postgresql_using='gin', postgresql_ops={'code': 'gin_trgm_ops'})
    op.create_index(op.f('ix_cmf_evagit_discussion_line_code'), 'cmf_evagit_discussion', ['line_code'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_name'), 'cmf_evagit_discussion', ['name'], unique=False)
    op.create_index('ix_cmf_evagit_discussion_name_gin_trgm', 'cmf_evagit_discussion', ['name'], unique=False, postgresql_using='gin', postgresql_ops={'name': 'gin_trgm_ops'})
    op.create_index(op.f('ix_cmf_evagit_discussion_orderno'), 'cmf_evagit_discussion', ['orderno'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_parent_id'), 'cmf_evagit_discussion', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_perm_acl_id'), 'cmf_evagit_discussion', ['perm_acl_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_perm_parent_id'), 'cmf_evagit_discussion', ['perm_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_project_id'), 'cmf_evagit_discussion', ['project_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_resolved_by_id'), 'cmf_evagit_discussion', ['resolved_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_root_parent_id'), 'cmf_evagit_discussion', ['root_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_status'), 'cmf_evagit_discussion', ['status'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_discussion_tree_parent_id'), 'cmf_evagit_discussion', ['tree_parent_id'], unique=False)
    op.create_table('cmf_evagit_merge_request_diff',
    sa.Column('id', sa.String(length=64), nullable=False),
    sa.Column('cmf_locked_at', sa.TIMESTAMP(timezone=True), nullable=True),
    sa.Column('cmf_created_at', sa.TIMESTAMP(timezone=True), nullable=False),
    sa.Column('cmf_modified_at', sa.TIMESTAMP(timezone=True), nullable=False),
    sa.Column('cmf_viewed_at', sa.TIMESTAMP(timezone=True), nullable=True),
    sa.Column('cmf_deleted', sa.Boolean(), nullable=False),
    sa.Column('cmf_version', sa.BIGINT(), nullable=True),
    sa.Column('name', sa.String(length=256), nullable=True),
    sa.Column('code', sa.String(length=64), nullable=True),
    sa.Column('system', sa.Boolean(), nullable=False),
    sa.Column('text', sa.TEXT(), nullable=True),
    sa.Column('import_original', sa.Boolean(), nullable=False),
    sa.Column('import_raw_json', sa.TEXT(), nullable=True),
    sa.Column('ext_id', sa.String(), nullable=True),
    sa.Column('cmf_archived', sa.Boolean(), nullable=False),
    sa.Column('is_favorite', sa.Boolean(), nullable=False),
    sa.Column('has_tree_nodes', sa.Boolean(), nullable=False),
    sa.Column('tree_node_is_branch', sa.Boolean(), nullable=False),
    sa.Column('tree_hidden', sa.Boolean(), nullable=False),
    sa.Column('sl_owner_lock', sa.Boolean(), nullable=False),
    sa.Column('orderno', sa.Integer(), nullable=True),
    sa.Column('perm_public', sa.Boolean(), nullable=False),
    sa.Column('perm_has_acl', sa.Boolean(), nullable=False),
    sa.Column('perm_inherit', sa.Boolean(), nullable=False),
    sa.Column('perm_parent_owner_id', sa.String(length=64), nullable=True),
    sa.Column('perm_inherit_acl_id', sa.String(length=64), nullable=True),
    sa.Column('perm_effective_acl_id', sa.String(length=64), nullable=True),
    sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True),
    sa.Column('perm_encrypt', sa.Boolean(), nullable=False),
    sa.Column('perm_encrypt_help', sa.String(length=256), nullable=True),
    sa.Column('base_sha', sa.String(length=128), nullable=False),
    sa.Column('target_sha', sa.String(length=128), nullable=False),
    sa.Column('source_sha', sa.String(length=128), nullable=False),
    sa.Column('patch_sha', sa.String(length=128), nullable=True),
    sa.Column('external_diff_path', sa.String(length=128), nullable=True),
    sa.Column('commits_count', sa.Integer(), nullable=True),
    sa.Column('cmf_author_id', sa.String(length=64), nullable=True),
    sa.Column('cmf_owner_id', sa.String(length=64), nullable=True),
    sa.Column('parent_id', sa.String(length=64), nullable=True),
    sa.Column('cmf_modified_by_id', sa.String(length=64), nullable=True),
    sa.Column('cmf_locked_by_id', sa.String(length=64), nullable=True),
    sa.Column('cmf_import_id', sa.String(length=64), nullable=True),
    sa.Column('tree_parent_id', sa.String(length=64), nullable=True),
    sa.Column('root_parent_id', sa.String(length=64), nullable=True),
    sa.Column('project_id', sa.String(length=64), nullable=True),
    sa.Column('perm_acl_id', sa.String(length=64), nullable=True),
    sa.Column('perm_parent_id', sa.String(length=64), nullable=True),
    sa.ForeignKeyConstraint(['cmf_import_id'], ['cmf_import.id'], ),
    sa.ForeignKeyConstraint(['perm_acl_id'], ['cmf_access_list.id'], ),
    sa.ForeignKeyConstraint(['project_id'], ['cmf_project.id'], ),
    sa.PrimaryKeyConstraint('id')
    )
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_base_sha'), 'cmf_evagit_merge_request_diff', ['base_sha'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_author_id'), 'cmf_evagit_merge_request_diff', ['cmf_author_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_created_at'), 'cmf_evagit_merge_request_diff', ['cmf_created_at'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_deleted'), 'cmf_evagit_merge_request_diff', ['cmf_deleted'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_import_id'), 'cmf_evagit_merge_request_diff', ['cmf_import_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_locked_at'), 'cmf_evagit_merge_request_diff', ['cmf_locked_at'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_locked_by_id'), 'cmf_evagit_merge_request_diff', ['cmf_locked_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_modified_at'), 'cmf_evagit_merge_request_diff', ['cmf_modified_at'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_modified_by_id'), 'cmf_evagit_merge_request_diff', ['cmf_modified_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_owner_id'), 'cmf_evagit_merge_request_diff', ['cmf_owner_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_version'), 'cmf_evagit_merge_request_diff', ['cmf_version'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_viewed_at'), 'cmf_evagit_merge_request_diff', ['cmf_viewed_at'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_code'), 'cmf_evagit_merge_request_diff', ['code'], unique=True)
    op.create_index('ix_cmf_evagit_merge_request_diff_code_gin_trgm', 'cmf_evagit_merge_request_diff', ['code'], unique=False, postgresql_using='gin', postgresql_ops={'code': 'gin_trgm_ops'})
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_name'), 'cmf_evagit_merge_request_diff', ['name'], unique=False)
    op.create_index('ix_cmf_evagit_merge_request_diff_name_gin_trgm', 'cmf_evagit_merge_request_diff', ['name'], unique=False, postgresql_using='gin', postgresql_ops={'name': 'gin_trgm_ops'})
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_orderno'), 'cmf_evagit_merge_request_diff', ['orderno'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_parent_id'), 'cmf_evagit_merge_request_diff', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_perm_acl_id'), 'cmf_evagit_merge_request_diff', ['perm_acl_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_perm_parent_id'), 'cmf_evagit_merge_request_diff', ['perm_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_project_id'), 'cmf_evagit_merge_request_diff', ['project_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_root_parent_id'), 'cmf_evagit_merge_request_diff', ['root_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_source_sha'), 'cmf_evagit_merge_request_diff', ['source_sha'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_target_sha'), 'cmf_evagit_merge_request_diff', ['target_sha'], unique=False)
    op.create_index(op.f('ix_cmf_evagit_merge_request_diff_tree_parent_id'), 'cmf_evagit_merge_request_diff', ['tree_parent_id'], unique=False)
    # ### end Alembic commands ###


def downgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_tree_parent_id'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_target_sha'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_source_sha'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_root_parent_id'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_project_id'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_perm_parent_id'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_perm_acl_id'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_parent_id'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_orderno'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index('ix_cmf_evagit_merge_request_diff_name_gin_trgm', table_name='cmf_evagit_merge_request_diff', postgresql_using='gin', postgresql_ops={'name': 'gin_trgm_ops'})
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_name'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index('ix_cmf_evagit_merge_request_diff_code_gin_trgm', table_name='cmf_evagit_merge_request_diff', postgresql_using='gin', postgresql_ops={'code': 'gin_trgm_ops'})
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_code'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_viewed_at'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_version'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_owner_id'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_modified_by_id'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_modified_at'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_locked_by_id'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_locked_at'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_import_id'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_deleted'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_created_at'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_cmf_author_id'), table_name='cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_merge_request_diff_base_sha'), table_name='cmf_evagit_merge_request_diff')
    op.drop_table('cmf_evagit_merge_request_diff')
    op.drop_index(op.f('ix_cmf_evagit_discussion_tree_parent_id'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_status'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_root_parent_id'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_resolved_by_id'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_project_id'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_perm_parent_id'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_perm_acl_id'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_parent_id'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_orderno'), table_name='cmf_evagit_discussion')
    op.drop_index('ix_cmf_evagit_discussion_name_gin_trgm', table_name='cmf_evagit_discussion', postgresql_using='gin', postgresql_ops={'name': 'gin_trgm_ops'})
    op.drop_index(op.f('ix_cmf_evagit_discussion_name'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_line_code'), table_name='cmf_evagit_discussion')
    op.drop_index('ix_cmf_evagit_discussion_code_gin_trgm', table_name='cmf_evagit_discussion', postgresql_using='gin', postgresql_ops={'code': 'gin_trgm_ops'})
    op.drop_index(op.f('ix_cmf_evagit_discussion_code'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_cmf_viewed_at'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_cmf_version'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_cmf_owner_id'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_cmf_modified_by_id'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_cmf_modified_at'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_cmf_locked_by_id'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_cmf_locked_at'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_cmf_import_id'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_cmf_deleted'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_cmf_created_at'), table_name='cmf_evagit_discussion')
    op.drop_index(op.f('ix_cmf_evagit_discussion_cmf_author_id'), table_name='cmf_evagit_discussion')
    op.drop_table('cmf_evagit_discussion')
    # ### end Alembic commands ###
