Source code for page.upgrade

""" 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)