"""new permisions iter 3 fix

Revision ID: e65411a2c66a
Revises: ff93e481ed54
Create Date: 2022-07-05 13:17:17.183905

"""
from alembic import op
import sqlalchemy as sa


# revision identifiers, used by Alembic.
revision = 'e65411a2c66a'
down_revision = 'ff93e481ed54'
branch_labels = None
depends_on = None


def upgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.drop_column('cmf_chat_group', 'perm_readonly')
    op.drop_column('cmf_chat_group', 'perm_private')
    op.drop_column('cmf_chat_topic', 'perm_readonly')
    op.drop_column('cmf_chat_topic', 'perm_private')
    op.drop_column('cmf_company', 'perm_readonly')
    op.drop_column('cmf_company', 'perm_private')
    op.drop_column('cmf_deal', 'perm_private')
    op.drop_column('cmf_deal', 'perm_readonly')
    op.drop_column('cmf_document', 'perm_readonly')
    op.drop_column('cmf_document', 'perm_private')
    op.drop_column('cmf_import', 'perm_readonly')
    op.drop_column('cmf_import', 'perm_private')
    op.drop_column('cmf_invoice', 'perm_readonly')
    op.drop_column('cmf_invoice', 'perm_private')
    op.drop_column('cmf_lead', 'perm_readonly')
    op.drop_column('cmf_lead', 'perm_private')
    op.drop_column('cmf_list', 'perm_readonly')
    op.drop_column('cmf_list', 'perm_private')
    op.drop_column('cmf_mail', 'perm_readonly')
    op.drop_column('cmf_mail', 'perm_private')
    op.drop_column('cmf_payment', 'perm_readonly')
    op.drop_column('cmf_payment', 'perm_private')
    op.drop_column('cmf_pipeline', 'perm_readonly')
    op.drop_column('cmf_pipeline', 'perm_private')
    op.drop_column('cmf_project', 'perm_readonly')
    op.drop_column('cmf_project', 'perm_private')
    op.drop_column('cmf_purchase_order', 'perm_readonly')
    op.drop_column('cmf_purchase_order', 'perm_private')
    op.drop_column('cmf_purchase_order_items', 'perm_readonly')
    op.drop_column('cmf_purchase_order_items', 'perm_private')
    op.drop_column('cmf_roadmap', 'perm_readonly')
    op.drop_column('cmf_roadmap', 'perm_private')
    op.drop_column('cmf_stock_incoming_order', 'perm_readonly')
    op.drop_column('cmf_stock_incoming_order', 'perm_private')
    op.drop_column('cmf_stock_initial', 'perm_readonly')
    op.drop_column('cmf_stock_initial', 'perm_private')
    op.drop_column('cmf_stock_inventory', 'perm_readonly')
    op.drop_column('cmf_stock_inventory', 'perm_private')
    op.drop_column('cmf_stock_move', 'perm_readonly')
    op.drop_column('cmf_stock_move', 'perm_private')
    op.drop_column('cmf_stock_outcoming_order', 'perm_readonly')
    op.drop_column('cmf_stock_outcoming_order', 'perm_private')
    op.drop_column('cmf_task', 'perm_private')
    op.drop_column('cmf_task', 'perm_readonly')
    op.drop_column('cmf_u_work_post', 'perm_readonly')
    op.drop_column('cmf_u_work_post', 'perm_private')
    # ### end Alembic commands ###


def downgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.add_column('cmf_u_work_post', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_u_work_post', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_task', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_task', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_stock_outcoming_order', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_stock_outcoming_order', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_stock_move', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_stock_move', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_stock_inventory', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_stock_inventory', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_stock_initial', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_stock_initial', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_stock_incoming_order', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_stock_incoming_order', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_roadmap', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_roadmap', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_purchase_order_items', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_purchase_order_items', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_purchase_order', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_purchase_order', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_project', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_project', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_pipeline', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_pipeline', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_payment', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_payment', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_mail', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_mail', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_list', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_list', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_lead', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_lead', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_invoice', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_invoice', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_import', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_import', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_document', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_document', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_deal', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_deal', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_company', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_company', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_chat_topic', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_chat_topic', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_chat_group', sa.Column('perm_private', sa.BOOLEAN(), autoincrement=False, nullable=True))
    op.add_column('cmf_chat_group', sa.Column('perm_readonly', sa.BOOLEAN(), autoincrement=False, nullable=True))
    # ### end Alembic commands ###
