aboutsummaryrefslogtreecommitdiff
path: root/manifests/mail.pp
blob: 78a3b7b81d43cfd985203db934fc950e6576dac4 (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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
class nodo::mail {
  # Class for mail nodes
  $mail_delivery         = "postfix"
  $postfix_smtp_listen   = "all"
  $postfix_mydestination = '$myhostname, $mydomain, localhost.$mydomain, localhost'

  case $postfix_mynetworks {
    '': { $postfix_mynetworks = "127.0.0.0/8" }
  }

  include nodo::vserver
  include postfix
  include database
  include ssl::mail

  # The needed packages
  package { [ 'postfix-mysql', 'dovecot-imapd', 'maildrop' ]:
    ensure => installed,
  }

  package { [ 'libauthen-sasl-cyrus-perl', 'libpam-mysql', 'libsasl2-modules',
              'libsasl2-modules-sql',      'libgsasl7',    'sasl2-bin' ]:
    ensure => installed,
  }

  package { [ 'postgrey', 'amavisd-new', 'spamassassin', 'spamc' ]:
    ensure => installed,
  }

  package { [ 'clamav-base', 'clamav-daemon', 'clamav-freshclam' ]:
    ensure => installed,
  }

  package { [ 'squirrelmail', 'squirrelmail-secure-login', 'squirrelmail-locales' ]:
    ensure => installed,
  } 

  # Postfix configuration
  postfix::config {
    "mydomain":           value => "$domain";
    "myhostname":         value => "$fqdn";
    "mydestination":      value => $postfix_mydestination;
    "mynetworks":         value => "$postfix_mynetworks";
    "relay_domains":      value => "$domain";
    "virtual_alias_maps": value => "hash:/etc/postfix/virtual";
    "transport_maps":     value => "hash:/etc/postfix/transport";
    "mailbox_command":    value => '/usr/bin/maildrop -d ${USER}';
  }

  postfix::hash { "/etc/postfix/virtual":
    ensure => present,
  }

  postfix::hash { "/etc/postfix/transport":
    ensure => present,
  }

  # SASL
  postfix::config { "smtpd_sasl_auth_enable":          value => 'yes' }
  postfix::config { "smtpd_sasl_local_domain":         value => '$myhostname' }
  postfix::config { "smtpd_sasl_security_options":     value => 'noanonymous' }
  postfix::config { "broken_sasl_auth_clients":        value => 'yes' }
  postfix::config { "smtpd_sasl_authenticated_header": value => 'yes' }

  # Recipient restrictions
  postfix::config { "smtpd_recipient_restrictions":
    value => 'permit_mynetworks, permit_sasl_authenticated, reject_unauth_destination, reject_rbl_client psbl.surriel.com, check_policy_service inet:127.0.0.1:60000' }

  # TLS
  postfix::config { "smtpd_tls_cert_file": value => '/etc/ssl/certs/cert.crt' }
  postfix::config { "smtpd_tls_key_file":  value => '/etc/ssl/private/cert.pem' }
  postfix::config { "smtpd_use_tls":       value => 'yes' }
  postfix::config { "smtp_use_tls":        value => 'yes' }
}