about summary refs log tree commit homepage
path: root/lib/PublicInbox/MDA.pm
diff options
context:
space:
mode:
authorEric Wong <e@80x24.org>2019-10-28 10:45:26 +0000
committerEric Wong <e@80x24.org>2019-10-30 08:49:39 +0000
commit74a3206babe0572a1494500d21267a31873af7b0 (patch)
treebbc5e00d25a50e85ccc30716ac8e6f728d6a8e53 /lib/PublicInbox/MDA.pm
parent4315455300e29e4ef0ea2f2d68bf4e86d261ae1d (diff)
downloadpublic-inbox-74a3206babe0572a1494500d21267a31873af7b0.tar.gz
While it's not RFC2919-conformant, mail software can
theoretically set multiple List-ID headers.  Deliver to all
inboxes which match a given List-ID since that's likely the
intended.

Cc: Eric W. Biederman <ebiederm@xmission.com>
Link: https://public-inbox.org/meta/87pniltscf.fsf@x220.int.ebiederm.org/
Diffstat (limited to 'lib/PublicInbox/MDA.pm')
-rw-r--r--lib/PublicInbox/MDA.pm20
1 files changed, 13 insertions, 7 deletions
diff --git a/lib/PublicInbox/MDA.pm b/lib/PublicInbox/MDA.pm
index ce2c870f..b0dfac45 100644
--- a/lib/PublicInbox/MDA.pm
+++ b/lib/PublicInbox/MDA.pm
@@ -83,19 +83,25 @@ sub set_list_headers {
         }
 }
 
-# TODO: deal with multiple List-ID headers?
-sub inbox_for_list_id ($$) {
+sub inboxes_for_list_id ($$) {
         my ($klass, $config, $simple) = @_;
 
         # newer Email::Simple allows header_raw, as does Email::MIME:
-        my $list_id = $simple->can('header_raw') ?
+        my @list_ids = $simple->can('header_raw') ?
                         $simple->header_raw('List-Id') :
                         $simple->header('List-Id');
-        my $ibx;
-        if (defined $list_id && $list_id =~ /<[ \t]*(.+)?[ \t]*>/) {
-                $ibx = $config->lookup_list_id($1);
+        my @dests;
+        for my $list_id (@list_ids) {
+                $list_id =~ /<[ \t]*(.+)?[ \t]*>/ or next;
+                if (my $ibx = $config->lookup_list_id($1)) {
+                        push @dests, $ibx;
+                }
+        }
+        if (scalar(@list_ids) > 1) {
+                warn "W: multiple List-IDs in message:\n";
+                warn "W: List-ID: $_\n" for @list_ids
         }
-        $ibx;
+        \@dests;
 }
 
 1;