/[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 18 by dpavlin, Sun May 15 17:01:19 2005 UTC revision 38 by dpavlin, Tue May 17 21:37:06 2005 UTC
# Line 1  Line 1 
1  #!/usr/bin/perl -w  #!/usr/bin/perl -w
2    
3  use strict;  use strict;
4  use Class::DBI::Loader::Pg;  use blib;
5    use Nos;
6  use Getopt::Long;  use Getopt::Long;
 use Email::Valid;  
 use Email::Send;  
7    
8  =head1 NAME  =head1 NAME
9    
# Line 12  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: "| /path/to/sender.pl --inbox=mylist"
23    
24  =head2 Command options  =head2 Command options
25    
26  =over 20  =over 20
# Line 25  sender.pl - command line notify sender u Line 29  sender.pl - command line notify sender u
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;  
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            "send:s" => \$opt->{'send'},
40            "inbox=s" => \$opt->{'inbox'},
41          "debug" => \$debug,          "debug" => \$debug,
42          "verbose" => \$verbose,          "verbose" => \$verbose,
         "email=s" => \$email_opt,  
43  );  );
44    
45    my $nos = new Nos(
46  my $loader = Class::DBI::Loader::Pg->new(          dsn => 'dbi:Pg:dbname=notices',
47          debug           => $debug,          user => 'dpavlin',
48          dsn             => "dbi:Pg:dbname=notices",          passwd => '',
49          user            => "dpavlin",          debug => $debug,
50          password        => "",          verbose => $verbose,
         namespace       => "Noticer",  
 #       additional_classes      => qw/Class::DBI::AbstractSearch/,  
 #       additional_base_classes => qw/My::Stuff/,  
         relationships   => 1,  
51  );  );
52    
53    my $loader = $nos->{'loader'} || die "can't find loader?";
54    
55  my $lists = $loader->find_class('lists');  my $lists = $loader->find_class('lists');
56  my $users = $loader->find_class('users');  my $users = $loader->find_class('users');
57  my $user_list = $loader->find_class('user_list');  my $user_list = $loader->find_class('user_list');
# Line 67  $queue->set_sql( list_queue => qq{ Line 66  $queue->set_sql( list_queue => qq{
66          JOIN lists on list_id = lists.id          JOIN lists on list_id = lists.id
67  } );  } );
68    
69    my $list_name;
70    
71    
72    =item --new=list_name my-list@example.com
73    
74    Adds new list. You can also feed list name as first line to C<STDIN>.
75    
76    =cut
77    
78    if ($list_name = $opt->{'new'}) {
79    
80            my $email = shift @ARGV || <>;
81            chomp($email);
82    
83            die "need e-mail address for list (as argument or on STDIN)\n" unless ($email);
84    
85            my $id = $nos->new_list(
86                    list => $list_name,
87                    email => $email,
88            ) || die "can't add list $list_name\n";
89    
90            print "added list $list_name with ID $id\n";
91    
92    
93  =item --list[=list_name]  =item --list[=list_name]
94    
# Line 77  on that list. Line 99  on that list.
99    
100  =cut  =cut
101    
102  if (defined($list_opt)) {  } elsif (defined($list_name = $opt->{'list'})) {
103    
104          my @lists;          my @lists;
105          if ($list_opt ne '') {  
106                  @lists = $lists->search( name=> $list_opt )->first || die "can't find list $list_opt";          if ($list_name ne '') {
107                    @lists = $lists->search( name=> $list_name )->first || die "can't find list $list_name";
108          } else {          } else {
109                  @lists = $lists->retrieve_all;                  @lists = $lists->retrieve_all;
110          }          }
# Line 93  if (defined($list_opt)) { Line 117  if (defined($list_opt)) {
117                  }                  }
118          }          }
119    
120    
121  =item --add=list_name  =item --add=list_name
122    
123  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 101  argument) or read from C<STDIN>. List sh Line 126  argument) or read from C<STDIN>. List sh
126   email@example.com      Optional full name of person   email@example.com      Optional full name of person
127   dpavlin@rot13.org      Dobrica Pavlinusic   dpavlin@rot13.org      Dobrica Pavlinusic
128    
 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>.  
   
