diff --git a/alembic/versions/0df481ee920b_add_publicstream_model.py b/alembic/legacy_versions/0df481ee920b_add_publicstream_model.py similarity index 100% rename from alembic/versions/0df481ee920b_add_publicstream_model.py rename to alembic/legacy_versions/0df481ee920b_add_publicstream_model.py diff --git a/alembic/versions/1ab2db0e4b5e_make_username_unique.py b/alembic/legacy_versions/1ab2db0e4b5e_make_username_unique.py similarity index 100% rename from alembic/versions/1ab2db0e4b5e_make_username_unique.py rename to alembic/legacy_versions/1ab2db0e4b5e_make_username_unique.py diff --git a/alembic/versions/8be4811023d8_add_display_name_to_user.py b/alembic/legacy_versions/8be4811023d8_add_display_name_to_user.py similarity index 100% rename from alembic/versions/8be4811023d8_add_display_name_to_user.py rename to alembic/legacy_versions/8be4811023d8_add_display_name_to_user.py diff --git a/alembic/versions/f86c93c7a872_add_processed_filename_to_uploadlog.py b/alembic/legacy_versions/f86c93c7a872_add_processed_filename_to_uploadlog.py similarity index 100% rename from alembic/versions/f86c93c7a872_add_processed_filename_to_uploadlog.py rename to alembic/legacy_versions/f86c93c7a872_add_processed_filename_to_uploadlog.py diff --git a/alembic/versions/5f0b37b50730_initial_base_schema.py b/alembic/versions/5f0b37b50730_initial_base_schema.py new file mode 100644 index 0000000..26ff90c --- /dev/null +++ b/alembic/versions/5f0b37b50730_initial_base_schema.py @@ -0,0 +1,85 @@ +"""initial base schema + +Revision ID: 5f0b37b50730 +Revises: +Create Date: 2025-08-08 08:42:06.859256 + +""" +from typing import Sequence, Union + +from alembic import op +import sqlalchemy as sa + + +# revision identifiers, used by Alembic. +revision: str = '5f0b37b50730' +down_revision: Union[str, Sequence[str], None] = None +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('publicstream', + sa.Column('uid', sqlmodel.sql.sqltypes.AutoString(), nullable=False), + sa.Column('username', sqlmodel.sql.sqltypes.AutoString(), nullable=True), + sa.Column('storage_bytes', sa.Integer(), nullable=False), + sa.Column('mtime', sa.Integer(), nullable=False), + sa.Column('last_updated', sa.DateTime(), nullable=True), + sa.Column('created_at', sa.DateTime(), nullable=False), + sa.Column('updated_at', sa.DateTime(), nullable=False), + sa.PrimaryKeyConstraint('uid') + ) + op.create_index(op.f('ix_publicstream_username'), 'publicstream', ['username'], unique=False) + op.create_table('uploadlog', + sa.Column('id', sa.Integer(), nullable=False), + sa.Column('uid', sqlmodel.sql.sqltypes.AutoString(), nullable=False), + sa.Column('ip', sqlmodel.sql.sqltypes.AutoString(), nullable=False), + sa.Column('filename', sqlmodel.sql.sqltypes.AutoString(), nullable=True), + sa.Column('processed_filename', sqlmodel.sql.sqltypes.AutoString(), nullable=True), + sa.Column('size_bytes', sa.Integer(), nullable=False), + sa.Column('created_at', sa.DateTime(), nullable=False), + sa.PrimaryKeyConstraint('id') + ) + op.create_table('user', + sa.Column('token_created', sa.DateTime(), nullable=False), + sa.Column('email', sqlmodel.sql.sqltypes.AutoString(), nullable=False), + sa.Column('username', sqlmodel.sql.sqltypes.AutoString(), nullable=False), + sa.Column('token', sqlmodel.sql.sqltypes.AutoString(), nullable=False), + sa.Column('confirmed', sa.Boolean(), nullable=False), + sa.Column('ip', sqlmodel.sql.sqltypes.AutoString(), nullable=False), + sa.PrimaryKeyConstraint('email') + ) + op.create_index(op.f('ix_user_username'), 'user', ['username'], unique=True) + op.create_table('userquota', + sa.Column('uid', sqlmodel.sql.sqltypes.AutoString(), nullable=False), + sa.Column('storage_bytes', sa.Integer(), nullable=False), + sa.PrimaryKeyConstraint('uid') + ) + op.create_table('dbsession', + sa.Column('token', sqlmodel.sql.sqltypes.AutoString(), nullable=False), + sa.Column('uid', sqlmodel.sql.sqltypes.AutoString(), nullable=False), + sa.Column('ip_address', sqlmodel.sql.sqltypes.AutoString(), nullable=False), + sa.Column('user_agent', sqlmodel.sql.sqltypes.AutoString(), nullable=False), + sa.Column('created_at', sa.DateTime(), nullable=False), + sa.Column('expires_at', sa.DateTime(), nullable=False), + sa.Column('is_active', sa.Boolean(), nullable=False), + sa.Column('last_activity', sa.DateTime(), nullable=False), + sa.ForeignKeyConstraint(['uid'], ['user.email'], ), + sa.PrimaryKeyConstraint('token') + ) + # ### end Alembic commands ### + + +def downgrade() -> None: + """Downgrade schema.""" + # ### commands auto generated by Alembic - please adjust! ### + op.drop_table('dbsession') + op.drop_table('userquota') + op.drop_index(op.f('ix_user_username'), table_name='user') + op.drop_table('user') + op.drop_table('uploadlog') + op.drop_index(op.f('ix_publicstream_username'), table_name='publicstream') + op.drop_table('publicstream') + # ### end Alembic commands ###