memory/db/migrations/versions/20250603_164859_add_user.py
2025-06-03 18:48:45 +02:00

50 lines
1.3 KiB
Python

"""Add user
Revision ID: 77cdbfc882e2
Revises: 152f8b4b52e8
Create Date: 2025-06-03 16:48:59.509683
"""
from typing import Sequence, Union
from alembic import op
import sqlalchemy as sa
revision: str = "77cdbfc882e2"
down_revision: Union[str, None] = "152f8b4b52e8"
branch_labels: Union[str, Sequence[str], None] = None
depends_on: Union[str, Sequence[str], None] = None
def upgrade() -> None:
op.create_table(
"users",
sa.Column("id", sa.Integer(), nullable=False),
sa.Column("name", sa.String(), nullable=False),
sa.Column("email", sa.String(), nullable=False),
sa.Column("password_hash", sa.String(), nullable=False),
sa.PrimaryKeyConstraint("id"),
sa.UniqueConstraint("email"),
)
op.create_table(
"user_sessions",
sa.Column("id", sa.String(), nullable=False),
sa.Column("user_id", sa.Integer(), nullable=False),
sa.Column(
"created_at", sa.DateTime(), server_default=sa.text("now()"), nullable=True
),
sa.Column("expires_at", sa.DateTime(), nullable=False),
sa.ForeignKeyConstraint(
["user_id"],
["users.id"],
),
sa.PrimaryKeyConstraint("id"),
)
def downgrade() -> None:
op.drop_table("user_sessions")
op.drop_table("users")