/[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 24 by dpavlin, Sun May 15 22:30:54 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'}) {
         my $list = $lists->find_or_create({  
                 name => $add_opt,  
         }) || die "can't add list $add_opt\n";  
139    
140          if ($email_opt && $list->email ne $email_opt) {          my $list = $lists->find_or_create({
141                  $list->email($email_opt);                  name => $list_name,
142                  $list->update;          }) || die "can't add list $list_name\n";
                 $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                  $added++ if ($nos->add_member_to_list( email => $email, name => $name, list => $add_opt ));                  $added++ if ($nos->add_member_to_list( email => $email, name => $name, list => $list_name ));
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 135  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    
171                  my $message_text;                  my $message_text;
# Line 145  add C<--verbose> flag, it will display a Line 173  add C<--verbose> flag, it will display a
173                          $message_text .= $_;                          $message_text .= $_;
174                  }                  }
175    
176                  my $id = $nos->add_message_to_queue(                  my $id = $nos->add_message_to_list(
177                          list => $queue_opt,                          list => $list_name,
178                          message => $message_text,                          message => $message_text,
179                  );                  ) || die "can't add message to list $list_name\n";
180    
181                  print "added message $id to list $queue_opt\n";                  print "added message $id to list $list_name\n";
182    
183          } else {          } else {
184                  # list messages in queue                          # list messages in queue        
# Line 165  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 173  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            $nos->send_queued_messages($list_name, $opt->{'email_send_driver'});
218    
219    
220    =item --inbox=list_name
221    
222    Feed incomming message back into notice sender.
223    
224    Optional argument C<--bounce> define that this message is received to
225    bounce address.
226    
227    =cut
228    
229    } elsif ($list_name = $opt->{'inbox'}) {
230    
231            my $message;
232            while(<>) {
233                    $message .= $_;
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    
         $nos->send_queued_messages($send_opt);  
242    
243  } else  {  } else  {
244          die "see perldoc $0 for help";          die "see perldoc $0 for help\n";
245  }  }
246    
247  =back  =back
# Line 204  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.24  
changed lines
  Added in v.48

  ViewVC Help
Powered by ViewVC 1.1.26