Asterisk - The Open Source Telephony Project  18.5.0
1ac563b350a8_add_pjsip_trust_send__connected_line.py
Go to the documentation of this file.
1 """add pjsip trust/send _connected_line
2 
3 Revision ID: 1ac563b350a8
4 Revises: 2bb1a85135ad
5 Create Date: 2018-10-12 17:10:34.530282
6 
7 """
8 
9 # revision identifiers, used by Alembic.
10 revision = '1ac563b350a8'
11 down_revision = '2bb1a85135ad'
12 
13 from alembic import op
14 import sqlalchemy as sa
15 from sqlalchemy.dialects.postgresql import ENUM
16 
17 AST_BOOL_NAME = 'ast_bool_values'
18 # We'll just ignore the n/y and f/t abbreviations as Asterisk does not write
19 # those aliases.
20 AST_BOOL_VALUES = [ '0', '1',
21  'off', 'on',
22  'false', 'true',
23  'no', 'yes' ]
24 
25 def upgrade():
26  ############################# Enums ##############################
27 
28  # ast_bool_values has already been created, so use postgres enum object
29  # type to get around "already created" issue - works okay with mysql
30  ast_bool_values = ENUM(*AST_BOOL_VALUES, name=AST_BOOL_NAME, create_type=False)
31 
32  op.add_column('ps_endpoints', sa.Column('trust_connected_line', ast_bool_values))
33  op.add_column('ps_endpoints', sa.Column('send_connected_line', ast_bool_values))
34 
35 def downgrade():
36  if op.get_context().bind.dialect.name == 'mssql':
37  op.drop_constraint('ck_ps_endpoints_trust_connected_line_ast_bool_values', 'ps_endpoints')
38  op.drop_constraint('ck_ps_endpoints_send_connected_line_ast_bool_values', 'ps_endpoints')
39  op.drop_column('ps_endpoints', 'trust_connected_line')
40  op.drop_column('ps_endpoints', 'send_connected_line')