/[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 29 by dpavlin, Mon May 16 20:58:44 2005 UTC revision 49 by dpavlin, Tue May 24 16:44:34 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]
# Line 18  sender.pl - command line notify sender u Line 19  sender.pl - command line notify sender u
19    
20  In C</etc/aliases> something like:  In C</etc/aliases> something like:
21    
22   mylist: "| /path/to/sender.pl --inbox=mylist"   mylist: "| cd /path/to && ./sender.pl --inbox=mylist"
23    
24  =head2 Command options  =head2 Command options
25    
# Line 28  In C</etc/aliases> something like: Line 29  In C</etc/aliases> something like:
29    
30  my $debug = 0;  my $debug = 0;
31  my $verbose = 0;  my $verbose = 0;
32  my $list_opt;  my $opt;
 my $add_opt;  
 my $queue_opt;  
 my $send_opt;  
 my $email_opt;  
 my $inbox_opt;  
33    
34  my $result = GetOptions(  my $result = GetOptions(
35          "list:s" => \$list_opt,          "new=s" => \$opt->{'new'},
36          "add=s" => \$add_opt,          "list:s" => \$opt->{'list'},
37          "queue:s" => \$queue_opt,          "add=s" => \$opt->{'add'},
38          "send:s" => \$send_opt,          "queue:s" => \$opt->{'queue'},
39          "inbox=s" => \$inbox_opt,          "send:s" => \$opt->{'send'},
40            "inbox=s" => \$opt->{'inbox'},
41          "debug" => \$debug,          "debug" => \$debug,
42          "verbose" => \$verbose,          "verbose" => \$verbose,
43          "email=s" => \$email_opt,          "from=s" => \$opt->{'from'},
44            "driver=s" => \$opt->{'email_send_driver'},
45            "sleep=i" => \$opt->{'sleep'},
46  );  );
47    
48  my $nos = new Nos(  my $nos = new Nos(
# Line 70  $queue->set_sql( list_queue => qq{ Line 69  $queue->set_sql( list_queue => qq{
69          JOIN lists on list_id = lists.id          JOIN lists on list_id = lists.id
70  } );  } );
71    
72    my $list_name;
73    
74    
75    =item --new=list_name my-list@example.com
76    
77    Adds new list. You can also feed list name as first line to C<STDIN>.
78    
79    You can also add C<--from='Full name of list'> to specify full name (comment)
80    in outgoing e-mail.
81    
82    =cut
83    
84    if ($list_name = $opt->{'new'}) {
85    
86            my $email = shift @ARGV || <>;
87            chomp($email);
88    
89            die "need e-mail address for list (as argument or on STDIN)\n" unless ($email);
90    
91            my $id = $nos->new_list(
92                    list => $list_name,
93                    from => ($opt->{'from'} || ''),
94                    email => $email,
95            ) || die "can't add list $list_name\n";
96    
97            print "added list $list_name with ID $id\n";
98    
99    
100  =item --list[=list_name]  =item --list[=list_name]
101    
# Line 80  on that list. Line 106  on that list.
106    
107  =cut  =cut
108    
109  if (defined($list_opt)) {  } elsif (defined($list_name = $opt->{'list'})) {
110    
111          my @lists;          my @lists;
112          if ($list_opt ne '') {  
113                  @lists = $lists->search( name=> $list_opt )->first || die "can't find list $list_opt";          if ($list_name ne '') {
114                    @lists = $lists->search( name=> $list_name )->first || die "can't find list $list_name";
115          } else {          } else {
116                  @lists = $lists->retrieve_all;                  @lists = $lists->retrieve_all;
117          }          }
118    
119          foreach my $list (@lists) {          foreach my $list (@lists) {
120                  print $list->name," <",$list->email,">\n";                  print $list->name," <",$list->email,">\n";
121                  foreach my $user_on_list ($user_list->search(list_id => $list->id)) {                  foreach my $u ($nos->list_members( list => $list->name )) {
122                          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";  
123                  }                  }
124          }          }
125    
126    
127  =item --add=list_name  =item --add=list_name
128    
129  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 104  argument) or read from C<STDIN>. List sh Line 132  argument) or read from C<STDIN>. List sh
132   email@example.com      Optional full name of person   email@example.com      Optional full name of person
133   dpavlin@rot13.org      Dobrica Pavlinusic   dpavlin@rot13.org      Dobrica Pavlinusic
134    
 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>.  
   
