module-postfix/manifests/mta.pp
2013-01-25 14:03:24 -02:00

70 lines
1.8 KiB
Puppet

#
# == Class: postfix::mta
#
# This class configures a minimal MTA, listening on
# $postfix_smtp_listen (default to localhost) and delivering mail to
# $postfix_mydestination (default to $fqdn).
#
# A valid relay host is required ($postfix_relayhost) for outbound email.
#
# transport & virtual maps get configured and can be populated with
# postfix::transport and postfix::virtual
#
# Parameters:
# - *$postfix_relayhost*
# - *$postfix_mydestination*
# - every global variable which works for class "postfix" will work here.
#
# Requires:
# - Class["postfix"]
#
# Example usage:
#
# node "toto.example.com" {
#
# class { 'postfix':
# smtp_listen => "0.0.0.0",
# }
#
# class { 'postfix::mta':
# relayhost => "mail.example.com",
# mydestination => "\$myorigin, myapp.example.com",
# }
#
# postfix::transport { "myapp.example.com":
# ensure => present,
# destination => "local:",
# }
# }
#
class postfix::mta(
$mydestination = '',
$relayhost = ''
) {
#case $relayhost {
# "": { fail("Required relayhost parameter is not defined.") }
#}
case $mydestination {
"": { $postfix_mydestination = "\$myorigin" }
default: { $postfix_mydestination = "$mydestination" }
}
postfix::config {
"mydestination": value => $postfix_mydestination;
"mynetworks": value => "127.0.0.0/8";
"relayhost": value => $relayhost;
"virtual_alias_maps": value => "hash:/etc/postfix/virtual";
"transport_maps": value => "hash:/etc/postfix/transport";
}
postfix::hash { "/etc/postfix/virtual":
ensure => present,
}
postfix::hash { "/etc/postfix/transport":
ensure => present,
}
}