1
# Copyright 2013 OpenStack Foundation
3
# Licensed under the Apache License, Version 2.0 (the "License"); you may
4
# not use this file except in compliance with the License. You may obtain
5
# a copy of the License at
7
# http://www.apache.org/licenses/LICENSE-2.0
9
# Unless required by applicable law or agreed to in writing, software
10
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12
# License for the specific language governing permissions and limitations
16
"""initial port security
18
Revision ID: 1149d7de0cfa
20
Create Date: 2013-01-22 14:05:20.696502
24
# revision identifiers, used by Alembic.
25
revision = '1149d7de0cfa'
26
down_revision = '1b693c095aa3'
28
# Change to ['*'] if this migration applies to all plugins
30
migration_for_plugins = [
31
'neutron.plugins.nicira.NeutronPlugin.NvpPluginV2',
32
'neutron.plugins.nicira.NeutronServicePlugin.NvpAdvancedPlugin',
33
'neutron.plugins.vmware.plugin.NsxPlugin',
34
'neutron.plugins.vmware.plugin.NsxServicePlugin'
37
from alembic import op
38
import sqlalchemy as sa
40
from neutron.db import migration
43
def upgrade(active_plugins=None, options=None):
44
if not migration.should_run(active_plugins, migration_for_plugins):
47
### commands auto generated by Alembic - please adjust! ###
48
op.create_table('networksecuritybindings',
49
sa.Column('network_id', sa.String(length=36),
51
sa.Column('port_security_enabled', sa.Boolean(),
53
sa.ForeignKeyConstraint(['network_id'], ['networks.id'],
55
sa.PrimaryKeyConstraint('network_id'))
56
op.create_table('portsecuritybindings',
57
sa.Column('port_id', sa.String(length=36),
59
sa.Column('port_security_enabled', sa.Boolean(),
61
sa.ForeignKeyConstraint(['port_id'], ['ports.id'],
63
sa.PrimaryKeyConstraint('port_id'))
64
### end Alembic commands ###
66
# Copy network and port ids over to network|port(securitybindings) table
67
# and set port_security_enabled to false as ip address pairs were not
68
# configured in NVP/NSX originally.
69
op.execute("INSERT INTO networksecuritybindings SELECT id as "
70
"network_id, False as port_security_enabled from networks")
71
op.execute("INSERT INTO portsecuritybindings SELECT id as port_id, "
72
"False as port_security_enabled from ports")
75
def downgrade(active_plugins=None, options=None):
76
if not migration.should_run(active_plugins, migration_for_plugins):
79
### commands auto generated by Alembic - please adjust! ###
80
op.drop_table('portsecuritybindings')
81
op.drop_table('networksecuritybindings')
82
### end Alembic commands ###