diff options
author | varac <varacanero@zeromail.org> | 2015-05-12 20:18:28 +0200 |
---|---|---|
committer | varac <varacanero@zeromail.org> | 2015-05-12 20:18:28 +0200 |
commit | b0c973424dfca43087636ac75f9f0674adda5d6e (patch) | |
tree | 9af886eeee35377f39e1755eaa29f7abeeaabda5 /manifests/ps.pp | |
parent | 205859d87884ac4ceee6d1365548e7dc55640bfa (diff) | |
parent | 9930649228a509eda998699e213ed458685763f0 (diff) |
Merge remote-tracking branch 'shared/master' into leap_master
Diffstat (limited to 'manifests/ps.pp')
-rw-r--r-- | manifests/ps.pp | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/manifests/ps.pp b/manifests/ps.pp new file mode 100644 index 0000000..1171a13 --- /dev/null +++ b/manifests/ps.pp @@ -0,0 +1,34 @@ +define check_mk::ps ( + $target, + $host, + $desc, + $procname = "/usr/sbin/${desc}", + $levels = '1, 1, 1, 1', + $user = undef +) { + # This class is called on check-mk agent machines in order to create + # checks using the built-in ps check type. They create stored configs + # and then the check_mk::server::collect_ps class on the server + # generates the config file to set them up + + # lines in the ps.mk config file look like + # ( "foo.example.com", "ps", "NAME", ( "/usr/sbin/foo", 1, 1, 1, 1 ) ) + # or with a user + # ( "foo.example.com", "ps", "NAME", ( "/usr/sbin/foo", "user", 1, 1, 1, 1 ) ) + if $user { + $check = " ( \"${host}\", \"ps\", \"${desc}\", ( \"${procname}\", ${user}, ${levels} ) ),\n" + } else { + $check = " ( \"${host}\", \"ps\", \"${desc}\", ( \"${procname}\", ${levels} ) ),\n" + } + + # FIXME: we could be smarter about this and consolidate host checks + # that have identical settings and that would make the config file + # make more sense for humans. but for now we'll just do separate + # lines (which may result in a very large file, but check-mk is fine) + concat::fragment { "check_mk_ps-${host}_${desc}": + target => $target, + content => $check, + order => 20 + } +} + |