Source code for directory.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 onegov.core.orm.types import UTCDateTime
from onegov.core.upgrade import upgrade_task, UpgradeContext
from onegov.directory import Directory
from sqlalchemy import Column, Integer


@upgrade_task('Add entries count')
[docs] def add_entries_count(context: UpgradeContext) -> None: if context.has_column('directories', 'count'): return context.operations.add_column('directories', Column( 'count', Integer, nullable=True )) context.session.flush() for directory in context.session.query(Directory): directory.count = len(directory.entries) context.session.flush() context.operations.alter_column('directories', 'count', nullable=False)
@upgrade_task('Update ordering')
[docs] def update_ordering(context: UpgradeContext) -> None: for directory in context.session.query(Directory): config = directory.configuration for entry in directory.entries: entry.order = config.extract_order(entry.values)
@upgrade_task('Make external link visible by default') @upgrade_task('Adds publication dates to directory entries')
[docs] def add_publication_dates_to_dir_entries(context: UpgradeContext) -> None: if not context.has_column('directory_entries', 'publication_start'): context.operations.add_column( 'directory_entries', Column('publication_start', UTCDateTime, nullable=True) ) if not context.has_column('directory_entries', 'publication_end'): context.operations.add_column( 'directory_entries', Column('publication_end', UTCDateTime, nullable=True) )
@upgrade_task('Make directory models polymorphic type non-nullable')
[docs] def make_directory_models_polymorphic_type_non_nullable( context: UpgradeContext ) -> None: for table in ('directories', 'directory_entries'): if context.has_table(table): context.operations.execute(f""" UPDATE {table} SET type = 'generic' WHERE type IS NULL; """) context.operations.alter_column(table, 'type', nullable=False)