]> ruderich.org/simon Gitweb - config/dotfiles.git/blob - mail/mutt/crypto-autoencrypt.pl
Move to mail/ in preparation for merge into new dotfiles repository
[config/dotfiles.git] / mail / mutt / crypto-autoencrypt.pl
1 #!/usr/bin/perl
2
3 # Helper script for mutt to create a list of send-hooks which enable
4 # crypt_autoencrypt for known GnuPG keys.
5
6 # Copyright (C) 2009-2013  Simon Ruderich
7 #
8 # This program is free software: you can redistribute it and/or modify
9 # it under the terms of the GNU General Public License as published by
10 # the Free Software Foundation, either version 3 of the License, or
11 # (at your option) any later version.
12 #
13 # This program is distributed in the hope that it will be useful,
14 # but WITHOUT ANY WARRANTY; without even the implied warranty of
15 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16 # GNU General Public License for more details.
17 #
18 # You should have received a copy of the GNU General Public License
19 # along with this program.  If not, see <http://www.gnu.org/licenses/>.
20
21
22 use strict;
23 use warnings;
24
25 open my $gpg, '-|', 'gpg --list-keys --with-colons --fixed-list-mode' or die $!;
26 while (<$gpg>) {
27     next if not /^uid:/;
28
29     # We don't skip invalid, deleted, revoked, expired and not-trusted UIDs to
30     # prevent sending an unencrypted mail when e.g. a key is revoked or
31     # expired; GnuPG will warn if we use any of them. If you really want to
32     # skip those UIDs (not recommended), uncomment the next line.
33     #next if /^uid:[idren]:/;
34
35     next if not /<(.+?@.+?)>:/;
36     print "send-hook '~t $1' 'set crypt_autoencrypt=yes'\n";
37 }
38 close $gpg or die $!;