Files
notifications-api/migrations/versions/0161_email_branding.py

61 lines
1.7 KiB
Python
Raw Normal View History

2018-01-30 15:58:26 +00:00
"""
Revision ID: 0161_email_branding
Revises: 0159_add_historical_redact
2018-01-30 15:58:26 +00:00
Create Date: 2018-01-30 15:35:12.016574
"""
import sqlalchemy as sa
from alembic import op
2018-01-30 15:58:26 +00:00
from sqlalchemy.dialects import postgresql
2023-08-29 14:54:30 -07:00
revision = "0161_email_branding"
down_revision = "0159_add_historical_redact"
2018-01-30 15:58:26 +00:00
def upgrade():
2023-08-29 14:54:30 -07:00
op.create_table(
"email_branding",
sa.Column("id", postgresql.UUID(as_uuid=True), nullable=False),
sa.Column("colour", sa.String(length=7), nullable=True),
sa.Column("logo", sa.String(length=255), nullable=True),
sa.Column("name", sa.String(length=255), nullable=True),
sa.PrimaryKeyConstraint("id"),
2018-01-30 15:58:26 +00:00
)
2023-08-29 14:54:30 -07:00
op.create_table(
"service_email_branding",
sa.Column("service_id", postgresql.UUID(as_uuid=True), nullable=True),
sa.Column("email_branding_id", postgresql.UUID(as_uuid=True), nullable=True),
sa.ForeignKeyConstraint(
["email_branding_id"],
["email_branding.id"],
),
sa.ForeignKeyConstraint(
["service_id"],
["services.id"],
),
sa.UniqueConstraint(
"service_id", name="uix_service_email_branding_one_per_service"
),
sa.PrimaryKeyConstraint("service_id"),
2018-01-30 15:58:26 +00:00
)
2023-08-29 14:54:30 -07:00
op.execute(
"""
2018-01-30 15:58:26 +00:00
INSERT INTO email_branding (id, colour, logo, name)
SELECT id, colour, logo, name
FROM organisation
2023-08-29 14:54:30 -07:00
"""
)
op.execute(
"""
2018-01-30 15:58:26 +00:00
INSERT INTO service_email_branding (service_id, email_branding_id)
SELECT id, organisation_id
FROM services where organisation_id is not null
2023-08-29 14:54:30 -07:00
"""
)
2018-01-30 15:58:26 +00:00
def downgrade():
2023-08-29 14:54:30 -07:00
op.drop_table("service_email_branding")
op.drop_table("email_branding")