migrations/versions/1d461753b2e_.py
"""empty message
Revision ID: 1d461753b2e
Revises: None
Create Date: 2015-09-17 18:18:16.670877
"""
# revision identifiers, used by Alembic.
revision = '1d461753b2e'
down_revision = None
branch_labels = ('beavy', )
from alembic import op
import sqlalchemy as sa
from sqlalchemy.dialects import postgresql
def upgrade():
### commands auto generated by Alembic - please adjust! ###
op.create_table('role',
sa.Column('id', sa.Integer(), nullable=False),
sa.Column('name', sa.String(length=80), nullable=False),
sa.Column('description', sa.String(length=255), nullable=True),
sa.PrimaryKeyConstraint('id'),
sa.UniqueConstraint('name')
)
op.create_table('user',
sa.Column('id', sa.Integer(), nullable=False),
sa.Column('created_at', sa.DateTime(), server_default=sa.text('now()'), nullable=False),
sa.Column('email', sa.String(length=255), nullable=False),
sa.Column('name', sa.String(length=255), nullable=True),
sa.Column('password', sa.String(length=255), nullable=True),
sa.Column('active', sa.Boolean(), nullable=True),
sa.Column('confirmed_at', sa.DateTime(), nullable=True),
sa.Column('last_login_at', sa.DateTime(), nullable=True),
sa.Column('current_login_at', sa.DateTime(), nullable=True),
sa.Column('last_login_ip', sa.String(length=255), nullable=True),
sa.Column('current_login_ip', sa.String(length=255), nullable=True),
sa.Column('login_count', sa.Integer(), nullable=True),
sa.PrimaryKeyConstraint('id'),
sa.UniqueConstraint('email')
)
op.create_table('objects',
sa.Column('id', sa.Integer(), nullable=False),
sa.Column('type', sa.String(length=100), nullable=False),
sa.Column('created_at', sa.DateTime(), server_default=sa.text('now()'), nullable=False),
sa.Column('payload', postgresql.JSONB(), nullable=True),
sa.Column('owner_id', sa.Integer(), nullable=False),
sa.Column('belongs_to', sa.Integer(), nullable=True),
sa.ForeignKeyConstraint(['belongs_to'], ['objects.id'], ),
sa.ForeignKeyConstraint(['owner_id'], ['user.id'], ),
sa.PrimaryKeyConstraint('id')
)
op.create_table('roles_users',
sa.Column('user_id', sa.Integer(), nullable=False),
sa.Column('role_id', sa.Integer(), nullable=False),
sa.ForeignKeyConstraint(['role_id'], ['role.id'], ),
sa.ForeignKeyConstraint(['user_id'], ['user.id'], )
)
op.create_table('social_connection',
sa.Column('id', sa.Integer(), nullable=False),
sa.Column('created_at', sa.DateTime(), server_default=sa.text('now()'), nullable=False),
sa.Column('user_id', sa.Integer(), nullable=False),
sa.Column('provider', sa.String(length=255), nullable=False),
sa.Column('profile_id', sa.String(length=255), nullable=False),
sa.Column('username', sa.String(length=255), nullable=True),
sa.Column('email', sa.String(length=255), nullable=True),
sa.Column('access_token', sa.String(length=255), nullable=True),
sa.Column('secret', sa.String(length=255), nullable=True),
sa.Column('first_name', sa.String(length=255), nullable=True),
sa.Column('last_name', sa.String(length=255), nullable=True),
sa.Column('cn', sa.String(length=255), nullable=True),
sa.Column('profile_url', sa.String(length=512), nullable=True),
sa.Column('image_url', sa.String(length=512), nullable=True),
sa.ForeignKeyConstraint(['user_id'], ['user.id'], ),
sa.PrimaryKeyConstraint('id')
)
op.create_table('activities',
sa.Column('id', sa.Integer(), nullable=False),
sa.Column('subject_id', sa.Integer(), nullable=False),
sa.Column('verb', sa.String(length=100), nullable=False),
sa.Column('created_at', sa.DateTime(), server_default=sa.text('now()'), nullable=False),
sa.Column('object_id', sa.Integer(), nullable=True),
sa.Column('whom_id', sa.Integer(), nullable=True),
sa.Column('payload', postgresql.JSONB(), nullable=True),
sa.ForeignKeyConstraint(['object_id'], ['objects.id'], ),
sa.ForeignKeyConstraint(['subject_id'], ['user.id'], ),
sa.ForeignKeyConstraint(['whom_id'], ['user.id'], ),
sa.PrimaryKeyConstraint('id')
)
### end Alembic commands ###
def downgrade():
### commands auto generated by Alembic - please adjust! ###
op.drop_table('activities')
op.drop_table('social_connection')
op.drop_table('roles_users')
op.drop_table('objects')
op.drop_table('user')
op.drop_table('role')
### end Alembic commands ###