Source code for ticket.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, UTCDateTime
from onegov.core.upgrade import upgrade_task
from onegov.ticket import Ticket
from sqlalchemy import Boolean, Column, Integer, Text, Enum


from typing import TYPE_CHECKING
if TYPE_CHECKING:
    from onegov.core.upgrade import UpgradeContext


@upgrade_task('Add handler_id to ticket')
[docs] def add_handler_id_to_ticket(context: UpgradeContext) -> None: if not context.has_column('tickets', 'handler_id'): context.operations.add_column( 'tickets', Column( 'handler_id', Text, nullable=True, unique=True, index=True ) ) for ticket in context.session.query(Ticket).all(): # this should probably use [] access, but either way it will # fail in the alter column below if some handler_ids ended # up being NULL at the end, so let's just ignore it ticket.handler_id = ticket.handler_data.get( # type:ignore 'submission_id' ) ticket.handler_data = {} context.session.flush() context.operations.alter_column( 'tickets', 'handler_id', nullable=False )
@upgrade_task('Add snapshot json column to ticket')
[docs] def add_snapshot_json_column_to_ticket(context: UpgradeContext) -> None: context.operations.add_column( 'tickets', Column('snapshot', JSON, nullable=True) ) for ticket in context.session.query(Ticket).all(): ticket.snapshot = {} context.session.flush() context.operations.alter_column('tickets', 'snapshot', nullable=False)
@upgrade_task('Add subtitle to ticket')
[docs] def add_subtitle_to_ticket(context: UpgradeContext) -> None: context.operations.add_column( 'tickets', Column('subtitle', Text, nullable=True)) for ticket in context.session.query(Ticket).all(): ticket.subtitle = ticket.handler.subtitle context.session.flush()
@upgrade_task('Add process time to ticket')
[docs] def add_process_time_to_ticket(context: UpgradeContext) -> None: if not context.has_column('tickets', 'last_state_change'): context.operations.add_column( 'tickets', Column('last_state_change', UTCDateTime, nullable=True)) if not context.has_column('tickets', 'reaction_time'): context.operations.add_column( 'tickets', Column('reaction_time', Integer, nullable=True)) if not context.has_column('tickets', 'process_time'): context.operations.add_column( 'tickets', Column('process_time', Integer, nullable=True))
@upgrade_task('Add muted state to ticket')
[docs] def add_muted_state_to_ticket(context: UpgradeContext) -> None: if context.has_column('tickets', 'muted'): return context.operations.add_column( 'tickets', Column('muted', Boolean, nullable=True)) for ticket in context.session.query(Ticket): ticket.muted = False context.session.flush() context.operations.alter_column('tickets', 'muted', nullable=False)
@upgrade_task('Add archived flag to ticket')
[docs] def add_archived_flag_to_ticket(context: UpgradeContext) -> None: pass
@upgrade_task('Add archived as a state and remove flag')
[docs] def add_archived_state_to_ticket(context: UpgradeContext) -> None: if context.has_column('tickets', 'archived'): context.operations.drop_column('tickets', 'archived') old_type = Enum( 'open', 'pending', 'closed', name='ticket_state' ) new_type = Enum( 'open', 'pending', 'closed', 'archived', name='ticket_state' ) tmp_type = Enum( 'open', 'pending', 'closed', 'archived', name='ticket_state_' ) op = context.operations tmp_type.create(op.get_bind(), checkfirst=False) op.execute(""" ALTER TABLE tickets ALTER COLUMN state TYPE ticket_state_ USING state::text::ticket_state_; """) old_type.drop(op.get_bind(), checkfirst=False) new_type.create(context.operations.get_bind(), checkfirst=False) op.execute(""" ALTER TABLE tickets ALTER COLUMN state TYPE ticket_state USING state::text::ticket_state """) tmp_type.drop(context.operations.get_bind(), checkfirst=False)