]> Sergey Matveev's repositories - public-inbox.git/commitdiff
examples: add imapd systemd examples
authorEric Wong <e@80x24.org>
Sun, 23 Aug 2020 07:49:18 +0000 (07:49 +0000)
committerEric Wong <e@yhbt.net>
Tue, 25 Aug 2020 02:47:21 +0000 (02:47 +0000)
We've got examples for all the other daemons, too!

MANIFEST
examples/public-inbox-imap-onion.socket [new file with mode: 0644]
examples/public-inbox-imapd.socket [new file with mode: 0644]
examples/public-inbox-imapd@.service [new file with mode: 0644]
examples/public-inbox-imaps.socket [new file with mode: 0644]

index d86d3b1576e6d383709d1f6ed8ce9af9dd931165..35adc8d3271624c50079284702a4a6e1af63c6b2 100644 (file)
--- a/MANIFEST
+++ b/MANIFEST
@@ -83,6 +83,10 @@ examples/nginx_proxy
 examples/public-inbox-config
 examples/public-inbox-httpd.socket
 examples/public-inbox-httpd@.service
+examples/public-inbox-imap-onion.socket
+examples/public-inbox-imapd.socket
+examples/public-inbox-imapd@.service
+examples/public-inbox-imaps.socket
 examples/public-inbox-nntpd.socket
 examples/public-inbox-nntpd@.service
 examples/public-inbox-nntps.socket
diff --git a/examples/public-inbox-imap-onion.socket b/examples/public-inbox-imap-onion.socket
new file mode 100644 (file)
index 0000000..76b4e7c
--- /dev/null
@@ -0,0 +1,12 @@
+# ==> /etc/systemd/system/public-inbox-imap-onion.socket <==
+# This unit is for the corresponding line in torrc(5):
+# HiddenServicePort 143 unix:/run/imapd.onion.sock
+[Unit]
+Description = public-inbox-imap .onion socket
+
+[Socket]
+ListenStream = /run/imapd.onion.sock
+Service = public-inbox-imapd@1.service
+
+[Install]
+WantedBy = sockets.target
diff --git a/examples/public-inbox-imapd.socket b/examples/public-inbox-imapd.socket
new file mode 100644 (file)
index 0000000..fcd924f
--- /dev/null
@@ -0,0 +1,12 @@
+# ==> /etc/systemd/system/public-inbox-imapd.socket <==
+[Unit]
+Description = public-inbox-imapd socket
+
+[Socket]
+ListenStream = 0.0.0.0:143
+BindIPv6Only = ipv6-only
+ListenStream = [::]:143
+Service = public-inbox-imapd@1.service
+
+[Install]
+WantedBy = sockets.target
diff --git a/examples/public-inbox-imapd@.service b/examples/public-inbox-imapd@.service
new file mode 100644 (file)
index 0000000..e0446ed
--- /dev/null
@@ -0,0 +1,43 @@
+# ==> /etc/systemd/system/public-inbox-imapd@.service <==
+# Since SIGUSR2 upgrades do not work under systemd, this service file
+# allows starting two simultaneous services during upgrade time
+# (e.g. public-inbox-imapd@1 public-inbox-imapd@2) with the intention
+# that they take turns running in-between upgrades.  This should
+# allow upgrading without downtime.
+
+[Unit]
+Description = public-inbox-imapd IMAP server %i
+Wants = public-inbox-imapd.socket public-inbox-imaps.socket \
+public-inbox-imap-onion.socket
+After = public-inbox-imapd.socket public-inbox-imaps.socket \
+public-inbox-imap-onion.socket
+
+[Service]
+Environment = PI_CONFIG=/home/pi/.public-inbox/config \
+PATH=/usr/local/bin:/usr/bin:/bin \
+PERL_INLINE_DIRECTORY=/tmp/.pub-inline
+
+LimitNOFILE = 30000
+ExecStartPre = /bin/mkdir -p -m 1777 /tmp/.pub-inline
+ExecStart = /usr/local/bin/public-inbox-imapd -W0 \
+-1 /var/log/public-inbox/imapd.out.log \
+--cert /etc/ssl/certs/news.example.com.pem \
+--key /etc/ssl/private/news.example.com.key
+StandardError = syslog
+
+# NonBlocking is REQUIRED to avoid a race condition if running
+# simultaneous services
+NonBlocking = true
+
+Sockets = public-inbox-imapd.socket public-inbox-imaps.socket \
+public-inbox-imap-onion.socket
+
+KillSignal = SIGQUIT
+User = nobody
+Group = ssl-cert
+ExecReload = /bin/kill -HUP $MAINPID
+TimeoutStopSec = 86400
+KillMode = process
+
+[Install]
+WantedBy = multi-user.target
diff --git a/examples/public-inbox-imaps.socket b/examples/public-inbox-imaps.socket
new file mode 100644 (file)
index 0000000..b61cc74
--- /dev/null
@@ -0,0 +1,12 @@
+# ==> /etc/systemd/system/public-inbox-imaps.socket <==
+[Unit]
+Description = public-inbox-imaps socket
+
+[Socket]
+ListenStream = 0.0.0.0:993
+BindIPv6Only = ipv6-only
+ListenStream = [::]:993
+Service = public-inbox-imapd@1.service
+
+[Install]
+WantedBy = sockets.target