"""workflow refactor

Revision ID: 099814b5aa85
Revises: 79093442c618
Create Date: 2022-05-26 17:33:38.971294

"""
from alembic import op
import sqlalchemy as sa


# revision identifiers, used by Alembic.
revision = '099814b5aa85'
down_revision = '79093442c618'
branch_labels = None
depends_on = None


def upgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.create_table('cmf_workflow',
    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('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('cmf_model', sa.String(length=32), 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('cmf_owner_assistant_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.ForeignKeyConstraint(['cmf_import_id'], ['cmf_import.id'], ),
    sa.PrimaryKeyConstraint('id')
    )
    op.create_index(op.f('ix_cmf_workflow_cmf_author_id'), 'cmf_workflow', ['cmf_author_id'], unique=False)
    op.create_index(op.f('ix_cmf_workflow_cmf_created_at'), 'cmf_workflow', ['cmf_created_at'], unique=False)
    op.create_index(op.f('ix_cmf_workflow_cmf_deleted'), 'cmf_workflow', ['cmf_deleted'], unique=False)
    op.create_index(op.f('ix_cmf_workflow_cmf_import_id'), 'cmf_workflow', ['cmf_import_id'], unique=False)
    op.create_index(op.f('ix_cmf_workflow_cmf_locked_at'), 'cmf_workflow', ['cmf_locked_at'], unique=False)
    op.create_index(op.f('ix_cmf_workflow_cmf_locked_by_id'), 'cmf_workflow', ['cmf_locked_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_workflow_cmf_modified_at'), 'cmf_workflow', ['cmf_modified_at'], unique=False)
    op.create_index(op.f('ix_cmf_workflow_cmf_modified_by_id'), 'cmf_workflow', ['cmf_modified_by_id'], unique=False)
    op.create_index(op.f('ix_cmf_workflow_cmf_owner_assistant_id'), 'cmf_workflow', ['cmf_owner_assistant_id'], unique=False)
    op.create_index(op.f('ix_cmf_workflow_cmf_owner_id'), 'cmf_workflow', ['cmf_owner_id'], unique=False)
    op.create_index(op.f('ix_cmf_workflow_cmf_version'), 'cmf_workflow', ['cmf_version'], unique=False)
    op.create_index(op.f('ix_cmf_workflow_cmf_viewed_at'), 'cmf_workflow', ['cmf_viewed_at'], unique=False)
    op.create_index(op.f('ix_cmf_workflow_code'), 'cmf_workflow', ['code'], unique=True)
    op.create_index(op.f('ix_cmf_workflow_name'), 'cmf_workflow', ['name'], unique=False)
    op.create_index(op.f('ix_cmf_workflow_orderno'), 'cmf_workflow', ['orderno'], unique=False)
    op.create_index(op.f('ix_cmf_workflow_parent_id'), 'cmf_workflow', ['parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_workflow_tree_parent_id'), 'cmf_workflow', ['tree_parent_id'], unique=False)
    op.add_column('cmf_active_entity_filter', sa.Column('filter_workflow_code', sa.String(length=32), nullable=True))
    op.drop_column('cmf_active_entity_filter', 'workflow_type')
    op.drop_column('cmf_active_entity_filter', 'filter_workflow_type')
    op.add_column('cmf_activity', sa.Column('default_task_workflow_id', sa.String(length=64), nullable=True))
    op.add_column('cmf_activity', sa.Column('default_document_workflow_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_activity_default_document_workflow_id'), 'cmf_activity', ['default_document_workflow_id'], unique=False)
    op.create_index(op.f('ix_cmf_activity_default_task_workflow_id'), 'cmf_activity', ['default_task_workflow_id'], unique=False)
    op.create_foreign_key(None, 'cmf_activity', 'cmf_workflow', ['default_task_workflow_id'], ['id'])
    op.create_foreign_key(None, 'cmf_activity', 'cmf_workflow', ['default_document_workflow_id'], ['id'])
    op.drop_index('ix_cmf_chat_group_workflow_code', table_name='cmf_chat_group')
    op.create_index(op.f('ix_cmf_chat_group_cache_workflow_code'), 'cmf_chat_group', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_chat_topic_workflow_code', table_name='cmf_chat_topic')
    op.create_index(op.f('ix_cmf_chat_topic_cache_workflow_code'), 'cmf_chat_topic', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_company_workflow_code', table_name='cmf_company')
    op.create_index(op.f('ix_cmf_company_cache_workflow_code'), 'cmf_company', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_deal_workflow_code', table_name='cmf_deal')
    op.create_index(op.f('ix_cmf_deal_cache_workflow_code'), 'cmf_deal', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_document_workflow_code', table_name='cmf_document')
    op.create_index(op.f('ix_cmf_document_cache_workflow_code'), 'cmf_document', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_invoice_workflow_code', table_name='cmf_invoice')
    op.create_index(op.f('ix_cmf_invoice_cache_workflow_code'), 'cmf_invoice', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_lead_workflow_code', table_name='cmf_lead')
    op.create_index(op.f('ix_cmf_lead_cache_workflow_code'), 'cmf_lead', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_list_workflow_code', table_name='cmf_list')
    op.create_index(op.f('ix_cmf_list_cache_workflow_code'), 'cmf_list', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_mail_workflow_code', table_name='cmf_mail')
    op.create_index(op.f('ix_cmf_mail_cache_workflow_code'), 'cmf_mail', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_payment_workflow_code', table_name='cmf_payment')
    op.create_index(op.f('ix_cmf_payment_cache_workflow_code'), 'cmf_payment', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_pipeline_workflow_code', table_name='cmf_pipeline')
    op.create_index(op.f('ix_cmf_pipeline_cache_workflow_code'), 'cmf_pipeline', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_project_workflow_code', table_name='cmf_project')
    op.create_index(op.f('ix_cmf_project_cache_workflow_code'), 'cmf_project', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_purchase_order_workflow_code', table_name='cmf_purchase_order')
    op.create_index(op.f('ix_cmf_purchase_order_cache_workflow_code'), 'cmf_purchase_order', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_purchase_order_items_workflow_code', table_name='cmf_purchase_order_items')
    op.create_index(op.f('ix_cmf_purchase_order_items_cache_workflow_code'), 'cmf_purchase_order_items', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_roadmap_workflow_code', table_name='cmf_roadmap')
    op.create_index(op.f('ix_cmf_roadmap_cache_workflow_code'), 'cmf_roadmap', ['cache_workflow_code'], unique=False)
    op.add_column('cmf_status', sa.Column('workflow_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_status_workflow_id'), 'cmf_status', ['workflow_id'], unique=False)
    op.create_foreign_key(None, 'cmf_status', 'cmf_workflow', ['workflow_id'], ['id'])
    op.drop_index('ix_cmf_stock_move_workflow_code', table_name='cmf_stock_move')
    op.create_index(op.f('ix_cmf_stock_move_cache_workflow_code'), 'cmf_stock_move', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_stock_move_items_workflow_code', table_name='cmf_stock_move_items')
    op.create_index(op.f('ix_cmf_stock_move_items_cache_workflow_code'), 'cmf_stock_move_items', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_task_workflow_code', table_name='cmf_task')
    op.create_index(op.f('ix_cmf_task_cache_workflow_code'), 'cmf_task', ['cache_workflow_code'], unique=False)
    op.drop_index('ix_cmf_u_work_post_workflow_code', table_name='cmf_u_work_post')
    op.create_index(op.f('ix_cmf_u_work_post_cache_workflow_code'), 'cmf_u_work_post', ['cache_workflow_code'], unique=False)
    # ### end Alembic commands ###


def downgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.drop_index(op.f('ix_cmf_u_work_post_cache_workflow_code'), table_name='cmf_u_work_post')
    op.create_index('ix_cmf_u_work_post_workflow_code', 'cmf_u_work_post', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_task_cache_workflow_code'), table_name='cmf_task')
    op.create_index('ix_cmf_task_workflow_code', 'cmf_task', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_stock_move_items_cache_workflow_code'), table_name='cmf_stock_move_items')
    op.create_index('ix_cmf_stock_move_items_workflow_code', 'cmf_stock_move_items', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_stock_move_cache_workflow_code'), table_name='cmf_stock_move')
    op.create_index('ix_cmf_stock_move_workflow_code', 'cmf_stock_move', ['cache_workflow_code'], unique=False)
    op.drop_constraint(None, 'cmf_status', type_='foreignkey')
    op.drop_index(op.f('ix_cmf_status_workflow_id'), table_name='cmf_status')
    op.drop_column('cmf_status', 'workflow_id')
    op.drop_index(op.f('ix_cmf_roadmap_cache_workflow_code'), table_name='cmf_roadmap')
    op.create_index('ix_cmf_roadmap_workflow_code', 'cmf_roadmap', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_purchase_order_items_cache_workflow_code'), table_name='cmf_purchase_order_items')
    op.create_index('ix_cmf_purchase_order_items_workflow_code', 'cmf_purchase_order_items', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_purchase_order_cache_workflow_code'), table_name='cmf_purchase_order')
    op.create_index('ix_cmf_purchase_order_workflow_code', 'cmf_purchase_order', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_project_cache_workflow_code'), table_name='cmf_project')
    op.create_index('ix_cmf_project_workflow_code', 'cmf_project', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_pipeline_cache_workflow_code'), table_name='cmf_pipeline')
    op.create_index('ix_cmf_pipeline_workflow_code', 'cmf_pipeline', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_payment_cache_workflow_code'), table_name='cmf_payment')
    op.create_index('ix_cmf_payment_workflow_code', 'cmf_payment', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_mail_cache_workflow_code'), table_name='cmf_mail')
    op.create_index('ix_cmf_mail_workflow_code', 'cmf_mail', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_list_cache_workflow_code'), table_name='cmf_list')
    op.create_index('ix_cmf_list_workflow_code', 'cmf_list', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_lead_cache_workflow_code'), table_name='cmf_lead')
    op.create_index('ix_cmf_lead_workflow_code', 'cmf_lead', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_invoice_cache_workflow_code'), table_name='cmf_invoice')
    op.create_index('ix_cmf_invoice_workflow_code', 'cmf_invoice', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_document_cache_workflow_code'), table_name='cmf_document')
    op.create_index('ix_cmf_document_workflow_code', 'cmf_document', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_deal_cache_workflow_code'), table_name='cmf_deal')
    op.create_index('ix_cmf_deal_workflow_code', 'cmf_deal', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_company_cache_workflow_code'), table_name='cmf_company')
    op.create_index('ix_cmf_company_workflow_code', 'cmf_company', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_chat_topic_cache_workflow_code'), table_name='cmf_chat_topic')
    op.create_index('ix_cmf_chat_topic_workflow_code', 'cmf_chat_topic', ['cache_workflow_code'], unique=False)
    op.drop_index(op.f('ix_cmf_chat_group_cache_workflow_code'), table_name='cmf_chat_group')
    op.create_index('ix_cmf_chat_group_workflow_code', 'cmf_chat_group', ['cache_workflow_code'], unique=False)
    op.drop_constraint(None, 'cmf_activity', type_='foreignkey')
    op.drop_constraint(None, 'cmf_activity', type_='foreignkey')
    op.drop_index(op.f('ix_cmf_activity_default_task_workflow_id'), table_name='cmf_activity')
    op.drop_index(op.f('ix_cmf_activity_default_document_workflow_id'), table_name='cmf_activity')
    op.drop_column('cmf_activity', 'default_document_workflow_id')
    op.drop_column('cmf_activity', 'default_task_workflow_id')
    op.add_column('cmf_active_entity_filter', sa.Column('filter_workflow_type', sa.VARCHAR(length=32), autoincrement=False, nullable=True))
    op.add_column('cmf_active_entity_filter', sa.Column('workflow_type', sa.VARCHAR(length=32), autoincrement=False, nullable=True))
    op.drop_column('cmf_active_entity_filter', 'filter_workflow_code')
    op.drop_index(op.f('ix_cmf_workflow_tree_parent_id'), table_name='cmf_workflow')
    op.drop_index(op.f('ix_cmf_workflow_parent_id'), table_name='cmf_workflow')
    op.drop_index(op.f('ix_cmf_workflow_orderno'), table_name='cmf_workflow')
    op.drop_index(op.f('ix_cmf_workflow_name'), table_name='cmf_workflow')
    op.drop_index(op.f('ix_cmf_workflow_code'), table_name='cmf_workflow')
    op.drop_index(op.f('ix_cmf_workflow_cmf_viewed_at'), table_name='cmf_workflow')
    op.drop_index(op.f('ix_cmf_workflow_cmf_version'), table_name='cmf_workflow')
    op.drop_index(op.f('ix_cmf_workflow_cmf_owner_id'), table_name='cmf_workflow')
    op.drop_index(op.f('ix_cmf_workflow_cmf_owner_assistant_id'), table_name='cmf_workflow')
    op.drop_index(op.f('ix_cmf_workflow_cmf_modified_by_id'), table_name='cmf_workflow')
    op.drop_index(op.f('ix_cmf_workflow_cmf_modified_at'), table_name='cmf_workflow')
    op.drop_index(op.f('ix_cmf_workflow_cmf_locked_by_id'), table_name='cmf_workflow')
    op.drop_index(op.f('ix_cmf_workflow_cmf_locked_at'), table_name='cmf_workflow')
    op.drop_index(op.f('ix_cmf_workflow_cmf_import_id'), table_name='cmf_workflow')
    op.drop_index(op.f('ix_cmf_workflow_cmf_deleted'), table_name='cmf_workflow')
    op.drop_index(op.f('ix_cmf_workflow_cmf_created_at'), table_name='cmf_workflow')
    op.drop_index(op.f('ix_cmf_workflow_cmf_author_id'), table_name='cmf_workflow')
    op.drop_table('cmf_workflow')
    # ### end Alembic commands ###