135  =cut  =cut
136    
137  } 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";  
138    
139          if ($email_opt && $list->email ne $email_opt) {          my $list = $lists->find_or_create({
140                  $list->email($email_opt);                  name => $list_name,
141                  $list->update;          }) || die "can't add list $list_name\n";
                 $list->dbi_commit;  
         }  
142    
143          my $added = 0;          my $added = 0;
144    
# Line 126  B<This seems somewhat cludgy, and it wil Line 146  B<This seems somewhat cludgy, and it wil
146                  chomp;                  chomp;
147                  next if (/^#/ || /^\s*$/);                  next if (/^#/ || /^\s*$/);
148                  my ($email, $name) = split(/\s+/,$_, 2);                  my ($email, $name) = split(/\s+/,$_, 2);
149                  $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 ));
150          }          }
151    
152          print "list ",$list->name," has $added users\n";          print "list ",$list->name," has $added users\n";
153    
154    
155  =item --queue[=list_name]  =item --queue[=list_name]
156    
157  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 141  add C<--verbose> flag, it will display a Line 162  add C<--verbose> flag, it will display a
162    
163  =cut  =cut
164    
165  } elsif (defined($queue_opt)) {  } elsif (defined($list_name = $opt->{'queue'})) {
166    
167          if ($queue_opt ne '') {          if ($list_name ne '') {
168                  # add message to list queue                  # add message to list queue
169    
170                  my $message_text;                  my $message_text;
# Line 152  add C<--verbose> flag, it will display a Line 173  add C<--verbose> flag, it will display a
173                  }                  }
174    
175                  my $id = $nos->add_message_to_list(                  my $id = $nos->add_message_to_list(
176                          list => $queue_opt,                          list => $list_name,
177                          message => $message_text,                          message => $message_text,
178                  );                  ) || die "can't add message to list $list_name\n";
179    
180                  print "added message $id to list $queue_opt\n";                  print "added message $id to list $list_name\n";
181    
182          } else {          } else {
183                  # list messages in queue                          # list messages in queue        
# Line 171  add C<--verbose> flag, it will display a Line 192  add C<--verbose> flag, it will display a
192                          my $msg = $m->message_id->message;                          my $msg = $m->message_id->message;
193                          $msg =~ s/\s+/ /gs;                          $msg =~ s/\s+/ /gs;
194    
195                          $l .= sprintf(" %-10s %15s : ", $m->list_id->name, $date);                          $l .= sprintf(" %-15s %15s : ", $m->list_id->name, $date);
196                          $l .= substr($msg, 0, 79 - length($l));                          $l .= substr($msg, 0, 79 - length($l));
197    
198                          print "$l\n";                          print "$l\n";
# Line 179  add C<--verbose> flag, it will display a Line 200  add C<--verbose> flag, it will display a
200    
201          }          }
202    
203    
204  =item --send[=list_name]  =item --send[=list_name]
205    
206  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
207  for single list.  for single list.
208    
209    Optional argument C<--driver=smtp> forces sending using SMTP server at
210    localhost (127.0.0.1).
211    
212    Optional argument C<--sleep=42> defines that sender will sleep 42 seconds
213    between sending e-mail.
214    
215  =cut  =cut
216    
217  } elsif (defined($send_opt)) {  } elsif (defined($list_name = $opt->{'send'})) {
218    
219            $nos->send_queued_messages(
220                    list => $list_name,
221                    driver => $opt->{'email_send_driver'},
222                    sleep => $opt->{'sleep'},
223            );
224    
         $nos->send_queued_messages($send_opt);  
225    
226  =item --inbox=list_name  =item --inbox=list_name
227    
# Line 196  Feed incomming message back into notice Line 229  Feed incomming message back into notice
229    
230  =cut  =cut
231    
232  } elsif ($inbox_opt) {  } elsif ($list_name = $opt->{'inbox'}) {
233    
234            my $message;
235            while(<>) {
236                    $message .= $_;
237            }
238    
239            $nos->inbox_message(
240                    list => $list_name,
241                    message => $message,
242            ) || die "can't receive message for list $list_name";
243    
         warn "inbox option is not implemented";  
244    
245  } else  {  } else  {
246          die "see perldoc $0 for help";          die "see perldoc $0 for help\n";
247  }  }
248    
249  =back  =back
# Line 220  Turn on debugging output from C<Class::D Line 262  Turn on debugging output from C<Class::D
262    
263  Dump more info on screen.  Dump more info on screen.
264    
 =item --email  
   
 Used to specify e-mail address where needed.  
   
265  =back  =back
266    
267    

Legend:
Removed from v.29  
changed lines
  Added in v.49

  ViewVC Help
Powered by ViewVC 1.1.26