""" 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.upgrade import upgrade_task, UpgradeContext
from onegov.org.models import Organisation
from sqlalchemy import Column, Integer, Enum
from onegov.core.orm.types import UTCDateTime
from onegov.winterthur.models.mission_report import MISSION_TYPES
@upgrade_task('Change the default geo provider')
[docs]
def change_default_geo_provider(context: UpgradeContext) -> bool | None:
org = context.session.query(Organisation).first()
if org is None:
return False
if 'Strassenverzeichnis' not in org.meta['homepage_structure']:
return False
org.meta['geo_provider'] = 'geo-vermessungsamt-winterthur'
return None
@upgrade_task('Adds mission count and type to reports')
[docs]
def add_mission_count_and_type_to_reports(context: UpgradeContext) -> None:
if not context.has_column('mission_reports', 'mission_type'):
context.add_column_with_defaults(
'mission_reports',
Column(
'mission_type',
Enum(*MISSION_TYPES, name='mission_type'),
default='single'),
default=lambda x: 'single'
)
if not context.has_column('mission_reports', 'mission_count'):
context.add_column_with_defaults(
'mission_reports',
Column('mission_count', Integer, default=1),
default=lambda x: 1
)
@upgrade_task('Add timestamps to street')
[docs]
def add_timestamps_to_street(context: UpgradeContext) -> None:
if not context.has_column('winterthur_addresses', 'created'):
context.operations.add_column('winterthur_addresses', Column(
'created', UTCDateTime
))
if not context.has_column('winterthur_addresses', 'modified'):
context.operations.add_column('winterthur_addresses', Column(
'modified', UTCDateTime
))