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:
Julia Kreger 2024-01-08 10:15:06 -08:00
parent ff4e836c55
commit c3074524da
3 changed files with 18 additions and 1 deletions

View File

@ -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,

View File

@ -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,

View File

@ -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.