blob: 50b861b5887e675088233a855f0069d4707acd35 (
plain)
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
|
# configure a specific munin plugin
#
# We only manage the plugin if it is not set to absent.
# A plugin (or its config) that should be removed should
# be purged by the recursively managed plugins- or
# config-directory. So we can safe a few resources being
# managed.
define munin::plugin (
$ensure = 'present',
$script_path_in = '',
$config = '',
) {
if $ensure != 'absent' {
include munin::plugin::scriptpaths
include munin::plugins::setup
$real_script_path = $script_path_in ? {
'' => $munin::plugin::scriptpaths::script_path,
default => $script_path_in
}
$plugin_src = $ensure ? {
'present' => $name,
default => $ensure
}
file { "/etc/munin/plugins/${name}":
ensure => link,
target =>"${real_script_path}/${plugin_src}",
notify => Service['munin-node'];
}
if (str2bool($::selinux) == true) and (($::operatingsystem != 'CentOS') or ($::operatingsystem == 'CentOS' and $::operatingsystemmajrelease != '5')){
File["/etc/munin/plugins/${name}"]{
seltype => 'munin_etc_t',
}
}
if !empty($config) {
file { "/etc/munin/plugin-conf.d/${name}.conf":
content => inline_template("[<%= @name %>]\n<%= Array(@config).join(\"\n\") %>\n"),
owner => root,
group => 0,
mode => '0640',
}
}
}
}
|