annotate mail.py @ 300:e9950e0185b0

more hosts
author drewp@bigasterisk.com
date Wed, 07 Aug 2024 00:58:20 -0700
parents 67fb7b27bfea
children c44677a25baf
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
16
c5784e3d4f8d mail/postfix setup on prime
drewp@bigasterisk.com
parents:
diff changeset
1 from pyinfra import host
c5784e3d4f8d mail/postfix setup on prime
drewp@bigasterisk.com
parents:
diff changeset
2 from pyinfra.operations import apt, files, server, systemd
c5784e3d4f8d mail/postfix setup on prime
drewp@bigasterisk.com
parents:
diff changeset
3
c5784e3d4f8d mail/postfix setup on prime
drewp@bigasterisk.com
parents:
diff changeset
4 if host.name == 'prime':
218
44b0da2e6d1f opendkim
drewp@bigasterisk.com
parents: 188
diff changeset
5 apt.packages(packages=['postfix', 'isync', 'opendkim', 'opendkim-tools'])
44b0da2e6d1f opendkim
drewp@bigasterisk.com
parents: 188
diff changeset
6
44b0da2e6d1f opendkim
drewp@bigasterisk.com
parents: 188
diff changeset
7 files.template(src='templates/mail/opendkim-KeyTable.j2', dest='/etc/opendkim/KeyTable')
44b0da2e6d1f opendkim
drewp@bigasterisk.com
parents: 188
diff changeset
8 files.template(src='templates/mail/opendkim-SigningTable.j2', dest='/etc/opendkim/SigningTable')
44b0da2e6d1f opendkim
drewp@bigasterisk.com
parents: 188
diff changeset
9 files.template(src='templates/mail/opendkim-TrustedHosts.j2', dest='/etc/opendkim/TrustedHosts')
44b0da2e6d1f opendkim
drewp@bigasterisk.com
parents: 188
diff changeset
10 files.template(src='templates/mail/opendkim.conf.j2', dest='/etc/opendkim.conf')
44b0da2e6d1f opendkim
drewp@bigasterisk.com
parents: 188
diff changeset
11 files.put(src='secrets/mail/bigasterisk.com-default.private',
44b0da2e6d1f opendkim
drewp@bigasterisk.com
parents: 188
diff changeset
12 dest='/etc/opendkim/keys/bigasterisk.com/default.private',
44b0da2e6d1f opendkim
drewp@bigasterisk.com
parents: 188
diff changeset
13 mode='0600', user='opendkim')
44b0da2e6d1f opendkim
drewp@bigasterisk.com
parents: 188
diff changeset
14
44b0da2e6d1f opendkim
drewp@bigasterisk.com
parents: 188
diff changeset
15 files.template(src='templates/mail/opendkim.service.j2', dest='/usr/lib/systemd/system/opendkim.service')
44b0da2e6d1f opendkim
drewp@bigasterisk.com
parents: 188
diff changeset
16 systemd.service(service='opendkim.service', enabled=True, running=True, restarted=True)
44b0da2e6d1f opendkim
drewp@bigasterisk.com
parents: 188
diff changeset
17
16
c5784e3d4f8d mail/postfix setup on prime
drewp@bigasterisk.com
parents:
diff changeset
18 files.template(src='templates/mail/main.cf.j2', dest='/etc/postfix/main.cf')
c5784e3d4f8d mail/postfix setup on prime
drewp@bigasterisk.com
parents:
diff changeset
19 files.template(src='templates/mail/mydestination.j2', dest='/etc/postfix/mydestination')
183
4cab03eb492e move aliases file to pyinfra finally
drewp@bigasterisk.com
parents: 41
diff changeset
20 files.put(src='secrets/mail/aliases', dest='/etc/postfix/aliases')
16
c5784e3d4f8d mail/postfix setup on prime
drewp@bigasterisk.com
parents:
diff changeset
21 files.put(src='secrets/mail/sender_access', dest='/etc/postfix/sender_access')
c5784e3d4f8d mail/postfix setup on prime
drewp@bigasterisk.com
parents:
diff changeset
22 files.put(src='secrets/mail/virtual', dest='/etc/postfix/virtual')
c5784e3d4f8d mail/postfix setup on prime
drewp@bigasterisk.com
parents:
diff changeset
23
18
fb226978c4d7 fix prime postfix setup. forwards to gmail were piling up
drewp@bigasterisk.com
parents: 16
diff changeset
24 server.shell(commands=[
fb226978c4d7 fix prime postfix setup. forwards to gmail were piling up
drewp@bigasterisk.com
parents: 16
diff changeset
25 'postmap /etc/postfix/sender_access',
fb226978c4d7 fix prime postfix setup. forwards to gmail were piling up
drewp@bigasterisk.com
parents: 16
diff changeset
26 'postmap /etc/postfix/virtual',
218
44b0da2e6d1f opendkim
drewp@bigasterisk.com
parents: 188
diff changeset
27 'postmap /etc/postfix/aliases', # broken
18
fb226978c4d7 fix prime postfix setup. forwards to gmail were piling up
drewp@bigasterisk.com
parents: 16
diff changeset
28 'postfix reload',
fb226978c4d7 fix prime postfix setup. forwards to gmail were piling up
drewp@bigasterisk.com
parents: 16
diff changeset
29 ])
184
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
30 systemd.service(service='postfix@-.service', enabled=True, running=True)
16
c5784e3d4f8d mail/postfix setup on prime
drewp@bigasterisk.com
parents:
diff changeset
31
c5784e3d4f8d mail/postfix setup on prime
drewp@bigasterisk.com
parents:
diff changeset
32 # something to run ~drewp/mbsync/go at startup
c5784e3d4f8d mail/postfix setup on prime
drewp@bigasterisk.com
parents:
diff changeset
33
41
768e655e487b some mail fix
drewp@bigasterisk.com
parents: 18
diff changeset
34 server.shell(commands=[
768e655e487b some mail fix
drewp@bigasterisk.com
parents: 18
diff changeset
35 "cd /home/drewp/mbsync; /usr/bin/mbsync-get-cert 10.5.0.1 > servercert",
768e655e487b some mail fix
drewp@bigasterisk.com
parents: 18
diff changeset
36 ])
16
c5784e3d4f8d mail/postfix setup on prime
drewp@bigasterisk.com
parents:
diff changeset
37
253
67fb7b27bfea maildir file count service
drewp@bigasterisk.com
parents: 218
diff changeset
38 files.put(src='templates/file-count/file_count.py', dest='/opt/file_count.py')
67fb7b27bfea maildir file count service
drewp@bigasterisk.com
parents: 218
diff changeset
39 files.template(src='templates/file-count/file-count.service.j2', dest='/etc/systemd/system/maildir-count.service')
67fb7b27bfea maildir file count service
drewp@bigasterisk.com
parents: 218
diff changeset
40 systemd.service(service='maildir-count.service', enabled=True, running=True, daemon_reload=True)
67fb7b27bfea maildir file count service
drewp@bigasterisk.com
parents: 218
diff changeset
41
67fb7b27bfea maildir file count service
drewp@bigasterisk.com
parents: 218
diff changeset
42
16
c5784e3d4f8d mail/postfix setup on prime
drewp@bigasterisk.com
parents:
diff changeset
43 # other machines, route mail to bang or prime for delivery
41
768e655e487b some mail fix
drewp@bigasterisk.com
parents: 18
diff changeset
44
768e655e487b some mail fix
drewp@bigasterisk.com
parents: 18
diff changeset
45 if host.name == 'bang':
184
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
46 apt.packages(packages=['postfix'])
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
47 files.template(src='templates/mail/main.cf.j2', dest='/etc/postfix/main.cf')
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
48 files.template(src='templates/mail/mydestination.j2', dest='/etc/postfix/mydestination')
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
49 files.put(src='secrets/mail/aliases', dest='/etc/postfix/aliases')
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
50 files.put(src='secrets/mail/sender_access', dest='/etc/postfix/sender_access')
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
51 files.put(src='secrets/mail/virtual', dest='/etc/postfix/virtual')
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
52
41
768e655e487b some mail fix
drewp@bigasterisk.com
parents: 18
diff changeset
53 server.shell(commands=[
184
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
54 'postmap /etc/postfix/sender_access',
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
55 'postmap /etc/postfix/virtual',
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
56 'postmap /etc/postfix/aliases',
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
57 'postfix reload',
41
768e655e487b some mail fix
drewp@bigasterisk.com
parents: 18
diff changeset
58 ])
184
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
59 systemd.service(service='postfix@-.service', enabled=True, running=True)
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
60
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
61 # server.shell(commands=[
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
62 # # not working
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
63 # "cd /my/serv/dovecot; runuser -u drewp -- invoke certs",
53b6457f75f3 also config postfix on bang (others, soon)
drewp@bigasterisk.com
parents: 183
diff changeset
64 # ])