from neutron.db import l3_db
from neutron.db import portbindings_db
from neutron.db import quota_db # noqa
+from neutron.db import securitygroups_db
from neutron.extensions import portbindings
+from neutron.extensions import securitygroup as sec_grp
from neutron.openstack.common import importutils
from neutron.openstack.common import log as logging
from neutron.plugins.plumgrid.common import exceptions as plum_excep
class NeutronPluginPLUMgridV2(db_base_plugin_v2.NeutronDbPluginV2,
- portbindings_db.PortBindingMixin,
external_net_db.External_net_db_mixin,
- l3_db.L3_NAT_db_mixin):
+ l3_db.L3_NAT_db_mixin,
+ portbindings_db.PortBindingMixin,
+ securitygroups_db.SecurityGroupDbMixin):
- supported_extension_aliases = ["external-net", "router", "binding",
- "quotas", "provider"]
+ supported_extension_aliases = ["binding", "external-net", "provider",
+ "quotas", "router", "security-group"]
binding_view = "extension:port_binding:view"
binding_set = "extension:port_binding:set"
super(NeutronPluginPLUMgridV2, self).__init__()
self.plumgrid_init()
- LOG.debug(_('Neutron PLUMgrid Director: Neutron server with '
- 'PLUMgrid Plugin has started'))
+ LOG.debug('Neutron PLUMgrid Director: Neutron server with '
+ 'PLUMgrid Plugin has started')
def plumgrid_init(self):
"""PLUMgrid initialization."""
Creates a PLUMgrid-based bridge.
"""
- LOG.debug(_('Neutron PLUMgrid Director: create_network() called'))
+ LOG.debug('Neutron PLUMgrid Director: create_network() called')
# Plugin DB - Network Create and validation
tenant_id = self._get_tenant_id_for_create(context,
self).create_network(context, network)
# Propagate all L3 data into DB
self._process_l3_create(context, net_db, network['network'])
+ self._ensure_default_security_group(context, tenant_id)
try:
- LOG.debug(_('PLUMgrid Library: create_network() called'))
+ LOG.debug('PLUMgrid Library: create_network() called')
self._plumlib.create_network(tenant_id, net_db, network)
except Exception as err_message:
Updates a PLUMgrid-based bridge.
"""
- LOG.debug(_("Neutron PLUMgrid Director: update_network() called"))
+ LOG.debug("Neutron PLUMgrid Director: update_network() called")
self._network_admin_state(network)
tenant_id = self._get_tenant_id_for_create(context, network["network"])
self._process_l3_update(context, net_db, network['network'])
try:
- LOG.debug(_("PLUMgrid Library: update_network() called"))
+ LOG.debug("PLUMgrid Library: update_network() called")
self._plumlib.update_network(tenant_id, net_id)
except Exception as err_message:
Deletes a PLUMgrid-based bridge.
"""
- LOG.debug(_("Neutron PLUMgrid Director: delete_network() called"))
+ LOG.debug("Neutron PLUMgrid Director: delete_network() called")
net_db = super(NeutronPluginPLUMgridV2,
self).get_network(context, net_id)
net_id)
try:
- LOG.debug(_("PLUMgrid Library: update_network() called"))
+ LOG.debug("PLUMgrid Library: update_network() called")
self._plumlib.delete_network(net_db, net_id)
except Exception as err_message:
Creates a PLUMgrid-based port on the specific Virtual Network
Function (VNF).
"""
- LOG.debug(_("Neutron PLUMgrid Director: create_port() called"))
+ LOG.debug("Neutron PLUMgrid Director: create_port() called")
# Port operations on PLUMgrid Director is an automatic operation
# from the VIF driver operations in Nova.
# It requires admin_state_up to be True
port["port"]["admin_state_up"] = True
+ port_data = port["port"]
with context.session.begin(subtransactions=True):
# Plugin DB - Port Create and Return port
port_db = super(NeutronPluginPLUMgridV2, self).create_port(context,
port)
+ # Update port security
+ port_data.update(port_db)
+
+ self._ensure_default_security_group_on_port(context, port)
+
+ port_data[sec_grp.SECURITYGROUPS] = (
+ self._get_security_groups_on_port(context, port))
+
+ self._process_port_create_security_group(
+ context, port_db, port_data[sec_grp.SECURITYGROUPS])
+
+ self._process_portbindings_create_and_update(context,
+ port_data, port_db)
+
device_id = port_db["device_id"]
if port_db["device_owner"] == constants.DEVICE_OWNER_ROUTER_GW:
router_db = self._get_router(context, device_id)
router_db = None
try:
- LOG.debug(_("PLUMgrid Library: create_port() called"))
+ LOG.debug("PLUMgrid Library: create_port() called")
self._plumlib.create_port(port_db, router_db)
except Exception as err_message:
Updates a PLUMgrid-based port on the specific Virtual Network
Function (VNF).
"""
- LOG.debug(_("Neutron PLUMgrid Director: update_port() called"))
+ LOG.debug("Neutron PLUMgrid Director: update_port() called")
with context.session.begin(subtransactions=True):
# Plugin DB - Port Create and Return port
router_db = self._get_router(context, device_id)
else:
router_db = None
+
+ if (self._check_update_deletes_security_groups(port) or
+ self._check_update_has_security_groups(port)):
+ self._delete_port_security_group_bindings(context,
+ port_db["id"])
+ sg_ids = self._get_security_groups_on_port(context, port)
+ self._process_port_create_security_group(context,
+ port_db,
+ sg_ids)
+
+ self._process_portbindings_create_and_update(context,
+ port['port'],
+ port_db)
+
try:
- LOG.debug(_("PLUMgrid Library: create_port() called"))
+ LOG.debug("PLUMgrid Library: create_port() called")
self._plumlib.update_port(port_db, router_db)
except Exception as err_message:
Function (VNF).
"""
- LOG.debug(_("Neutron PLUMgrid Director: delete_port() called"))
+ LOG.debug("Neutron PLUMgrid Director: delete_port() called")
with context.session.begin(subtransactions=True):
# Plugin DB - Port Create and Return port
else:
router_db = None
try:
- LOG.debug(_("PLUMgrid Library: delete_port() called"))
+ LOG.debug("PLUMgrid Library: delete_port() called")
self._plumlib.delete_port(port_db, router_db)
except Exception as err_message:
Functions (VNFs).
"""
- LOG.debug(_("Neutron PLUMgrid Director: create_subnet() called"))
+ LOG.debug("Neutron PLUMgrid Director: create_subnet() called")
with context.session.begin(subtransactions=True):
# Plugin DB - Subnet Create
context, subnet)
try:
- LOG.debug(_("PLUMgrid Library: create_subnet() called"))
+ LOG.debug("PLUMgrid Library: create_subnet() called")
self._plumlib.create_subnet(sub_db, net_db, ipnet)
except Exception as err_message:
raise plum_excep.PLUMgridException(err_msg=err_message)
def delete_subnet(self, context, subnet_id):
"""Delete subnet core Neutron API."""
- LOG.debug(_("Neutron PLUMgrid Director: delete_subnet() called"))
+ LOG.debug("Neutron PLUMgrid Director: delete_subnet() called")
# Collecting subnet info
sub_db = self._get_subnet(context, subnet_id)
tenant_id = self._get_tenant_id_for_create(context, subnet_id)
super(NeutronPluginPLUMgridV2, self).delete_subnet(
context, subnet_id)
try:
- LOG.debug(_("PLUMgrid Library: delete_subnet() called"))
+ LOG.debug("PLUMgrid Library: delete_subnet() called")
self._plumlib.delete_subnet(tenant_id, net_db, net_id)
except Exception as err_message:
raise plum_excep.PLUMgridException(err_msg=err_message)
def update_subnet(self, context, subnet_id, subnet):
"""Update subnet core Neutron API."""
- LOG.debug(_("update_subnet() called"))
+ LOG.debug("update_subnet() called")
# Collecting subnet info
orig_sub_db = self._get_subnet(context, subnet_id)
try:
# PLUMgrid Server does not support updating resources yet
- LOG.debug(_("PLUMgrid Library: update_network() called"))
+ LOG.debug("PLUMgrid Library: update_network() called")
self._plumlib.update_subnet(orig_sub_db, new_sub_db, ipnet)
except Exception as err_message:
"""
Create router extension Neutron API
"""
- LOG.debug(_("Neutron PLUMgrid Director: create_router() called"))
+ LOG.debug("Neutron PLUMgrid Director: create_router() called")
tenant_id = self._get_tenant_id_for_create(context, router["router"])
# Create router on the network controller
try:
# Add Router to VND
- LOG.debug(_("PLUMgrid Library: create_router() called"))
+ LOG.debug("PLUMgrid Library: create_router() called")
self._plumlib.create_router(tenant_id, router_db)
except Exception as err_message:
raise plum_excep.PLUMgridException(err_msg=err_message)
def update_router(self, context, router_id, router):
- LOG.debug(_("Neutron PLUMgrid Director: update_router() called"))
+ LOG.debug("Neutron PLUMgrid Director: update_router() called")
with context.session.begin(subtransactions=True):
router_db = super(NeutronPluginPLUMgridV2,
self).update_router(context, router_id, router)
try:
- LOG.debug(_("PLUMgrid Library: update_router() called"))
+ LOG.debug("PLUMgrid Library: update_router() called")
self._plumlib.update_router(router_db, router_id)
except Exception as err_message:
raise plum_excep.PLUMgridException(err_msg=err_message)
return router_db
def delete_router(self, context, router_id):
- LOG.debug(_("Neutron PLUMgrid Director: delete_router() called"))
+ LOG.debug("Neutron PLUMgrid Director: delete_router() called")
with context.session.begin(subtransactions=True):
orig_router = self._get_router(context, router_id)
router_id)
try:
- LOG.debug(_("PLUMgrid Library: delete_router() called"))
+ LOG.debug("PLUMgrid Library: delete_router() called")
self._plumlib.delete_router(tenant_id, router_id)
except Exception as err_message:
def add_router_interface(self, context, router_id, interface_info):
- LOG.debug(_("Neutron PLUMgrid Director: "
- "add_router_interface() called"))
+ LOG.debug("Neutron PLUMgrid Director: "
+ "add_router_interface() called")
with context.session.begin(subtransactions=True):
# Validate args
router_db = self._get_router(context, router_id)
# Create interface on the network controller
try:
- LOG.debug(_("PLUMgrid Library: add_router_interface() called"))
+ LOG.debug("PLUMgrid Library: add_router_interface() called")
self._plumlib.add_router_interface(tenant_id, router_id,
port_db, ipnet)
def remove_router_interface(self, context, router_id, int_info):
- LOG.debug(_("Neutron PLUMgrid Director: "
- "remove_router_interface() called"))
+ LOG.debug("Neutron PLUMgrid Director: remove_router_interface()"
+ " called")
with context.session.begin(subtransactions=True):
# Validate args
router_db = self._get_router(context, router_id)
int_info)
try:
- LOG.debug(_("PLUMgrid Library: "
- "remove_router_interface() called"))
+ LOG.debug("PLUMgrid Library: "
+ "remove_router_interface() called")
self._plumlib.remove_router_interface(tenant_id,
net_id, router_id)
return del_int_router
def create_floatingip(self, context, floatingip):
- LOG.debug(_("Neutron PLUMgrid Director: create_floatingip() called"))
+ LOG.debug("Neutron PLUMgrid Director: create_floatingip() called")
with context.session.begin(subtransactions=True):
floating_ip = super(NeutronPluginPLUMgridV2,
self).create_floatingip(context, floatingip)
try:
- LOG.debug(_("PLUMgrid Library: create_floatingip() called"))
+ LOG.debug("PLUMgrid Library: create_floatingip() called")
self._plumlib.create_floatingip(floating_ip)
except Exception as err_message:
return floating_ip
def update_floatingip(self, context, id, floatingip):
- LOG.debug(_("Neutron PLUMgrid Director: update_floatingip() called"))
+ LOG.debug("Neutron PLUMgrid Director: update_floatingip() called")
with context.session.begin(subtransactions=True):
floating_ip_orig = super(NeutronPluginPLUMgridV2,
self).update_floatingip(context, id,
floatingip)
try:
- LOG.debug(_("PLUMgrid Library: update_floatingip() called"))
+ LOG.debug("PLUMgrid Library: update_floatingip() called")
self._plumlib.update_floatingip(floating_ip_orig, floating_ip,
id)
return floating_ip
def delete_floatingip(self, context, id):
- LOG.debug(_("Neutron PLUMgrid Director: delete_floatingip() called"))
+ LOG.debug("Neutron PLUMgrid Director: delete_floatingip() called")
with context.session.begin(subtransactions=True):
super(NeutronPluginPLUMgridV2, self).delete_floatingip(context, id)
try:
- LOG.debug(_("PLUMgrid Library: delete_floatingip() called"))
+ LOG.debug("PLUMgrid Library: delete_floatingip() called")
self._plumlib.delete_floatingip(floating_ip_orig, id)
except Exception as err_message:
raise plum_excep.PLUMgridException(err_msg=err_message)
def disassociate_floatingips(self, context, port_id, do_notify=True):
- LOG.debug(_("Neutron PLUMgrid Director: disassociate_floatingips() "
- "called"))
+ LOG.debug("Neutron PLUMgrid Director: disassociate_floatingips() "
+ "called")
try:
fip_qry = context.session.query(l3_db.FloatingIP)
floating_ip = fip_qry.filter_by(fixed_port_id=port_id).one()
- LOG.debug(_("PLUMgrid Library: disassociate_floatingips()"
- " called"))
+ LOG.debug("PLUMgrid Library: disassociate_floatingips()"
+ " called")
self._plumlib.disassociate_floatingips(floating_ip, port_id)
except sa_exc.NoResultFound:
self).disassociate_floatingips(
context, port_id, do_notify=do_notify)
+ def create_security_group(self, context, security_group, default_sg=False):
+ """Create a security group
+
+ Create a new security group, including the default security group
+ """
+ LOG.debug("Neutron PLUMgrid Director: create_security_group()"
+ " called")
+
+ with context.session.begin(subtransactions=True):
+
+ sg = security_group.get('security_group')
+
+ tenant_id = self._get_tenant_id_for_create(context, sg)
+ if not default_sg:
+ self._ensure_default_security_group(context, tenant_id)
+
+ sg_db = super(NeutronPluginPLUMgridV2,
+ self).create_security_group(context, security_group,
+ default_sg)
+ try:
+ LOG.debug("PLUMgrid Library: create_security_group()"
+ " called")
+ self._plumlib.create_security_group(sg_db)
+
+ except Exception as err_message:
+ raise plum_excep.PLUMgridException(err_msg=err_message)
+
+ return sg_db
+
+ def update_security_group(self, context, sg_id, security_group):
+ """Update a security group
+
+ Update security group name/description in Neutron and PLUMgrid
+ platform
+ """
+ with context.session.begin(subtransactions=True):
+ sg_db = (super(NeutronPluginPLUMgridV2,
+ self).update_security_group(context,
+ sg_id,
+ security_group))
+ if ('name' in security_group['security_group'] and
+ sg_db['name'] != 'default'):
+ try:
+ LOG.debug("PLUMgrid Library: update_security_group()"
+ " called")
+ self._plumlib.update_security_group(sg_db)
+
+ except Exception as err_message:
+ raise plum_excep.PLUMgridException(err_msg=err_message)
+ return sg_db
+
+ def delete_security_group(self, context, sg_id):
+ """Delete a security group
+
+ Delete security group from Neutron and PLUMgrid Platform
+
+ :param sg_id: security group ID of the rule to be removed
+ """
+ with context.session.begin(subtransactions=True):
+
+ sg = super(NeutronPluginPLUMgridV2, self).get_security_group(
+ context, sg_id)
+ if not sg:
+ raise sec_grp.SecurityGroupNotFound(id=sg_id)
+
+ if sg['name'] == 'default' and not context.is_admin:
+ raise sec_grp.SecurityGroupCannotRemoveDefault()
+
+ sec_grp_ip = sg['id']
+ filters = {'security_group_id': [sec_grp_ip]}
+ if super(NeutronPluginPLUMgridV2,
+ self)._get_port_security_group_bindings(context,
+ filters):
+ raise sec_grp.SecurityGroupInUse(id=sec_grp_ip)
+
+ sec_db = super(NeutronPluginPLUMgridV2,
+ self).delete_security_group(context, sg_id)
+ try:
+ LOG.debug("PLUMgrid Library: delete_security_group()"
+ " called")
+ self._plumlib.delete_security_group(sg)
+
+ except Exception as err_message:
+ raise plum_excep.PLUMgridException(err_msg=err_message)
+
+ return sec_db
+
+ def create_security_group_rule(self, context, security_group_rule):
+ """Create a security group rule
+
+ Create a security group rule in Neutron and PLUMgrid Platform
+ """
+ LOG.debug("Neutron PLUMgrid Director: create_security_group_rule()"
+ " called")
+ bulk_rule = {'security_group_rules': [security_group_rule]}
+ return self.create_security_group_rule_bulk(context, bulk_rule)[0]
+
+ def create_security_group_rule_bulk(self, context, security_group_rule):
+ """Create security group rules
+
+ Create security group rules in Neutron and PLUMgrid Platform
+
+ :param security_group_rule: list of rules to create
+ """
+ sg_rules = security_group_rule.get('security_group_rules')
+
+ with context.session.begin(subtransactions=True):
+ sg_id = super(NeutronPluginPLUMgridV2,
+ self)._validate_security_group_rules(
+ context, security_group_rule)
+
+ # Check to make sure security group exists
+ security_group = super(NeutronPluginPLUMgridV2,
+ self).get_security_group(context,
+ sg_id)
+
+ if not security_group:
+ raise sec_grp.SecurityGroupNotFound(id=sg_id)
+
+ # Check for duplicate rules
+ self._check_for_duplicate_rules(context, sg_rules)
+
+ sec_db = (super(NeutronPluginPLUMgridV2,
+ self).create_security_group_rule_bulk_native(
+ context, security_group_rule))
+ try:
+ LOG.debug("PLUMgrid Library: create_security_"
+ "group_rule_bulk() called")
+ self._plumlib.create_security_group_rule_bulk(sec_db)
+
+ except Exception as err_message:
+ raise plum_excep.PLUMgridException(err_msg=err_message)
+
+ return sec_db
+
+ def delete_security_group_rule(self, context, sgr_id):
+ """Delete a security group rule
+
+ Delete a security group rule in Neutron and PLUMgrid Platform
+ """
+
+ LOG.debug("Neutron PLUMgrid Director: delete_security_group_rule()"
+ " called")
+
+ sgr = (super(NeutronPluginPLUMgridV2,
+ self).get_security_group_rule(context, sgr_id))
+
+ if not sgr:
+ raise sec_grp.SecurityGroupRuleNotFound(id=sgr_id)
+
+ super(NeutronPluginPLUMgridV2,
+ self).delete_security_group_rule(context, sgr_id)
+ try:
+ LOG.debug("PLUMgrid Library: delete_security_"
+ "group_rule() called")
+ self._plumlib.delete_security_group_rule(sgr)
+
+ except Exception as err_message:
+ raise plum_excep.PLUMgridException(err_msg=err_message)
+
"""
Internal PLUMgrid Fuctions
"""