create basic user table

this will allow users to sign up and submit reports
This commit is contained in:
Jack Case
2025-10-17 20:29:14 +00:00
parent 84ba67a3f0
commit 4931a785a1
2 changed files with 51 additions and 1 deletions

View File

@@ -0,0 +1,42 @@
"""user table
Revision ID: 12eca4bad288
Revises: 72dcd047d7bf
Create Date: 2025-10-17 20:26:00.002707
"""
from typing import Sequence, Union
from alembic import op
import sqlalchemy as sa
import sqlmodel.sql.sqltypes
# revision identifiers, used by Alembic.
revision: str = '12eca4bad288'
down_revision: Union[str, Sequence[str], None] = '72dcd047d7bf'
branch_labels: Union[str, Sequence[str], None] = None
depends_on: Union[str, Sequence[str], None] = None
def upgrade() -> None:
"""Upgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.create_table('user',
sa.Column('id', sa.Integer(), nullable=False),
sa.Column('email', sqlmodel.sql.sqltypes.AutoString(), nullable=False),
sa.Column('password_hash', sqlmodel.sql.sqltypes.AutoString(), nullable=False),
sa.Column('salt', sqlmodel.sql.sqltypes.AutoString(), nullable=False),
sa.Column('email_verified', sa.Boolean(), nullable=False),
sa.PrimaryKeyConstraint('id', name=op.f('pk_user'))
)
op.create_index(op.f('ix_user_email'), 'user', ['email'], unique=True)
# ### end Alembic commands ###
def downgrade() -> None:
"""Downgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.drop_index(op.f('ix_user_email'), table_name='user')
op.drop_table('user')
# ### end Alembic commands ###

View File

@@ -23,3 +23,11 @@ class Path(SQLModel, table=True):
domain_id: int = Field(foreign_key="domain.id") domain_id: int = Field(foreign_key="domain.id")
domain: Domain = Relationship(back_populates="paths") domain: Domain = Relationship(back_populates="paths")
class User(SQLModel, table=True):
id: int | None = Field(default=None, primary_key=True)
email: str = Field(index=True, unique=True)
password_hash: str
salt: str
email_verified: bool = Field(default=False)