/[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 32 by dpavlin, Mon May 16 22:32:58 2005 UTC revision 61 by dpavlin, Wed Jun 22 12:26:54 2005 UTC
# Line 13  sender.pl - command line notify sender u Line 13  sender.pl - command line notify sender u
13    
14   sender.pl --new=mylist   sender.pl --new=mylist
15   sender.pl --add=mylist members.txt   sender.pl --add=mylist members.txt
16     sender.pl --delete=mylist members.txt
17   sender.pl --list[=mylist]   sender.pl --list[=mylist]
18   sender.pl --queue[=mylist message.txt]   sender.pl --queue[=mylist message.txt]
19   sender.pl --send=mylist   sender.pl --send=mylist
20    
21  In C</etc/aliases> something like:  In C</etc/aliases> something like:
22    
23   mylist: "| /path/to/sender.pl --inbox=mylist"   mylist: "| cd /path/to && ./sender.pl --inbox=mylist"
24    
25  =head2 Command options  =head2 Command options
26    
# Line 35  my $result = GetOptions( Line 36  my $result = GetOptions(
36          "new=s" => \$opt->{'new'},          "new=s" => \$opt->{'new'},
37          "list:s" => \$opt->{'list'},          "list:s" => \$opt->{'list'},
38          "add=s" => \$opt->{'add'},          "add=s" => \$opt->{'add'},
39            "delete=s" => \$opt->{'delete'},
40          "queue:s" => \$opt->{'queue'},          "queue:s" => \$opt->{'queue'},
41          "send:s" => \$opt->{'send'},          "send:s" => \$opt->{'send'},
42          "inbox=s" => \$opt->{'inbox'},          "inbox=s" => \$opt->{'inbox'},
43          "debug" => \$debug,          "debug" => \$debug,
44          "verbose" => \$verbose,          "verbose" => \$verbose,
45          "email=s" => \$opt->{'email'},          "from=s" => \$opt->{'from'},
46            "driver=s" => \$opt->{'email_send_driver'},
47            "sleep=i" => \$opt->{'sleep'},
48  );  );
49    
50  my $nos = new Nos(  my $nos = new Nos(
# Line 74  my $list_name; Line 78  my $list_name;
78    
79  Adds new list. You can also feed list name as first line to C<STDIN>.  Adds new list. You can also feed list name as first line to C<STDIN>.
80    
81    You can also add C<--from='Full name of list'> to specify full name (comment)
82    in outgoing e-mail.
83    
84  =cut  =cut
85    
86  if ($list_name = $opt->{'new'}) {  if ($list_name = $opt->{'new'}) {
# Line 83  if ($list_name = $opt->{'new'}) { Line 90  if ($list_name = $opt->{'new'}) {
90    
91          die "need e-mail address for list (as argument or on STDIN)\n" unless ($email);          die "need e-mail address for list (as argument or on STDIN)\n" unless ($email);
92    
93          my $l = $nos->_get_list($list_name) || $nos->_add_list(          my $id = $nos->new_list(
94                  list => $list_name,                  list => $list_name,
95                    from => ($opt->{'from'} || ''),
96                  email => $email,                  email => $email,
97          ) || die "can't add list $list_name\n";          ) || die "can't add list $list_name\n";
98    
99          print "added list $list_name with ID ",$l->id,"\n";          print "added list $list_name with ID $id\n";
100    
101    
102  =item --list[=list_name]  =item --list[=list_name]
# Line 111  on that list. Line 119  on that list.
119          }          }
120    
121          foreach my $list (@lists) {          foreach my $list (@lists) {
122                  print $list->name," <",$list->email,">\n";                  print $list->name,": ",$list->from_addr," <",$list->email,">\n";
123                  foreach my $user_on_list ($user_list->search(list_id => $list->id)) {                  foreach my $u ($nos->list_members( list => $list->name )) {
124                          my $user = $users->retrieve( id => $user_on_list->user_id );                          print "\t",$u->{'name'}, " <", $u->{'email'}, ">",( $u->{'ext_id'} ? ' ['.$u->{'ext_id'}.']' : '' ),"\n";
                         print "\t",$user->full_name," <", $user->email, ">\n";  
125                  }                  }
126          }          }
127    
# Line 127  argument) or read from C<STDIN>. List sh Line 134  argument) or read from C<STDIN>. List sh
134   email@example.com      Optional full name of person   email@example.com      Optional full name of person
135   dpavlin@rot13.org      Dobrica Pavlinusic   dpavlin@rot13.org      Dobrica Pavlinusic
136    
 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>.  
   
137  =cut  =cut
138    
139  } elsif ($list_name = $opt->{'add'}) {  } elsif ($list_name = $opt->{'add'}) {
140    
141          my $list = $lists->find_or_create({          my $list = $nos->_get_list($list_name) || die "can't find list $list_name\n";
                 name => $list_name,  
         }) || die "can't add list $list_name\n";  
142    
143          my $added = 0;          my $added = 0;
144    
# Line 150  B<This seems somewhat cludgy, and it wil Line 152  B<This seems somewhat cludgy, and it wil
152          print "list ",$list->name," has $added users\n";          print "list ",$list->name," has $added users\n";
153    
154    
155    =item --delete=list_name
156    
157    Delete users from list. User e-mails can be stored in file (which can be
158    supplied as argument) or read from C<STDIN>.
159    
160    =cut
161    } elsif ($list_name = $opt->{'delete'}) {
162    
163            my $list = $nos->_get_list($list_name) || die "can't find list $list_name\n";
164    
165            my $deleted = 0;
166    
167            while(<>) {
168                    chomp;
169                    next if (/^#/ || /^\s*$/);
170                    my $email = $_;
171                    $deleted++ if ($nos->delete_member_from_list( email => $email, list => $list_name ));
172            }
173    
174            print "list ",$list->name," lost $deleted users\n";
175    
176    
177  =item --queue[=list_name]  =item --queue[=list_name]
178    
179  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 190  add C<--verbose> flag, it will display a Line 214  add C<--verbose> flag, it will display a
214                          my $msg = $m->message_id->message;                          my $msg = $m->message_id->message;
215                          $msg =~ s/\s+/ /gs;                          $msg =~ s/\s+/ /gs;
216    
217                          $l .= sprintf(" %-10s %15s : ", $m->list_id->name, $date);                          $l .= sprintf(" %-15s %15s : ", $m->list_id->name, $date);
218                          $l .= substr($msg, 0, 79 - length($l));                          $l .= substr($msg, 0, 79 - length($l));
219    
220                          print "$l\n";                          print "$l\n";
# Line 204  add C<--verbose> flag, it will display a Line 228  add C<--verbose> flag, it will display a
228  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
229  for single list.  for single list.
230    
231    Optional argument C<--driver=smtp> forces sending using SMTP server at
232    localhost (127.0.0.1).
233    
234    Optional argument C<--sleep=42> defines that sender will sleep 42 seconds
235    between sending e-mail.
236    
237  =cut  =cut
238    
239  } elsif (defined($list_name = $opt->{'send'})) {  } elsif (defined($list_name = $opt->{'send'})) {
240    
241          $nos->send_queued_messages($list_name);          unless ($opt->{'email_send_driver'}) {
242                    print "WARNING: this will dump debugging output to STDERR\n";
243                    print "enter alternative driver (e.g. smtp): ";
244                    my $d = <STDIN>;
245                    chomp($d);
246                    $opt->{'email_send_driver'} = $d;
247            }
248    
249            $nos->send_queued_messages(
250                    list => $list_name,
251                    driver => $opt->{'email_send_driver'},
252                    sleep => $opt->{'sleep'},
253            );
254    
255    
256  =item --inbox=list_name  =item --inbox=list_name
# Line 217  Feed incomming message back into notice Line 259  Feed incomming message back into notice
259    
260  =cut  =cut
261    
262  } elsif ($opt->{'inbox'}) {  } elsif ($list_name = $opt->{'inbox'}) {
263    
264            my $message;
265            while(<>) {
266                    $message .= $_;
267            }
268    
269            $nos->inbox_message(
270                    list => $list_name,
271                    message => $message,
272            ) || die "can't receive message for list $list_name";
273    
         warn "inbox option is not implemented";  
274    
275  } else  {  } else  {
276          die "see perldoc $0 for help\n";          die "see perldoc $0 for help\n";
# Line 241  Turn on debugging output from C<Class::D Line 292  Turn on debugging output from C<Class::D
292    
293  Dump more info on screen.  Dump more info on screen.
294    
 =item --email  
   
 Used to specify e-mail address where needed.  
   
295  =back  =back
296    
297    

Legend:
Removed from v.32  
changed lines
  Added in v.61

  ViewVC Help
Powered by ViewVC 1.1.26