Source code for translator_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 JSON
from onegov.core.upgrade import upgrade_task, UpgradeContext
from sqlalchemy import Column, Boolean, Enum, Text


@upgrade_task('Change withholding tax column to boolean')
[docs] def change_withholding_tax_column_type(context: UpgradeContext) -> None: if not context.has_table('translators'): return if context.has_column('translators', 'withholding_tax'): context.operations.execute( 'ALTER TABLE translators ' 'ALTER COLUMN withholding_tax TYPE BOOLEAN ' 'USING false' )
@upgrade_task('Adds meta and content columns')
[docs] def add_meta_content_columns(context: UpgradeContext) -> None: if not context.has_table('translators'): return table = 'translators' new_cols = ('meta', 'content') for col_name in new_cols: if not context.has_column(table, col_name): context.add_column_with_defaults( table=table, column=Column(col_name, JSON, nullable=False), default=lambda x: {} )
@upgrade_task('Adds imported tag for translators')
[docs] def add_imported_column(context: UpgradeContext) -> None: if not context.has_table('translators'): return if not context.has_column('translators', 'imported'): context.add_column_with_defaults( table='translators', column=Column('imported', Boolean, nullable=False), default=lambda x: False )
@upgrade_task('Add self-employed column')
[docs] def add_self_employed_column(context: UpgradeContext) -> None: if not context.has_table('translators'): return if not context.has_column('translators', 'self_employed'): context.add_column_with_defaults( table='translators', column=Column('self_employed', Boolean), default=lambda x: False )
@upgrade_task('Add unique constraint to translator email')
[docs] def add_unique_constraint_to_translator_email(context: UpgradeContext) -> None: if not context.has_table('translators'): return if context.has_column('translators', 'email'): context.operations.execute( "UPDATE translators SET email=NULL WHERE email='';" ) context.operations.create_unique_constraint( 'unique_translators_email', 'translators', ['email'] )
@upgrade_task('Add translator type')
[docs] def add_translator_type(context: UpgradeContext) -> None: if not context.has_table('translators'): return if not context.has_column('translators', 'state'): state = Enum('proposed', 'published', name='translator_state') if not context.has_enum('translator_state'): state.create(context.operations.get_bind()) context.add_column_with_defaults( table='translators', column=Column('state', state, nullable=False, default='published'), default=lambda x: 'published' )
@upgrade_task('Add translator profession')
[docs] def add_translator_profession(context: UpgradeContext) -> None: if not context.has_table('translators'): return if not context.has_column('translators', 'profession'): context.operations.add_column( 'translators', Column('profession', Text) )
@upgrade_task('Moves the hometown field onto the translator itself.')
[docs] def add_hometown(context: UpgradeContext) -> None: if not context.has_table('translators'): return if not context.has_column('translators', 'hometown'): context.operations.add_column( 'translators', Column('hometown', Text) )
@upgrade_task('Remove old unused column translator nationality')
[docs] def remove_nationality_column(context: UpgradeContext) -> None: if not context.has_table('translators'): return if context.has_column('translators', 'nationality'): context.operations.drop_column('translators', 'nationality')