summaryrefslogtreecommitdiff
path: root/puppet/modules/leap_mx/manifests/init.pp
blob: 6bdcec420f3b9e96e0a9622ae132d5ab6f1d90b3 (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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
class leap_mx {

  $leap_mx          = hiera('couchdb_leap_mx_user')
  $couchdb_user     = $leap_mx['username']
  $couchdb_password = $leap_mx['password']

  $couchdb_host     = 'localhost'
  $couchdb_port     = '4096'

  $sources          = hiera('sources')

  include soledad::common
  include site_apt::preferences::twisted

  #
  # USER AND GROUP
  #
  # Make the user for leap-mx. This user is where all legitimate, non-system
  # mail is delivered so leap-mx can process it. Previously, we let the system
  # pick a uid/gid, but we need to know what they are set to in order to set the
  # virtual_uid_maps and virtual_gid_maps. Its a bit overkill write a fact just
  # for this, so instead we pick arbitrary numbers that seem unlikely to be used
  # and then use them in the postfix configuration

  group { 'leap-mx':
    ensure    => present,
    gid       => 42424,
    allowdupe => false;
  }

  user { 'leap-mx':
    ensure     => present,
    comment    => 'Leap Mail',
    allowdupe  => false,
    uid        => 42424,
    gid        => 'leap-mx',
    home       => '/var/mail/leap-mx',
    shell      => '/bin/false',
    managehome => true,
    require    => Group['leap-mx'];
  }

  file {
    '/var/mail/leap-mx':
      ensure  => directory,
      owner   => 'leap-mx',
      group   => 'leap-mx',
      mode    => '0755',
      require => User['leap-mx'];

    '/var/mail/leap-mx/Maildir':
      ensure => directory,
      owner  => 'leap-mx',
      group  => 'leap-mx',
      mode   => '0700';

    '/var/mail/leap-mx/Maildir/new':
      ensure => directory,
      owner  => 'leap-mx',
      group  => 'leap-mx',
      mode   => '0700';

    '/var/mail/leap-mx/Maildir/cur':
      ensure => directory,
      owner  => 'leap-mx',
      group  => 'leap-mx',
      mode   => '0700';

    '/var/mail/leap-mx/Maildir/tmp':
      ensure => directory,
      owner  => 'leap-mx',
      group  => 'leap-mx',
      mode   => '0700';
  }

  #
  # LEAP-MX CONFIG
  #

  file { '/etc/leap/mx.conf':
    content => template('leap_mx/mx.conf.erb'),
    owner   => 'leap-mx',
    group   => 'leap-mx',
    mode    => '0600',
    notify  => Service['leap-mx'];
  }

  leap::logfile { 'leap-mx':
    log => '/var/log/leap/mx.log',
    process => 'leap-mx'
  }

  #
  # LEAP-MX CODE AND DEPENDENCIES
  #

  package {
    $sources['leap-mx']['package']:
      ensure  => $sources['leap-mx']['revision'],
      require => [
        Class['site_apt::preferences::twisted'],
        Class['site_apt::leap_repo'],
        User['leap-mx'] ];

    'leap-keymanager':
      ensure => latest;
  }

  #
  # LEAP-MX DAEMON
  #

  service { 'leap-mx':
    ensure     => running,
    enable     => true,
    hasstatus  => true,
    hasrestart => true,
    require    => [ Package['leap-mx'] ];
  }
}