129  =cut  =cut
130    
131  } elsif ($add_opt) {  } elsif ($list_name = $opt->{'add'}) {
132          #my $noticer = $loader->find_class('Noticer') || die "can't find my class!";  
133          my $list = $lists->find_or_create({          my $list = $lists->find_or_create({
134                  name => $add_opt,                  name => $list_name,
135          }) || 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;  
         }  
136    
137          my $added = 0;          my $added = 0;
138    
# Line 123  B<This seems somewhat cludgy, and it wil Line 140  B<This seems somewhat cludgy, and it wil
140                  chomp;                  chomp;
141                  next if (/^#/ || /^\s*$/);                  next if (/^#/ || /^\s*$/);
142                  my ($email, $name) = split(/\s+/,$_, 2);                  my ($email, $name) = split(/\s+/,$_, 2);
143                  $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();  
144          }          }
145    
146          print "list ",$list->name," has $added users\n";          print "list ",$list->name," has $added users\n";
147    
148    
149  =item --queue[=list_name]  =item --queue[=list_name]
150    
151  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 157  add C<--verbose> flag, it will display a Line 156  add C<--verbose> flag, it will display a
156    
157  =cut  =cut
158    
159  } elsif (defined($queue_opt)) {  } elsif (defined($list_name = $opt->{'queue'})) {
160    
161          if ($queue_opt ne '') {          if ($list_name ne '') {
162                  # add message to list queue                  # add message to list queue
163    
                 my $this_list = $lists->search(  
                         name => $queue_opt,  
                 )->first || die "can't find list $queue_opt";  
   
164                  my $message_text;                  my $message_text;
165                  while(<>) {                  while(<>) {
166                          $message_text .= $_;                          $message_text .= $_;
167                  }                  }
168    
169                  die "no message" unless ($message_text);                  my $id = $nos->add_message_to_list(
170                            list => $list_name,
171                  my $this_message = $messages->find_or_create({                          message => $message_text,
172                          message => $message_text                  ) || die "can't add message to list $list_name\n";
                 }) || die "can't insert message";  
173    
174                  $this_message->dbi_commit() || die "can't add message";                  print "added message $id to list $list_name\n";
   
                 $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;  
   
                 $queue->dbi_commit || die "can't add message to list ",$this_list->name;  
   
                 print "added message ",$this_message->id, " to list ",$this_list->name,"\n";  
175    
176          } else {          } else {
177                  # list messages in queue                          # list messages in queue        
# Line 201  add C<--verbose> flag, it will display a Line 186  add C<--verbose> flag, it will display a
186                          my $msg = $m->message_id->message;                          my $msg = $m->message_id->message;
187                          $msg =~ s/\s+/ /gs;                          $msg =~ s/\s+/ /gs;
188    
189                          $l .= sprintf(" %-10s %15s : ", $m->list_id->name, $date);                          $l .= sprintf(" %-15s %15s : ", $m->list_id->name, $date);
190                          $l .= substr($msg, 0, 79 - length($l));                          $l .= substr($msg, 0, 79 - length($l));
191    
192                          print "$l\n";                          print "$l\n";
# Line 209  add C<--verbose> flag, it will display a Line 194  add C<--verbose> flag, it will display a
194    
195          }          }
196    
197    
198  =item --send[=list_name]  =item --send[=list_name]
199    
200  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
# Line 216  for single list. Line 202  for single list.
202    
203  =cut  =cut
204    
205  } elsif (defined($send_opt)) {  } elsif (defined($list_name = $opt->{'send'})) {
206    
207          my $my_q;          $nos->send_queued_messages($list_name);
         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;  
         }  
208    
         while (my $m = $my_q->next) {  
                 next if ($m->all_sent);  
209    
210                  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;  
211    
212                  foreach my $u ($user_list->search(list_id => $m->list_id)) {  Feed incomming message back into notice sender.
213    
214                          my $hdr = "To: ".$u->user_id->full_name." <". $u->user_id->email. ">\n";  =cut
215    
216                          if ($sent->search( message_id => $m->message_id, user_id => $u->user_id )) {  } elsif ($list_name = $opt->{'inbox'}) {
217                                  print "SKIP ",$u->user_id->email," message allready sent\n";  
218                          } else {          my $message;
219                                  print "\t",$u->user_id->email,"\n";          while(<>) {
220                    $message .= $_;
                                 # FIXME do real sending :-)  
                                 send IO => "$hdr\n$msg";  
   
                                 $sent->create({  
                                         message_id => $m->message_id,  
                                         user_id => $u->user_id,  
                                 });  
                                 $sent->dbi_commit;  
                         }  
                 }  
                 $m->all_sent(1);  
                 $m->update;  
                 $m->dbi_commit;  
221          }          }
222    
223            $nos->inbox_message(
224                    list => $list_name,
225                    message => $message,
226            ) || die "can't receive message for list $list_name";
227    
228    
229  } else  {  } else  {
230          die "see perldoc $0 for help";          die "see perldoc $0 for help\n";
231  }  }
232    
233  =back  =back
# Line 278  Turn on debugging output from C<Class::D Line 246  Turn on debugging output from C<Class::D
246    
247  Dump more info on screen.  Dump more info on screen.
248    
 =item --email  
   
 Used to specify e-mail address where needed.  
   
249  =back  =back
250    
251    

Legend:
Removed from v.18  
changed lines
  Added in v.38

  ViewVC Help
Powered by ViewVC 1.1.26