X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=cgi%2Flibravatar.cgi;h=406f696e229643b6151c079a76852718da7af36d;hb=e70e704b15e8e3a2ffd207d4251dbeb19e0b39ff;hp=276b3925fee74f07a658a9f595b457f66548ada0;hpb=6d58a53155cd78fd9ae2b8726da7dd9fc179ffbd;p=debbugs.git diff --git a/cgi/libravatar.cgi b/cgi/libravatar.cgi index 276b392..406f696 100755 --- a/cgi/libravatar.cgi +++ b/cgi/libravatar.cgi @@ -3,20 +3,40 @@ use warnings; use strict; +# if we're running out of git, we want to use the git base directory as the +# first INC directory. If you're not running out of git, don't do that. +use File::Basename qw(dirname); +use Cwd qw(abs_path); +our $debbugs_dir; +BEGIN { + $debbugs_dir = + abs_path(dirname(abs_path(__FILE__)) . '/../'); + # clear the taint; we'll assume that the absolute path to __FILE__ is the + # right path if there's a .git directory there + ($debbugs_dir) = $debbugs_dir =~ /([[:print:]]+)/; + if (defined $debbugs_dir and + -d $debbugs_dir . '/.git/') { + } else { + undef $debbugs_dir; + } + # if the first directory in @INC is not an absolute directory, assume that + # someone has overridden us via -I. + if ($INC[0] !~ /^\//) { + } +} +use if defined $debbugs_dir, lib => $debbugs_dir; + use Debbugs::Config qw(:config); use Debbugs::CGI qw(cgi_parameters); use Debbugs::Common; -use Digest::MD5 qw(md5_hex); use File::LibMagic; -use File::Temp qw(tempfile); use Debbugs::Libravatar qw(:libravatar); use Libravatar::URL; -use HTTP::Request; - use CGI::Simple; use Cwd qw(abs_path); +use Digest::MD5 qw(md5_hex); my $q = CGI::Simple->new(); @@ -29,47 +49,64 @@ my %param = ); # if avatar is no, serve the empty png if ($param{avatar} ne 'yes' or not defined $param{email} or not length $param{email}) { - serve_cache('',$q); + serve_cache('',$q,0); exit 0; } -# figure out what the md5sum of the e-mail is. -my $email_md5sum = md5_hex(lc($param{email})); -my $cache_location = cache_location(email => lc($param{email})); +my ($cache_location, $timestamp) = cache_location(email => lc($param{email})); # if we've got it, and it's less than one hour old, return it. -if (cache_valid($cache_location)) { - serve_cache($cache_location,$q); +if ($timestamp) { + serve_cache($cache_location,$q,$timestamp); exit 0; } # if we don't have it, get it, and store it in the cache -$cache_location = retrieve_libravatar(location => $cache_location, - email => lc($param{email}), - ); +($cache_location,$timestamp) = + retrieve_libravatar(location => $cache_location, + email => lc($param{email}), + ); if (not defined $cache_location) { # failure, serve the default image - serve_cache('',$q); + serve_cache('',$q,0); exit 0; } else { - serve_cache($cache_location,$q); + serve_cache($cache_location,$q,$timestamp); exit 0; } sub serve_cache { - my ($cache_location,$q) = @_; + my ($cache_location,$q,$timestamp) = @_; if (not defined $cache_location or not length $cache_location) { # serve the default image $cache_location = $config{libravatar_default_image}; + if (not defined $timestamp or not $timestamp) { + $timestamp = (stat($cache_location))[9]; + } + } + if (not defined $timestamp) { + # this probably means that the default image doesn't exist + print $q->header(status => 404); + print "404: Not found\n"; + return; + } + my $etag = md5_hex($cache_location.$timestamp); + if (defined $q->http('if-none-match') + and $etag eq $q->http('if-none-match')) { + print $q->header(-status => 304); + print "304: Not modified\n"; + return; } my $fh = IO::File->new($cache_location,'r') or - error($q,404, "Failed to open cached image $cache_location"); + error($q,404, "Failed to open cached image $cache_location"); my $m = File::LibMagic->new() or - error($q,500,'Unable to create File::LibMagic object'); + error($q,500,'Unable to create File::LibMagic object'); my $mime_string = $m->checktype_filename(abs_path($cache_location)) or - error($q,500,'Bad file; no mime known'); + error($q,500,'Bad file; no mime known'); print $q->header(-type => $mime_string, - -expires => '+1d', - ); + -expires => '+1d', + -status => 200, + -etag => $etag, + ); print <$fh>; close($fh); }