2016-06-25 14:04:30 +02:00
|
|
|
""" Initial schema
|
|
|
|
|
|
|
|
Revision ID: ff0417f4318f
|
|
|
|
Revises: None
|
|
|
|
Create Date: 2016-06-25 13:07:11.132070
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
# revision identifiers, used by Alembic.
|
|
|
|
revision = 'ff0417f4318f'
|
|
|
|
down_revision = None
|
|
|
|
|
|
|
|
from alembic import op
|
|
|
|
import sqlalchemy as sa
|
|
|
|
|
|
|
|
|
|
|
|
def upgrade():
|
|
|
|
op.create_table('domain',
|
|
|
|
sa.Column('created_at', sa.Date(), nullable=False),
|
|
|
|
sa.Column('updated_at', sa.Date(), nullable=True),
|
|
|
|
sa.Column('comment', sa.String(length=255), nullable=True),
|
|
|
|
sa.Column('name', sa.String(length=80), nullable=False),
|
|
|
|
sa.Column('max_users', sa.Integer(), nullable=False),
|
|
|
|
sa.Column('max_aliases', sa.Integer(), nullable=False),
|
2018-12-09 16:11:57 +01:00
|
|
|
sa.PrimaryKeyConstraint('name', name=op.f('domain_pkey'))
|
2016-06-25 14:04:30 +02:00
|
|
|
)
|
|
|
|
op.create_table('alias',
|
|
|
|
sa.Column('created_at', sa.Date(), nullable=False),
|
|
|
|
sa.Column('updated_at', sa.Date(), nullable=True),
|
|
|
|
sa.Column('comment', sa.String(length=255), nullable=True),
|
|
|
|
sa.Column('localpart', sa.String(length=80), nullable=False),
|
2018-12-06 17:04:48 +01:00
|
|
|
sa.Column('destination', sa.String(length=1023), nullable=False),
|
2016-06-25 14:04:30 +02:00
|
|
|
sa.Column('domain_name', sa.String(length=80), nullable=False),
|
|
|
|
sa.Column('email', sa.String(length=255), nullable=False),
|
2018-12-09 16:11:57 +01:00
|
|
|
sa.ForeignKeyConstraint(['domain_name'], ['domain.name'], name=op.f('alias_domain_name_fkey')),
|
|
|
|
sa.PrimaryKeyConstraint('email', name=op.f('alias_pkey'))
|
2016-06-25 14:04:30 +02:00
|
|
|
)
|
|
|
|
op.create_table('user',
|
|
|
|
sa.Column('created_at', sa.Date(), nullable=False),
|
|
|
|
sa.Column('updated_at', sa.Date(), nullable=True),
|
|
|
|
sa.Column('comment', sa.String(length=255), nullable=True),
|
|
|
|
sa.Column('localpart', sa.String(length=80), nullable=False),
|
|
|
|
sa.Column('password', sa.String(length=255), nullable=False),
|
2019-01-15 10:20:57 +01:00
|
|
|
sa.Column('quota_bytes', sa.Integer(), nullable=False),
|
2016-06-25 14:04:30 +02:00
|
|
|
sa.Column('global_admin', sa.Boolean(), nullable=False),
|
|
|
|
sa.Column('enable_imap', sa.Boolean(), nullable=False),
|
|
|
|
sa.Column('enable_pop', sa.Boolean(), nullable=False),
|
|
|
|
sa.Column('forward_enabled', sa.Boolean(), nullable=False),
|
|
|
|
sa.Column('forward_destination', sa.String(length=255), nullable=True),
|
|
|
|
sa.Column('reply_enabled', sa.Boolean(), nullable=False),
|
|
|
|
sa.Column('reply_subject', sa.String(length=255), nullable=True),
|
|
|
|
sa.Column('reply_body', sa.Text(), nullable=True),
|
|
|
|
sa.Column('displayed_name', sa.String(length=160), nullable=False),
|
|
|
|
sa.Column('spam_enabled', sa.Boolean(), nullable=False),
|
|
|
|
sa.Column('spam_threshold', sa.Numeric(), nullable=False),
|
|
|
|
sa.Column('domain_name', sa.String(length=80), nullable=False),
|
|
|
|
sa.Column('email', sa.String(length=255), nullable=False),
|
2018-12-09 16:11:57 +01:00
|
|
|
sa.ForeignKeyConstraint(['domain_name'], ['domain.name'], name=op.f('user_domain_name_fkey')),
|
|
|
|
sa.PrimaryKeyConstraint('email', name=op.f('user_pkey'))
|
2016-06-25 14:04:30 +02:00
|
|
|
)
|
|
|
|
op.create_table('fetch',
|
|
|
|
sa.Column('created_at', sa.Date(), nullable=False),
|
|
|
|
sa.Column('updated_at', sa.Date(), nullable=True),
|
|
|
|
sa.Column('comment', sa.String(length=255), nullable=True),
|
|
|
|
sa.Column('id', sa.Integer(), nullable=False),
|
|
|
|
sa.Column('user_email', sa.String(length=255), nullable=False),
|
2018-12-06 17:04:48 +01:00
|
|
|
sa.Column('protocol', sa.Enum('imap', 'pop3', name='enum_protocol'), nullable=False),
|
2016-06-25 14:04:30 +02:00
|
|
|
sa.Column('host', sa.String(length=255), nullable=False),
|
|
|
|
sa.Column('port', sa.Integer(), nullable=False),
|
|
|
|
sa.Column('tls', sa.Boolean(), nullable=False),
|
|
|
|
sa.Column('username', sa.String(length=255), nullable=False),
|
|
|
|
sa.Column('password', sa.String(length=255), nullable=False),
|
2018-12-09 16:11:57 +01:00
|
|
|
sa.ForeignKeyConstraint(['user_email'], ['user.email'], name=op.f('fetch_user_email_fkey')),
|
|
|
|
sa.PrimaryKeyConstraint('id', name=op.f('fetch_pkey'))
|
2016-06-25 14:04:30 +02:00
|
|
|
)
|
2016-06-25 14:17:45 +02:00
|
|
|
op.create_table('manager',
|
2016-06-25 14:04:30 +02:00
|
|
|
sa.Column('domain_name', sa.String(length=80), nullable=True),
|
|
|
|
sa.Column('user_email', sa.String(length=255), nullable=True),
|
2018-12-09 16:11:57 +01:00
|
|
|
sa.ForeignKeyConstraint(['domain_name'], ['domain.name'], name=op.f('manager_domain_name_fkey')),
|
|
|
|
sa.ForeignKeyConstraint(['user_email'], ['user.email'], name=op.f('manager_user_email_fkey'))
|
2016-06-25 14:04:30 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def downgrade():
|
|
|
|
op.drop_table('manager')
|
|
|
|
op.drop_table('fetch')
|
|
|
|
op.drop_table('user')
|
|
|
|
op.drop_table('alias')
|
|
|
|
op.drop_table('domain')
|