"""add CmfTextSearch model

Revision ID: 6134d8cd101c
Revises: 5661ec6b696e
Create Date: 2023-09-13 19:16:11.369448

"""
from alembic import op
import sqlalchemy as sa
from sqlalchemy.dialects import postgresql

# revision identifiers, used by Alembic.
revision = '6134d8cd101c'
down_revision = '5661ec6b696e'
branch_labels = None
depends_on = None


def upgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.create_table('cmf_text_search',
    sa.Column('id', sa.String(length=64), nullable=False),
    sa.Column('obj_id', sa.String(length=64), nullable=False),
    sa.Column('obj_model', sa.TEXT(), nullable=True),
    sa.Column('obj_name', sa.TEXT(), nullable=True),
    sa.Column('obj_text', sa.TEXT(), nullable=True),
    sa.Column('obj_tags', sa.TEXT(), nullable=True),
    sa.Column('obj_parent_id', sa.String(length=64), nullable=True),
    sa.Column('obj_tree_parent_id', sa.String(length=64), nullable=True),
    sa.Column('obj_root_parent_id', sa.String(length=64), nullable=True),
    sa.Column('obj_created_at', sa.TIMESTAMP(timezone=True), nullable=True),
    sa.Column('obj_modified_at', sa.TIMESTAMP(timezone=True), nullable=True),
    sa.Column('name_tsvector', postgresql.TSVECTOR(), nullable=True),
    sa.Column('text_tsvector', postgresql.TSVECTOR(), nullable=True),
    sa.Column('tags_tsvector', postgresql.TSVECTOR(), nullable=True),
    sa.PrimaryKeyConstraint('id')
    )
    op.create_index(op.f('ix_cmf_text_search_obj_id'), 'cmf_text_search', ['obj_id'], unique=False)
    op.create_index(op.f('ix_cmf_text_search_obj_model'), 'cmf_text_search', ['obj_model'], unique=False)
    op.create_index(op.f('ix_cmf_text_search_obj_parent_id'), 'cmf_text_search', ['obj_parent_id'], unique=False)
    op.create_index(op.f('ix_cmf_text_search_obj_root_parent_id'), 'cmf_text_search', ['obj_root_parent_id'], unique=False)
    # ### end Alembic commands ###


def downgrade():
    # ### commands auto generated by Alembic - please adjust! ###
    op.drop_index(op.f('ix_cmf_text_search_obj_root_parent_id'), table_name='cmf_text_search')
    op.drop_index(op.f('ix_cmf_text_search_obj_parent_id'), table_name='cmf_text_search')
    op.drop_index(op.f('ix_cmf_text_search_obj_model'), table_name='cmf_text_search')
    op.drop_index(op.f('ix_cmf_text_search_obj_id'), table_name='cmf_text_search')
    op.drop_table('cmf_text_search')
    # ### end Alembic commands ###
