"""2fa

Revision ID: d964fa1b37e7
Revises: 9c5fecada0b8
Create Date: 2023-05-23 12:00:36.346654

"""
from alembic import op
import sqlalchemy as sa


# revision identifiers, used by Alembic.
revision = 'd964fa1b37e7'
down_revision = '9c5fecada0b8'
branch_labels = None
depends_on = None


def upgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.create_table('cmf_auth_two_factor',
    sa.Column('id', sa.String(length=64), nullable=False),
    sa.Column('email', sa.String(length=128), nullable=True),
    sa.Column('phone', sa.String(length=64), nullable=True),
    sa.Column('application', sa.String(length=32), nullable=True),
    sa.Column('topt_secret', sa.String(length=4096), nullable=True),
    sa.Column('two_factor_opt', sa.String(length=32), nullable=True),
    sa.PrimaryKeyConstraint('id')
    )
    op.add_column('cmf_global_settings', sa.Column('two_factor_opt', sa.String(length=32), nullable=True))
    op.add_column('cmf_person', sa.Column('two_factor_id', sa.String(length=64), nullable=True))
    op.create_index(op.f('ix_cmf_person_two_factor_id'), 'cmf_person', ['two_factor_id'], unique=False)
    op.create_foreign_key(None, 'cmf_person', 'cmf_auth_two_factor', ['two_factor_id'], ['id'])
    # ### end Alembic commands ###


def downgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.drop_constraint(None, 'cmf_person', type_='foreignkey')
    op.drop_index(op.f('ix_cmf_person_two_factor_id'), table_name='cmf_person')
    op.drop_column('cmf_person', 'two_factor_id')
    op.drop_column('cmf_global_settings', 'two_factor_opt')
    op.drop_table('cmf_auth_two_factor')
    # ### end Alembic commands ###
