beerds/server/migration/versions/2026-01-12-1828-474b572b7fe...

72 lines
2.5 KiB
Python

"""a284498
Revision ID: 474b572b7fe2
Revises:
Create Date: 2026-01-12 18:28:37.783462
"""
import pathlib
from collections.abc import Sequence
import sqlalchemy as sa
from alembic import op
# revision identifiers, used by Alembic.
revision: str = "474b572b7fe2"
down_revision: str | None = None
branch_labels: str | Sequence[str] | None = None
depends_on: str | Sequence[str] | None = None
def upgrade() -> None:
# ### commands auto generated by Alembic - please adjust! ###
op.create_table(
"attachments",
sa.Column("id", sa.String(), nullable=False),
sa.Column("size", sa.BigInteger(), nullable=False),
sa.Column("storage_driver_name", sa.String(), nullable=False),
sa.Column("path", sa.String(), nullable=False),
sa.Column("media_type", sa.String(), nullable=False),
sa.Column("content_type", sa.String(), nullable=False),
sa.Column("created_at", sa.DateTime(timezone=True), nullable=False),
sa.Column("updated_at", sa.DateTime(timezone=True), nullable=False),
sa.Column("is_deleted", sa.Boolean(), nullable=False),
sa.PrimaryKeyConstraint("id"),
)
op.create_table(
"beerds",
sa.Column("id", sa.String(), nullable=False),
sa.Column("name", sa.Text(), nullable=False),
sa.Column("alias", sa.Text(), nullable=False),
sa.Column("descriptions", sa.Text(), nullable=False),
sa.Column("signs", sa.JSON(), nullable=False),
sa.PrimaryKeyConstraint("id"),
)
op.create_table(
"votes",
sa.Column("id", sa.String(), nullable=False),
sa.Column("attachemnt_id", sa.String(), nullable=False),
sa.Column("beerd_id", sa.String(), nullable=False),
sa.Column("rate", sa.BigInteger(), nullable=False),
sa.Column("created_at", sa.DateTime(timezone=True), nullable=False),
sa.ForeignKeyConstraint(["attachemnt_id"], ["attachments.id"], name="votes_attachemnt_id_fk"),
sa.ForeignKeyConstraint(["beerd_id"], ["beerds.id"], name="votes_beerd_id_fk"),
sa.PrimaryKeyConstraint("id"),
)
# ### end Alembic commands ###
with open(
pathlib.Path(__file__).resolve().parent / "dumps/beerds_insert.sql",
encoding="utf-8",
) as upgrade_file:
sql = upgrade_file.read()
op.execute(sql)
def downgrade() -> None:
# ### commands auto generated by Alembic - please adjust! ###
op.drop_table("votes")
op.drop_table("beerds")
op.drop_table("attachments")
# ### end Alembic commands ###