
This adds defined anchor points for external modules to hook into the software install, config and service dependency chain. This allows external modules to manage software installation (virtualenv, containers, etc) and service management (pacemaker) without needing rely on resources that may change or be renamed. Change-Id: I00cf4846bb933291469be94c9debed425eddf798
53 lines
1.2 KiB
Puppet
53 lines
1.2 KiB
Puppet
# == Class: swift::keystone::dispersion
|
|
#
|
|
# This class creates a user in Keystone for the swift-dispersion-report
|
|
# and swift-dispersion-populate tools.
|
|
#
|
|
# The user is given the admin role in the services tenant.
|
|
#
|
|
# Use the class swift::dispersion to create the matching config file.
|
|
#
|
|
# === Parameters
|
|
#
|
|
# [*auth_user*]
|
|
# String. The name of the user.
|
|
# Optional. Defaults to 'dispersion'.
|
|
#
|
|
# [*auth_pass*]
|
|
# String. The user's password.
|
|
# Optional. Defaults to 'dispersion_password'.
|
|
#
|
|
# [*email*]
|
|
# (Optional) The email address for the swift service user
|
|
# Defaults to 'swift@localhost'
|
|
#
|
|
# [*tenant*]
|
|
# (Optional) The tenant to use for the swift service user
|
|
# Defaults to 'services'
|
|
#
|
|
# === Authors
|
|
#
|
|
# Francois Charlier fcharlier@ploup.net
|
|
#
|
|
class swift::keystone::dispersion(
|
|
$auth_user = 'dispersion',
|
|
$auth_pass = 'dispersion_password',
|
|
$email = 'swift@localhost',
|
|
$tenant = 'services'
|
|
) {
|
|
|
|
include ::swift::deps
|
|
|
|
keystone_user { $auth_user:
|
|
ensure => present,
|
|
password => $auth_pass,
|
|
email => $email,
|
|
}
|
|
|
|
keystone_user_role { "${auth_user}@${tenant}":
|
|
ensure => present,
|
|
roles => 'admin',
|
|
require => Keystone_user[$auth_user],
|
|
}
|
|
}
|