"""initial schema - 8 tables Revision ID: 1855836abf6c Revises: Create Date: 2026-02-24 09:35:47.297957 """ from typing import Sequence, Union from alembic import op import sqlalchemy as sa import sqlmodel # revision identifiers, used by Alembic. revision: str = '1855836abf6c' 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('exercises', sa.Column('id', sa.Integer(), nullable=False), sa.Column('name', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('muscle_group', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('workout_day', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('sets', sa.Integer(), nullable=False), sa.Column('tempo', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('form_cues', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('created_at', sa.DateTime(), nullable=False), sa.PrimaryKeyConstraint('id') ) op.create_index(op.f('ix_exercises_name'), 'exercises', ['name'], unique=False) op.create_index(op.f('ix_exercises_workout_day'), 'exercises', ['workout_day'], unique=False) op.create_table('users', sa.Column('id', sa.Integer(), nullable=False), sa.Column('username', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('password_hash', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('display_name', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('height', sqlmodel.sql.sqltypes.AutoString(), nullable=True), sa.Column('weight', sqlmodel.sql.sqltypes.AutoString(), nullable=True), sa.Column('goals', sqlmodel.sql.sqltypes.AutoString(), nullable=True), sa.Column('is_admin', sa.Boolean(), nullable=False), sa.Column('created_at', sa.DateTime(), nullable=False), sa.Column('updated_at', sa.DateTime(), nullable=False), sa.PrimaryKeyConstraint('id') ) op.create_index(op.f('ix_users_username'), 'users', ['username'], unique=True) op.create_table('warmups', sa.Column('id', sa.Integer(), nullable=False), sa.Column('name', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('type', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('reps', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('form_cues', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('sort_order', sa.Integer(), nullable=False), sa.Column('created_at', sa.DateTime(), nullable=False), sa.PrimaryKeyConstraint('id') ) op.create_index(op.f('ix_warmups_name'), 'warmups', ['name'], unique=False) op.create_table('workout_days', sa.Column('id', sa.Integer(), nullable=False), sa.Column('name', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('day_number', sa.Integer(), nullable=False), sa.Column('description', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.PrimaryKeyConstraint('id'), sa.UniqueConstraint('day_number') ) op.create_index(op.f('ix_workout_days_name'), 'workout_days', ['name'], unique=True) op.create_table('progress_log', sa.Column('id', sa.Integer(), nullable=False), sa.Column('user_id', sa.Integer(), nullable=False), sa.Column('exercise_id', sa.Integer(), nullable=False), sa.Column('date', sa.Date(), nullable=False), sa.Column('suggested_reps', sa.Integer(), nullable=True), sa.Column('suggested_weight', sqlmodel.sql.sqltypes.AutoString(), nullable=True), sa.Column('actual_reps', sa.Integer(), nullable=True), sa.Column('actual_weight', sqlmodel.sql.sqltypes.AutoString(), nullable=True), sa.Column('progression_applied', sqlmodel.sql.sqltypes.AutoString(), nullable=True), sa.Column('created_at', sa.DateTime(), nullable=False), sa.ForeignKeyConstraint(['exercise_id'], ['exercises.id'], ), sa.ForeignKeyConstraint(['user_id'], ['users.id'], ), sa.PrimaryKeyConstraint('id') ) op.create_index(op.f('ix_progress_log_user_id'), 'progress_log', ['user_id'], unique=False) op.create_table('user_exercise_programs', sa.Column('id', sa.Integer(), nullable=False), sa.Column('user_id', sa.Integer(), nullable=False), sa.Column('exercise_id', sa.Integer(), nullable=False), sa.Column('wk1_reps', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('wk4_reps', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('wk1_weight', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('wk4_weight', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('created_at', sa.DateTime(), nullable=False), sa.Column('updated_at', sa.DateTime(), nullable=False), sa.ForeignKeyConstraint(['exercise_id'], ['exercises.id'], ), sa.ForeignKeyConstraint(['user_id'], ['users.id'], ), sa.PrimaryKeyConstraint('id') ) op.create_index(op.f('ix_user_exercise_programs_exercise_id'), 'user_exercise_programs', ['exercise_id'], unique=False) op.create_index(op.f('ix_user_exercise_programs_user_id'), 'user_exercise_programs', ['user_id'], unique=False) op.create_table('workout_sessions', sa.Column('id', sa.Integer(), nullable=False), sa.Column('user_id', sa.Integer(), nullable=False), sa.Column('workout_day_id', sa.Integer(), nullable=False), sa.Column('date', sa.Date(), nullable=False), sa.Column('notes', sqlmodel.sql.sqltypes.AutoString(), nullable=True), sa.Column('created_at', sa.DateTime(), nullable=False), sa.ForeignKeyConstraint(['user_id'], ['users.id'], ), sa.ForeignKeyConstraint(['workout_day_id'], ['workout_days.id'], ), sa.PrimaryKeyConstraint('id') ) op.create_index(op.f('ix_workout_sessions_user_id'), 'workout_sessions', ['user_id'], unique=False) op.create_table('workout_logs', sa.Column('id', sa.Integer(), nullable=False), sa.Column('session_id', sa.Integer(), nullable=False), sa.Column('exercise_id', sa.Integer(), nullable=False), sa.Column('set_number', sa.Integer(), nullable=False), sa.Column('reps_completed', sa.Integer(), nullable=False), sa.Column('weight_used', sqlmodel.sql.sqltypes.AutoString(), nullable=False), sa.Column('felt_easy', sa.Boolean(), nullable=False), sa.Column('notes', sqlmodel.sql.sqltypes.AutoString(), nullable=True), sa.Column('created_at', sa.DateTime(), nullable=False), sa.ForeignKeyConstraint(['exercise_id'], ['exercises.id'], ), sa.ForeignKeyConstraint(['session_id'], ['workout_sessions.id'], ), sa.PrimaryKeyConstraint('id') ) op.create_index(op.f('ix_workout_logs_session_id'), 'workout_logs', ['session_id'], unique=False) # ### end Alembic commands ### def downgrade() -> None: """Downgrade schema.""" # ### commands auto generated by Alembic - please adjust! ### op.drop_index(op.f('ix_workout_logs_session_id'), table_name='workout_logs') op.drop_table('workout_logs') op.drop_index(op.f('ix_workout_sessions_user_id'), table_name='workout_sessions') op.drop_table('workout_sessions') op.drop_index(op.f('ix_user_exercise_programs_user_id'), table_name='user_exercise_programs') op.drop_index(op.f('ix_user_exercise_programs_exercise_id'), table_name='user_exercise_programs') op.drop_table('user_exercise_programs') op.drop_index(op.f('ix_progress_log_user_id'), table_name='progress_log') op.drop_table('progress_log') op.drop_index(op.f('ix_workout_days_name'), table_name='workout_days') op.drop_table('workout_days') op.drop_index(op.f('ix_warmups_name'), table_name='warmups') op.drop_table('warmups') op.drop_index(op.f('ix_users_username'), table_name='users') op.drop_table('users') op.drop_index(op.f('ix_exercises_workout_day'), table_name='exercises') op.drop_index(op.f('ix_exercises_name'), table_name='exercises') op.drop_table('exercises') # ### end Alembic commands ###