/[notice-sender]/trunk/sender.pl
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /trunk/sender.pl

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 20 by dpavlin, Sun May 15 21:19:26 2005 UTC revision 48 by dpavlin, Tue May 24 15:19:44 2005 UTC
# Line 11  sender.pl - command line notify sender u Line 11  sender.pl - command line notify sender u
11    
12  =head1 SYNOPSYS  =head1 SYNOPSYS
13    
14     sender.pl --new=mylist
15   sender.pl --add=mylist members.txt   sender.pl --add=mylist members.txt
16   sender.pl --list[=mylist]   sender.pl --list[=mylist]
17   sender.pl --queue[=mylist message.txt]   sender.pl --queue[=mylist message.txt]
18   sender.pl --send=mylist   sender.pl --send=mylist
19    
20    In C</etc/aliases> something like:
21    
22     mylist: "| cd /path/to && ./sender.pl --inbox=mylist"
23     mylist-bounce: "| cd /path/to && ./sender.pl --inbox=mylist --bounce"
24    
25  =head2 Command options  =head2 Command options
26    
27  =over 20  =over 20
# Line 24  sender.pl - command line notify sender u Line 30  sender.pl - command line notify sender u
30    
31  my $debug = 0;  my $debug = 0;
32  my $verbose = 0;  my $verbose = 0;
33  my $list_opt;  my $opt;
 my $add_opt;  
 my $queue_opt;  
 my $send_opt;  
 my $email_opt;  
