"""Add Project Perms

Revision ID: 8297c5d22031
Revises: 45675fa62aa2
Create Date: 2023-01-10 16:04:27.398011

"""
from alembic import op
import sqlalchemy as sa


# revision identifiers, used by Alembic.
revision = '8297c5d22031'
down_revision = '45675fa62aa2'
branch_labels = None
depends_on = None


def upgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.create_table('cmf_project_perm_permission',
    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.String(length=256), 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('category', sa.String(length=32), 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=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('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_project_perm_permission_cmf_author_id'), 'cmf_project_perm_permission', ['cmf_author_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_cmf_created_at'), 'cmf_project_perm_permission', ['cmf_created_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_cmf_deleted'), 'cmf_project_perm_permission', ['cmf_deleted'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_cmf_import_id'), 'cmf_project_perm_permission', ['cmf_import_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_cmf_locked_at'), 'cmf_project_perm_permission', ['cmf_locked_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_cmf_locked_by_id'), 'cmf_project_perm_permission', ['cmf_locked_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_cmf_modified_at'), 'cmf_project_perm_permission', ['cmf_modified_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_cmf_modified_by_id'), 'cmf_project_perm_permission', ['cmf_modified_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_cmf_owner_id'), 'cmf_project_perm_permission', ['cmf_owner_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_cmf_version'), 'cmf_project_perm_permission', ['cmf_version'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_cmf_viewed_at'), 'cmf_project_perm_permission', ['cmf_viewed_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_code'), 'cmf_project_perm_permission', ['code'], unique=True)
    op.create_index(op.f('ix_cmf_project_perm_permission_name'), 'cmf_project_perm_permission', ['name'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_orderno'), 'cmf_project_perm_permission', ['orderno'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_parent_id'), 'cmf_project_perm_permission', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_perm_acl_id'), 'cmf_project_perm_permission', ['perm_acl_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_perm_parent_id'), 'cmf_project_perm_permission', ['perm_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_text'), 'cmf_project_perm_permission', ['text'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_permission_tree_parent_id'), 'cmf_project_perm_permission', ['tree_parent_id'], unique=False)
    op.create_table('cmf_project_perm_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=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('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('shared', 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=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('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_project_perm_scheme_cmf_author_id'), 'cmf_project_perm_scheme', ['cmf_author_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_cmf_created_at'), 'cmf_project_perm_scheme', ['cmf_created_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_cmf_deleted'), 'cmf_project_perm_scheme', ['cmf_deleted'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_cmf_import_id'), 'cmf_project_perm_scheme', ['cmf_import_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_cmf_locked_at'), 'cmf_project_perm_scheme', ['cmf_locked_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_cmf_locked_by_id'), 'cmf_project_perm_scheme', ['cmf_locked_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_cmf_modified_at'), 'cmf_project_perm_scheme', ['cmf_modified_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_cmf_modified_by_id'), 'cmf_project_perm_scheme', ['cmf_modified_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_cmf_owner_id'), 'cmf_project_perm_scheme', ['cmf_owner_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_cmf_version'), 'cmf_project_perm_scheme', ['cmf_version'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_cmf_viewed_at'), 'cmf_project_perm_scheme', ['cmf_viewed_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_code'), 'cmf_project_perm_scheme', ['code'], unique=True)
    op.create_index(op.f('ix_cmf_project_perm_scheme_name'), 'cmf_project_perm_scheme', ['name'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_orderno'), 'cmf_project_perm_scheme', ['orderno'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_parent_id'), 'cmf_project_perm_scheme', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_perm_acl_id'), 'cmf_project_perm_scheme', ['perm_acl_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_perm_parent_id'), 'cmf_project_perm_scheme', ['perm_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_tree_parent_id'), 'cmf_project_perm_scheme', ['tree_parent_id'], unique=False)
    op.create_table('cmf_project_perm_scheme_rule',
    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('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('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('perm_acl_id', sa.String(length=64), nullable=True),
    sa.Column('perm_parent_id', sa.String(length=64), nullable=True),
    sa.Column('project_permission_id', sa.String(length=64), nullable=False),
    sa.ForeignKeyConstraint(['cmf_import_id'], ['cmf_import.id'], ),
    sa.ForeignKeyConstraint(['parent_id'], ['cmf_project_perm_scheme.id'], ),
    sa.ForeignKeyConstraint(['perm_acl_id'], ['cmf_access_list.id'], ),
    sa.ForeignKeyConstraint(['project_permission_id'], ['cmf_project_perm_permission.id'], ),
    sa.PrimaryKeyConstraint('id')
    )
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_author_id'), 'cmf_project_perm_scheme_rule', ['cmf_author_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_created_at'), 'cmf_project_perm_scheme_rule', ['cmf_created_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_deleted'), 'cmf_project_perm_scheme_rule', ['cmf_deleted'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_import_id'), 'cmf_project_perm_scheme_rule', ['cmf_import_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_locked_at'), 'cmf_project_perm_scheme_rule', ['cmf_locked_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_locked_by_id'), 'cmf_project_perm_scheme_rule', ['cmf_locked_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_modified_at'), 'cmf_project_perm_scheme_rule', ['cmf_modified_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_modified_by_id'), 'cmf_project_perm_scheme_rule', ['cmf_modified_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_owner_id'), 'cmf_project_perm_scheme_rule', ['cmf_owner_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_version'), 'cmf_project_perm_scheme_rule', ['cmf_version'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_viewed_at'), 'cmf_project_perm_scheme_rule', ['cmf_viewed_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_code'), 'cmf_project_perm_scheme_rule', ['code'], unique=True)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_name'), 'cmf_project_perm_scheme_rule', ['name'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_orderno'), 'cmf_project_perm_scheme_rule', ['orderno'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_parent_id'), 'cmf_project_perm_scheme_rule', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_perm_acl_id'), 'cmf_project_perm_scheme_rule', ['perm_acl_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_perm_parent_id'), 'cmf_project_perm_scheme_rule', ['perm_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_project_permission_id'), 'cmf_project_perm_scheme_rule', ['project_permission_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_tree_parent_id'), 'cmf_project_perm_scheme_rule', ['tree_parent_id'], unique=False)
    op.create_table('cmf_project_perm_scheme_rule_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_project_perm_scheme_rule_access_members_left_id'), 'cmf_project_perm_scheme_rule_access_members', ['left_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_access_members_parent_id'), 'cmf_project_perm_scheme_rule_access_members', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_access_members_right_id'), 'cmf_project_perm_scheme_rule_access_members', ['right_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_access_members_root_id'), 'cmf_project_perm_scheme_rule_access_members', ['root_id'], unique=False)
    op.create_table('cmf_project_role',
    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.String(length=256), 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('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_table('cmf_project_perm_scheme_rule_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_project_perm_scheme_rule.id'], ),
    sa.ForeignKeyConstraint(['right_id'], ['cmf_project_role.id'], ),
    sa.PrimaryKeyConstraint('id')
    )
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_project_role_left_id'), 'cmf_project_perm_scheme_rule_cmf_project_role', ['left_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_project_role_parent_id'), 'cmf_project_perm_scheme_rule_cmf_project_role', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_project_role_right_id'), 'cmf_project_perm_scheme_rule_cmf_project_role', ['right_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_project_role_root_id'), 'cmf_project_perm_scheme_rule_cmf_project_role', ['root_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_cmf_author_id'), 'cmf_project_role', ['cmf_author_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_cmf_created_at'), 'cmf_project_role', ['cmf_created_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_cmf_deleted'), 'cmf_project_role', ['cmf_deleted'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_cmf_import_id'), 'cmf_project_role', ['cmf_import_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_cmf_locked_at'), 'cmf_project_role', ['cmf_locked_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_cmf_locked_by_id'), 'cmf_project_role', ['cmf_locked_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_cmf_modified_at'), 'cmf_project_role', ['cmf_modified_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_cmf_modified_by_id'), 'cmf_project_role', ['cmf_modified_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_cmf_owner_id'), 'cmf_project_role', ['cmf_owner_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_cmf_version'), 'cmf_project_role', ['cmf_version'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_cmf_viewed_at'), 'cmf_project_role', ['cmf_viewed_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_code'), 'cmf_project_role', ['code'], unique=True)
    op.create_index(op.f('ix_cmf_project_role_name'), 'cmf_project_role', ['name'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_orderno'), 'cmf_project_role', ['orderno'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_parent_id'), 'cmf_project_role', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_perm_acl_id'), 'cmf_project_role', ['perm_acl_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_perm_parent_id'), 'cmf_project_role', ['perm_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_text'), 'cmf_project_role', ['text'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_tree_parent_id'), 'cmf_project_role', ['tree_parent_id'], unique=False)
    op.create_table('cmf_project_role_assign',
    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('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('perm_acl_id', sa.String(length=64), nullable=True),
    sa.Column('perm_parent_id', sa.String(length=64), nullable=True),
    sa.Column('project_role_id', sa.String(length=64), nullable=True),
    sa.ForeignKeyConstraint(['cmf_import_id'], ['cmf_import.id'], ),
    sa.ForeignKeyConstraint(['parent_id'], ['cmf_project.id'], ),
    sa.ForeignKeyConstraint(['perm_acl_id'], ['cmf_access_list.id'], ),
    sa.ForeignKeyConstraint(['project_role_id'], ['cmf_project_role.id'], ),
    sa.PrimaryKeyConstraint('id')
    )
    op.create_index(op.f('ix_cmf_project_role_assign_cmf_author_id'), 'cmf_project_role_assign', ['cmf_author_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_cmf_created_at'), 'cmf_project_role_assign', ['cmf_created_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_cmf_deleted'), 'cmf_project_role_assign', ['cmf_deleted'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_cmf_import_id'), 'cmf_project_role_assign', ['cmf_import_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_cmf_locked_at'), 'cmf_project_role_assign', ['cmf_locked_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_cmf_locked_by_id'), 'cmf_project_role_assign', ['cmf_locked_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_cmf_modified_at'), 'cmf_project_role_assign', ['cmf_modified_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_cmf_modified_by_id'), 'cmf_project_role_assign', ['cmf_modified_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_cmf_owner_id'), 'cmf_project_role_assign', ['cmf_owner_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_cmf_version'), 'cmf_project_role_assign', ['cmf_version'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_cmf_viewed_at'), 'cmf_project_role_assign', ['cmf_viewed_at'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_code'), 'cmf_project_role_assign', ['code'], unique=True)
    op.create_index(op.f('ix_cmf_project_role_assign_name'), 'cmf_project_role_assign', ['name'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_orderno'), 'cmf_project_role_assign', ['orderno'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_parent_id'), 'cmf_project_role_assign', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_perm_acl_id'), 'cmf_project_role_assign', ['perm_acl_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_perm_parent_id'), 'cmf_project_role_assign', ['perm_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_project_role_id'), 'cmf_project_role_assign', ['project_role_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_tree_parent_id'), 'cmf_project_role_assign', ['tree_parent_id'], unique=False)
    op.create_table('cmf_project_role_assign_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_project_role_assign_members_left_id'), 'cmf_project_role_assign_members', ['left_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_members_parent_id'), 'cmf_project_role_assign_members', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_members_right_id'), 'cmf_project_role_assign_members', ['right_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_assign_members_root_id'), 'cmf_project_role_assign_members', ['root_id'], unique=False)
    op.create_table('cmf_project_role_default_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_project_role_default_members_left_id'), 'cmf_project_role_default_members', ['left_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_default_members_parent_id'), 'cmf_project_role_default_members', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_default_members_right_id'), 'cmf_project_role_default_members', ['right_id'], unique=False)
    op.create_index(op.f('ix_cmf_project_role_default_members_root_id'), 'cmf_project_role_default_members', ['root_id'], unique=False)
    op.add_column('cmf_project', sa.Column('project_perm_scheme_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_project_project_perm_scheme_id'), 'cmf_project', ['project_perm_scheme_id'], unique=False)
    op.create_foreign_key(None, 'cmf_project', 'cmf_project_perm_scheme', ['project_perm_scheme_id'], ['id'])
    # ### end Alembic commands ###


def downgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.drop_constraint(None, 'cmf_project', type_='foreignkey')
    op.drop_index(op.f('ix_cmf_project_project_perm_scheme_id'), table_name='cmf_project')
    op.drop_column('cmf_project', 'project_perm_scheme_id')
    op.drop_index(op.f('ix_cmf_project_role_default_members_root_id'), table_name='cmf_project_role_default_members')
    op.drop_index(op.f('ix_cmf_project_role_default_members_right_id'), table_name='cmf_project_role_default_members')
    op.drop_index(op.f('ix_cmf_project_role_default_members_parent_id'), table_name='cmf_project_role_default_members')
    op.drop_index(op.f('ix_cmf_project_role_default_members_left_id'), table_name='cmf_project_role_default_members')
    op.drop_table('cmf_project_role_default_members')
    op.drop_index(op.f('ix_cmf_project_role_assign_members_root_id'), table_name='cmf_project_role_assign_members')
    op.drop_index(op.f('ix_cmf_project_role_assign_members_right_id'), table_name='cmf_project_role_assign_members')
    op.drop_index(op.f('ix_cmf_project_role_assign_members_parent_id'), table_name='cmf_project_role_assign_members')
    op.drop_index(op.f('ix_cmf_project_role_assign_members_left_id'), table_name='cmf_project_role_assign_members')
    op.drop_table('cmf_project_role_assign_members')
    op.drop_index(op.f('ix_cmf_project_role_assign_tree_parent_id'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_project_role_id'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_perm_parent_id'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_perm_acl_id'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_parent_id'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_orderno'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_name'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_code'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_cmf_viewed_at'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_cmf_version'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_cmf_owner_id'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_cmf_modified_by_id'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_cmf_modified_at'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_cmf_locked_by_id'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_cmf_locked_at'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_cmf_import_id'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_cmf_deleted'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_cmf_created_at'), table_name='cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_assign_cmf_author_id'), table_name='cmf_project_role_assign')
    op.drop_table('cmf_project_role_assign')
    op.drop_index(op.f('ix_cmf_project_role_tree_parent_id'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_text'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_perm_parent_id'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_perm_acl_id'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_parent_id'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_orderno'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_name'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_code'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_cmf_viewed_at'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_cmf_version'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_cmf_owner_id'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_cmf_modified_by_id'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_cmf_modified_at'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_cmf_locked_by_id'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_cmf_locked_at'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_cmf_import_id'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_cmf_deleted'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_cmf_created_at'), table_name='cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_role_cmf_author_id'), table_name='cmf_project_role')
    op.drop_table('cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_project_role_root_id'), table_name='cmf_project_perm_scheme_rule_cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_project_role_right_id'), table_name='cmf_project_perm_scheme_rule_cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_project_role_parent_id'), table_name='cmf_project_perm_scheme_rule_cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_project_role_left_id'), table_name='cmf_project_perm_scheme_rule_cmf_project_role')
    op.drop_table('cmf_project_perm_scheme_rule_cmf_project_role')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_access_members_root_id'), table_name='cmf_project_perm_scheme_rule_access_members')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_access_members_right_id'), table_name='cmf_project_perm_scheme_rule_access_members')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_access_members_parent_id'), table_name='cmf_project_perm_scheme_rule_access_members')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_access_members_left_id'), table_name='cmf_project_perm_scheme_rule_access_members')
    op.drop_table('cmf_project_perm_scheme_rule_access_members')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_tree_parent_id'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_project_permission_id'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_perm_parent_id'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_perm_acl_id'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_parent_id'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_orderno'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_name'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_code'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_viewed_at'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_version'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_owner_id'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_modified_by_id'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_modified_at'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_locked_by_id'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_locked_at'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_import_id'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_deleted'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_created_at'), table_name='cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_rule_cmf_author_id'), table_name='cmf_project_perm_scheme_rule')
    op.drop_table('cmf_project_perm_scheme_rule')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_tree_parent_id'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_perm_parent_id'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_perm_acl_id'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_parent_id'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_orderno'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_name'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_code'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_cmf_viewed_at'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_cmf_version'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_cmf_owner_id'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_cmf_modified_by_id'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_cmf_modified_at'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_cmf_locked_by_id'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_cmf_locked_at'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_cmf_import_id'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_cmf_deleted'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_cmf_created_at'), table_name='cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_scheme_cmf_author_id'), table_name='cmf_project_perm_scheme')
    op.drop_table('cmf_project_perm_scheme')
    op.drop_index(op.f('ix_cmf_project_perm_permission_tree_parent_id'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_text'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_perm_parent_id'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_perm_acl_id'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_parent_id'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_orderno'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_name'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_code'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_cmf_viewed_at'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_cmf_version'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_cmf_owner_id'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_cmf_modified_by_id'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_cmf_modified_at'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_cmf_locked_by_id'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_cmf_locked_at'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_cmf_import_id'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_cmf_deleted'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_cmf_created_at'), table_name='cmf_project_perm_permission')
    op.drop_index(op.f('ix_cmf_project_perm_permission_cmf_author_id'), table_name='cmf_project_perm_permission')
    op.drop_table('cmf_project_perm_permission')
    # ### end Alembic commands ###
