Files
puppet-designate/manifests/api.pp
Xingchao Yu 681250724c Remove pick for managing package name.
Change-Id: I861b7bfab076def6106df1a64e6479684f96a448
2016-01-14 04:10:23 +08:00

101 lines
2.9 KiB
Puppet

# == Class designate::api
#
# Configure designate API service
#
# == Parameters
#
# [*package_ensure*]
# (optional) The state of the package
# Defaults to 'present'
#
# [*api_package_name*]
# (optional) Name of the package containing api resources
# Defaults to $::designate::paramas::api_package_name
#
# [*enabled*]
# (optional) Whether to enable services.
# Defaults to true
#
# [*service_ensure*]
# (optional) Whether the designate api service will be running.
# Defaults to 'running'
#
# [*auth_strategy*]
# (optional) Authentication strategy to use, can be either "noauth" or "keystone"
# Defaults to 'noauth'
#
# [*keystone_host*]
# (optional) Host running auth service.
# Defaults to '127.0.0.1'
#
# [*keystone_port*]
# (optional) Port to use for auth service on auth_host.
# Defaults to '35357'
#
# [*keystone_protocol*]
# (optional) Protocol to use for auth.
# Defaults to 'http'
#
# [*keystone_tenant*]
# (optional) Tenant to authenticate to.
# Defaults to 'services'
#
# [*keystone_user*]
# (optional) User to authenticate as with keystone.
# Defaults to 'designate'
#
# [*keystone_password*]
# (optional) Password used to authentication.
# Defaults to false
#
# [*enable_api_v1*]
# (optional) Enable Designate API Version 1
# Defaults to true
#
# [*enable_api_v2*]
# (optional) Enable Designate API Version 2 (experimental)
# Defaults to false
#
class designate::api (
$package_ensure = present,
$api_package_name = $::designate::params::api_package_name,
$enabled = true,
$service_ensure = 'running',
$auth_strategy = 'noauth',
$keystone_host = '127.0.0.1',
$keystone_port = '35357',
$keystone_protocol = 'http',
$keystone_tenant = 'services',
$keystone_user = 'designate',
$keystone_password = false,
$enable_api_v1 = true,
$enable_api_v2 = false,
) inherits designate {
# API Service
designate_config {
'service:api/auth_strategy' : value => $auth_strategy;
'service:api/enable_api_v1' : value => $enable_api_v1;
'service:api/enable_api_v2' : value => $enable_api_v2;
}
# Keystone Middleware
designate_config {
'keystone_authtoken/auth_host' : value => $keystone_host;
'keystone_authtoken/auth_port' : value => $keystone_port;
'keystone_authtoken/auth_protocol' : value => $keystone_protocol;
'keystone_authtoken/admin_tenant_name' : value => $keystone_tenant;
'keystone_authtoken/admin_user' : value => $keystone_user;
'keystone_authtoken/admin_password' : value => $keystone_password, secret => true;
}
designate::generic_service { 'api':
enabled => $enabled,
manage_service => $service_ensure,
ensure_package => $package_ensure,
package_name => $api_package_name,
service_name => $::designate::params::api_service_name,
}
}