Files
resolutionflow/backend/alembic/versions/7e00fa3c75c9_fix_datetime_timezone.py

149 lines
7.0 KiB
Python

"""Fix datetime timezone
Revision ID: 7e00fa3c75c9
Revises: 001
Create Date: 2026-01-23 11:51:47.640123
"""
from typing import Sequence, Union
from alembic import op
import sqlalchemy as sa
from sqlalchemy.dialects import postgresql
# revision identifiers, used by Alembic.
revision: str = '7e00fa3c75c9'
down_revision: Union[str, None] = '001'
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.alter_column('attachments', 'uploaded_at',
existing_type=postgresql.TIMESTAMP(),
nullable=False,
existing_server_default=sa.text('now()'))
op.alter_column('sessions', 'started_at',
existing_type=postgresql.TIMESTAMP(),
nullable=False,
existing_server_default=sa.text('now()'))
op.alter_column('sessions', 'exported',
existing_type=sa.BOOLEAN(),
nullable=False,
existing_server_default=sa.text('false'))
op.drop_index('idx_sessions_dates', table_name='sessions')
op.drop_index('idx_sessions_tree', table_name='sessions')
op.drop_index('idx_sessions_user', table_name='sessions')
op.create_index(op.f('ix_sessions_completed_at'), 'sessions', ['completed_at'], unique=False)
op.create_index(op.f('ix_sessions_started_at'), 'sessions', ['started_at'], unique=False)
op.create_index(op.f('ix_sessions_tree_id'), 'sessions', ['tree_id'], unique=False)
op.create_index(op.f('ix_sessions_user_id'), 'sessions', ['user_id'], unique=False)
op.alter_column('teams', 'created_at',
existing_type=postgresql.TIMESTAMP(),
nullable=False,
existing_server_default=sa.text('now()'))
op.alter_column('trees', 'is_active',
existing_type=sa.BOOLEAN(),
nullable=False,
existing_server_default=sa.text('true'))
op.alter_column('trees', 'version',
existing_type=sa.INTEGER(),
nullable=False,
existing_server_default=sa.text('1'))
op.alter_column('trees', 'created_at',
existing_type=postgresql.TIMESTAMP(),
nullable=False,
existing_server_default=sa.text('now()'))
op.alter_column('trees', 'updated_at',
existing_type=postgresql.TIMESTAMP(),
nullable=False,
existing_server_default=sa.text('now()'))
op.alter_column('trees', 'usage_count',
existing_type=sa.INTEGER(),
nullable=False,
existing_server_default=sa.text('0'))
op.drop_index('idx_trees_category', table_name='trees')
op.drop_index('idx_trees_search', table_name='trees', postgresql_using='gin')
op.drop_index('idx_trees_team', table_name='trees')
op.create_index(op.f('ix_trees_category'), 'trees', ['category'], unique=False)
op.create_index(op.f('ix_trees_team_id'), 'trees', ['team_id'], unique=False)
op.alter_column('users', 'created_at',
existing_type=postgresql.TIMESTAMP(),
type_=sa.DateTime(timezone=True),
nullable=False,
existing_server_default=sa.text('now()'))
op.alter_column('users', 'last_login',
existing_type=postgresql.TIMESTAMP(),
type_=sa.DateTime(timezone=True),
existing_nullable=True)
op.drop_index('idx_users_email', table_name='users')
op.drop_constraint('users_email_key', 'users', type_='unique')
op.create_index(op.f('ix_users_email'), 'users', ['email'], unique=True)
# ### end Alembic commands ###
def downgrade() -> None:
# ### commands auto generated by Alembic - please adjust! ###
op.drop_index(op.f('ix_users_email'), table_name='users')
op.create_unique_constraint('users_email_key', 'users', ['email'])
op.create_index('idx_users_email', 'users', ['email'], unique=True)
op.alter_column('users', 'last_login',
existing_type=sa.DateTime(timezone=True),
type_=postgresql.TIMESTAMP(),
existing_nullable=True)
op.alter_column('users', 'created_at',
existing_type=sa.DateTime(timezone=True),
type_=postgresql.TIMESTAMP(),
nullable=True,
existing_server_default=sa.text('now()'))
op.drop_index(op.f('ix_trees_team_id'), table_name='trees')
op.drop_index(op.f('ix_trees_category'), table_name='trees')
op.create_index('idx_trees_team', 'trees', ['team_id'], unique=False)
op.create_index('idx_trees_search', 'trees', [sa.text("to_tsvector('english'::regconfig, (COALESCE(name, ''::character varying)::text || ' '::text) || COALESCE(description, ''::text))")], unique=False, postgresql_using='gin')
op.create_index('idx_trees_category', 'trees', ['category'], unique=False)
op.alter_column('trees', 'usage_count',
existing_type=sa.INTEGER(),
nullable=True,
existing_server_default=sa.text('0'))
op.alter_column('trees', 'updated_at',
existing_type=postgresql.TIMESTAMP(),
nullable=True,
existing_server_default=sa.text('now()'))
op.alter_column('trees', 'created_at',
existing_type=postgresql.TIMESTAMP(),
nullable=True,
existing_server_default=sa.text('now()'))
op.alter_column('trees', 'version',
existing_type=sa.INTEGER(),
nullable=True,
existing_server_default=sa.text('1'))
op.alter_column('trees', 'is_active',
existing_type=sa.BOOLEAN(),
nullable=True,
existing_server_default=sa.text('true'))
op.alter_column('teams', 'created_at',
existing_type=postgresql.TIMESTAMP(),
nullable=True,
existing_server_default=sa.text('now()'))
op.drop_index(op.f('ix_sessions_user_id'), table_name='sessions')
op.drop_index(op.f('ix_sessions_tree_id'), table_name='sessions')
op.drop_index(op.f('ix_sessions_started_at'), table_name='sessions')
op.drop_index(op.f('ix_sessions_completed_at'), table_name='sessions')
op.create_index('idx_sessions_user', 'sessions', ['user_id'], unique=False)
op.create_index('idx_sessions_tree', 'sessions', ['tree_id'], unique=False)
op.create_index('idx_sessions_dates', 'sessions', ['started_at', 'completed_at'], unique=False)
op.alter_column('sessions', 'exported',
existing_type=sa.BOOLEAN(),
nullable=True,
existing_server_default=sa.text('false'))
op.alter_column('sessions', 'started_at',
existing_type=postgresql.TIMESTAMP(),
nullable=True,
existing_server_default=sa.text('now()'))
op.alter_column('attachments', 'uploaded_at',
existing_type=postgresql.TIMESTAMP(),
nullable=True,
existing_server_default=sa.text('now()'))
# ### end Alembic commands ###