/[mws]/trunk/httpd.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

Annotation of /trunk/httpd.pl

Parent Directory Parent Directory | Revision Log Revision Log


Revision 19 - (hide annotations)
Fri May 7 20:52:34 2004 UTC (20 years ago) by dpavlin
File MIME type: text/plain
File size: 4302 byte(s)
added From, To, Cc lists with unique feature: it will count same names
in different order as, well, same name :-) It will also remove accented
characters when counting names, to detect false duplicates (using
Text::Unaccent)

1 dpavlin 5 #!/usr/bin/perl
2    
3     # based on post
4     # http://www.mail-archive.com/libwww@perl.org/msg04750.html
5    
6     use strict;
7     use warnings;
8     use HTTP::Daemon;
9     use HTTP::Status;
10     use IO::String;
11 dpavlin 6 use CGI::Lite;
12     use Template;
13     use MWS;
14 dpavlin 5
15 dpavlin 6 use Data::Dumper;
16    
17 dpavlin 17 my $debug = 1;
18    
19 dpavlin 5 my $d = HTTP::Daemon->new( Reuse => 1, LocalPort => 6969 ) || die;
20 dpavlin 6 my $cgi = new CGI::Lite;
21     my $mws = MWS->new('global.conf');
22     my $tt = Template->new({
23     INCLUDE_PATH => $mws->{config}->val('global', 'templates'),
24     FILTERS => {
25     'body5' => \&body5_filter,
26 dpavlin 14 'subject_search' => \&subject_search_filter,
27 dpavlin 6 },
28     });
29    
30 dpavlin 13 print "Web server ready at: ", $d->url, "\n";
31 dpavlin 6
32 dpavlin 13
33 dpavlin 5 while ( my $c = $d->accept ) {
34     while ( my $r = $c->get_request ) {
35    
36     # environs that a webserver should set.
37     $ENV{'REQUEST_METHOD'} = $r->method;
38     $ENV{'GATEWAY_INTERFACE'} = "CGI/1.0";
39     $ENV{'SERVER_PROTOCOL'} = $r->protocol;
40     $ENV{'CONTENT_TYPE'} = $r->content_type;
41    
42 dpavlin 6 # this part is based on CGI::Lite
43 dpavlin 5
44 dpavlin 6 $cgi->close_all_files();
45     $cgi->{web_data} = {};
46     $cgi->{ordered_keys} = [];
47     $cgi->{all_handles} = [];
48     $cgi->{error_status} = 0;
49     $cgi->{error_message} = undef;
50    
51 dpavlin 5 if ( $r->method eq 'GET' || $r->uri =~ /\?/ ) {
52 dpavlin 6 my $query_string = $r->uri;
53     $query_string =~ s/[^\?]+\?(.*)/$1/;
54     $cgi->_decode_url_encoded_data (\$query_string, 'form');
55    
56     } elsif ( $r->method eq 'POST' ) {
57    
58     if ($r->content_type eq 'application/x-www-form-urlencoded') {
59     # local $^W = 0;
60     $cgi->_decode_url_encoded_data (\$r->content, 'form');
61     } elsif ($r->content_type =~ /multipart\/form-data/) {
62     my ($boundary) = $r->content_type =~ /boundary=(\S+)$/;
63     $cgi->_parse_multipart_data ($r->content_length, $boundary);
64     }
65     } else {
66     $c->send_error(RC_FORBIDDEN);
67 dpavlin 5 }
68    
69 dpavlin 6 my $param = $cgi->{web_data};
70     my $url = $r->url->path;
71 dpavlin 5
72 dpavlin 6 # XXX LOG
73 dpavlin 17 print $r->method," ",$url,"\n",Dumper($param),"\n" if ($debug);
74 dpavlin 5
75 dpavlin 7 # template file name (use ?format=html as default)
76     my $tpl_file = 'master.';
77     $tpl_file .= $param->{'format'} || 'html';
78    
79     #
80     # implement functionality and generate HTML
81     #
82 dpavlin 6 my $html;
83 dpavlin 5
84 dpavlin 12 if ($param->{'search_val'} && $param->{'search_fld'} && !$param->{'search'}) {
85     $param->{'search'} = $param->{'search_fld'}.":".$param->{'search_val'};
86 dpavlin 16 } elsif ($param->{'search'}) {
87     ($param->{'search_fld'}, $param->{'search_val'}) = split(/:/,$param->{'search'},2);
88 dpavlin 12 }
89    
90 dpavlin 13 my $tpl_var = {
91     param => $param
92     };
93    
94 dpavlin 7 # show search results
95     # ?search=foo:bar
96     if ($param->{'search'}) {
97 dpavlin 5
98 dpavlin 7 print STDERR "search: ",$param->{'search'},"\n";
99 dpavlin 5
100 dpavlin 7 my $results = $mws->search($param->{'search'});
101 dpavlin 6 my @res = $mws->fetch_all_results();
102 dpavlin 5
103 dpavlin 13 $tpl_var->{results} = \@res;
104 dpavlin 17 $tpl_var->{total_hits} = $mws->{total_hits};
105 dpavlin 7
106 dpavlin 13
107 dpavlin 7 #
108     # ?show_id=XXXXxxxx___message_id___xxxxXXXX
109     } elsif ($param->{'show_id'}) {
110 dpavlin 19
111     $mws->reset_counters;
112 dpavlin 7 my $row = $mws->fetch_result_by_id($param->{'show_id'});
113 dpavlin 13 $tpl_var->{message} = $row;
114 dpavlin 6 }
115 dpavlin 5
116 dpavlin 19 print Dumper($mws->{counter});
117    
118     # push counters to template
119     foreach my $f (qw(from to cc bcc)) {
120     my $h = $mws->counter($f) || next;
121     my @a;
122     foreach my $k (sort { $h->{$b}->{usage} <=> $h->{$a}->{usage} } keys %$h) {
123     push @a, $h->{$k};
124     }
125     $tpl_var->{counters}->{$f} = [ @a ] if (@a);
126     }
127    
128 dpavlin 13 $tt->process($tpl_file, $tpl_var, \$html) || die $tt->error();
129    
130 dpavlin 7 #
131     # send HTMLto client
132     #
133    
134 dpavlin 5 my $res = HTTP::Response->new(RC_OK);
135 dpavlin 14 $res->header( 'Content-type' => 'text/html; charset=ISO-8859-2' );
136 dpavlin 6 $res->content($html);
137 dpavlin 5 $c->send_response($res);
138    
139     $c->close;
140     }
141     undef($c);
142     }
143 dpavlin 6
144     # template toolkit filter
145    
146 dpavlin 12 #use Text::Context::EitherSide;
147    
148 dpavlin 6 sub body5_filter {
149     my $text = shift;
150     $text =~ s/^\s+//gs;
151 dpavlin 12 $text =~ s/^[\>:\|=]+\s*.*?$//msg; # remove quoted text
152     $text =~ s/[\n\r]+/\n/gs; # compress cr/lf
153 dpavlin 14 if ($text =~ s,^((?:.*?[\n\r]){5}).*$,$1,s) {
154     $text =~ s/[\n\r]*$/ .../;
155     }
156 dpavlin 7 $text =~ s/[\n\r]+--\s*[\n\r]+.*$//s;
157 dpavlin 12
158     # my $context = Text::Context::EitherSide->new($text, context => 5);
159     # return $context->as_string("perl");
160    
161 dpavlin 6 return $text;
162     }
163 dpavlin 7
164 dpavlin 14 sub subject_search_filter {
165     my $s = shift;
166     # remove re: fdw: [list] preffixes from e-mail
167 dpavlin 16 while ( $s =~ s/^\s*\[(?:re|fwd|fw):\s+(.+)\]\s*$/$1/ig ||
168     $s =~ s/^\s*(?:re|fwd|fw):\s+(.+?)\s*$/$1/ig ||
169     $s =~ s/^\[\S+\]\s*//ig ||
170 dpavlin 19 $s =~ s/^\[[^@]+@\w+\.\w+\s*:\s+(.+)\s*\]\s*$/$1/g ||
171     $s =~ s/\(fwd\)\s*$//ig ||
172     $s =~ s/\"//g
173 dpavlin 14 ) { };
174     return $s;
175     }

Properties

Name Value
svn:executable *

  ViewVC Help
Powered by ViewVC 1.1.26