"""Add firmware_update table Revision ID: 00edfb13e611 Revises: c7f72154c90b Create Date: 2025-03-23 14:01:14.029527+00:00 """ from typing import Sequence, Union from alembic import op import sqlalchemy as sa # revision identifiers, used by Alembic. revision: str = '00edfb13e611' down_revision: Union[str, None] = 'c7f72154c90b' branch_labels: Union[str, Sequence[str], None] = None depends_on: Union[str, Sequence[str], None] = None def upgrade() -> None: # ### commands auto generated by Alembic - please adjust! ### op.create_table('firmware_updates', sa.Column('id', sa.Uuid(), nullable=False), sa.Column('request_id', sa.Integer(), nullable=True), sa.Column('status', sa.Enum('CREATED', 'SUBMITTED', 'DOWNLOADED', 'DOWNLOAD_FAILED', 'DOWNLOADING', 'DOWNLOAD_SCHEDULED', 'DOWNLOAD_PAUSED', 'IDLE', 'INSTALLATION_FAILED', 'INSTALLING', 'INSTALLED', 'INSTALL_REBOOTING', 'INSTALL_SCHEDULED', 'INSTALL_VERIFICATION_FAILED', 'INVALID_SIGNATURE', 'SIGNATURE_VERIFIED', name='firmwareupdatestatus'), nullable=True), sa.Column('retries', sa.Integer(), nullable=True), sa.Column('retry_interval', sa.Integer(), nullable=True), sa.Column('location', sa.String(), nullable=True), sa.Column('retrieve_date_time', sa.DateTime(), nullable=True), sa.Column('install_date_time', sa.DateTime(), nullable=True), sa.Column('chargepoint_id', sa.Uuid(), nullable=True), sa.ForeignKeyConstraint(['chargepoint_id'], ['chargepoints.id'], ), sa.PrimaryKeyConstraint('id') ) op.create_index(op.f('ix_firmware_updates_chargepoint_id'), 'firmware_updates', ['chargepoint_id'], unique=False) op.alter_column('users', 'is_active', existing_type=sa.BOOLEAN(), nullable=False) # ### end Alembic commands ### def downgrade() -> None: # ### commands auto generated by Alembic - please adjust! ### op.alter_column('users', 'is_active', existing_type=sa.BOOLEAN(), nullable=True) op.drop_index(op.f('ix_firmware_updates_chargepoint_id'), table_name='firmware_updates') op.drop_table('firmware_updates') # ### end Alembic commands ###