1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
|
#
# == Define: designate::generic_service
#
# This defined type implements basic designate services.
# It is introduced to attempt to consolidate
# common code.
#
# It also allows users to specify ad-hoc services
# as needed
#
# This define creates a service resource with title designate-${name} and
# conditionally creates a package resource with title designate-${name}
#
# === Parameters:
#
# [*package_name*]
# (mandatory) The package name (for the generic_service)
#
# [*service_name*]
# (mandatory) The service name (for the generic_service)
#
# [*enabled*]
# (optional) Define if the service must be enabled or not
# Defaults to false.
#
# [*manage_service*]
# (optional) Manage or not the service (if a service_name is provided).
# Defaults to true.
#
# [*package_ensure*]
# (optional) Control the ensure parameter for the package resource.
# Defaults to 'present'.
#
define designate::generic_service(
$package_name,
$service_name,
Boolean $enabled = false,
Boolean $manage_service = true,
$package_ensure = 'present',
) {
include designate::deps
include designate::params
$designate_title = "designate-${name}"
if ($package_name) {
if !defined(Package[$package_name]) {
package { $designate_title:
ensure => $package_ensure,
name => $package_name,
notify => Anchor['designate::install::end'],
tag => ['openstack', 'designate-package'],
}
}
}
if $service_name {
if $manage_service {
if $enabled {
$service_ensure = 'running'
} else {
$service_ensure = 'stopped'
}
service { $designate_title:
ensure => $service_ensure,
name => $service_name,
enable => $enabled,
hasstatus => true,
tag => ['openstack','designate-service'],
}
}
}
}
|