Merge branch 'master' into ken-migrate-default-service-permissions

This commit is contained in:
Rebecca Law
2017-06-08 15:21:08 +01:00
73 changed files with 2608 additions and 581 deletions

View File

@@ -0,0 +1,24 @@
"""empty message
Revision ID: 0088_add_schedule_serv_perm
Revises: 0087_scheduled_notifications
Create Date: 2017-05-26 14:53:18.581320
"""
# revision identifiers, used by Alembic.
revision = '0088_add_schedule_serv_perm'
down_revision = '0087_scheduled_notifications'
from alembic import op
def upgrade():
op.get_bind()
op.execute("insert into service_permission_types values('schedule_notifications')")
def downgrade():
op.get_bind()
op.execute("delete from service_permissions where permission = 'schedule_notifications'")
op.execute("delete from service_permission_types where name = 'schedule_notifications'")

View File

@@ -0,0 +1,25 @@
"""empty message
Revision ID: 0089_govuk_sms_sender
Revises: 0088_add_schedule_serv_perm
Create Date: 2017-05-22 13:46:09.584801
"""
# revision identifiers, used by Alembic.
revision = '0089_govuk_sms_sender'
down_revision = '0088_add_schedule_serv_perm'
from alembic import op
def upgrade():
op.execute("UPDATE services SET sms_sender = 'GOVUK' where sms_sender is null")
op.execute("UPDATE services_history SET sms_sender = 'GOVUK' where sms_sender is null")
op.alter_column('services', 'sms_sender', nullable=False)
op.alter_column('services_history', 'sms_sender', nullable=False)
def downgrade():
op.alter_column('services_history', 'sms_sender', nullable=True)
op.alter_column('services', 'sms_sender', nullable=True)

View File

@@ -0,0 +1,37 @@
"""empty message
Revision ID: 0090_inbound_sms
Revises: 0089_govuk_sms_sender
Create Date: 2017-05-22 11:28:53.471004
"""
# revision identifiers, used by Alembic.
revision = '0090_inbound_sms'
down_revision = '0089_govuk_sms_sender'
from alembic import op
import sqlalchemy as sa
from sqlalchemy.dialects import postgresql
def upgrade():
op.create_table(
'inbound_sms',
sa.Column('id', postgresql.UUID(as_uuid=True), nullable=False),
sa.Column('service_id', postgresql.UUID(as_uuid=True), nullable=False),
sa.Column('content', sa.String, nullable=False),
sa.Column('notify_number', sa.String, nullable=False),
sa.Column('user_number', sa.String, nullable=False),
sa.Column('created_at', sa.DateTime, nullable=False),
sa.Column('provider_date', sa.DateTime, nullable=True),
sa.Column('provider_reference', sa.String, nullable=True),
sa.ForeignKeyConstraint(['service_id'], ['services.id'], ),
sa.PrimaryKeyConstraint('id')
)
op.create_index(op.f('ix_inbound_sms_service_id'), 'inbound_sms', ['service_id'], unique=False)
op.create_index(op.f('ix_inbound_sms_user_number'), 'inbound_sms', ['user_number'], unique=False)
def downgrade():
op.drop_table('inbound_sms')

View File

@@ -0,0 +1,50 @@
"""empty message
Revision ID: 0091_letter_billing
Revises: 0090_inbound_sms
Create Date: 2017-05-31 11:43:55.744631
"""
import uuid
from alembic import op
import sqlalchemy as sa
from sqlalchemy.dialects import postgresql
revision = '0091_letter_billing'
down_revision = '0090_inbound_sms'
def upgrade():
op.create_table('letter_rates',
sa.Column('id', postgresql.UUID(as_uuid=True), nullable=False),
sa.Column('valid_from', sa.DateTime(), nullable=False),
sa.PrimaryKeyConstraint('id')
)
op.create_table('letter_rate_details',
sa.Column('id', postgresql.UUID(as_uuid=True), nullable=False),
sa.Column('letter_rate_id', postgresql.UUID(as_uuid=True), nullable=False),
sa.Column('page_total', sa.Integer(), nullable=False),
sa.Column('rate', sa.Numeric(), nullable=False),
sa.ForeignKeyConstraint(['letter_rate_id'], ['letter_rates.id'], ),
sa.PrimaryKeyConstraint('id')
)
op.create_index(op.f('ix_letter_rate_details_letter_rate_id'), 'letter_rate_details', ['letter_rate_id'],
unique=False)
op.get_bind()
letter_id = uuid.uuid4()
op.execute("insert into letter_rates(id, valid_from) values('{}', '2017-03-31 23:00:00')".format(letter_id))
insert_details = "insert into letter_rate_details(id, letter_rate_id, page_total, rate) values('{}', '{}', {}, {})"
op.execute(
insert_details.format(uuid.uuid4(), letter_id, 1, 29.3))
op.execute(
insert_details.format(uuid.uuid4(), letter_id, 2, 32))
op.execute(
insert_details.format(uuid.uuid4(), letter_id, 3, 35))
def downgrade():
op.get_bind()
op.drop_index('ix_letter_rate_details_letter_rate_id')
op.drop_table('letter_rate_details')
op.drop_table('letter_rates')

View File

@@ -0,0 +1,22 @@
"""empty message
Revision ID: 0092_add_inbound_provider
Revises: 0091_letter_billing
Create Date: 2017-06-02 16:07:35.445423
"""
# revision identifiers, used by Alembic.
revision = '0092_add_inbound_provider'
down_revision = '0091_letter_billing'
from alembic import op
import sqlalchemy as sa
from sqlalchemy.dialects import postgresql
def upgrade():
op.add_column('inbound_sms', sa.Column('provider', sa.String(), nullable=True))
def downgrade():
op.drop_column('inbound_sms', 'provider')

View File

@@ -0,0 +1,32 @@
"""empty message
Revision ID: 0093_data_gov_uk
Revises: 0092_add_inbound_provider
Create Date: 2017-06-05 16:15:17.744908
"""
# revision identifiers, used by Alembic.
revision = '0093_data_gov_uk'
down_revision = '0092_add_inbound_provider'
from alembic import op
import sqlalchemy as sa
from sqlalchemy.dialects import postgresql
DATA_GOV_UK_ID = '123496d4-44cb-4324-8e0a-4187101f4bdc'
def upgrade():
op.execute("""INSERT INTO organisation VALUES (
'{}',
'',
'data_gov_uk_x2.png',
''
)""".format(DATA_GOV_UK_ID))
def downgrade():
op.execute("""
DELETE FROM organisation WHERE "id" = '{}'
""".format(DATA_GOV_UK_ID))

View File

@@ -0,0 +1,25 @@
"""empty message
Revision ID: 0094_job_stats_update
Revises: 0093_data_gov_uk
Create Date: 2017-06-06 14:37:30.051647
"""
from alembic import op
import sqlalchemy as sa
# revision identifiers, used by Alembic.
revision = '0094_job_stats_update'
down_revision = '0093_data_gov_uk'
def upgrade():
op.add_column('job_statistics', sa.Column('sent', sa.BigInteger(), nullable=True))
op.add_column('job_statistics', sa.Column('delivered', sa.BigInteger(), nullable=True))
op.add_column('job_statistics', sa.Column('failed', sa.BigInteger(), nullable=True))
def downgrade():
op.drop_column('job_statistics', 'sent')
op.drop_column('job_statistics', 'failed')
op.drop_column('job_statistics', 'delivered')