neutron/neutron/db/migration/alembic_migrations/nsxv_initial_opts.py

138 lines
6.8 KiB
Python

# Copyright 2015 OpenStack Foundation
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
#
from alembic import op
import sqlalchemy as sa
appliance_sizes_enum = sa.Enum('compact', 'large', 'xlarge', 'quadlarge',
name='nsxv_router_bindings_appliance_size')
edge_types_enum = sa.Enum('service', 'vdr',
name='nsxv_router_bindings_edge_type')
internal_network_purpose_enum = sa.Enum('inter_edge_net',
name='nsxv_internal_networks_purpose')
internal_edge_purpose_enum = sa.Enum('inter_edge_net',
name='nsxv_internal_edges_purpose')
tz_binding_type_enum = sa.Enum('flat', 'vlan', 'portgroup',
name='nsxv_tz_network_bindings_binding_type')
router_types_enum = sa.Enum('shared', 'exclusive',
name='nsxv_router_type')
def upgrade():
op.create_table(
'nsxv_router_bindings',
sa.Column('status', sa.String(length=16), nullable=False),
sa.Column('status_description', sa.String(length=255), nullable=True),
sa.Column('router_id', sa.String(length=36), nullable=False),
sa.Column('edge_id', sa.String(length=36), nullable=True),
sa.Column('lswitch_id', sa.String(length=36), nullable=True),
sa.Column('appliance_size',
appliance_sizes_enum,
nullable=True),
sa.Column('edge_type', edge_types_enum, nullable=True),
sa.PrimaryKeyConstraint('router_id'))
op.create_table(
'nsxv_internal_networks',
sa.Column('network_purpose', internal_network_purpose_enum,
nullable=False),
sa.Column('network_id', sa.String(length=36), nullable=True),
sa.ForeignKeyConstraint(['network_id'], ['networks.id'],
ondelete='CASCADE'),
sa.PrimaryKeyConstraint('network_purpose'))
op.create_table(
'nsxv_internal_edges',
sa.Column('ext_ip_address', sa.String(length=64), nullable=False),
sa.Column('router_id', sa.String(length=36), nullable=True),
sa.Column('purpose', internal_edge_purpose_enum, nullable=True),
sa.PrimaryKeyConstraint('ext_ip_address'))
op.create_table(
'nsxv_firewall_rule_bindings',
sa.Column('rule_id', sa.String(length=36), nullable=False),
sa.Column('edge_id', sa.String(length=36), nullable=False),
sa.Column('rule_vse_id', sa.String(length=36), nullable=True),
sa.PrimaryKeyConstraint('rule_id', 'edge_id'))
op.create_table(
'nsxv_edge_dhcp_static_bindings',
sa.Column('edge_id', sa.String(length=36), nullable=False),
sa.Column('mac_address', sa.String(length=32), nullable=False),
sa.Column('binding_id', sa.String(length=36), nullable=False),
sa.PrimaryKeyConstraint('edge_id', 'mac_address'))
op.create_table(
'nsxv_edge_vnic_bindings',
sa.Column('edge_id', sa.String(length=36), nullable=False),
sa.Column('vnic_index', sa.Integer(), nullable=False),
sa.Column('tunnel_index', sa.Integer(), nullable=False),
sa.Column('network_id', sa.String(length=36), nullable=True),
sa.PrimaryKeyConstraint('edge_id', 'vnic_index', 'tunnel_index'))
op.create_table(
'nsxv_spoofguard_policy_network_mappings',
sa.Column('network_id', sa.String(length=36), nullable=False),
sa.Column('policy_id', sa.String(length=36), nullable=False),
sa.ForeignKeyConstraint(['network_id'], ['networks.id'],
ondelete='CASCADE'),
sa.PrimaryKeyConstraint('network_id'))
op.create_table(
'nsxv_security_group_section_mappings',
sa.Column('neutron_id', sa.String(length=36), nullable=False),
sa.Column('ip_section_id', sa.String(length=100), nullable=True),
sa.ForeignKeyConstraint(['neutron_id'], ['securitygroups.id'],
ondelete='CASCADE'),
sa.PrimaryKeyConstraint('neutron_id'))
op.create_table(
'nsxv_tz_network_bindings',
sa.Column('network_id', sa.String(length=36), nullable=False),
sa.Column('binding_type',
tz_binding_type_enum,
nullable=False),
sa.Column('phy_uuid', sa.String(length=36), nullable=True),
sa.Column('vlan_id', sa.Integer(), autoincrement=False, nullable=True),
sa.ForeignKeyConstraint(['network_id'], ['networks.id'],
ondelete='CASCADE'),
sa.PrimaryKeyConstraint('network_id', 'binding_type', 'phy_uuid',
'vlan_id'))
op.create_table(
'nsxv_port_vnic_mappings',
sa.Column('neutron_id', sa.String(length=36), nullable=False),
sa.Column('nsx_id', sa.String(length=42), nullable=False),
sa.ForeignKeyConstraint(['neutron_id'], ['ports.id'],
ondelete='CASCADE'),
sa.PrimaryKeyConstraint('neutron_id', 'nsx_id'))
op.create_table(
'nsxv_port_index_mappings',
sa.Column('port_id', sa.String(length=36), nullable=False),
sa.Column('device_id', sa.String(length=255), nullable=False),
sa.Column('index', sa.Integer(), nullable=False),
sa.ForeignKeyConstraint(['port_id'], ['ports.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('port_id'),
sa.UniqueConstraint('device_id', 'index'))
op.create_table(
'nsxv_rule_mappings',
sa.Column('neutron_id', sa.String(length=36), nullable=False),
sa.Column('nsx_rule_id', sa.String(length=36), nullable=False),
sa.ForeignKeyConstraint(['neutron_id'], ['securitygrouprules.id'],
ondelete='CASCADE'),
sa.PrimaryKeyConstraint('neutron_id', 'nsx_rule_id'))
op.create_table(
'nsxv_router_ext_attributes',
sa.Column('router_id', sa.String(length=36), nullable=False),
sa.Column('distributed', sa.Boolean(), nullable=False),
sa.Column('router_type', router_types_enum,
default='exclusive', nullable=False),
sa.Column('service_router', sa.Boolean(), nullable=False),
sa.ForeignKeyConstraint(['router_id'], ['routers.id'],
ondelete='CASCADE'),
sa.PrimaryKeyConstraint('router_id'))