Skip to content

Commit 536cbbc

Browse files
migration
1 parent ef1c2d7 commit 536cbbc

File tree

1 file changed

+150
-0
lines changed

1 file changed

+150
-0
lines changed
Lines changed: 150 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,150 @@
1+
"""Initial migration
2+
3+
Revision ID: 1b157524498d
4+
Revises:
5+
Create Date: 2026-01-14 18:06:50.282984
6+
7+
"""
8+
from typing import Sequence, Union
9+
10+
from alembic import op
11+
import sqlalchemy as sa
12+
13+
14+
# revision identifiers, used by Alembic.
15+
revision: str = '1b157524498d'
16+
down_revision: Union[str, Sequence[str], None] = None
17+
branch_labels: Union[str, Sequence[str], None] = None
18+
depends_on: Union[str, Sequence[str], None] = None
19+
20+
21+
def upgrade() -> None:
22+
"""Upgrade schema."""
23+
# ### commands auto generated by Alembic - please adjust! ###
24+
op.create_table('blocked_tokens',
25+
sa.Column('token', sa.String(length=512), nullable=False),
26+
sa.Column('expired_at', sa.DateTime(), nullable=False),
27+
sa.PrimaryKeyConstraint('token')
28+
)
29+
op.create_table('category',
30+
sa.Column('id', sa.String(length=36), nullable=False),
31+
sa.Column('name', sa.String(length=20), nullable=False),
32+
sa.PrimaryKeyConstraint('id')
33+
)
34+
op.create_index(op.f('ix_category_id'), 'category', ['id'], unique=False)
35+
op.create_index(op.f('ix_category_name'), 'category', ['name'], unique=True)
36+
op.create_table('region',
37+
sa.Column('id', sa.String(length=36), nullable=False),
38+
sa.Column('name', sa.String(length=20), nullable=False),
39+
sa.PrimaryKeyConstraint('id')
40+
)
41+
op.create_index(op.f('ix_region_id'), 'region', ['id'], unique=False)
42+
op.create_index(op.f('ix_region_name'), 'region', ['name'], unique=True)
43+
op.create_table('user',
44+
sa.Column('id', sa.String(length=36), nullable=False),
45+
sa.Column('email', sa.String(length=60), nullable=False),
46+
sa.Column('nickname', sa.String(length=20), nullable=True),
47+
sa.Column('profile_image', sa.String(length=150), nullable=True),
48+
sa.Column('coin', sa.Integer(), nullable=False),
49+
sa.Column('region_id', sa.String(length=36), nullable=True),
50+
sa.Column('status', sa.Enum('PENDING', 'ACTIVE', name='userstatus'), nullable=False),
51+
sa.ForeignKeyConstraint(['region_id'], ['region.id'], ondelete='CASCADE'),
52+
sa.PrimaryKeyConstraint('id')
53+
)
54+
op.create_index(op.f('ix_user_email'), 'user', ['email'], unique=True)
55+
op.create_index(op.f('ix_user_id'), 'user', ['id'], unique=False)
56+
op.create_index(op.f('ix_user_region_id'), 'user', ['region_id'], unique=False)
57+
op.create_table('chat_room',
58+
sa.Column('id', sa.String(length=36), nullable=False),
59+
sa.Column('user_one_id', sa.String(length=36), nullable=False),
60+
sa.Column('user_two_id', sa.String(length=36), nullable=False),
61+
sa.Column('created_at', sa.DateTime(), nullable=False),
62+
sa.Column('is_active', sa.Boolean(), nullable=False),
63+
sa.ForeignKeyConstraint(['user_one_id'], ['user.id'], ),
64+
sa.ForeignKeyConstraint(['user_two_id'], ['user.id'], ),
65+
sa.PrimaryKeyConstraint('id')
66+
)
67+
op.create_index(op.f('ix_chat_room_id'), 'chat_room', ['id'], unique=False)
68+
op.create_index(op.f('ix_chat_room_user_one_id'), 'chat_room', ['user_one_id'], unique=False)
69+
op.create_index(op.f('ix_chat_room_user_two_id'), 'chat_room', ['user_two_id'], unique=False)
70+
op.create_table('local_account',
71+
sa.Column('user_id', sa.String(length=36), nullable=False),
72+
sa.Column('hashed_password', sa.String(length=100), nullable=False),
73+
sa.ForeignKeyConstraint(['user_id'], ['user.id'], ondelete='CASCADE'),
74+
sa.PrimaryKeyConstraint('user_id')
75+
)
76+
op.create_table('product',
77+
sa.Column('id', sa.String(length=36), nullable=False),
78+
sa.Column('owner_id', sa.String(length=36), nullable=False),
79+
sa.Column('title', sa.String(length=50), nullable=False),
80+
sa.Column('content', sa.String(length=500), nullable=True),
81+
sa.Column('price', sa.Integer(), nullable=False),
82+
sa.Column('like_count', sa.Integer(), nullable=False),
83+
sa.Column('category_id', sa.String(length=36), nullable=False),
84+
sa.Column('is_sold', sa.Boolean(), nullable=False),
85+
sa.ForeignKeyConstraint(['category_id'], ['category.id'], ondelete='CASCADE'),
86+
sa.ForeignKeyConstraint(['owner_id'], ['user.id'], ondelete='CASCADE'),
87+
sa.PrimaryKeyConstraint('id')
88+
)
89+
op.create_index(op.f('ix_product_id'), 'product', ['id'], unique=False)
90+
op.create_table('social_account',
91+
sa.Column('user_id', sa.String(length=36), nullable=False),
92+
sa.Column('provider', sa.String(length=20), nullable=False),
93+
sa.Column('provider_sub', sa.String(length=256), nullable=False),
94+
sa.ForeignKeyConstraint(['user_id'], ['user.id'], ondelete='CASCADE'),
95+
sa.PrimaryKeyConstraint('user_id')
96+
)
97+
op.create_table('chat_message',
98+
sa.Column('id', sa.Integer(), autoincrement=True, nullable=False),
99+
sa.Column('room_id', sa.String(length=36), nullable=False),
100+
sa.Column('sender_id', sa.String(length=36), nullable=False),
101+
sa.Column('content', sa.Text(), nullable=False),
102+
sa.Column('created_at', sa.DateTime(), nullable=False),
103+
sa.Column('is_read', sa.Boolean(), nullable=False),
104+
sa.ForeignKeyConstraint(['room_id'], ['chat_room.id'], ondelete='CASCADE'),
105+
sa.ForeignKeyConstraint(['sender_id'], ['user.id'], ),
106+
sa.PrimaryKeyConstraint('id')
107+
)
108+
op.create_index(op.f('ix_chat_message_created_at'), 'chat_message', ['created_at'], unique=False)
109+
op.create_index(op.f('ix_chat_message_room_id'), 'chat_message', ['room_id'], unique=False)
110+
op.create_table('user_product',
111+
sa.Column('id', sa.String(length=36), nullable=False),
112+
sa.Column('user_id', sa.String(length=36), nullable=False),
113+
sa.Column('product_id', sa.String(length=36), nullable=False),
114+
sa.Column('like', sa.Boolean(), nullable=False),
115+
sa.ForeignKeyConstraint(['product_id'], ['product.id'], ondelete='CASCADE'),
116+
sa.ForeignKeyConstraint(['user_id'], ['user.id'], ondelete='CASCADE'),
117+
sa.PrimaryKeyConstraint('id')
118+
)
119+
op.create_index(op.f('ix_user_product_id'), 'user_product', ['id'], unique=False)
120+
# ### end Alembic commands ###
121+
122+
123+
def downgrade() -> None:
124+
"""Downgrade schema."""
125+
# ### commands auto generated by Alembic - please adjust! ###
126+
op.drop_index(op.f('ix_user_product_id'), table_name='user_product')
127+
op.drop_table('user_product')
128+
op.drop_index(op.f('ix_chat_message_room_id'), table_name='chat_message')
129+
op.drop_index(op.f('ix_chat_message_created_at'), table_name='chat_message')
130+
op.drop_table('chat_message')
131+
op.drop_table('social_account')
132+
op.drop_index(op.f('ix_product_id'), table_name='product')
133+
op.drop_table('product')
134+
op.drop_table('local_account')
135+
op.drop_index(op.f('ix_chat_room_user_two_id'), table_name='chat_room')
136+
op.drop_index(op.f('ix_chat_room_user_one_id'), table_name='chat_room')
137+
op.drop_index(op.f('ix_chat_room_id'), table_name='chat_room')
138+
op.drop_table('chat_room')
139+
op.drop_index(op.f('ix_user_region_id'), table_name='user')
140+
op.drop_index(op.f('ix_user_id'), table_name='user')
141+
op.drop_index(op.f('ix_user_email'), table_name='user')
142+
op.drop_table('user')
143+
op.drop_index(op.f('ix_region_name'), table_name='region')
144+
op.drop_index(op.f('ix_region_id'), table_name='region')
145+
op.drop_table('region')
146+
op.drop_index(op.f('ix_category_name'), table_name='category')
147+
op.drop_index(op.f('ix_category_id'), table_name='category')
148+
op.drop_table('category')
149+
op.drop_table('blocked_tokens')
150+
# ### end Alembic commands ###

0 commit comments

Comments
 (0)