"""security levels

Revision ID: 3032822e2ef5
Revises: f5f884670fbc
Create Date: 2023-07-11 16:45:08.892055

"""
from alembic import op
import sqlalchemy as sa


# revision identifiers, used by Alembic.
revision = '3032822e2ef5'
down_revision = 'f5f884670fbc'
branch_labels = None
depends_on = None


def upgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.create_table('cmf_security_level',
    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=False),
    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('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_encrypt', sa.Boolean(), nullable=True),
    sa.Column('access_local_user', sa.Boolean(), nullable=False),
    sa.Column('access_owner', sa.Boolean(), nullable=False),
    sa.Column('access_owner_assistant', sa.Boolean(), nullable=False),
    sa.Column('access_author', sa.Boolean(), nullable=False),
    sa.Column('access_project_owner', sa.Boolean(), nullable=False),
    sa.Column('access_responsible', sa.Boolean(), nullable=False),
    sa.Column('access_sdesk_client', sa.Boolean(), nullable=False),
    sa.Column('access_anonymous', sa.Boolean(), nullable=False),
    sa.Column('access_guest', sa.Boolean(), nullable=False),
    sa.Column('access_sharelink_anonymous', sa.Boolean(), nullable=False),
    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=False),
    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_security_level_cmf_author_id'), 'cmf_security_level', ['cmf_author_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_cmf_created_at'), 'cmf_security_level', ['cmf_created_at'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_cmf_deleted'), 'cmf_security_level', ['cmf_deleted'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_cmf_import_id'), 'cmf_security_level', ['cmf_import_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_cmf_locked_at'), 'cmf_security_level', ['cmf_locked_at'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_cmf_locked_by_id'), 'cmf_security_level', ['cmf_locked_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_cmf_modified_at'), 'cmf_security_level', ['cmf_modified_at'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_cmf_modified_by_id'), 'cmf_security_level', ['cmf_modified_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_cmf_owner_id'), 'cmf_security_level', ['cmf_owner_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_cmf_version'), 'cmf_security_level', ['cmf_version'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_cmf_viewed_at'), 'cmf_security_level', ['cmf_viewed_at'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_code'), 'cmf_security_level', ['code'], unique=True)
    op.create_index(op.f('ix_cmf_security_level_name'), 'cmf_security_level', ['name'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_orderno'), 'cmf_security_level', ['orderno'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_parent_id'), 'cmf_security_level', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_perm_acl_id'), 'cmf_security_level', ['perm_acl_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_perm_parent_id'), 'cmf_security_level', ['perm_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_root_parent_id'), 'cmf_security_level', ['root_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_tree_parent_id'), 'cmf_security_level', ['tree_parent_id'], unique=False)
    op.create_table('cmf_security_level_access_members',
    sa.Column('id', sa.String(length=128), nullable=False),
    sa.Column('parent_id', sa.String(length=64), nullable=True),
    sa.Column('root_id', sa.String(length=64), nullable=True),
    sa.Column('description', sa.String(length=4096), nullable=True),
    sa.Column('left_id', sa.String(length=64), nullable=True),
    sa.Column('right_id', sa.String(length=64), nullable=True),
    sa.Column('left_name_cache', sa.String(length=256), nullable=True),
    sa.Column('right_name_cache', sa.String(length=256), nullable=True),
    sa.PrimaryKeyConstraint('id')
    )
    op.create_index(op.f('ix_cmf_security_level_access_members_left_id'), 'cmf_security_level_access_members', ['left_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_access_members_parent_id'), 'cmf_security_level_access_members', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_access_members_right_id'), 'cmf_security_level_access_members', ['right_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_access_members_root_id'), 'cmf_security_level_access_members', ['root_id'], unique=False)
    op.create_table('cmf_security_level_cmf_project_role',
    sa.Column('id', sa.String(length=128), nullable=False),
    sa.Column('parent_id', sa.String(length=64), nullable=True),
    sa.Column('root_id', sa.String(length=64), nullable=True),
    sa.Column('description', sa.String(length=4096), nullable=True),
    sa.Column('left_id', sa.String(length=64), nullable=True),
    sa.Column('right_id', sa.String(length=64), nullable=True),
    sa.Column('left_name_cache', sa.String(length=256), nullable=True),
    sa.Column('right_name_cache', sa.String(length=256), nullable=True),
    sa.ForeignKeyConstraint(['left_id'], ['cmf_security_level.id'], ),
    sa.ForeignKeyConstraint(['right_id'], ['cmf_project_role.id'], ),
    sa.PrimaryKeyConstraint('id')
    )
    op.create_index(op.f('ix_cmf_security_level_cmf_project_role_left_id'), 'cmf_security_level_cmf_project_role', ['left_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_cmf_project_role_parent_id'), 'cmf_security_level_cmf_project_role', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_cmf_project_role_right_id'), 'cmf_security_level_cmf_project_role', ['right_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_cmf_project_role_root_id'), 'cmf_security_level_cmf_project_role', ['root_id'], unique=False)
    op.create_table('cmf_security_level_scheme',
    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=False),
    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('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_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.Column('default_security_level_id', sa.String(length=64), nullable=True),
    sa.ForeignKeyConstraint(['cmf_import_id'], ['cmf_import.id'], ),
    sa.ForeignKeyConstraint(['default_security_level_id'], ['cmf_security_level.id'], ),
    sa.ForeignKeyConstraint(['perm_acl_id'], ['cmf_access_list.id'], ),
    sa.PrimaryKeyConstraint('id')
    )
    op.create_index(op.f('ix_cmf_security_level_scheme_cmf_author_id'), 'cmf_security_level_scheme', ['cmf_author_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_cmf_created_at'), 'cmf_security_level_scheme', ['cmf_created_at'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_cmf_deleted'), 'cmf_security_level_scheme', ['cmf_deleted'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_cmf_import_id'), 'cmf_security_level_scheme', ['cmf_import_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_cmf_locked_at'), 'cmf_security_level_scheme', ['cmf_locked_at'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_cmf_locked_by_id'), 'cmf_security_level_scheme', ['cmf_locked_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_cmf_modified_at'), 'cmf_security_level_scheme', ['cmf_modified_at'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_cmf_modified_by_id'), 'cmf_security_level_scheme', ['cmf_modified_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_cmf_owner_id'), 'cmf_security_level_scheme', ['cmf_owner_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_cmf_version'), 'cmf_security_level_scheme', ['cmf_version'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_cmf_viewed_at'), 'cmf_security_level_scheme', ['cmf_viewed_at'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_code'), 'cmf_security_level_scheme', ['code'], unique=True)
    op.create_index(op.f('ix_cmf_security_level_scheme_default_security_level_id'), 'cmf_security_level_scheme', ['default_security_level_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_name'), 'cmf_security_level_scheme', ['name'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_orderno'), 'cmf_security_level_scheme', ['orderno'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_parent_id'), 'cmf_security_level_scheme', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_perm_acl_id'), 'cmf_security_level_scheme', ['perm_acl_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_perm_parent_id'), 'cmf_security_level_scheme', ['perm_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_root_parent_id'), 'cmf_security_level_scheme', ['root_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_security_level_scheme_tree_parent_id'), 'cmf_security_level_scheme', ['tree_parent_id'], unique=False)
    op.add_column('cmf_chat_group', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_chat_group', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_chat_group_perm_security_level_id'), 'cmf_chat_group', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_chat_group', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_chat_topic', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_chat_topic', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_chat_topic_perm_security_level_id'), 'cmf_chat_topic', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_chat_topic', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_company', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_company', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_company_perm_security_level_id'), 'cmf_company', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_company', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_component', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_component', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_component_perm_security_level_id'), 'cmf_component', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_component', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_dashboard', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_dashboard', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_dashboard_perm_security_level_id'), 'cmf_dashboard', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_dashboard', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_deal', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_deal', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_deal_perm_security_level_id'), 'cmf_deal', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_deal', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_document', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_document', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_document_perm_security_level_id'), 'cmf_document', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_document', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_folder', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_folder', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_folder_perm_security_level_id'), 'cmf_folder', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_folder', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_import', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_import', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_import_perm_security_level_id'), 'cmf_import', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_import', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_invoice', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_invoice', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_invoice_perm_security_level_id'), 'cmf_invoice', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_invoice', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_kanban_board', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_kanban_board', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_kanban_board_perm_security_level_id'), 'cmf_kanban_board', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_kanban_board', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_lead', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_lead', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_lead_perm_security_level_id'), 'cmf_lead', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_lead', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_list', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_list', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_list_perm_security_level_id'), 'cmf_list', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_list', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_mail_handler', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_mail_handler', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_mail_handler_perm_security_level_id'), 'cmf_mail_handler', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_mail_handler', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_payment', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_payment', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_payment_perm_security_level_id'), 'cmf_payment', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_payment', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_pipeline', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_pipeline', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_pipeline_perm_security_level_id'), 'cmf_pipeline', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_pipeline', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_project', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_project', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.add_column('cmf_project', sa.Column('security_level_scheme_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_project_perm_security_level_id'), 'cmf_project', ['perm_security_level_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_security_level_scheme_id'), 'cmf_project', ['security_level_scheme_id'], unique=False)
    op.create_foreign_key(None, 'cmf_project', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.create_foreign_key(None, 'cmf_project', 'cmf_security_level_scheme', ['security_level_scheme_id'], ['id'])
    op.add_column('cmf_purchase_order', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_purchase_order', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_purchase_order_perm_security_level_id'), 'cmf_purchase_order', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_purchase_order', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_purchase_order_items', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_purchase_order_items', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_purchase_order_items_perm_security_level_id'), 'cmf_purchase_order_items', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_purchase_order_items', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_roadmap', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_roadmap', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_roadmap_perm_security_level_id'), 'cmf_roadmap', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_roadmap', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_scheme_wf', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_scheme_wf', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_scheme_wf_perm_security_level_id'), 'cmf_scheme_wf', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_scheme_wf', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_stock_incoming_order', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_stock_incoming_order', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_stock_incoming_order_perm_security_level_id'), 'cmf_stock_incoming_order', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_stock_incoming_order', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_stock_initial', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_stock_initial', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_stock_initial_perm_security_level_id'), 'cmf_stock_initial', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_stock_initial', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_stock_inventory', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_stock_inventory', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_stock_inventory_perm_security_level_id'), 'cmf_stock_inventory', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_stock_inventory', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_stock_move', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_stock_move', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_stock_move_perm_security_level_id'), 'cmf_stock_move', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_stock_move', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_stock_outcoming_order', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_stock_outcoming_order', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_stock_outcoming_order_perm_security_level_id'), 'cmf_stock_outcoming_order', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_stock_outcoming_order', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_task', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_task', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_task_perm_security_level_id'), 'cmf_task', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_task', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_task_filter', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_task_filter', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_task_filter_perm_security_level_id'), 'cmf_task_filter', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_task_filter', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_task_queue', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_task_queue', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_task_queue_perm_security_level_id'), 'cmf_task_queue', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_task_queue', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_task_report', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_task_report', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_task_report_perm_security_level_id'), 'cmf_task_report', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_task_report', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    op.add_column('cmf_u_work_post', sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), nullable=True))
    op.add_column('cmf_u_work_post', sa.Column('perm_security_level_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_u_work_post_perm_security_level_id'), 'cmf_u_work_post', ['perm_security_level_id'], unique=False)
    op.create_foreign_key(None, 'cmf_u_work_post', 'cmf_security_level', ['perm_security_level_id'], ['id'])
    # ### end Alembic commands ###


def downgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.drop_index(op.f('ix_cmf_u_work_post_perm_security_level_id'), table_name='cmf_u_work_post')
    op.drop_column('cmf_u_work_post', 'perm_security_level_id')
    op.drop_column('cmf_u_work_post', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_task_report_perm_security_level_id'), table_name='cmf_task_report')
    op.drop_column('cmf_task_report', 'perm_security_level_id')
    op.drop_column('cmf_task_report', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_task_queue_perm_security_level_id'), table_name='cmf_task_queue')
    op.drop_column('cmf_task_queue', 'perm_security_level_id')
    op.drop_column('cmf_task_queue', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_task_filter_perm_security_level_id'), table_name='cmf_task_filter')
    op.drop_column('cmf_task_filter', 'perm_security_level_id')
    op.drop_column('cmf_task_filter', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_task_perm_security_level_id'), table_name='cmf_task')
    op.drop_column('cmf_task', 'perm_security_level_id')
    op.drop_column('cmf_task', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_stock_outcoming_order_perm_security_level_id'), table_name='cmf_stock_outcoming_order')
    op.drop_column('cmf_stock_outcoming_order', 'perm_security_level_id')
    op.drop_column('cmf_stock_outcoming_order', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_stock_move_perm_security_level_id'), table_name='cmf_stock_move')
    op.drop_column('cmf_stock_move', 'perm_security_level_id')
    op.drop_column('cmf_stock_move', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_stock_inventory_perm_security_level_id'), table_name='cmf_stock_inventory')
    op.drop_column('cmf_stock_inventory', 'perm_security_level_id')
    op.drop_column('cmf_stock_inventory', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_stock_initial_perm_security_level_id'), table_name='cmf_stock_initial')
    op.drop_column('cmf_stock_initial', 'perm_security_level_id')
    op.drop_column('cmf_stock_initial', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_stock_incoming_order_perm_security_level_id'), table_name='cmf_stock_incoming_order')
    op.drop_column('cmf_stock_incoming_order', 'perm_security_level_id')
    op.drop_column('cmf_stock_incoming_order', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_scheme_wf_perm_security_level_id'), table_name='cmf_scheme_wf')
    op.drop_column('cmf_scheme_wf', 'perm_security_level_id')
    op.drop_column('cmf_scheme_wf', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_roadmap_perm_security_level_id'), table_name='cmf_roadmap')
    op.drop_column('cmf_roadmap', 'perm_security_level_id')
    op.drop_column('cmf_roadmap', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_purchase_order_items_perm_security_level_id'), table_name='cmf_purchase_order_items')
    op.drop_column('cmf_purchase_order_items', 'perm_security_level_id')
    op.drop_column('cmf_purchase_order_items', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_purchase_order_perm_security_level_id'), table_name='cmf_purchase_order')
    op.drop_column('cmf_purchase_order', 'perm_security_level_id')
    op.drop_column('cmf_purchase_order', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_project_security_level_scheme_id'), table_name='cmf_project')
    op.drop_index(op.f('ix_cmf_project_perm_security_level_id'), table_name='cmf_project')
    op.drop_column('cmf_project', 'security_level_scheme_id')
    op.drop_column('cmf_project', 'perm_security_level_id')
    op.drop_column('cmf_project', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_pipeline_perm_security_level_id'), table_name='cmf_pipeline')
    op.drop_column('cmf_pipeline', 'perm_security_level_id')
    op.drop_column('cmf_pipeline', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_payment_perm_security_level_id'), table_name='cmf_payment')
    op.drop_column('cmf_payment', 'perm_security_level_id')
    op.drop_column('cmf_payment', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_mail_handler_perm_security_level_id'), table_name='cmf_mail_handler')
    op.drop_column('cmf_mail_handler', 'perm_security_level_id')
    op.drop_column('cmf_mail_handler', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_list_perm_security_level_id'), table_name='cmf_list')
    op.drop_column('cmf_list', 'perm_security_level_id')
    op.drop_column('cmf_list', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_lead_perm_security_level_id'), table_name='cmf_lead')
    op.drop_column('cmf_lead', 'perm_security_level_id')
    op.drop_column('cmf_lead', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_kanban_board_perm_security_level_id'), table_name='cmf_kanban_board')
    op.drop_column('cmf_kanban_board', 'perm_security_level_id')
    op.drop_column('cmf_kanban_board', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_invoice_perm_security_level_id'), table_name='cmf_invoice')
    op.drop_column('cmf_invoice', 'perm_security_level_id')
    op.drop_column('cmf_invoice', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_import_perm_security_level_id'), table_name='cmf_import')
    op.drop_column('cmf_import', 'perm_security_level_id')
    op.drop_column('cmf_import', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_folder_perm_security_level_id'), table_name='cmf_folder')
    op.drop_column('cmf_folder', 'perm_security_level_id')
    op.drop_column('cmf_folder', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_document_perm_security_level_id'), table_name='cmf_document')
    op.drop_column('cmf_document', 'perm_security_level_id')
    op.drop_column('cmf_document', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_deal_perm_security_level_id'), table_name='cmf_deal')
    op.drop_column('cmf_deal', 'perm_security_level_id')
    op.drop_column('cmf_deal', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_dashboard_perm_security_level_id'), table_name='cmf_dashboard')
    op.drop_column('cmf_dashboard', 'perm_security_level_id')
    op.drop_column('cmf_dashboard', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_component_perm_security_level_id'), table_name='cmf_component')
    op.drop_column('cmf_component', 'perm_security_level_id')
    op.drop_column('cmf_component', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_company_perm_security_level_id'), table_name='cmf_company')
    op.drop_column('cmf_company', 'perm_security_level_id')
    op.drop_column('cmf_company', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_chat_topic_perm_security_level_id'), table_name='cmf_chat_topic')
    op.drop_column('cmf_chat_topic', 'perm_security_level_id')
    op.drop_column('cmf_chat_topic', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_chat_group_perm_security_level_id'), table_name='cmf_chat_group')
    op.drop_column('cmf_chat_group', 'perm_security_level_id')
    op.drop_column('cmf_chat_group', 'perm_security_level_allowed_ids_cache')
    op.drop_index(op.f('ix_cmf_security_level_scheme_tree_parent_id'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_root_parent_id'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_perm_parent_id'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_perm_acl_id'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_parent_id'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_orderno'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_name'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_default_security_level_id'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_code'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_cmf_viewed_at'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_cmf_version'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_cmf_owner_id'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_cmf_modified_by_id'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_cmf_modified_at'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_cmf_locked_by_id'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_cmf_locked_at'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_cmf_import_id'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_cmf_deleted'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_cmf_created_at'), table_name='cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_scheme_cmf_author_id'), table_name='cmf_security_level_scheme')
    op.drop_table('cmf_security_level_scheme')
    op.drop_index(op.f('ix_cmf_security_level_cmf_project_role_root_id'), table_name='cmf_security_level_cmf_project_role')
    op.drop_index(op.f('ix_cmf_security_level_cmf_project_role_right_id'), table_name='cmf_security_level_cmf_project_role')
    op.drop_index(op.f('ix_cmf_security_level_cmf_project_role_parent_id'), table_name='cmf_security_level_cmf_project_role')
    op.drop_index(op.f('ix_cmf_security_level_cmf_project_role_left_id'), table_name='cmf_security_level_cmf_project_role')
    op.drop_table('cmf_security_level_cmf_project_role')
    op.drop_index(op.f('ix_cmf_security_level_access_members_root_id'), table_name='cmf_security_level_access_members')
    op.drop_index(op.f('ix_cmf_security_level_access_members_right_id'), table_name='cmf_security_level_access_members')
    op.drop_index(op.f('ix_cmf_security_level_access_members_parent_id'), table_name='cmf_security_level_access_members')
    op.drop_index(op.f('ix_cmf_security_level_access_members_left_id'), table_name='cmf_security_level_access_members')
    op.drop_table('cmf_security_level_access_members')
    op.drop_index(op.f('ix_cmf_security_level_tree_parent_id'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_root_parent_id'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_perm_parent_id'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_perm_acl_id'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_parent_id'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_orderno'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_name'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_code'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_cmf_viewed_at'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_cmf_version'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_cmf_owner_id'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_cmf_modified_by_id'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_cmf_modified_at'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_cmf_locked_by_id'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_cmf_locked_at'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_cmf_import_id'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_cmf_deleted'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_cmf_created_at'), table_name='cmf_security_level')
    op.drop_index(op.f('ix_cmf_security_level_cmf_author_id'), table_name='cmf_security_level')
    op.drop_table('cmf_security_level')
    # ### end Alembic commands ###