34    
35  my $result = GetOptions(  my $result = GetOptions(
36          "list:s" => \$list_opt,          "new=s" => \$opt->{'new'},
37          "add=s" => \$add_opt,          "list:s" => \$opt->{'list'},
38          "queue:s" => \$queue_opt,          "add=s" => \$opt->{'add'},
39          "send:s" => \$send_opt,          "queue:s" => \$opt->{'queue'},
40            "send:s" => \$opt->{'send'},
41            "inbox=s" => \$opt->{'inbox'},
42          "debug" => \$debug,          "debug" => \$debug,
43          "verbose" => \$verbose,          "verbose" => \$verbose,
44          "email=s" => \$email_opt,          "from=s" => \$opt->{'from'},
45            "driver=s" => \$opt->{'email_send_driver'},
46            "bounce" => \$opt->{'bounce'},
47  );  );
48    
49  my $nos = new Nos(  my $nos = new Nos(
# Line 64  $queue->set_sql( list_queue => qq{ Line 70  $queue->set_sql( list_queue => qq{
70          JOIN lists on list_id = lists.id          JOIN lists on list_id = lists.id
71  } );  } );
72    
73    my $list_name;
74    
75    
76    =item --new=list_name my-list@example.com
77    
78    Adds new list. You can also feed list name as first line to C<STDIN>.
79    
80    You can also add C<--from='Full name of list'> to specify full name (comment)
81    in outgoing e-mail.
82    
83    =cut
84    
85    if ($list_name = $opt->{'new'}) {
86    
87            my $email = shift @ARGV || <>;
88            chomp($email);
89    
90            die "need e-mail address for list (as argument or on STDIN)\n" unless ($email);
91    
92            my $id = $nos->new_list(
93                    list => $list_name,
94                    from => ($opt->{'from'} || ''),
95                    email => $email,
96            ) || die "can't add list $list_name\n";
97    
98            print "added list $list_name with ID $id\n";
99    
100    
101  =item --list[=list_name]  =item --list[=list_name]
102    
# Line 74  on that list. Line 107  on that list.
107    
108  =cut  =cut
109    
110  if (defined($list_opt)) {  } elsif (defined($list_name = $opt->{'list'})) {
111    
112          my @lists;          my @lists;
113          if ($list_opt ne '') {  
114                  @lists = $lists->search( name=> $list_opt )->first || die "can't find list $list_opt";          if ($list_name ne '') {
115                    @lists = $lists->search( name=> $list_name )->first || die "can't find list $list_name";
116          } else {          } else {
117                  @lists = $lists->retrieve_all;                  @lists = $lists->retrieve_all;
118          }          }
119    
120          foreach my $list (@lists) {          foreach my $list (@lists) {
121                  print $list->name," <",$list->email,">\n";                  print $list->name," <",$list->email,">\n";
122                  foreach my $user_on_list ($user_list->search(list_id => $list->id)) {                  foreach my $u ($nos->list_members( list => $list->name )) {
123                          my $user = $users->retrieve( id => $user_on_list->user_id );                          print "\t",$u->{'name'}, " <", $u->{'email'}, ">\n";
                         print "\t",$user->full_name," <", $user->email, ">\n";  
124                  }                  }
125          }          }
126    
127    
128  =item --add=list_name  =item --add=list_name
129    
130  Add users to list. Users are stored in file (which can be supplied as  Add users to list. Users are stored in file (which can be supplied as
# Line 98  argument) or read from C<STDIN>. List sh Line 133  argument) or read from C<STDIN>. List sh
133   email@example.com      Optional full name of person   email@example.com      Optional full name of person
134   dpavlin@rot13.org      Dobrica Pavlinusic   dpavlin@rot13.org      Dobrica Pavlinusic
135    
 You may use C<--email> parametar at any time to set From: e-mail address for list.  
 B<This seems somewhat cludgy, and it will probably change in future>.  
   
136  =cut  =cut
137    
138  } elsif ($add_opt) {  } elsif ($list_name = $opt->{'add'}) {
139          #my $noticer = $loader->find_class('Noticer') || die "can't find my class!";  
140          my $list = $lists->find_or_create({          my $list = $lists->find_or_create({
141                  name => $add_opt,                  name => $list_name,
142          }) || die "can't add list $add_opt\n";          }) || die "can't add list $list_name\n";
         if ($email_opt && $list->email ne $email_opt) {  
                 $list->email($email_opt);  
                 $list->update;  
                 $list->dbi_commit;  
         }  
143    
144          my $added = 0;          my $added = 0;
145    
# Line 120  B<This seems somewhat cludgy, and it wil Line 147  B<This seems somewhat cludgy, and it wil
147                  chomp;                  chomp;
148                  next if (/^#/ || /^\s*$/);                  next if (/^#/ || /^\s*$/);
149                  my ($email, $name) = split(/\s+/,$_, 2);                  my ($email, $name) = split(/\s+/,$_, 2);
150                  $name ||= '';                  $added++ if ($nos->add_member_to_list( email => $email, name => $name, list => $list_name ));
                 if (! Email::Valid->address($email)) {  
                         print "SKIPPING $name <$email>\n";  
                         next;  
                 }  
                 print "# $name <$email>\n";  
                 my $this_user = $users->find_or_create({  
                         email => $email,  
                         full_name => $name,  
                 }) || die "can't find or create member\n";  
                 my $user_on_list = $user_list->find_or_create({  
                         user_id => $this_user->id,  
                         list_id => $list->id,  
                 }) || die "can't add user to list";  
                 $added++;  
         }  
   
         foreach my $c_name ($loader->tables) {  
                 my $c = $loader->find_class($c_name)|| die "can't find $c_name";  
                 $c->dbi_commit();  
151          }          }
152    
153          print "list ",$list->name," has $added users\n";          print "list ",$list->name," has $added users\n";
154    
155    
156  =item --queue[=list_name]  =item --queue[=list_name]
157    
158  Queue message for later delivery. Message can be read from file (specified as  Queue message for later delivery. Message can be read from file (specified as
# Line 154  add C<--verbose> flag, it will display a Line 163  add C<--verbose> flag, it will display a
163    
164  =cut  =cut
165    
166  } elsif (defined($queue_opt)) {  } elsif (defined($list_name = $opt->{'queue'})) {
167    
168          if ($queue_opt ne '') {          if ($list_name ne '') {
169                  # add message to list queue                  # add message to list queue
170    
                 my $this_list = $lists->search(  
                         name => $queue_opt,  
                 )->first || die "can't find list $queue_opt";  
   
171                  my $message_text;                  my $message_text;
172                  while(<>) {                  while(<>) {
173                          $message_text .= $_;                          $message_text .= $_;
174                  }                  }
175    
176                  die "no message" unless ($message_text);                  my $id = $nos->add_message_to_list(
177                            list => $list_name,
178                  my $this_message = $messages->find_or_create({                          message => $message_text,
179                          message => $message_text                  ) || die "can't add message to list $list_name\n";
                 }) || die "can't insert message";  
   
                 $this_message->dbi_commit() || die "can't add message";  
   
                 $queue->find_or_create({  
                         message_id => $this_message->id,  
                         list_id => $this_list->id,  
                 }) || die "can't add message ",$this_message->id," to list ",$this_list->id, ": ",$this_list->name;  
180    
181                  $queue->dbi_commit || die "can't add message to list ",$this_list->name;                  print "added message $id to list $list_name\n";
   
                 print "added message ",$this_message->id, " to list ",$this_list->name,"\n";  
182    
183          } else {          } else {
184                  # list messages in queue                          # list messages in queue        
# Line 198  add C<--verbose> flag, it will display a Line 193  add C<--verbose> flag, it will display a
193                          my $msg = $m->message_id->message;                          my $msg = $m->message_id->message;
194                          $msg =~ s/\s+/ /gs;                          $msg =~ s/\s+/ /gs;
195    
196                          $l .= sprintf(" %-10s %15s : ", $m->list_id->name, $date);                          $l .= sprintf(" %-15s %15s : ", $m->list_id->name, $date);
197                          $l .= substr($msg, 0, 79 - length($l));                          $l .= substr($msg, 0, 79 - length($l));
198    
199                          print "$l\n";                          print "$l\n";
# Line 206  add C<--verbose> flag, it will display a Line 201  add C<--verbose> flag, it will display a
201    
202          }          }
203    
204    
205  =item --send[=list_name]  =item --send[=list_name]
206    
207  Send e-mails waiting in queue, or with optional argument, just send messages  Send e-mails waiting in queue, or with optional argument, just send messages
208  for single list.  for single list.
209    
210    Optional argument C<--driver=smtp> forces sending using SMTP server at
211    localhost (127.0.0.1).
212    
213  =cut  =cut
214    
215  } elsif (defined($send_opt)) {  } elsif (defined($list_name = $opt->{'send'})) {
216    
217          my $my_q;          $nos->send_queued_messages($list_name, $opt->{'email_send_driver'});
         if ($send_opt ne '') {  
                 my $l_id = $lists->search_like( name => $send_opt )->first ||  
                         die "can't find list $send_opt";  
                 $my_q = $queue->search_like( list_id => $l_id ) ||  
                         die "can't find list $send_opt";  
         } else {  
                 $my_q = $queue->retrieve_all;  
         }  
218    
         while (my $m = $my_q->next) {  
                 next if ($m->all_sent);  
219    
220                  print "sending message ",$m->message_id," enqueued on ",$m->date," to list ",$m->list_id->name,"\n";  =item --inbox=list_name
                 my $msg = $m->message_id->message;  
221    
222                  foreach my $u ($user_list->search(list_id => $m->list_id)) {  Feed incomming message back into notice sender.
223    
224                          if ($sent->search( message_id => $m->message_id, user_id => $u->user_id )) {  Optional argument C<--bounce> define that this message is received to
225                                  print "SKIP ",$u->user_id->email," message allready sent\n";  bounce address.
226                          } else {  
227                                  print "\t",$u->user_id->email,"\n";  =cut
228    
229                                  my $hdr = "From: " . $u->list_id->name . " <" . $u->list_id->email . ">\n" .  } elsif ($list_name = $opt->{'inbox'}) {
230                                          "To: " . $u->user_id->full_name . " <". $u->user_id->email. ">\n";  
231            my $message;
232                                  # FIXME do real sending :-)          while(<>) {
233                                  $nos->send_email("$hdr\n$msg");                  $message .= $_;
   
                                 $sent->create({  
                                         message_id => $m->message_id,  
                                         user_id => $u->user_id,  
                                 });  
                                 $sent->dbi_commit;  
                         }  
                 }  
                 $m->all_sent(1);  
                 $m->update;  
                 $m->dbi_commit;  
234          }          }
235    
236            $nos->inbox_message(
237                    list => $list_name,
238                    message => $message,
239                    bounce => $opt->{'bounce'},
240            ) || die "can't receive message for list $list_name";
241    
242    
243  } else  {  } else  {
244          die "see perldoc $0 for help";          die "see perldoc $0 for help\n";
245  }  }
246    
247  =back  =back
# Line 276  Turn on debugging output from C<Class::D Line 260  Turn on debugging output from C<Class::D
260    
261  Dump more info on screen.  Dump more info on screen.
262    
 =item --email  
   
 Used to specify e-mail address where needed.  
   
263  =back  =back
264    
265    

Legend:
Removed from v.20  
changed lines
  Added in v.48

  ViewVC Help
Powered by ViewVC 1.1.26