| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- """add chat and chat message
- Revision ID: 8ac522441108
- Revises: e403a4152f6b
- Create Date: 2025-07-11 16:27:23.975758
- """
- from typing import Sequence, Union
- from alembic import op
- import sqlalchemy as sa
- # revision identifiers, used by Alembic.
- revision: str = '8ac522441108'
- down_revision: Union[str, None] = 'e403a4152f6b'
- 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('chats',
- sa.Column('id', sa.UUID(), nullable=False),
- sa.Column('title', sa.Text(), nullable=False),
- sa.Column('description', sa.Text(), nullable=True),
- sa.Column('created_at', sa.DateTime(timezone=True), server_default=sa.text('now()'), nullable=True),
- sa.Column('last_updated_at', sa.DateTime(timezone=True), server_default=sa.text('now()'), nullable=True),
- sa.Column('owner_id', sa.UUID(), nullable=True),
- sa.Column('investigation_id', sa.UUID(), nullable=True),
- sa.ForeignKeyConstraint(['investigation_id'], ['investigations.id'], onupdate='CASCADE', ondelete='CASCADE'),
- sa.ForeignKeyConstraint(['owner_id'], ['profiles.id'], onupdate='CASCADE', ondelete='CASCADE'),
- sa.PrimaryKeyConstraint('id')
- )
- op.create_index('idx_chats_investigation_id', 'chats', ['investigation_id'], unique=False)
- op.create_index('idx_chats_owner_id', 'chats', ['owner_id'], unique=False)
- op.create_table('messages',
- sa.Column('id', sa.UUID(), nullable=False),
- sa.Column('content', sa.JSON(), nullable=True),
- sa.Column('is_bot', sa.Boolean(), nullable=False),
- sa.Column('created_at', sa.DateTime(timezone=True), server_default=sa.text('now()'), nullable=True),
- sa.Column('chat_id', sa.UUID(), nullable=False),
- sa.ForeignKeyConstraint(['chat_id'], ['chats.id'], onupdate='CASCADE', ondelete='CASCADE'),
- sa.PrimaryKeyConstraint('id')
- )
- op.create_index('idx_messages_chat_id', 'messages', ['chat_id'], unique=False)
- # ### end Alembic commands ###
- def downgrade() -> None:
- """Downgrade schema."""
- # ### commands auto generated by Alembic - please adjust! ###
- op.drop_index('idx_messages_chat_id', table_name='messages')
- op.drop_table('messages')
- op.drop_index('idx_chats_owner_id', table_name='chats')
- op.drop_index('idx_chats_investigation_id', table_name='chats')
- op.drop_table('chats')
- # ### end Alembic commands ###
|