diff --git a/manifests/master.pp b/manifests/master.pp index 6d7e26a..6c14981 100644 --- a/manifests/master.pp +++ b/manifests/master.pp @@ -1,113 +1,117 @@ # munin::master - Define a munin master # # The munin master will install munin, and collect all exported munin # node definitions as files into /etc/munin/munin-conf.d/. # # Parameters: # # - node_definitions: A hash of node definitions used by # create_resources to make static node definitions. # # - graph_strategy: 'cgi' (default) or 'cron' # Controls if munin-graph graphs all services ('cron') or if graphing is done # by munin-cgi-graph (which must configured seperatly) # # - html_strategy: 'cgi' (default) or 'cron' # Controls if munin-html will recreate all html pages every run interval # ('cron') or if html pages are generated by munin-cgi-graph (which must # configured seperatly) # # - config_root: the root directory of the munin master configuration. # Default: /etc/munin on most platforms. # # - collect_nodes: 'enabled' or 'disabled' default 'enabled'. # Makes puppetmaster collect exported node_definitions. # # - dbdir: Path to the munin dbdir, where munin stores everything # # - htmldir: Path to where munin will generate HTML documents and # graphs, used if graph_strategy is cron. # # - rundir: Path to directory munin uses for pid and lock files. # # - tls: 'enabled' or 'disabled' (default). Controls the use of TLS # globally for master to node communications. # # - tls_certificate: Path to a file containing a TLS certificate. No # default. Required if tls is enabled. # # - tls_private_key: Path to a file containing a TLS key. No default. # Required if tls is enabled. # # - tls_verify_certificate: 'yes' (default) or 'no'. +# +# - extra_config: Extra lines of config to put in munin.conf. class munin::master ( $node_definitions = $munin::params::master::node_defintions, $graph_strategy = $munin::params::master::graph_strategy, $html_strategy = $munin::params::master::html_strategy, $config_root = $munin::params::master::config_root, $collect_nodes = $munin::params::master::collect_nodes, $dbdir = $munin::params::master::dbdir, $htmldir = $munin::params::master::htmldir, $logdir = $munin::params::master::logdir, $rundir = $munin::params::master::rundir, $tls = $munin::params::master::tls, $tls_certificate = $munin::params::master::tls_certificate, $tls_private_key = $munin::params::master::tls_private_key, $tls_verify_certificate = $munin::params::master::tls_verify_certificate, - + $extra_config = $munin::params::master::extra_config, ) inherits munin::params::master { if $node_definitions { validate_hash($node_definitions) } if $graph_strategy { validate_re($graph_strategy, [ '^cgi$', '^cron$' ]) } if $html_strategy { validate_re($html_strategy, [ '^cgi$', '^cron$' ]) } validate_re($collect_nodes, [ '^enabled$', '^disabled$' ]) validate_absolute_path($config_root) validate_re($tls, [ '^enabled$', '^disabled$' ]) if $tls == 'enabled' { validate_re($tls_verify_certificate, [ '^yes$', '^no$' ]) validate_absolute_path($tls_private_key) validate_absolute_path($tls_certificate) } + validate_array($extra_config) + # The munin package and configuration package { 'munin': ensure => latest, } File { owner => 'root', group => 'root', mode => '0644', require => Package['munin'], } file { "${config_root}/munin.conf": content => template('munin/munin.conf.erb'), } file { "${config_root}/munin-conf.d": ensure => directory, recurse => true, purge => true, force => true, } if $collect_nodes == 'enabled' { # Collect all exported node definitions Munin::Master::Node_definition <<| mastername == $::fqdn or mastername == '' |>> } # Create static node definitions if $node_definitions { create_resources(munin::master::node_definition, $node_definitions, {}) } } diff --git a/manifests/params/master.pp b/manifests/params/master.pp index 69724f2..862e224 100644 --- a/manifests/params/master.pp +++ b/manifests/params/master.pp @@ -1,29 +1,30 @@ class munin::params::master { $message = "Unsupported osfamily ${::osfamily}" $graph_strategy = 'cgi' $html_strategy = 'cgi' $node_definitions = '' $collect_nodes = 'enabled' $dbdir = undef $htmldir = undef $logdir = undef $rundir = undef $tls = 'disabled' $tls_certificate = undef $tls_private_key = undef $tls_verify_certificate = 'yes' + $extra_config = [] case $::osfamily { 'Debian', 'RedHat': { $config_root = '/etc/munin' } 'Solaris': { $config_root = '/opt/local/etc/munin' } default: { fail($message) } } } diff --git a/templates/munin.conf.erb b/templates/munin.conf.erb index a0bab83..29f47de 100644 --- a/templates/munin.conf.erb +++ b/templates/munin.conf.erb @@ -1,31 +1,37 @@ # /etc/munin/munin.conf - Configuration file for the munin master # # This file is handled by puppet, all local modifications will be lost <% if @dbdir -%> dbdir <%= @dbdir %> <% end -%> <% if @htmldir -%> htmldir <%= @htmldir %> <% end -%> <% if @logdir -%> logdir <%= @logdir %> <% end -%> <% if @rundir -%> rundir <%= @rundir %> <% end -%> <% if @html_strategy -%> html_strategy <%= @html_strategy %> <% end -%> <% if @graph_strategy -%> graph_strategy <%= @graph_strategy %> <% end -%> <% if @tls == 'enabled' -%> tls = <%= @tls %> tls_certificate = <%= @tls_certificate %> tls_private_key = <%= @tls_private_key %> tls_verify_certificate = <%= @tls_verify_certificate %> <% end -%> +<% if @extra_config -%> + +<% @extra_config.each do |this| -%> +<%= this %> +<% end -%> +<% end -%> # Where to look for puppet generated munin master configuration. includedir /etc/munin/munin-conf.d