110 lines
3.0 KiB
Puppet
110 lines
3.0 KiB
Puppet
# Installs & configure the octavia service
|
|
#
|
|
# == Parameters
|
|
#
|
|
# [*enabled*]
|
|
# (optional) Should the service be enabled.
|
|
# Defaults to true
|
|
#
|
|
# [*manage_service*]
|
|
# (optional) Whether the service should be managed by Puppet.
|
|
# Defaults to true.
|
|
#
|
|
# [*keystone_user*]
|
|
# (optional) The name of the auth user
|
|
# Defaults to octavia
|
|
#
|
|
# [*keystone_tenant*]
|
|
# (optional) Tenant to authenticate with.
|
|
# Defaults to 'services'.
|
|
#
|
|
# [*keystone_password*]
|
|
# (Required) Password to authenticate with.
|
|
#
|
|
# [*keystone_auth_uri*]
|
|
# (optional) Public Identity API endpoint.
|
|
# Defaults to 'http://127.0.0.0:5000'.
|
|
#
|
|
# [*keystone_identity_uri*]
|
|
# (optional) Complete admin Identity API endpoint.
|
|
# Defaults to: $::os_service_default
|
|
#
|
|
# [*host*]
|
|
# (optional) The octavia api bind address.
|
|
# Defaults to 0.0.0.0
|
|
#
|
|
# [*port*]
|
|
# (optional) The octavia api port.
|
|
# Defaults to 9876
|
|
#
|
|
# [*package_ensure*]
|
|
# (optional) ensure state for package.
|
|
# Defaults to 'present'
|
|
#
|
|
# [*sync_db*]
|
|
# (optional) Run octavia-db-manage upgrade head on api nodes after installing the package.
|
|
# Defaults to false
|
|
|
|
class octavia::api (
|
|
$keystone_password,
|
|
$manage_service = true,
|
|
$enabled = true,
|
|
$package_ensure = 'present',
|
|
$keystone_user = 'octavia',
|
|
$keystone_tenant = 'services',
|
|
$keystone_auth_uri = 'http://127.0.0.0:5000',
|
|
$keystone_identity_uri = $::os_service_default,
|
|
$host = '0.0.0.0',
|
|
$port = '9876',
|
|
$sync_db = false,
|
|
) inherits octavia::params {
|
|
|
|
include ::octavia::policy
|
|
|
|
validate_string($keystone_password)
|
|
|
|
Octavia_config<||> ~> Service['octavia-api']
|
|
Class['octavia::policy'] ~> Service['octavia-api']
|
|
|
|
Package['octavia-api'] -> Service['octavia-api']
|
|
Package['octavia-api'] -> Class['octavia::policy']
|
|
package { 'octavia-api':
|
|
ensure => $package_ensure,
|
|
name => $::octavia::params::api_package_name,
|
|
tag => ['openstack', 'octavia-package'],
|
|
}
|
|
|
|
if $manage_service {
|
|
if $enabled {
|
|
$service_ensure = 'running'
|
|
} else {
|
|
$service_ensure = 'stopped'
|
|
}
|
|
}
|
|
|
|
if $sync_db {
|
|
include ::octavia::db::sync
|
|
}
|
|
|
|
service { 'octavia-api':
|
|
ensure => $service_ensure,
|
|
name => $::octavia::params::api_service_name,
|
|
enable => $enabled,
|
|
hasstatus => true,
|
|
hasrestart => true,
|
|
require => Class['octavia::db'],
|
|
tag => ['octavia-service', 'octavia-db-sync-service'],
|
|
}
|
|
|
|
octavia_config {
|
|
'keystone_authtoken/auth_uri' : value => $keystone_auth_uri;
|
|
'keystone_authtoken/admin_tenant_name' : value => $keystone_tenant;
|
|
'keystone_authtoken/admin_user' : value => $keystone_user;
|
|
'keystone_authtoken/admin_password' : value => $keystone_password, secret => true;
|
|
'keystone_authtoken/identity_uri' : value => $keystone_identity_uri;
|
|
'api/host' : value => $host;
|
|
'api/port' : value => $port;
|
|
}
|
|
|
|
}
|