"""users Revision ID: 3785e9a2a0c0 Revises: Create Date: 2024-11-04 19:12:43.374773 """ from alembic import op import sqlalchemy as sa import sqlmodel from fastapi_user_auth.utils.sqltypes import SecretStrType # revision identifiers, used by Alembic. revision = "3785e9a2a0c0" down_revision = None branch_labels = None depends_on = None def upgrade() -> None: # ### commands auto generated by Alembic - please adjust! ### op.create_table( "auth_casbin_rule", sa.Column("id", sa.Integer(), autoincrement=True, nullable=False), sa.Column("ptype", sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column("v0", sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column("v1", sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column("v2", sqlmodel.sql.sqltypes.AutoString(), nullable=True), sa.Column("v3", sqlmodel.sql.sqltypes.AutoString(), nullable=True), sa.Column("v4", sqlmodel.sql.sqltypes.AutoString(), nullable=True), sa.Column("v5", sqlmodel.sql.sqltypes.AutoString(), nullable=True), sa.PrimaryKeyConstraint("id"), ) op.create_table( "auth_login_history", sa.Column("create_time", sa.DateTime(), nullable=False), sa.Column("id", sa.Integer(), autoincrement=True, nullable=False), sa.Column("user_id", sa.Integer(), nullable=True), sa.Column( "login_name", sqlmodel.sql.sqltypes.AutoString(length=20), nullable=False, ), sa.Column("ip", sqlmodel.sql.sqltypes.AutoString(length=20), nullable=False), sa.Column( "ip_info", sqlmodel.sql.sqltypes.AutoString(length=255), nullable=False, ), sa.Column( "client", sqlmodel.sql.sqltypes.AutoString(length=20), nullable=False, ), sa.Column( "user_agent", sqlmodel.sql.sqltypes.AutoString(length=400), nullable=False, ), sa.Column( "login_type", sqlmodel.sql.sqltypes.AutoString(length=20), nullable=False, ), sa.Column( "login_status", sqlmodel.sql.sqltypes.AutoString(length=20), nullable=False, ), sa.Column( "forwarded_for", sqlmodel.sql.sqltypes.AutoString(length=60), nullable=False, ), sa.PrimaryKeyConstraint("id"), ) op.create_index( op.f("ix_auth_login_history_create_time"), "auth_login_history", ["create_time"], unique=False, ) op.create_table( "auth_role", sa.Column("delete_time", sa.DateTime(), nullable=True), sa.Column( "update_time", sa.DateTime(), server_default=sa.text("now()"), nullable=True, ), sa.Column("create_time", sa.DateTime(), nullable=False), sa.Column("id", sa.Integer(), autoincrement=True, nullable=False), sa.Column("key", sqlmodel.sql.sqltypes.AutoString(length=40), nullable=False), sa.Column("name", sqlmodel.sql.sqltypes.AutoString(length=40), nullable=False), sa.Column( "desc", sqlmodel.sql.sqltypes.AutoString(length=400), nullable=False, ), sa.PrimaryKeyConstraint("id"), ) op.create_index( op.f("ix_auth_role_create_time"), "auth_role", ["create_time"], unique=False, ) op.create_index(op.f("ix_auth_role_key"), "auth_role", ["key"], unique=True) op.create_index( op.f("ix_auth_role_update_time"), "auth_role", ["update_time"], unique=False, ) op.create_table( "auth_token", sa.Column("create_time", sa.DateTime(), nullable=False), sa.Column("id", sa.Integer(), autoincrement=True, nullable=False), sa.Column("token", sa.String(length=48), nullable=False), sa.Column("data", sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.PrimaryKeyConstraint("id"), ) op.create_index( op.f("ix_auth_token_create_time"), "auth_token", ["create_time"], unique=False, ) op.create_index(op.f("ix_auth_token_token"), "auth_token", ["token"], unique=True) op.create_table( "auth_user", sa.Column("email", sqlmodel.sql.sqltypes.AutoString(), nullable=True), sa.Column( "password", SecretStrType(), nullable=False, ), sa.Column( "username", sqlmodel.sql.sqltypes.AutoString(length=32), nullable=False, ), sa.Column("delete_time", sa.DateTime(), nullable=True), sa.Column( "update_time", sa.DateTime(), server_default=sa.text("now()"), nullable=True, ), sa.Column("create_time", sa.DateTime(), nullable=False), sa.Column("id", sa.Integer(), autoincrement=True, nullable=False), sa.Column("is_active", sa.Boolean(), nullable=False), sa.Column( "nickname", sqlmodel.sql.sqltypes.AutoString(length=40), nullable=True, ), sa.Column( "avatar", sqlmodel.sql.sqltypes.AutoString(length=255), nullable=True, ), sa.Column("phone", sqlmodel.sql.sqltypes.AutoString(length=15), nullable=True), sa.Column( "student_id", sqlmodel.sql.sqltypes.AutoString(length=15), nullable=True, ), sa.PrimaryKeyConstraint("id"), ) op.create_index( op.f("ix_auth_user_create_time"), "auth_user", ["create_time"], unique=False, ) op.create_index(op.f("ix_auth_user_email"), "auth_user", ["email"], unique=False) op.create_index( op.f("ix_auth_user_update_time"), "auth_user", ["update_time"], unique=False, ) op.create_index( op.f("ix_auth_user_username"), "auth_user", ["username"], unique=True ) # ### end Alembic commands ### def downgrade() -> None: # ### commands auto generated by Alembic - please adjust! ### op.drop_index(op.f("ix_auth_user_username"), table_name="auth_user") op.drop_index(op.f("ix_auth_user_update_time"), table_name="auth_user") op.drop_index(op.f("ix_auth_user_email"), table_name="auth_user") op.drop_index(op.f("ix_auth_user_create_time"), table_name="auth_user") op.drop_table("auth_user") op.drop_index(op.f("ix_auth_token_token"), table_name="auth_token") op.drop_index(op.f("ix_auth_token_create_time"), table_name="auth_token") op.drop_table("auth_token") op.drop_index(op.f("ix_auth_role_update_time"), table_name="auth_role") op.drop_index(op.f("ix_auth_role_key"), table_name="auth_role") op.drop_index(op.f("ix_auth_role_create_time"), table_name="auth_role") op.drop_table("auth_role") op.drop_index( op.f("ix_auth_login_history_create_time"), table_name="auth_login_history", ) op.drop_table("auth_login_history") op.drop_table("auth_casbin_rule") # ### end Alembic commands ###