"""event options

Revision ID: 860455f7b8a2
Revises: a671f07faa59
Create Date: 2023-07-21 17:37:53.179984

"""
from alembic import op
import sqlalchemy as sa
from sqlalchemy.dialects import postgresql

# revision identifiers, used by Alembic.
revision = '860455f7b8a2'
down_revision = 'a671f07faa59'
branch_labels = None
depends_on = None


def upgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.drop_index('ix_cmf_person_notify_opt_cmf_author_id', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_cmf_created_at', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_cmf_deleted', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_cmf_import_id', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_cmf_locked_at', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_cmf_locked_by_id', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_cmf_modified_at', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_cmf_modified_by_id', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_cmf_owner_id', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_cmf_version', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_cmf_viewed_at', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_code', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_name', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_orderno', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_parent_id', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_perm_acl_id', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_perm_parent_id', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_root_parent_id', table_name='cmf_person_notify_opt')
    op.drop_index('ix_cmf_person_notify_opt_tree_parent_id', table_name='cmf_person_notify_opt')
    op.add_column('cmf_person', sa.Column('email_if_spectator', sa.Boolean(), nullable=False, server_default="true"))
    op.add_column('cmf_person', sa.Column('email_if_author', sa.Boolean(), nullable=False, server_default="false"))
    op.add_column('cmf_person', sa.Column('email_if_responsible', sa.Boolean(), nullable=False, server_default="true"))
    op.add_column('cmf_person', sa.Column('email_if_mentions', sa.Boolean(), nullable=False, server_default="true"))
    op.add_column('cmf_person', sa.Column('email_if_self_changes', sa.Boolean(), nullable=False, server_default="false"))
    op.drop_index('ix_cmf_person_notify_opt_id', table_name='cmf_person')
    op.drop_constraint('cmf_person_notify_opt_id_fkey', 'cmf_person', type_='foreignkey')
    op.drop_column('cmf_person', 'notify_opt_id')
    op.drop_table('cmf_person_notify_opt')
    # ### end Alembic commands ###


def downgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.add_column('cmf_person', sa.Column('notify_opt_id', sa.VARCHAR(length=64), autoincrement=False, nullable=True))
    op.create_foreign_key('cmf_person_notify_opt_id_fkey', 'cmf_person', 'cmf_person_notify_opt', ['notify_opt_id'], ['id'])
    op.create_index('ix_cmf_person_notify_opt_id', 'cmf_person', ['notify_opt_id'], unique=False)
    op.drop_column('cmf_person', 'email_if_self_changes')
    op.drop_column('cmf_person', 'email_if_mentions')
    op.drop_column('cmf_person', 'email_if_responsible')
    op.drop_column('cmf_person', 'email_if_author')
    op.drop_column('cmf_person', 'email_if_spectator')
    op.create_table('cmf_person_notify_opt',
    sa.Column('id', sa.VARCHAR(length=64), autoincrement=False, nullable=False),
    sa.Column('cmf_locked_at', postgresql.TIMESTAMP(timezone=True), autoincrement=False, nullable=True),
    sa.Column('cmf_created_at', postgresql.TIMESTAMP(timezone=True), autoincrement=False, nullable=False),
    sa.Column('cmf_modified_at', postgresql.TIMESTAMP(timezone=True), autoincrement=False, nullable=False),
    sa.Column('cmf_viewed_at', postgresql.TIMESTAMP(timezone=True), autoincrement=False, nullable=True),
    sa.Column('cmf_deleted', sa.BOOLEAN(), autoincrement=False, nullable=False),
    sa.Column('cmf_version', sa.BIGINT(), autoincrement=False, nullable=True),
    sa.Column('name', sa.VARCHAR(length=256), autoincrement=False, nullable=True),
    sa.Column('code', sa.VARCHAR(length=64), autoincrement=False, nullable=True),
    sa.Column('system', sa.BOOLEAN(), autoincrement=False, nullable=False),
    sa.Column('text', sa.TEXT(), autoincrement=False, nullable=True),
    sa.Column('import_original', sa.BOOLEAN(), autoincrement=False, nullable=True),
    sa.Column('import_raw_json', sa.TEXT(), autoincrement=False, nullable=True),
    sa.Column('ext_id', sa.VARCHAR(), autoincrement=False, nullable=True),
    sa.Column('is_favorite', sa.BOOLEAN(), autoincrement=False, nullable=True),
    sa.Column('has_tree_nodes', sa.BOOLEAN(), autoincrement=False, nullable=True),
    sa.Column('tree_node_is_branch', sa.BOOLEAN(), autoincrement=False, nullable=True),
    sa.Column('tree_hidden', sa.BOOLEAN(), autoincrement=False, nullable=True),
    sa.Column('orderno', sa.INTEGER(), autoincrement=False, nullable=True),
    sa.Column('perm_public', sa.BOOLEAN(), autoincrement=False, nullable=True),
    sa.Column('perm_has_acl', sa.BOOLEAN(), autoincrement=False, nullable=True),
    sa.Column('perm_inherit', sa.BOOLEAN(), autoincrement=False, nullable=True),
    sa.Column('perm_parent_owner_id', sa.VARCHAR(length=64), autoincrement=False, nullable=True),
    sa.Column('perm_inherit_acl_id', sa.VARCHAR(length=64), autoincrement=False, nullable=True),
    sa.Column('perm_effective_acl_id', sa.VARCHAR(length=64), autoincrement=False, nullable=True),
    sa.Column('perm_encrypt', sa.BOOLEAN(), autoincrement=False, nullable=True),
    sa.Column('cmf_author_id', sa.VARCHAR(length=64), autoincrement=False, nullable=True),
    sa.Column('cmf_owner_id', sa.VARCHAR(length=64), autoincrement=False, nullable=True),
    sa.Column('parent_id', sa.VARCHAR(length=64), autoincrement=False, nullable=True),
    sa.Column('cmf_modified_by_id', sa.VARCHAR(length=64), autoincrement=False, nullable=True),
    sa.Column('cmf_locked_by_id', sa.VARCHAR(length=64), autoincrement=False, nullable=True),
    sa.Column('cmf_import_id', sa.VARCHAR(length=64), autoincrement=False, nullable=True),
    sa.Column('tree_parent_id', sa.VARCHAR(length=64), autoincrement=False, nullable=True),
    sa.Column('root_parent_id', sa.VARCHAR(length=64), autoincrement=False, nullable=True),
    sa.Column('perm_acl_id', sa.VARCHAR(length=64), autoincrement=False, nullable=True),
    sa.Column('perm_parent_id', sa.VARCHAR(length=64), autoincrement=False, nullable=True),
    sa.Column('perm_security_level_allowed_ids_cache', sa.TEXT(), autoincrement=False, nullable=True),
    sa.Column('email_if_spectator', sa.BOOLEAN(), server_default=sa.text('true'), autoincrement=False, nullable=False),
    sa.Column('email_if_author', sa.BOOLEAN(), server_default=sa.text('true'), autoincrement=False, nullable=False),
    sa.Column('email_if_responsible', sa.BOOLEAN(), server_default=sa.text('true'), autoincrement=False, nullable=False),
    sa.Column('email_if_mentions', sa.BOOLEAN(), server_default=sa.text('true'), autoincrement=False, nullable=False),
    sa.Column('email_if_self_changes', sa.BOOLEAN(), server_default=sa.text('false'), autoincrement=False, nullable=False),
    sa.ForeignKeyConstraint(['cmf_import_id'], ['cmf_import.id'], name='cmf_person_notify_opt_cmf_import_id_fkey'),
    sa.ForeignKeyConstraint(['perm_acl_id'], ['cmf_access_list.id'], name='cmf_person_notify_opt_perm_acl_id_fkey'),
    sa.PrimaryKeyConstraint('id', name='cmf_person_notify_opt_pkey')
    )
    op.create_index('ix_cmf_person_notify_opt_tree_parent_id', 'cmf_person_notify_opt', ['tree_parent_id'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_root_parent_id', 'cmf_person_notify_opt', ['root_parent_id'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_perm_parent_id', 'cmf_person_notify_opt', ['perm_parent_id'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_perm_acl_id', 'cmf_person_notify_opt', ['perm_acl_id'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_parent_id', 'cmf_person_notify_opt', ['parent_id'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_orderno', 'cmf_person_notify_opt', ['orderno'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_name', 'cmf_person_notify_opt', ['name'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_code', 'cmf_person_notify_opt', ['code'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_cmf_viewed_at', 'cmf_person_notify_opt', ['cmf_viewed_at'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_cmf_version', 'cmf_person_notify_opt', ['cmf_version'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_cmf_owner_id', 'cmf_person_notify_opt', ['cmf_owner_id'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_cmf_modified_by_id', 'cmf_person_notify_opt', ['cmf_modified_by_id'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_cmf_modified_at', 'cmf_person_notify_opt', ['cmf_modified_at'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_cmf_locked_by_id', 'cmf_person_notify_opt', ['cmf_locked_by_id'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_cmf_locked_at', 'cmf_person_notify_opt', ['cmf_locked_at'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_cmf_import_id', 'cmf_person_notify_opt', ['cmf_import_id'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_cmf_deleted', 'cmf_person_notify_opt', ['cmf_deleted'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_cmf_created_at', 'cmf_person_notify_opt', ['cmf_created_at'], unique=False)
    op.create_index('ix_cmf_person_notify_opt_cmf_author_id', 'cmf_person_notify_opt', ['cmf_author_id'], unique=False)
    # ### end Alembic commands ###
