""" Contains upgrade tasks that are executed when the application is being
upgraded on the server. See :class:`onegov.core.upgrade.upgrade_task`.
"""
from __future__ import annotations
from sqlalchemy import Column
from onegov.core.orm.types import UTCDateTime
from onegov.core.upgrade import upgrade_task
from sqlalchemy.sql.expression import text
from typing import TYPE_CHECKING
if TYPE_CHECKING:
from onegov.core.upgrades import UpgradeContext
@upgrade_task('Add parent order index')
[docs]
def add_parent_order_index(context: UpgradeContext) -> None:
context.operations.create_index(
'page_order', 'pages', [
text('"parent_id" NULLS FIRST'),
text('"order" NULLS FIRST')
]
)
@upgrade_task('Adds publication dates to pages')
[docs]
def add_publication_dates_to_pages(context: UpgradeContext) -> None:
if not context.has_column('pages', 'publication_start'):
context.operations.add_column(
'pages',
Column('publication_start', UTCDateTime, nullable=True)
)
if not context.has_column('pages', 'publication_end'):
context.operations.add_column(
'pages',
Column('publication_end', UTCDateTime, nullable=True)
)
@upgrade_task('Make pages polymorphic type non-nullable')
[docs]
def make_pages_polymorphic_type_non_nullable(
context: UpgradeContext
) -> None:
if context.has_table('pages'):
context.operations.execute("""
UPDATE pages SET type = 'generic' WHERE type IS NULL;
""")
context.operations.alter_column('pages', 'type', nullable=False)