Use OPENSTACK_ENDPOINT_TYPE by default

This is follow-up of I8438bedaf7cead452fc499e484d23690b48894d9 and
ensures the OPENSTACK_ENDPOINT_TYPE parameter is used when
OPENSTACK_KEYSTONE_ENDPOINT_TYPE is not set. This avoids backward-
incompatible change which affects deployments with endpoint type set
to non-default values.

Co-Authored-By: Akihiro Motoki <amotoki@gmail.com>
Change-Id: I94d2d3e31fc0103773fb5d3ed2f5f792e8851f78
This commit is contained in:
Takashi Kajinami 2022-12-19 17:05:10 +09:00 committed by Akihiro Motoki
parent 0add65eddc
commit 9fa98969e7
7 changed files with 21 additions and 19 deletions

View File

@ -600,10 +600,12 @@ OPENSTACK_KEYSTONE_ENDPOINT_TYPE
.. versionadded:: 23.1.0(Antelope) .. versionadded:: 23.1.0(Antelope)
Default: ``"publicURL"`` Default: ``None``
A string which specifies the endpoint type to use for the Keystone (identity) A string which specifies the endpoint type to use for the Keystone (identity)
endpoint when looking it up in the service catalog. endpoint when looking it up in the service catalog. This overrides
the ``OPENSTACK_ENDPOINT_TYPE`` parameter. If set to ``None``,
``OPENSTACK_ENDPOINT_TYPE`` is used for the identity endpoint.
OPENSTACK_HOST OPENSTACK_HOST
-------------- --------------

View File

@ -171,7 +171,10 @@ class KeystoneBackend(object):
region_name = id_endpoint['region'] region_name = id_endpoint['region']
break break
interface = settings.OPENSTACK_KEYSTONE_ENDPOINT_TYPE if settings.OPENSTACK_KEYSTONE_ENDPOINT_TYPE:
interface = settings.OPENSTACK_KEYSTONE_ENDPOINT_TYPE
else:
interface = settings.OPENSTACK_ENDPOINT_TYPE
endpoint = scoped_auth_ref.service_catalog.url_for( endpoint = scoped_auth_ref.service_catalog.url_for(
service_type='identity', service_type='identity',

View File

@ -28,7 +28,7 @@ OPENSTACK_KEYSTONE_URL = "http://localhost/identity/v3"
# TODO(amotoki): The default value in openstack_dashboard is different: # TODO(amotoki): The default value in openstack_dashboard is different:
# publicURL. It should be consistent. # publicURL. It should be consistent.
OPENSTACK_ENDPOINT_TYPE = 'public' OPENSTACK_ENDPOINT_TYPE = 'public'
OPENSTACK_KEYSTONE_ENDPOINT_TYPE = 'public' OPENSTACK_KEYSTONE_ENDPOINT_TYPE = None
OPENSTACK_SSL_NO_VERIFY = False OPENSTACK_SSL_NO_VERIFY = False
# TODO(amotoki): Is it correct? # TODO(amotoki): Is it correct?
OPENSTACK_SSL_CACERT = True OPENSTACK_SSL_CACERT = True

View File

@ -77,7 +77,8 @@ class Service(base.APIDictWrapper):
super().__init__(service, *args, **kwargs) super().__init__(service, *args, **kwargs)
self.public_url = base.get_url_for_service(service, region, self.public_url = base.get_url_for_service(service, region,
'publicURL') 'publicURL')
if (service and 'type' in service and service['type'] == 'identity'): if (service.get('type') == 'identity' and
settings.OPENSTACK_KEYSTONE_ENDPOINT_TYPE):
endpoint_type = settings.OPENSTACK_KEYSTONE_ENDPOINT_TYPE endpoint_type = settings.OPENSTACK_KEYSTONE_ENDPOINT_TYPE
else: else:
endpoint_type = settings.OPENSTACK_ENDPOINT_TYPE endpoint_type = settings.OPENSTACK_ENDPOINT_TYPE

View File

@ -354,10 +354,9 @@ OPENSTACK_ENDPOINT_TYPE = 'publicURL'
# value should differ from OPENSTACK_ENDPOINT_TYPE if used. # value should differ from OPENSTACK_ENDPOINT_TYPE if used.
SECONDARY_ENDPOINT_TYPE = None SECONDARY_ENDPOINT_TYPE = None
# OPENSTACK_KEYSTONE_ENDPOINT_TYPE specifies the endpoint type use from # OPENSTACK_KEYSTONE_ENDPOINT_TYPE specifies the endpoint type use from
# service catalog when looking up the Keystone (identity) endpoint. The # service catalog when looking up the Keystone (identity) endpoint. This
# default is 'publicURL' like OPENSTACK_ENDPOINT_TYPE to keep backward # parameter overrides OPENSTACK_ENDPOINT_TYPE.
# compatibility. OPENSTACK_KEYSTONE_ENDPOINT_TYPE = None
OPENSTACK_KEYSTONE_ENDPOINT_TYPE = 'publicURL'
# Set True to disable SSL certificate checks # Set True to disable SSL certificate checks
# (useful for self-signed certificates): # (useful for self-signed certificates):

View File

@ -119,11 +119,11 @@ class ServiceAPITests(test.APIMockTestCase):
service = api.keystone.Service(identity_data, "RegionOne") service = api.keystone.Service(identity_data, "RegionOne")
self.assertEqual(u"identity (native backend)", str(service)) self.assertEqual(u"identity (native backend)", str(service))
self.assertEqual("RegionOne", service.region) self.assertEqual("RegionOne", service.region)
self.assertEqual("http://public.keystone.example.com/identity/v3", self.assertEqual("http://int.keystone.example.com/identity/v3",
service.url) service.url)
self.assertEqual("http://public.keystone.example.com/identity/v3", self.assertEqual("http://public.keystone.example.com/identity/v3",
service.public_url) service.public_url)
self.assertEqual("public.keystone.example.com", service.host) self.assertEqual("int.keystone.example.com", service.host)
@override_settings(OPENSTACK_ENDPOINT_TYPE='publicURL') @override_settings(OPENSTACK_ENDPOINT_TYPE='publicURL')
def test_service_wrapper_for_public_endpoint_type(self): def test_service_wrapper_for_public_endpoint_type(self):

View File

@ -1,11 +1,8 @@
--- ---
features: features:
- | - |
Added new setting ``OPENSTACK_KEYSTONE_ENDPOINT_TYPE`` that can be used to Added a new setting ``OPENSTACK_KEYSTONE_ENDPOINT_TYPE`` that can be used to
specify the endpoint type to use when talking to the identity API. The default specify the endpoint type to use when talking to the identity API.
is set to the value of ``OPENSTACK_ENDPOINT_TYPE`` for backward compatibility. By default, ``OPENSTACK_ENDPOINT_TYPE`` is still referred for the identity
upgrade: API, If you would like to use a different endpoint for the identity API,
- | you can use this setting.
If you are setting ``OPENSTACK_ENDPOINT_TYPE`` to change the default endpoint type
for Keystone you must now set ``OPENSTACK_KEYSTONE_ENDPOINT_TYPE`` as the former
now only applies to other services.