X-Git-Url: https://defaria.com/gitweb/?a=blobdiff_plain;f=maps%2Fbin%2Fdisplay.cgi;h=55d31f828a7a9a3d85ab94bbfaf9532046007b64;hb=ae9e57b169de143d2b8a7c761c3bf7394385e0d0;hp=76f5ab6fef6f541c65aba432c9ad920f9c502e79;hpb=447c849fd507a59596617bec83358d82e4cf7736;p=clearscm.git diff --git a/maps/bin/display.cgi b/maps/bin/display.cgi index 76f5ab6..55d31f8 100755 --- a/maps/bin/display.cgi +++ b/maps/bin/display.cgi @@ -16,7 +16,7 @@ use strict; use warnings; use FindBin; -$0 = $FindBin::Script; +local $0 = $FindBin::Script; use lib "$FindBin::Bin/../lib"; @@ -30,10 +30,15 @@ use MIME::Parser; use MIME::Base64; use MIME::Words qw(:all); -my $userid = cookie('MAPSUser'); -my $sender = param('sender'); -my $msg_nbr = param('msg_nbr'); -my $table_name = 'message'; +my $userid = cookie('MAPSUser'); +my $sender = param('sender'); + +# CGI will replace '+' with ' ', which many mailers are starting to do, +# so add it back +$sender =~ s/ /\+/; + +my $msg_date = param('msg_date'); +my $table_name = 'message'; sub ParseEmail(@) { my (@header) = @_; @@ -65,24 +70,23 @@ sub ParseEmail(@) { } # ParseEmail sub Body($) { - my ($count) = @_; - - $count ||= 1; + my ($date) = @_; - my $handle = FindEmail $sender; + # Find unique message using $date + my ($err, $msg) = FindEmail( + userid => $userid, + sender => $sender, + timestamp => $date, + ); - my ($userid, $sender, $subject, $timestamp, $message); - - # Need to handle multiple messages - for (my $i = 0; $i < $count; $i++) { - ($userid, $sender, $subject, $timestamp, $message) = GetEmail $handle; - } # for + my $rec = GetEmail; my $parser = MIME::Parser->new(); - $parser->output_to_core (1); + $parser->output_to_core(1); + $parser->tmp_to_core(1); - my $entity = $parser->parse_data ($message); + my $entity = $parser->parse_data($rec->{data}); my %header = ParseEmail @{($entity->header)[0]}; @@ -94,7 +98,8 @@ sub Body($) { -cellpadding => 0, -width => "100%"}); print start_table ({-align => "center", - -bgcolor => "#d4d0c8", + -bgcolor => 'steelblue', + #-bgcolor => "#d4d0c8", -border => 0, -cellspacing => 2, -cellpadding => 2, @@ -104,28 +109,31 @@ sub Body($) { -border => 0, -cellspacing => 0, -cellpadding => 2, - -bgcolor => "#ece9d8", + -bgcolor => 'black', + #-bgcolor => "#ece9d8", -width => "100%"}) . "\n"; - foreach (keys (%header)) { + for (keys (%header)) { next if /base64/; - my $str = decode_mimewords ($header{$_}); + my $str = decode_mimewords($header{$_}); print Tr ([ - th ({-align => "right", - -bgcolor => "#ece9d8", - -width => "8%"}, "$_:") . "\n" . - td ({-bgcolor => "white"}, $str) + th ({-align => 'right', + -bgcolor => 'steelblue', + -style => 'color: white', + #-bgcolor => "#ece9d8", + -width => "8%"}, ucfirst "$_:") . "\n" . + td ({-bgcolor => 'white'}, $str) ]); - } # if + } # for print end_table; print ""; print end_table; - print start_table ({-align => "center", - -bgcolor => "black", + print start_table ({-align => 'center', + -bgcolor => 'steelblue', -border => 0, -cellspacing => 0, -cellpadding => 2, @@ -135,7 +143,7 @@ sub Body($) { -border => 0, -cellspacing => 0, -cellpadding => 2, - -bgcolor => "white", + -bgcolor => 'white', -width => "100%"}) . "\n"; print "\n"; @@ -147,7 +155,7 @@ sub Body($) { print $entity->{ME_Bodyhandle}{MBS_Data}; } else { print '
';
-      $entity->print_body;
+      print $entity->print_body;
       print '
'; } # if } else { @@ -161,9 +169,9 @@ sub Body($) { # There should be an easier way to get this but I couldn't find one. my $encoding = ${$subpart->{mail_inet_head}{mail_hdr_hash}{'Content-Transfer-Encoding'}[0]}; if ($encoding =~ /base64/) { - $subpart->bodyhandle->print(); + $subpart->bodayhandle->print; } else { - $subpart->print_body; + print $subpart->print_body; } # if last; } elsif ($subpart->mime_type eq 'multipart/related') { @@ -174,7 +182,7 @@ sub Body($) { } # for } elsif ($part->mime_type eq 'multipart/related') { # Sometimes parts are 'multipart/relative'... - $part->print_body; + $part->print_body; } else { if ($part->mime_type =~ /text/) { my $encoding = ''; @@ -186,7 +194,7 @@ sub Body($) { $part->bodyhandle->print(); } else { print '
';
-            $part->print_body;
+            print $part->print_body;
             print '
'; } # if } # if @@ -210,9 +218,11 @@ $userid = Heading( $table_name, ); +$userid //= $ENV{USER}; + SetContext($userid); NavigationBar($userid); -Body($msg_nbr); +Body($msg_date); Footing($table_name);