136 lines
4.2 KiB
Puppet
136 lines
4.2 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
|
|
#
|
|
# [*keystone_memcached_servers*]
|
|
# (optional) Memcached Servers for keystone. Supply a list of memcached server
|
|
# IP's:Memcached Port.
|
|
# 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
|
|
#
|
|
# [*enable_api_admin*]
|
|
# (optional) Enable Designate Admin API
|
|
# Defaults to false.
|
|
#
|
|
# [*api_host*]
|
|
# (optional) Address to bind the API server
|
|
# Defaults to '0.0.0.0'
|
|
#
|
|
# [*api_port*]
|
|
# (optional) Port the bind the API server to
|
|
# Defaults to '9001'
|
|
#
|
|
# [*api_base_uri*]
|
|
# Set the base URI of the Designate API service.
|
|
#
|
|
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,
|
|
$keystone_memcached_servers = false,
|
|
$enable_api_v1 = true,
|
|
$enable_api_v2 = false,
|
|
$enable_api_admin = false,
|
|
$api_host = '0.0.0.0',
|
|
$api_port = '9001',
|
|
$api_base_uri = $::os_service_default,
|
|
) inherits designate {
|
|
|
|
# API Service
|
|
designate_config {
|
|
'service:api/api_host' : value => $api_host;
|
|
'service:api/api_port' : value => $api_port;
|
|
'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;
|
|
'service:api/enable_api_admin' : value => $enable_api_admin;
|
|
'service:api/api_base_uri' : value => $api_base_uri;
|
|
}
|
|
|
|
# Keystone Middleware
|
|
if $keystone_memcached_servers {
|
|
designate_config { 'keystone_authtoken/memcached_servers' : value => join(any2array($keystone_memcached_servers), ',') }
|
|
} else {
|
|
designate_config { 'keystone_authtoken/memcached_servers' : ensure => absent, }
|
|
}
|
|
|
|
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,
|
|
}
|
|
|
|
}
|