From 1820686852fe5742547f106a4696bf4530fa970c Mon Sep 17 00:00:00 2001 From: Dan Wendlandt Date: Sat, 8 Sep 2012 22:25:19 -0700 Subject: [PATCH] fix generation of exception for mismatched floating ip tenant-ids bug 1048104 There was a KeyError in the case where we tried to throw an exception to inform the user that a newly created floating ip could not be associated with the requested port because they belonged to different tenants. Change-Id: I387e5f166761da78b941b62a9a396809491b8f09 --- quantum/db/l3_db.py | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/quantum/db/l3_db.py b/quantum/db/l3_db.py index cea813d8659..6e5b59a5536 100644 --- a/quantum/db/l3_db.py +++ b/quantum/db/l3_db.py @@ -399,10 +399,17 @@ class L3_NAT_db_mixin(l3.RouterPluginBase): """ internal_port = self._get_port(context, fip['port_id']) if not internal_port['tenant_id'] == fip['tenant_id']: - msg = ('Port %s is associated with a different tenant' - 'and therefore cannot be found to floating IP %s' - % (fip['port_id'], fip['id'])) - raise q_exc.BadRequest(resource='floating', msg=msg) + port_id = fip['port_id'] + if 'id' in fip: + floatingip_id = fip['id'] + msg = _('Port %(port_id)s is associated with a different ' + 'tenant than Floating IP %(floatingip_id)s and ' + 'therefore cannot be bound.') + else: + msg = _('Cannnot create floating IP and bind it to ' + 'Port %(port_id)s, since that port is owned by a ' + 'different tenant.') + raise q_exc.BadRequest(resource='floatingip', msg=msg % locals()) internal_subnet_id = None if 'fixed_ip_address' in fip and fip['fixed_ip_address']: