Spaces:
Running
Running
File size: 1,308 Bytes
220d87f |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 |
from alembic import op
import sqlalchemy as sa
revision = '0001_init'
down_revision = None
branch_labels = None
depends_on = None
def upgrade():
op.create_table(
'users',
sa.Column('id', sa.Integer(), primary_key=True),
sa.Column('email', sa.String(255), nullable=False, unique=True),
sa.Column('password_hash', sa.String(255), nullable=False),
sa.Column('created_at', sa.DateTime(), nullable=True),
)
op.create_table(
'api_keys',
sa.Column('id', sa.Integer(), primary_key=True),
sa.Column('key', sa.String(255), nullable=False, unique=True),
sa.Column('revoked', sa.Boolean(), default=False),
sa.Column('created_at', sa.DateTime(), nullable=True),
sa.Column('user_id', sa.Integer(), sa.ForeignKey('users.id', ondelete='CASCADE'))
)
op.create_table(
'chat_history',
sa.Column('id', sa.Integer(), primary_key=True),
sa.Column('role', sa.String(20)),
sa.Column('content', sa.Text(), nullable=False),
sa.Column('created_at', sa.DateTime(), nullable=True),
sa.Column('user_id', sa.Integer(), sa.ForeignKey('users.id', ondelete='CASCADE'))
)
def downgrade():
op.drop_table('chat_history')
op.drop_table('api_keys')
op.drop_table('users')
|