X-Git-Url: https://git.sesse.net/?p=pr0n;a=blobdiff_plain;f=perl%2FSesse%2Fpr0n%2Fpr0n.pm;h=eeb93b0a7aa544df4b88db2e350a6d24e9ec4e04;hp=487a01a1398827cfb86e1e49ecf567c962ff00df;hb=290a2bdcb92997fd2537603dee5c67350b2bb7b1;hpb=84b16cfb3e4428c4b07dddd8e4c5aa1f2aa1b6d7 diff --git a/perl/Sesse/pr0n/pr0n.pm b/perl/Sesse/pr0n/pr0n.pm index 487a01a..eeb93b0 100644 --- a/perl/Sesse/pr0n/pr0n.pm +++ b/perl/Sesse/pr0n/pr0n.pm @@ -6,6 +6,8 @@ use Sesse::pr0n::Rotate; use Sesse::pr0n::Select; use Sesse::pr0n::WebDAV; use Sesse::pr0n::NewEvent; +use Sesse::pr0n::Registry; +use Sesse::pr0n::Wizard; package Sesse::pr0n::pr0n; use strict; @@ -15,7 +17,7 @@ sub handler { my $r = shift; my $uri = $r->uri; - if ($uri eq '/') { + if ($uri eq '/' || $uri =~ /^\/\+tags\/?$/) { return Sesse::pr0n::Listing::handler($r); } elsif ($uri eq '/robots.txt' || $uri eq '/pr0n.css' || @@ -23,17 +25,33 @@ sub handler { $uri eq '/blah.png' || $uri eq '/faq.html' || $uri eq '/pr0n-fullscreen.css' || + $uri eq '/pr0n-fullscreen-ie.css' || $uri eq '/pr0n-fullscreen.js' || $uri eq '/previous.png' || $uri eq '/next.png' || + $uri eq '/close.png' || + $uri eq '/wizard.js' || + $uri eq '/wizard.css' || + $uri eq '/pr0n.ico' || $uri =~ m#^/usage/([a-zA-Z0-9_.]+)$#) { $uri =~ s#^/##; + my $fname = Sesse::pr0n::Common::get_base($r) . 'files/' . $uri; + my (undef, undef, undef, undef, undef, undef, undef, $size, undef, $mtime) = stat($fname) + or error($r, "stat of $fname: $!"); + $r->content_type(Sesse::pr0n::Common::get_mimetype_from_filename($uri)); - $r->sendfile(Sesse::pr0n::Common::get_base($r) . $uri); + $r->set_content_length($size); + $r->set_last_modified($mtime); + + if((my $rc = $r->meets_conditions) != Apache2::Const::OK) { + return $rc; + } + + $r->sendfile(Sesse::pr0n::Common::get_base($r) . 'files/' . $uri); return Apache2::Const::OK; } elsif ($uri eq '/newevent.html') { $r->content_type('text/html; charset=utf-8'); - $r->sendfile(Sesse::pr0n::Common::get_base($r) . "newevent.html"); + $r->sendfile(Sesse::pr0n::Common::get_base($r) . "files/newevent.html"); return Apache2::Const::OK; } elsif ($uri =~ m#^/webdav#) { return Sesse::pr0n::WebDAV::handler($r); @@ -46,9 +64,15 @@ sub handler { return Sesse::pr0n::Select::handler($r); } elsif ($uri =~ m#^/newevent$#) { return Sesse::pr0n::NewEvent::handler($r); - } elsif ($uri =~ m#^/[a-zA-Z0-9-]+/?$#) { + } elsif ($uri =~ m#^/registry$#) { + return Sesse::pr0n::Registry::handler($r); + } elsif ($uri =~ m#^/wizard$#) { + return Sesse::pr0n::Wizard::handler($r); + } elsif ($uri =~ /^\/[a-zA-Z0-9-]+\/?$/ || + $uri =~ /^\/\+all\/?$/ || + $uri =~ /^\/\+tags\/[a-zA-Z0-9-]+\/?$/) { return Sesse::pr0n::Index::handler($r); - } elsif ($uri =~ m#^/[a-zA-Z0-9-]+/(\d+x\d+/|original)?(nobox/)?[a-zA-Z0-9._-]+$#) { + } elsif ($uri =~ m#^/[a-zA-Z0-9-]+/(\d+x\d+/|original/)?((?:no)?box/)?[a-zA-Z0-9._()-]+$#) { return Sesse::pr0n::Image::handler($r); }