puppet-sahara/manifests/service/api.pp
Denis Egorenko 0c465a0333 Remove require on main init class
Now all Sahara packages are fixed and we don't need use require
for main init.pp class from service classes anymore.

Change-Id: If11b03675ed62f3f56e69cb4fbeb75a3d46a5ab7
2015-12-09 20:27:20 +03:00

67 lines
1.5 KiB
Puppet

# == Class: sahara::service::api
#
# Installs & configure the Sahara API service
#
# === Parameters
#
# [*api_workers*]
# (Optional) Number of workers for Sahara API service
# 0 means all-in-one-thread configuration
# Defaults to $::os_service_default
#
# [*enabled*]
# (Optional) Should the service be enabled.
# Defaults to 'true'.
#
# [*manage_service*]
# (Optional) Whether the service should be managed by Puppet.
# Defaults to 'true'.
#
# [*package_ensure*]
# (Optional) Ensure state for package.
# Defaults to 'present'
#
class sahara::service::api (
$api_workers = $::os_service_default,
$enabled = true,
$manage_service = true,
$package_ensure = 'present',
) {
include ::sahara::policy
include ::sahara::params
Sahara_config<||> ~> Service['sahara-api']
Class['sahara::policy'] ~> Service['sahara-api']
package { 'sahara-api':
ensure => $package_ensure,
name => $::sahara::params::api_package_name,
tag => ['openstack', 'sahara-package'],
notify => Service['sahara-api'],
}
sahara_config {
'DEFAULT/api_workers': value => $api_workers;
}
if $manage_service {
if $enabled {
$service_ensure = 'running'
} else {
$service_ensure = 'stopped'
}
}
service { 'sahara-api':
ensure => $service_ensure,
name => $::sahara::params::api_service_name,
enable => $enabled,
hasstatus => true,
hasrestart => true,
require => Package['sahara-api'],
tag => 'sahara-service',
}
}