Colleen Murphy 282121a28f Use "default" domain in auth credentials
Even if we change the default domain, the admin user and admin project
created by keystone::roles::admin belong to the domain with ID
"default". When the admin token is disabled with
keystone::disable_admin_auth_token, puppet needs to use the admin user
and password with the domain it was created in.

Eventually the keystone::roles::admin class should be adjusted to
properly re-create the admin resources in the new default domain. This
patch should help fix CI in the meantime.

Change-Id: I6eea23c588de0498b8f3c412e3fe9c4a09efd2f7
2016-02-20 22:36:17 -08:00

59 lines
1.8 KiB
Puppet

# Configure the Keystone service
#
# [*default_domain*]
# (optional) Define the default domain id.
# Set to 'undef' for 'Default' domain.
# Default to undef.
#
# [*using_domain_config*]
# (optional) Eases the use of the keystone_domain_config resource type.
# It ensures that a directory for holding the domain configuration is present
# and the associated configuration in keystone.conf is set up right.
# Defaults to false
#
class openstack_integration::keystone (
$default_domain = undef,
$using_domain_config = false,
) {
class { '::keystone::client': }
class { '::keystone::cron::token_flush': }
class { '::keystone::db::mysql':
password => 'keystone',
}
class { '::keystone':
verbose => true,
debug => true,
database_connection => 'mysql+pymysql://keystone:keystone@127.0.0.1/keystone',
admin_token => 'admin_token',
enabled => true,
service_name => 'httpd',
default_domain => $default_domain,
using_domain_config => $using_domain_config,
# RDO is now using default value (keystone-paste.ini)
# so we make sure the value is undef for both distros.
# once this patch will be merged, we'll patch puppet-keystone to drop default in params.pp
# and drop this parameter here.
paste_config => 'keystone-paste.ini',
}
include ::apache
class { '::keystone::wsgi::apache':
ssl => false,
workers => 2,
}
class { '::keystone::roles::admin':
email => 'test@example.tld',
password => 'a_big_secret',
}
class { '::keystone::endpoint':
default_domain => $default_domain,
}
class { '::keystone::disable_admin_token_auth': }
class { '::openstack_extras::auth_file':
password => 'a_big_secret',
project_domain => 'default',
user_domain => 'default',
}
}