Merge "Revert "Enable keystone token caching by OSC""

This commit is contained in:
Zuul 2023-11-15 19:41:16 +00:00 committed by Gerrit Code Review
commit 9a55a925c4
3 changed files with 6 additions and 35 deletions

View File

@ -1047,8 +1047,6 @@ function get_or_create_service {
--description="$3" \ --description="$3" \
-f value -c id -f value -c id
) )
# Drop cached token to invalidate catalog info in the token
remove_token_cache
echo $service_id echo $service_id
} }
@ -1066,6 +1064,7 @@ function _get_or_create_endpoint_with_interface {
endpoint_id=$(openstack --os-cloud devstack-system-admin endpoint create \ endpoint_id=$(openstack --os-cloud devstack-system-admin endpoint create \
$1 $2 $3 --region $4 -f value -c id) $1 $2 $3 --region $4 -f value -c id)
fi fi
echo $endpoint_id echo $endpoint_id
} }
@ -1089,8 +1088,6 @@ function get_or_create_endpoint {
if [[ -n "$5" ]]; then if [[ -n "$5" ]]; then
_get_or_create_endpoint_with_interface $1 internal $5 $2 _get_or_create_endpoint_with_interface $1 internal $5 $2
fi fi
# Drop cached token to invalidate catalog info in the token
remove_token_cache
# return the public id to indicate success, and this is the endpoint most likely wanted # return the public id to indicate success, and this is the endpoint most likely wanted
echo $public_id echo $public_id
} }
@ -2520,11 +2517,6 @@ function is_fips_enabled {
[ "$fips" == "1" ] [ "$fips" == "1" ]
} }
function remove_token_cache {
# Remove Keyring cache file
rm ~/.local/share/python_keyring/keyring_pass.cfg
}
# Restore xtrace # Restore xtrace
$_XTRACE_FUNCTIONS_COMMON $_XTRACE_FUNCTIONS_COMMON

View File

@ -138,10 +138,6 @@ function install_libs {
# doesn't pull in etcd3. # doesn't pull in etcd3.
pip_install etcd3 pip_install etcd3
pip_install etcd3gw pip_install etcd3gw
# Add libraries required for token caching by OpenStackSDK/CLI
pip_install keyring
pip_install keyrings.alt
} }
# Restore xtrace # Restore xtrace

View File

@ -30,9 +30,7 @@ class UpdateCloudsYaml(object):
self._clouds_path = os.path.expanduser( self._clouds_path = os.path.expanduser(
'~/.config/openstack/clouds.yaml') '~/.config/openstack/clouds.yaml')
self._create_directory = True self._create_directory = True
self._keyringrc_path = os.path.expanduser( self._clouds = {}
'~/.config/python_keyring/keyringrc.cfg')
self._config = {}
self._cloud = args.os_cloud self._cloud = args.os_cloud
self._cloud_data = { self._cloud_data = {
@ -67,17 +65,14 @@ class UpdateCloudsYaml(object):
def _read_clouds(self): def _read_clouds(self):
try: try:
with open(self._clouds_path) as clouds_file: with open(self._clouds_path) as clouds_file:
self._config = yaml.safe_load(clouds_file) self._clouds = yaml.safe_load(clouds_file)
except IOError: except IOError:
# The user doesn't have a clouds.yaml file. # The user doesn't have a clouds.yaml file.
print("The user clouds.yaml file didn't exist.") print("The user clouds.yaml file didn't exist.")
if "cache" not in self._config: self._clouds = {}
# Enable auth (and only auth) caching. Currently caching into the
# file on FS is configured in `_write_clouds` function.
self._config["cache"] = {"auth": True}
def _update_clouds(self): def _update_clouds(self):
self._config.setdefault('clouds', {})[self._cloud] = self._cloud_data self._clouds.setdefault('clouds', {})[self._cloud] = self._cloud_data
def _write_clouds(self): def _write_clouds(self):
@ -86,19 +81,7 @@ class UpdateCloudsYaml(object):
os.makedirs(clouds_dir) os.makedirs(clouds_dir)
with open(self._clouds_path, 'w') as clouds_file: with open(self._clouds_path, 'w') as clouds_file:
yaml.dump(self._config, clouds_file, default_flow_style=False) yaml.dump(self._clouds, clouds_file, default_flow_style=False)
# Enable keyring token caching
keyringrc_dir = os.path.dirname(self._keyringrc_path)
os.makedirs(keyringrc_dir, exist_ok=True)
# Configure auth caching into the file on FS. We do not bother of any
# expiration since SDK is smart enough to reauth once the token becomes
# invalid.
with open(self._keyringrc_path, 'w') as keyringrc_file:
keyringrc_file.write("[backend]\n")
keyringrc_file.write(
"default-keyring=keyrings.alt.file.PlaintextKeyring\n")
def main(): def main():