1 package Promulger::Dispatch;
7 # XXX allow the user to specify their own Email::Sender::Transport -- apeiron,
9 use Email::Sender::Simple qw(sendmail);
10 # XXX not yet -- apeiron, 2010-06-25
13 use Promulger::Config;
15 # XXX no bounce parsing yet -- apeiron, 2010-03-13
18 my $config = Promulger::Config->config;
20 my $email = Email::MIME->new($message);
21 my $recipient = $email->header_str('To');
22 my $local_user = user_for_address($recipient);
23 my $sender = $email->header_str('From');
24 my $subject = $email->header_str('Subject');
26 my $list = Promulger::List->resolve($local_user);
28 reject($recipient, $sender);
32 if($local_user =~ /-request$/) {
33 handle_request($list, $sender, $local_user, $subject, $config);
37 # they don't have a request for us, so they want to post a message
38 post_message($list, $email, $config);
43 my ($list, $sender, $recipient, $subject) = @_;
45 my $sender_address = bare_address($sender);
46 if($subject =~ /^\s*subscribe/i) {
47 $list->subscribe($sender_address)
48 or already_subscribed($list, $recipient, $sender_address);
49 } elsif($subject =~ /^\s*unsubscribe/i) {
50 $list->unsubscribe($sender_address)
51 or not_subscribed($list, $recipient, $sender_address);
56 my ($list, $email, $config) = @_;
58 my $sender = $email->header_str('From');
59 my $sender_address = bare_address($sender);
60 my $recipient = $email->header_str('To');
62 unless($list->accept_posts_from($sender_address) && $list->active) {
63 reject($recipient, $sender);
67 # they're allowed to post (subscribed or not), the list is active. let's do
70 # XXX no MIME or other fancy handling for now -- apeiron, 2010-03-13
71 my $body = $email->body_str;
72 for my $subscriber (keys %{$list->subscribers}) {
73 #my $verped_from = Mail::Verp->encode($recipient, $subscriber);
74 # XXX we let the MTA create the message-id for us for now -- apeiron,
76 my $new_message = Email::MIME->create(
78 From => $sender_address,
80 Subject => $email->header_str('Subject'),
81 'Reply-to' => $recipient,
85 # XXX no queuing or job distribution for now beyond what the MTA provides
86 # -- apeiron, 2010-03-13
87 sendmail($new_message);
91 # XXX make this actually not suck -- apeiron, 2010-03-13
93 my ($recipient, $sender) = @_;
94 my $email = Email::MIME->create(
98 Subject => 'Rejected',
101 Sorry, your message to $recipient has been denied.
108 my ($list, $recipient, $sender) = @_;
109 my $email = Email::MIME->create(
110 # XXX need admin address
114 Subject => 'Not subscribed',
117 Sorry, you are not subscribed to $list.
123 sub already_subscribed {
124 my ($list, $recipient, $sender) = @_;
125 my $email = Email::MIME->create(
129 Subject => 'Already subscribed',
132 Sorry, you are already subscribed to $list.
139 my ($full_addr) = @_;
140 my ($addr_obj) = Email::Address->parse($full_addr);
141 return $addr_obj->address;
144 sub user_for_address {
145 my ($full_addr) = @_;
146 my ($addr_obj) = Email::Address->parse($full_addr);
147 return $addr_obj->user;
150 'http://www.shadowcat.co.uk/blog/matt-s-trout/oh-subdispatch-oh-subdispatch/';