Fix system scoped manageable node network failure
Before this change, if a user requested a node to be cleaned or "managed" with cleaning enabled when the user is in the system scope, Ironic would attempt to user's token to make the request to Neutron. This, unfortunately, does not work, as the neutron client explicitly requires a project ID to make the request to Neutron. As a result, Ironic now falls back to it's internal credential configuration to make the forward request, which matches the behavior if a node has been unprovisioned and the cleaning has been started automatically. Closes-Bug: 2048416 Change-Id: Id91ec6afcf89642fb3069918e768016b8b657a31
This commit is contained in:
parent
ff4e836c55
commit
c3074524da
@ -70,7 +70,11 @@ def get_client(token=None, context=None, auth_from_config=False):
|
|||||||
|
|
||||||
user_auth = None
|
user_auth = None
|
||||||
if (not auth_from_config and CONF.neutron.auth_type != 'none'
|
if (not auth_from_config and CONF.neutron.auth_type != 'none'
|
||||||
and context.auth_token):
|
and context.auth_token and not context.system_scope):
|
||||||
|
# If we have a token, we *should* use the user's auth, however we
|
||||||
|
# can only do so *if* it is a project scoped request. If it is
|
||||||
|
# system scoped, we cannot leverage user auth data to make the next
|
||||||
|
# request.
|
||||||
user_auth = keystone.get_service_auth(context, endpoint, service_auth)
|
user_auth = keystone.get_service_auth(context, endpoint, service_auth)
|
||||||
|
|
||||||
sess = keystone.get_session('neutron', timeout=CONF.neutron.timeout,
|
sess = keystone.get_session('neutron', timeout=CONF.neutron.timeout,
|
||||||
|
@ -75,6 +75,7 @@ class TestNeutronClient(base.TestCase):
|
|||||||
mock_auth, mock_sauth):
|
mock_auth, mock_sauth):
|
||||||
mock_ctxt.return_value = ctxt = mock.Mock()
|
mock_ctxt.return_value = ctxt = mock.Mock()
|
||||||
ctxt.auth_token = 'test-token-123'
|
ctxt.auth_token = 'test-token-123'
|
||||||
|
ctxt.system_scope = None
|
||||||
neutron.get_client(token='test-token-123')
|
neutron.get_client(token='test-token-123')
|
||||||
mock_ctxt.assert_called_once_with(auth_token='test-token-123')
|
mock_ctxt.assert_called_once_with(auth_token='test-token-123')
|
||||||
mock_client_init.assert_called_once_with(oslo_conf=mock.ANY,
|
mock_client_init.assert_called_once_with(oslo_conf=mock.ANY,
|
||||||
|
@ -0,0 +1,12 @@
|
|||||||
|
---
|
||||||
|
fixes:
|
||||||
|
- |
|
||||||
|
Fixes an issue where a System Scoped user could not trigger a node into
|
||||||
|
a ``manageable`` state with cleaning enabled, as the Neutron client would
|
||||||
|
attempt to utilize their user's token to create the Neutron port for the
|
||||||
|
cleaning operation, as designed. This is because with requests made in the
|
||||||
|
``system`` scope, there is no associated project and the request fails.
|
||||||
|
|
||||||
|
Ironic now checks if the request has been made with a ``system`` scope,
|
||||||
|
and if so it utilizes the internal credential configuration to communicate
|
||||||
|
with Neutron.
|
Loading…
x
Reference in New Issue
Block a user