Disable the zaqar-messaging service user

The zaqar::keystone::auth_websocket class has been added to create
an independent keystone endpoint for websocket service but the service
user created by the class has never been used.
This change disables the logic to create the user and the associated
resources like roles and projects, so that only required resources are
created.

Change-Id: Iaa0042acb9fda198f10e6067523301bfd08bf249
This commit is contained in:
Takashi Kajinami 2022-01-03 15:15:54 +09:00
parent 07822ab838
commit 7eeb46e04d
3 changed files with 77 additions and 58 deletions

View File

@ -4,62 +4,65 @@
# #
# === Parameters # === Parameters
# #
# [*password*]
# (required) Password for zaqar websocket user.
#
# [*auth_name*]
# Username for zaqar service. Defaults to 'zaqar-websocket'.
#
# [*email*]
# Email for zaqar websocket user. Defaults to 'zaqar-websocket@localhost'.
#
# [*tenant*]
# Tenant for zaqar websocket user. Defaults to 'services'.
#
# [*configure_endpoint*] # [*configure_endpoint*]
# Should zaqar websocket endpoint be configured? Defaults to 'true'. # (Optional) Should zaqar websocket endpoint be configured?
#
# [*configure_user*]
# (Optional) Should the service user be configured?
# Defaults to 'true'. # Defaults to 'true'.
# #
# [*service_type*] # [*service_type*]
# Type of service. Defaults to 'messaging'. # (Optional) Type of service.
# Defaults to 'messaging-websocket'.
# #
# [*public_url*] # [*public_url*]
# (optional) The endpoint's public url. # (Optional) The endpoint's public url.
# (Defaults to 'ws://127.0.0.1:9000') # Defaults to 'ws://127.0.0.1:9000'
# #
# [*internal_url*] # [*internal_url*]
# (optional) The endpoint's internal url. # (Optional) The endpoint's internal url.
# (Defaults to 'ws://127.0.0.1:9000') # Defaults to 'ws://127.0.0.1:9000'
# #
# [*admin_url*] # [*admin_url*]
# (optional) The endpoint's admin url. # (Optional) The endpoint's admin url.
# (Defaults to 'ws://127.0.0.1:9000') # Defaults to 'ws://127.0.0.1:9000'
# #
# [*region*] # [*region*]
# Region for endpoint. Defaults to 'RegionOne'. # (Optional) Region for endpoint.
# Defaults to 'RegionOne'.
# #
# [*service_name*] # [*service_name*]
# (optional) Name of the service. # (Optional) Name of the service.
# Defaults to 'zaqar-websocket' # Defaults to 'zaqar-websocket'
# #
# [*configure_service*] # [*configure_service*]
# Should zaqar websocket service be configured? Defaults to 'true'. # (Optional) Should zaqar websocket service be configured?
# Defaults to 'true'.
# #
# [*service_description*] # [*service_description*]
# (optional) Description for keystone service. # (Optional) Description for keystone service.
# Defaults to 'OpenStack Messaging Websocket Service'. # Defaults to 'OpenStack Messaging Websocket Service'.
#
# DEPRECATED PARAMETERS
#
# [*password*]
# (Optional) Password for zaqar websocket user. Defaults to undef.
#
# [*auth_name*]
# (Optional) Username for zaqar service. Defaults to undef.
#
# [*email*]
# (Optional) Email for zaqar websocket user. Defaults to undef.
#
# [*tenant*]
# (Optional) Tenant for zaqar websocket user. Defaults to undef.
#
# [*configure_user*]
# (Optional) Should the service user be configured?
# Defaults to undef
#
# [*configure_user_role*] # [*configure_user_role*]
# (optional) Whether to configure the admin role for the service user. # (Optional) Whether to configure the admin role for the service user.
# Defaults to true # Defaults to undef
# #
class zaqar::keystone::auth_websocket( class zaqar::keystone::auth_websocket(
$password,
$email = 'zaqar-websocket@localhost',
$auth_name = 'zaqar-websocket',
$service_name = 'zaqar-websocket', $service_name = 'zaqar-websocket',
$service_type = 'messaging-websocket', $service_type = 'messaging-websocket',
$public_url = 'ws://127.0.0.1:9000', $public_url = 'ws://127.0.0.1:9000',
@ -69,27 +72,39 @@ class zaqar::keystone::auth_websocket(
$tenant = 'services', $tenant = 'services',
$configure_endpoint = true, $configure_endpoint = true,
$configure_service = true, $configure_service = true,
$configure_user = true,
$configure_user_role = true,
$service_description = 'OpenStack Messaging Websocket Service', $service_description = 'OpenStack Messaging Websocket Service',
# DEPRECATED PARAMETERS
$auth_name = undef,
$password = undef,
$email = undef,
$configure_user = undef,
$configure_user_role = undef,
) { ) {
include zaqar::deps include zaqar::deps
validate_legacy(String, 'validate_string', $password) validate_legacy(String, 'validate_string', $password)
[
'auth_name',
'password',
'email',
'configure_user',
'configure_user_role'
].each |String $param| {
if getvar($param) != undef {
warning("The zaqar::keystone::auth_websocket::${param} parameter is deprecated and has no effect")
}
}
keystone::resource::service_identity { 'zaqar-websocket': keystone::resource::service_identity { 'zaqar-websocket':
configure_user => $configure_user, configure_user => false,
configure_user_role => $configure_user_role, configure_user_role => false,
configure_endpoint => $configure_endpoint, configure_endpoint => $configure_endpoint,
service_type => $service_type, service_type => $service_type,
service_description => $service_description, service_description => $service_description,
service_name => $service_name, service_name => $service_name,
auth_name => $auth_name,
region => $region, region => $region,
password => $password,
email => $email,
tenant => $tenant,
public_url => $public_url, public_url => $public_url,
admin_url => $admin_url, admin_url => $admin_url,
internal_url => $internal_url, internal_url => $internal_url,

View File

@ -0,0 +1,18 @@
---
upgrade:
- |
The ``zaqar::keystone::auth_websocket`` class no longer creates
the ``zaqar-websocket`` service user because it has been unused.
The service user should be deleted manually during upgrade.
deprecations:
- |
The following parameters of the ``zaqar::keystone::auth_websocket`` class
have been deprecated and have no effect now.
- ``configure_user``
- ``configure_user_role``
- ``auth_name``
- ``password``
- ``email``
- ``tenant``

View File

@ -12,17 +12,13 @@ describe 'zaqar::keystone::auth_websocket' do
end end
it { is_expected.to contain_keystone__resource__service_identity('zaqar-websocket').with( it { is_expected.to contain_keystone__resource__service_identity('zaqar-websocket').with(
:configure_user => true, :configure_user => false,
:configure_user_role => true, :configure_user_role => false,
:configure_endpoint => true, :configure_endpoint => true,
:service_name => 'zaqar-websocket', :service_name => 'zaqar-websocket',
:service_type => 'messaging-websocket', :service_type => 'messaging-websocket',
:service_description => 'OpenStack Messaging Websocket Service', :service_description => 'OpenStack Messaging Websocket Service',
:region => 'RegionOne', :region => 'RegionOne',
:auth_name => 'zaqar-websocket',
:password => 'zaqar-websocket_password',
:email => 'zaqar-websocket@localhost',
:tenant => 'services',
:public_url => 'ws://127.0.0.1:9000', :public_url => 'ws://127.0.0.1:9000',
:internal_url => 'ws://127.0.0.1:9000', :internal_url => 'ws://127.0.0.1:9000',
:admin_url => 'ws://127.0.0.1:9000', :admin_url => 'ws://127.0.0.1:9000',
@ -31,13 +27,7 @@ describe 'zaqar::keystone::auth_websocket' do
context 'when overriding parameters' do context 'when overriding parameters' do
let :params do let :params do
{ :password => 'zaqar-websocket_password', { :configure_endpoint => false,
:auth_name => 'alt_zaqar-websocket',
:email => 'alt_zaqar-websocket@alt_localhost',
:tenant => 'alt_service',
:configure_endpoint => false,
:configure_user => false,
:configure_user_role => false,
:service_description => 'Alternative OpenStack Messaging Websocket Service', :service_description => 'Alternative OpenStack Messaging Websocket Service',
:service_name => 'alt_service', :service_name => 'alt_service',
:service_type => 'alt_messaging-websocket', :service_type => 'alt_messaging-websocket',
@ -55,10 +45,6 @@ describe 'zaqar::keystone::auth_websocket' do
:service_type => 'alt_messaging-websocket', :service_type => 'alt_messaging-websocket',
:service_description => 'Alternative OpenStack Messaging Websocket Service', :service_description => 'Alternative OpenStack Messaging Websocket Service',
:region => 'RegionTwo', :region => 'RegionTwo',
:auth_name => 'alt_zaqar-websocket',
:password => 'zaqar-websocket_password',
:email => 'alt_zaqar-websocket@alt_localhost',
:tenant => 'alt_service',
:public_url => 'wss://10.10.10.10:80', :public_url => 'wss://10.10.10.10:80',
:internal_url => 'ws://10.10.10.11:81', :internal_url => 'ws://10.10.10.11:81',
:admin_url => 'ws://10.10.10.12:81', :admin_url => 'ws://10.10.10.12:81',