diff options
author | intrigeri <intrigeri@boum.org> | 2011-03-05 04:45:37 +0100 |
---|---|---|
committer | intrigeri <intrigeri@boum.org> | 2011-03-05 04:45:37 +0100 |
commit | 0583cf4988aec251f129ac4c595e38ff5bb93132 (patch) | |
tree | e923af95d471b346a431827c10436eb5627227b5 /manifests/definitions/header_checks_snippet.pp | |
parent | cc8c37d5da948ac9a086a6e6ac6428d8231b7ff4 (diff) | |
download | puppet-postfix-0583cf4988aec251f129ac4c595e38ff5bb93132.tar.gz puppet-postfix-0583cf4988aec251f129ac4c595e38ff5bb93132.tar.bz2 |
Add support for managing header_checks.
This support is modeled after the existing TLS policy management: the
header_cheks file is produced by merging snippets shipped by the Puppet
fileserver, a site-module and/or postfix::header_checks_snippet defines.
Diffstat (limited to 'manifests/definitions/header_checks_snippet.pp')
-rw-r--r-- | manifests/definitions/header_checks_snippet.pp | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/manifests/definitions/header_checks_snippet.pp b/manifests/definitions/header_checks_snippet.pp new file mode 100644 index 0000000..454d219 --- /dev/null +++ b/manifests/definitions/header_checks_snippet.pp @@ -0,0 +1,67 @@ +/* +== Definition: postfix::header_checks_snippet + +Adds a header_checks snippets to /etc/postfix/header_checks. +See the postfix::header_checks class for details. + +Parameters: +- *source* or *content*: source or content of the header_checks snippet +- *ensure*: present (default) or absent + +Requires: +- Class["postfix"] + +Example usage: + + node "toto.example.com" { + include postfix + postfix::header_checks { + 'wrong_date': content => 'FIXME'; + 'bla': source => 'puppet:///files/etc/postfix/header_checks.d/bla'; + } + } + +*/ + +define postfix::header_checks_snippet ( + $ensure = "present", + $source = '', + $content = undef +) { + + if $source == '' and $content == undef { + fail("One of \$source or \$content must be specified for postfix::header_checks_snippet ${name}") + } + + if $source != '' and $content != undef { + fail("Only one of \$source or \$content must specified for postfix::header_checks_snippet ${name}") + } + + if ($value == false) and ($ensure == "present") { + fail("The value parameter must be set when using the postfix::header_checks_snippet define with ensure=present.") + } + + include postfix::header_checks + + $snippetfile = "${postfix::header_checks::postfix_header_checks_snippets_dir}/${name}" + + file { "$snippetfile": + ensure => "$ensure", + mode => 600, + owner => root, + group => 0, + notify => Exec["concat_${postfix::header_checks::postfix_merged_header_checks}"], + } + + if $source { + File["$snippetfile"] { + source => $source, + } + } + else { + File["$snippetfile"] { + content => $content, + } + } + +} |