Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
36 changes: 36 additions & 0 deletions backend/alembic/versions/0080_devices_client_device_identifier.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
"""Add client_device_identifier to devices

Revision ID: 0080_devices_client_identifier
Revises: 0079_add_rom_files_rom_id_index
Create Date: 2026-04-24 00:00:00.000000

"""

import sqlalchemy as sa
from alembic import op

# revision identifiers, used by Alembic.
revision = "0080_devices_client_identifier"
down_revision = "0079_add_rom_files_rom_id_index"
branch_labels = None
depends_on = None


def upgrade() -> None:
with op.batch_alter_table("devices", schema=None) as batch_op:
batch_op.add_column(
sa.Column("client_device_identifier", sa.String(length=255), nullable=True),
if_not_exists=True,
)
batch_op.create_index(
"ix_devices_user_client_identifier",
["user_id", "client_device_identifier"],
unique=True,
if_not_exists=True,
)


def downgrade() -> None:
with op.batch_alter_table("devices", schema=None) as batch_op:
batch_op.drop_index("ix_devices_user_client_identifier", if_exists=True)
batch_op.drop_column("client_device_identifier", if_exists=True)
45 changes: 45 additions & 0 deletions backend/alembic/versions/0081_client_tokens_device_id.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
"""Add device_id FK to client_tokens

Revision ID: 0081_client_tokens_device_id
Revises: 0080_devices_client_identifier
Create Date: 2026-04-24 00:00:00.000000

"""

import sqlalchemy as sa
from alembic import op

# revision identifiers, used by Alembic.
revision = "0081_client_tokens_device_id"
down_revision = "0080_devices_client_identifier"
branch_labels = None
depends_on = None


def upgrade() -> None:
with op.batch_alter_table("client_tokens", schema=None) as batch_op:
batch_op.add_column(
sa.Column("device_id", sa.String(length=255), nullable=True),
if_not_exists=True,
)
batch_op.create_foreign_key(
"fk_client_tokens_device_id",
"devices",
["device_id"],
["id"],
ondelete="SET NULL",
)
batch_op.create_index(
"ix_client_tokens_device_id",
["device_id"],
unique=False,
if_not_exists=True,
)


def downgrade() -> None:
with op.batch_alter_table("client_tokens", schema=None) as batch_op:
# Drop FK before the backing index -- MariaDB refuses otherwise
batch_op.drop_constraint("fk_client_tokens_device_id", type_="foreignkey")
batch_op.drop_index("ix_client_tokens_device_id", if_exists=True)
batch_op.drop_column("device_id", if_exists=True)
Loading
Loading