chiark / gitweb /
dot/emacs: Bind a key to `magit-toggle-buffer-lock'.
[profile] / dot / gnus-local.el.distorted
1 ;;; -*-emacs-lisp-*-
2 ;;;
3 ;;; Local GNUS configuration -- distorted.org.uk version
4 ;;;
5 ;;; (c) 2014 Mark Wooding
6 ;;;
7
8 (setq auth-sources '("~/.authinfo.gpg"))
9
10 ;;;--------------------------------------------------------------------------
11 ;;; How to send mail.
12
13 (setq smtpmail-smtp-service 587
14       smtpmail-auth-credentials "~/.authinfo.gpg")
15
16 (setq mdw-send-mail-alist
17       `((distorted-smtp
18          (send-mail-function . smtpmail-send-it)
19          (smtpmail-smtp-server . "mail.distorted.org.uk")
20          (smtpmail-starttls-credentials
21           ("mail.distorted.org.uk" 587 nil nil)))
22         (chiark-smtp
23          (send-mail-function . smtpmail-send-it)
24          (smtpmail-smtp-server . "smtp.dovecot.chiark.greenend.org.uk")
25          (starttls-extra-arguments "--insecure")
26          (smtpmail-starttls-credentials
27           ("smtp.dovecot.chiark.greenend.org.uk" 587 nil nil)))
28         (gmail-smtp
29          (send-mail-function . smtpmail-send-it)
30          (smtpmail-smtp-server . "smtp.gmail.com")
31          (smtpmail-starttls-credentials
32           ("smtp.gmail.com" 587 nil nil))))
33       mdw-guess-send-mail-alist
34       `((,(concat "@\\(" "\\(chiark\\|slimy\\|coriolis\\)"
35                          "\\.greenend\\.org\\.uk"
36                   "\\|"  "evade\\.org\\.uk"
37                   "\\|"  "fyvzl\\.net"
38                   "\\)$") . chiark-smtp)
39         ("@g\\(oogle\\)?mail\\.com$" . gmail-smtp))
40       mdw-default-send-mail-method nil)
41
42 ;;;--------------------------------------------------------------------------
43 ;;; News via chiark.
44
45 ;; Currently we assume an SSH tunnel.  This will be fixed later.
46 (setq gnus-select-method
47       '(nntp "chiark-ssh-kludge"
48              (nntp-open-connection-function nntp-open-authinfo-kludge)
49              (nntp-address "tunnel.chiark.greenend.org.uk")
50              (nntp-authinfo-generic "md5cookie1way mdw")))
51
52 ;;;--------------------------------------------------------------------------
53 ;;; Mail group configuration.
54
55 ;; General splitting configuration.
56 (setq nnimap-split-rule 'nnimap-split-fancy
57       nnmail-split-methods 'nnmail-split-fancy
58       nnimap-split-predicate "UNDELETED"
59       nnimap-split-crosspost t
60       nnmail-split-crosspost t
61       nnmail-split-fancy-match-partial-words nil)
62
63 ;; Automatic expiry for particular groups.
64 (setq gnus-auto-expirable-newsgroups
65       (concat "^"
66               "\\(nnimap\\+[^:]+\\|nnvirtual\\):"
67               "\\(" "\\(admin\\|crap\\|lists\\|nag\\)\\."
68               "\\|" "spam\\.oubliette"
69               "\\)"))
70
71 ;; My various email addresses.
72 (setq message-alternative-emails bbdb-user-mail-names
73       message-dont-reply-to-names message-alternative-emails)
74
75 ;; Augment Gnus's built-in header-list abbreviations.
76 (require 'nnmail)
77 (setq nnmail-split-abbrev-alist
78       (mdw-uniquify-alist
79        `((to . ,(concat "to\\|cc\\|apparently-to\\|envelope-to\\|"
80                         "resent-to\\|resent-cc"))
81          (any . ,(concat "from\\|sender\\|resent-from\\|"
82                          "to\\|cc\\|apparently-to\\|envelope-to\\|"
83                          "resent-to\\|resent-cc"))
84          ,@nnmail-split-abbrev-alist)))
85
86 ;; Find out about my `odin.gg' mappings.
87 (defvar mdw-odin-parse-regexp
88   (concat "^"
89           "\\S-+" "\\s-+"               ; time limit
90           "\\(" "\\S-+" "\\)" "\\s-+"   ; local part
91           "\\S-+" "\\s-+"               ; recipient email address
92           "=" "\\(" "\\S-+" "\\)"       ; mailbox tag
93           "\\(" "$" "\\|" "\\s-" "\\)"))
94
95 (defvar mdw-odin-splits nil)
96 (defvar mdw-odin-sender-alist nil)
97
98 (defun mdw-update-odin-info ()
99   (let ((splits nil) (senders nil))
100     (with-temp-buffer
101       (call-process "ssh" nil t nil
102                     "stratocaster" "userv" "odin" "mail" "list")
103       (goto-char (point-min))
104       (while (< (point) (point-max))
105         (when (looking-at mdw-odin-parse-regexp)
106           (let ((local-part (match-string 1))
107                 (tag (match-string 2)))
108             (push `(to ,(format "%s@odin\\.gg" local-part)
109                        ,(format "crap.%s" tag))
110                   splits)
111             (push (cons tag local-part) senders)))
112         (forward-line)))
113     (setq mdw-odin-splits (nreverse splits)
114           mdw-odin-sender-alist (nreverse senders))))
115 (mdw-update-odin-info)
116
117 ;; Mail sent to `mdw-nospam-THING' should appear to come from this address.
118 (setq gnus-posting-styles
119       '(("^nnimap\\+distorted:crap\\."
120          (address (let* ((mailbox (substring gnus-newsgroup-name
121                                              (match-end 0)))
122                          (entry (assoc mailbox mdw-odin-sender-alist)))
123                     (if entry (concat (cdr entry) "@odin.gg")
124                       (concat "mdw-nospam-" mailbox "@distorted.org.uk")))))
125         ("^nnimap\\+[^:]+-chiark:"
126          ("X-mdw-Send-Mail" "chiark-smtp"))
127         ("^nnimap\\+google:"
128          (address "distorted.mdw@gmail.com")
129          ("X-mdw-Send-Mail" "gmail-smtp"))))
130
131 ;; The actual splitting rules.
132 (setq nnmail-split-fancy
133       `(|
134           ;; Administrative boxes.
135           (to "\\<\\(root\\|postgres\\|ca\\|noc\\)@" "admin.misc" t)
136           (to "\\<\\(jukebox\\|nobody\\|darchive\\)@" "admin.misc" t)
137           (to "\\<\\(hostmaster\\)@" "admin.dns" t)
138           (to "\\<\\(news\\|newsmaster\\|usenet\\)@" "admin.news" t)
139           (to "\\<\\(postmaster\\|spamd\\|mailer-daemon\\)@" "admin.mail" t)
140           (to "\\<\\(irc\\|blight\\|ircbot\\)@" "admin.irc" t)
141           (to "\\<\\(www\\|webmaster\\|mtos\\)@" "admin.web" t)
142           (to "\\<\\(ftp\\|ftpadmin\\|mirror\\)@" "admin.ftp" t)
143           (to "\\\<\\(abuse\\|security\\)@" "admin.keep" t)
144           (from "cron daemon" "admin.misc")
145           (from "uucp@distorted\\.org\\.uk" "admin.uucp")
146           (from "darchive@.*\\.distorted\\.org\\.uk" "admin.misc")
147           (from "support@aa\\.net\\.uk" "admin.aaisp")
148           (from "bugs@distorted\\.org\\.uk" "admin.bugs")
149           (from "darchive@distorted\\.org\\.uk" "admin.darchive")
150
151           ;; Colo and network provider.
152           (from "\\(accounts\\|support\\)@jump\\.net\\.uk" "keep.colo")
153           (from "\\(accounts\\|support\\)@aa\\.net\\.uk" "keep.aaisp")
154
155           ;; Mailing lists, not split out earlier.
156           (to "python-list@python\\.org" "lists.python")
157           (to ,(concat "\\(jump-\\(announce\\|discuss\\)\\)@"
158                        "\\(lists\\.\\)?" "jump\\.net\\.uk")
159               "lists.\\1")
160           (to "cambridgecryptowhiskyclub@gmail\\.com"
161               "lists.cambridge-crypto-whisky")
162           (from ,(concat "@" "\\(" "liberty-human-rights"
163                              "\\|" "libertyhumanrights"
164                              "\\|" "libertymail"
165                              "\\)" "\\.org\\.uk" "\\>")
166                 "lists.liberty" t)
167           (from "@openrightsgroup\\.org\\>" "lists.org" t)
168           (from "@warwick\\.ac\\.uk\\>" "lists.warwick-uni" t)
169           (to "chiark-\\(motd\\|announce\\)@chiark\\.greenend\\.org\\.uk"
170               "lists.chiark-announce")
171           (any "clive-cambridge-gamers@nsict\\.org" "lists.nsict-games")
172
173           ;; Per-sender addresses.
174           (to "\\<mdw-nospam-justgviing@" "crap.justgiving" t)
175           (to "\\<mdw-nospam-\\([^@]+\\)@" "crap.\\1" t)
176           (to "\\<mdw-nopspam-\\([^@]+\\)@" "crap.\\1" t)
177
178           (to "\\(markw\\|mdw\\|mw\\)@odin\\.gg" "mail.misc")
179           ,@mdw-odin-splits
180           (to "\\([a-z0-9]+\\)@odin\\.gg" "crap.odin-misc")
181
182           ;; Regular nags.
183           (from "\\(sealbot\\|cardbot\\)@ncipher\\.com" "nag.cardbot")
184           (from "\\<mailman-owner@" "nag.mailman" t)
185
186           ;; Uninteresting mail.
187           (from "expiry@letsencrypt\\.org" "admin.letsencrypt")
188
189           ;; Other splits I've not given a per-sender address.
190           (from "@\\(.*\\.\\)?lovefilm\\.com\\>" "crap.lovefilm" t)
191           (from "@\\(.*\\.\\)?amazon\\." "crap.amazon" t)
192           (from "@cineworldmail\\.com\\>" "crap.cineworld" t)
193           (from "@picturehouses\\.co\\.uk\\>" "crap.picturehouse" t)
194           (from "@nationwide" "crap.nationwide" t)
195           (from "nationwide@securesuiteemail\\.com\\>" "crap.nationwide" t)
196           (from "@\\(.*\\.\\)?spotify\\(mail\\)?\\.com\\>" "crap.spotify" t)
197           (from "@action\\.openrightsgroup\\.org\\>" "crap.org" t)
198           (from "unlimited@cineworld\\.com\\>" "crap.cineworld" t)
199           (from "@tshirthell\\.com\\>" "crap.tshirt-hell" t)
200           (from "campaigns@jolla\\.com\\>" "crap.jolla" t)
201           (from "@thomann\\.de\\>" "crap.thomann" t)
202           (from "@wikimedia\\.org\\>" "crap.wikimedia" t)
203           (from "@\\(.*\\.\\)?gandi\\.net\\>" "crap.gandi" t)
204           (from "@mythic-beasts\\.com\\>" "crap.mythic-beasts" t)
205           (from "@accounts\\.google\\.com\\>" "crap.google" t)
206
207           ;; Default.
208           "mail.misc"))
209
210 ;;;--------------------------------------------------------------------------
211 ;;; Where we get mail from.
212
213 ;; Read mail on the IMAP server.
214 (setq gnus-secondary-select-methods
215       `((nnimap "distorted"
216                 (nnimap-address "mail.distorted.org.uk")
217                 (nnimap-user "mdw")
218                 (nnimap-stream starttls)
219                 (nnimap-inbox ("INBOX" "to.split"))
220                 (nnimap-split-methods nnimap-split-fancy)
221                 (nnimap-split-fancy ,nnmail-split-fancy)
222                 (nnimap-unsplittable-articles (%Deleted)))
223         (nnimap "markw-distorted"
224                 (nnimap-address "mail.distorted.org.uk")
225                 (nnimap-user "markw")
226                 (nnimap-stream starttls)
227                 (nnimap-inbox ("INBOX" "to.split"))
228                 (nnimap-split-methods nnimap-split-fancy)
229                 (nnimap-split-fancy ,nnmail-split-fancy)
230                 (nnimap-unsplittable-articles (%Deleted)))
231         (nnimap "mdw-chiark"
232                 (nnimap-address "imap.dovecot.chiark.greenend.org.uk")
233                 (nnimap-user "mdw")
234                 (nnimap-stream starttls)
235                 (nnimap-inbox ("INBOX" "to.split"))
236                 (nnimap-split-methods nnimap-split-fancy)
237                 (nnimap-split-fancy ,nnmail-split-fancy)
238                 (nnimap-unsplittable-articles (%Deleted)))
239         (nnimap "mwooding-chiark"
240                 (nnimap-address "imap.dovecot.chiark.greenend.org.uk")
241                 (nnimap-user "mwooding")
242                 (nnimap-stream starttls)
243                 (nnimap-inbox ("INBOX" "to.split"))
244                 (nnimap-split-methods nnimap-split-fancy)
245                 (nnimap-split-fancy ,nnmail-split-fancy)
246                 (nnimap-unsplittable-articles (%Deleted)))
247         (nnimap "google"
248                 (nnimap-address "imap.gmail.com")
249                 (nnimap-stream tls)
250                 (nnimap-inbox ("INBOX" "to.split"))
251                 (nnimap-split-methods nnimap-split-fancy)
252                 (nnimap-split-fancy ,nnmail-split-fancy)
253                 (nnimap-unsplittable-articles (%Deleted)))))
254
255 ;; Send sent mail back to me.
256 (setq gnus-message-archive-method "mail"
257       gnus-gcc-mark-as-read t
258       gnus-message-archive-group "nnimap+distorted:mail.sent")
259
260 ;;;----- That's all, folks --------------------------------------------------