Create heat user in keystone profile

Rather than use the heat::keystone::domain class which also includes the
configuration options, we should just create the user for heat in
keystone independently of the configuration.

Change-Id: I7d42d04ef0c53dc1e62d684d8edacfed9fd28fbe
Related-Bug: #1638350
Closes-Bug: #1638626
This commit is contained in:
Alex Schultz 2016-11-01 13:43:17 -06:00
parent 91f764b597
commit 44d3ebe546
2 changed files with 37 additions and 16 deletions
manifests/profile/base

@ -53,7 +53,7 @@ class tripleo::profile::base::heat (
) { ) {
# Domain resources will be created at step5 on the node running keystone.pp # Domain resources will be created at step5 on the node running keystone.pp
# configure heat.conf at step3 and 4 but actually create the domain later. # configure heat.conf at step3 and 4 but actually create the domain later.
if $step == 3 or $step == 4 { if $step >= 3 {
class { '::heat::keystone::domain': class { '::heat::keystone::domain':
manage_domain => false, manage_domain => false,
manage_user => false, manage_user => false,

@ -74,6 +74,23 @@
# for more details. # for more details.
# Defaults to hiera('step') # Defaults to hiera('step')
# #
# [*heat_admin_domain*]
# domain name for heat admin
# Defaults to hiera('heat::keystone::domain::domain_name', 'heat')
#
# [*heat_admin_user*]
# heat admin user name
# Defaults to hiera('heat::keystone::domain::domain_admin', 'heat_admin')
#
# [*heat_admin_email*]
# heat admin email address
# Defaults to hiera('heat::keystone::domain::domain_admin_email',
# 'heat_admin@localhost')
#
# [*heat_admin_password*]
# heat admin password
# Defaults to hiera('heat::keystone::domain::domain_password')
#
class tripleo::profile::base::keystone ( class tripleo::profile::base::keystone (
$admin_endpoint_network = hiera('keystone_admin_api_network', undef), $admin_endpoint_network = hiera('keystone_admin_api_network', undef),
$bootstrap_node = hiera('bootstrap_nodeid', undef), $bootstrap_node = hiera('bootstrap_nodeid', undef),
@ -85,6 +102,10 @@ class tripleo::profile::base::keystone (
$rabbit_hosts = hiera('rabbitmq_node_ips', undef), $rabbit_hosts = hiera('rabbitmq_node_ips', undef),
$rabbit_port = hiera('keystone::rabbit_port', 5672), $rabbit_port = hiera('keystone::rabbit_port', 5672),
$step = hiera('step'), $step = hiera('step'),
$heat_admin_domain = hiera('heat::keystone::domain::domain_name', 'heat'),
$heat_admin_user = hiera('heat::keystone::domain::domain_admin', 'heat_admin'),
$heat_admin_email = hiera('heat::keystone::domain::domain_admin_email', 'heat_admin@localhost'),
$heat_admin_password = hiera('heat::keystone::domain::domain_password'),
) { ) {
if $::hostname == downcase($bootstrap_node) { if $::hostname == downcase($bootstrap_node) {
$sync_db = true $sync_db = true
@ -153,22 +174,22 @@ class tripleo::profile::base::keystone (
if $step >= 5 and $manage_domain { if $step >= 5 and $manage_domain {
if hiera('heat_engine_enabled', false) { if hiera('heat_engine_enabled', false) {
# if Heat and Keystone are collocated, so we want to # create these seperate and don't use ::heat::keystone::domain since
# both configure heat.conf and create Keystone resources. # that class writes out the configs
# note: domain_password is given via Hiera. keystone_domain { $heat_admin_domain:
if defined(Class['::tripleo::profile::base::heat']) { ensure => 'present',
include ::heat::keystone::domain enabled => true
} else { }
# if Heat and Keystone are not collocated, we want Puppet keystone_user { "${heat_admin_user}::${heat_admin_domain}":
# to only create Keystone resources on the Keystone node ensure => 'present',
# but not try to configure Heat, to avoid leaking the password. enabled => true,
class { '::heat::keystone::domain': email => $heat_admin_email,
domain_name => $::os_service_default, password => $heat_admin_password
domain_admin => $::os_service_default, }
domain_password => $::os_service_default, keystone_user_role { "${heat_admin_user}::${heat_admin_domain}@::${heat_admin_domain}":
} roles => ['admin'],
require => Class['::keystone::roles::admin']
} }
Class['::keystone::roles::admin'] -> Class['::heat::keystone::domain']
} }
} }