]> git.sommitrealweird.co.uk Git - onak.git/blob - onak-mail.pl
0e3c2b5b46ba359eb778452339143e21543a160a
[onak.git] / onak-mail.pl
1 #!/usr/bin/perl -w
2
3 #
4 # onak-mail.pl - Mail processing interface for onak, an OpenPGP Keyserver.
5 #
6 # Written by Jonathan McDowell <noodles@earth.li>
7 # Copyright 2002 Project Purple
8 # Released under the GPL.
9 #
10
11 use strict;
12 use IPC::Open3;
13
14 my %config;
15
16 #
17 # readconfig
18 #
19 # Reads in our config file. Ignores any command it doesn't understand rather
20 # than having to list all the ones that are of no interest to us.
21 #
22 sub readconfig {
23
24         open(CONFIG, "/home/noodles/projects/onak/onak.conf") or
25                 die "Can't read config file: $!";
26         
27         while (<CONFIG>) {
28                 if (/^#/ or /^$/) {
29                         # Ignore; comment line.
30                 } elsif (/^this_site (.*)/) {
31                         $config{'thissite'} = $1;
32                 } elsif (/^maintainer_email (.*)/) {
33                         $config{'adminemail'} = $1;
34                 } elsif (/^mail_delivery_client (.*)/) {
35                         $config{'mta'} = $1;
36                 } elsif (/^syncsite (.*)/) {
37                         push @{$config{'syncsites'}}, $1;
38                 }
39         }
40
41         close(CONFIG);
42
43         return;
44 }
45
46 #
47 # submitupdate
48 #
49 # Takes an armored OpenPGP stream and submits it to the keyserver. Returns the
50 # difference between what we just added and what we had before (ie the least
51 # data need to get from what we had to what we have).
52 #
53 sub submitupdate {
54         my @data = @_;
55         my (@errors, @mergedata);
56
57         open3(\*MERGEIN, \*MERGEOUT, \*MERGEERR,
58                 "/home/noodles/onak-0.0.3/onak", "add");
59
60         print MERGEIN @data;
61         close MERGEIN;
62         @errors = <MERGEERR>;
63         @mergedata = <MERGEOUT>;
64
65         open (LOG, ">>/home/noodles/onak-0.0.3/keyadd.log");
66         print LOG @errors;
67         close LOG;
68
69         return @mergedata;
70 }
71
72 my ($inheader, %syncsites, $subject, $from, $replyto, @body, @syncmail);
73
74 $inheader = 1;
75 $subject = "";
76 &readconfig;
77
78 while (<>) {
79         if ($inheader) {
80                 if (/^Subject:\s*(.*)\s*$/i) {
81                         $subject = $1;
82                 } elsif (/^X-KeyServer-Sent:\s*(.*)\s*$/i) {
83                         $syncsites{$1} = 1;
84                 } elsif (/^From:\s*(.*)\s*$/i) {
85                         $from = $1;
86                 } elsif (/^Reply-To:\s*(.*)\s*$/i) {
87                         $replyto = $1;
88                 } elsif (/^$/) {
89                         $inheader = 0;
90                 }
91         }
92         if (!$inheader) {
93                 push @body, $_;
94         }
95 }
96
97 # HELP, ADD, INCREMENTAL, VERBOSE INDEX <keyid>, INDEX <keyid>, GET <keyid>,
98 # LAST <days>
99
100 if ($subject =~ /^INCREMENTAL$/i) {
101         submitupdate(@body);
102 }