"""clients spravochniki

Revision ID: 9c9521effcac
Revises: 253e667847b0
Create Date: 2024-02-12 21:05:44.658004

"""
from alembic import op
import sqlalchemy as sa


# revision identifiers, used by Alembic.
revision = '9c9521effcac'
down_revision = '253e667847b0'
branch_labels = None
depends_on = None


def upgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.create_table('cmf_business_sector',
    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=True),
    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=True),
    sa.Column('has_tree_nodes', sa.Boolean(), nullable=True),
    sa.Column('tree_node_is_branch', sa.Boolean(), nullable=True),
    sa.Column('tree_hidden', sa.Boolean(), nullable=True),
    sa.Column('orderno', sa.Integer(), nullable=True),
    sa.Column('perm_public', sa.Boolean(), nullable=True),
    sa.Column('perm_has_acl', sa.Boolean(), nullable=True),
    sa.Column('perm_inherit', sa.Boolean(), nullable=True),
    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=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('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.PrimaryKeyConstraint('id')
    )
    op.create_index(op.f('ix_cmf_business_sector_cmf_author_id'), 'cmf_business_sector', ['cmf_author_id'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_cmf_created_at'), 'cmf_business_sector', ['cmf_created_at'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_cmf_deleted'), 'cmf_business_sector', ['cmf_deleted'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_cmf_import_id'), 'cmf_business_sector', ['cmf_import_id'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_cmf_locked_at'), 'cmf_business_sector', ['cmf_locked_at'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_cmf_locked_by_id'), 'cmf_business_sector', ['cmf_locked_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_cmf_modified_at'), 'cmf_business_sector', ['cmf_modified_at'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_cmf_modified_by_id'), 'cmf_business_sector', ['cmf_modified_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_cmf_owner_id'), 'cmf_business_sector', ['cmf_owner_id'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_cmf_version'), 'cmf_business_sector', ['cmf_version'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_cmf_viewed_at'), 'cmf_business_sector', ['cmf_viewed_at'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_code'), 'cmf_business_sector', ['code'], unique=True)
    op.create_index(op.f('ix_cmf_business_sector_name'), 'cmf_business_sector', ['name'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_orderno'), 'cmf_business_sector', ['orderno'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_parent_id'), 'cmf_business_sector', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_perm_acl_id'), 'cmf_business_sector', ['perm_acl_id'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_perm_parent_id'), 'cmf_business_sector', ['perm_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_root_parent_id'), 'cmf_business_sector', ['root_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_business_sector_tree_parent_id'), 'cmf_business_sector', ['tree_parent_id'], unique=False)
    op.create_table('cmf_client_job',
    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=True),
    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=True),
    sa.Column('has_tree_nodes', sa.Boolean(), nullable=True),
    sa.Column('tree_node_is_branch', sa.Boolean(), nullable=True),
    sa.Column('tree_hidden', sa.Boolean(), nullable=True),
    sa.Column('orderno', sa.Integer(), nullable=True),
    sa.Column('perm_public', sa.Boolean(), nullable=True),
    sa.Column('perm_has_acl', sa.Boolean(), nullable=True),
    sa.Column('perm_inherit', sa.Boolean(), nullable=True),
    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=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('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.PrimaryKeyConstraint('id')
    )
    op.create_index(op.f('ix_cmf_client_job_cmf_author_id'), 'cmf_client_job', ['cmf_author_id'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_cmf_created_at'), 'cmf_client_job', ['cmf_created_at'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_cmf_deleted'), 'cmf_client_job', ['cmf_deleted'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_cmf_import_id'), 'cmf_client_job', ['cmf_import_id'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_cmf_locked_at'), 'cmf_client_job', ['cmf_locked_at'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_cmf_locked_by_id'), 'cmf_client_job', ['cmf_locked_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_cmf_modified_at'), 'cmf_client_job', ['cmf_modified_at'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_cmf_modified_by_id'), 'cmf_client_job', ['cmf_modified_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_cmf_owner_id'), 'cmf_client_job', ['cmf_owner_id'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_cmf_version'), 'cmf_client_job', ['cmf_version'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_cmf_viewed_at'), 'cmf_client_job', ['cmf_viewed_at'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_code'), 'cmf_client_job', ['code'], unique=True)
    op.create_index(op.f('ix_cmf_client_job_name'), 'cmf_client_job', ['name'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_orderno'), 'cmf_client_job', ['orderno'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_parent_id'), 'cmf_client_job', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_perm_acl_id'), 'cmf_client_job', ['perm_acl_id'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_perm_parent_id'), 'cmf_client_job', ['perm_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_root_parent_id'), 'cmf_client_job', ['root_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_client_job_tree_parent_id'), 'cmf_client_job', ['tree_parent_id'], unique=False)
    op.add_column('cmf_company', sa.Column('business_sector_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_company_business_sector_id'), 'cmf_company', ['business_sector_id'], unique=False)
    op.create_foreign_key(None, 'cmf_company', 'cmf_business_sector', ['business_sector_id'], ['id'])
    op.add_column('cmf_person', sa.Column('client_job_id', sa.String(length=64), nullable=True))
    op.alter_column('cmf_person', 'phone_internal',
               existing_type=sa.VARCHAR(length=32),
               type_=sa.String(length=256),
               existing_nullable=True)
    op.alter_column('cmf_person', 'phone_2',
               existing_type=sa.VARCHAR(length=32),
               type_=sa.String(length=256),
               existing_nullable=True)
    op.alter_column('cmf_person', 'email_2',
               existing_type=sa.VARCHAR(length=32),
               type_=sa.String(length=128),
               existing_nullable=True)
    op.create_index(op.f('ix_cmf_person_client_job_id'), 'cmf_person', ['client_job_id'], unique=False)
    op.create_foreign_key(None, 'cmf_person', 'cmf_client_job', ['client_job_id'], ['id'])
    # ### end Alembic commands ###


def downgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.drop_constraint(None, 'cmf_person', type_='foreignkey')
    op.drop_index(op.f('ix_cmf_person_client_job_id'), table_name='cmf_person')
    op.alter_column('cmf_person', 'email_2',
               existing_type=sa.String(length=128),
               type_=sa.VARCHAR(length=32),
               existing_nullable=True)
    op.alter_column('cmf_person', 'phone_2',
               existing_type=sa.String(length=256),
               type_=sa.VARCHAR(length=32),
               existing_nullable=True)
    op.alter_column('cmf_person', 'phone_internal',
               existing_type=sa.String(length=256),
               type_=sa.VARCHAR(length=32),
               existing_nullable=True)
    op.drop_column('cmf_person', 'client_job_id')
    op.drop_constraint(None, 'cmf_company', type_='foreignkey')
    op.drop_index(op.f('ix_cmf_company_business_sector_id'), table_name='cmf_company')
    op.drop_column('cmf_company', 'business_sector_id')
    op.drop_index(op.f('ix_cmf_client_job_tree_parent_id'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_root_parent_id'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_perm_parent_id'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_perm_acl_id'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_parent_id'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_orderno'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_name'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_code'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_cmf_viewed_at'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_cmf_version'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_cmf_owner_id'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_cmf_modified_by_id'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_cmf_modified_at'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_cmf_locked_by_id'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_cmf_locked_at'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_cmf_import_id'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_cmf_deleted'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_cmf_created_at'), table_name='cmf_client_job')
    op.drop_index(op.f('ix_cmf_client_job_cmf_author_id'), table_name='cmf_client_job')
    op.drop_table('cmf_client_job')
    op.drop_index(op.f('ix_cmf_business_sector_tree_parent_id'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_root_parent_id'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_perm_parent_id'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_perm_acl_id'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_parent_id'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_orderno'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_name'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_code'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_cmf_viewed_at'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_cmf_version'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_cmf_owner_id'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_cmf_modified_by_id'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_cmf_modified_at'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_cmf_locked_by_id'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_cmf_locked_at'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_cmf_import_id'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_cmf_deleted'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_cmf_created_at'), table_name='cmf_business_sector')
    op.drop_index(op.f('ix_cmf_business_sector_cmf_author_id'), table_name='cmf_business_sector')
    op.drop_table('cmf_business_sector')
    # ### end Alembic commands ###
