X-Git-Url: https://git.sesse.net/?p=pr0n;a=blobdiff_plain;f=perl%2FSesse%2Fpr0n%2Fpr0n.pm;h=54e55be8270f43ca12c42f89b262e3d59b91c053;hp=c2d9dbc93ddefb1dc155b9f2ad76bd023c39cd57;hb=d5489e1aa91408c7b89766adfe269849d587cf9a;hpb=f9ff3e7edda055056a4de903d4b959f8fa1c2542 diff --git a/perl/Sesse/pr0n/pr0n.pm b/perl/Sesse/pr0n/pr0n.pm index c2d9dbc..54e55be 100644 --- a/perl/Sesse/pr0n/pr0n.pm +++ b/perl/Sesse/pr0n/pr0n.pm @@ -6,8 +6,7 @@ use Sesse::pr0n::Rotate; use Sesse::pr0n::Select; use Sesse::pr0n::WebDAV; use Sesse::pr0n::NewEvent; -use Sesse::pr0n::Registry; -use Sesse::pr0n::Wizard; +use IO::File::WithPath; package Sesse::pr0n::pr0n; use strict; @@ -16,8 +15,8 @@ use warnings; sub handler { my $r = shift; - my $uri = $r->uri; - if ($uri eq '/' || $uri eq '/+tags' || $uri eq '/+tags/') { + my $uri = $r->path_info; + if ($uri eq '/') { return Sesse::pr0n::Listing::handler($r); } elsif ($uri eq '/robots.txt' || $uri eq '/pr0n.css' || @@ -25,6 +24,7 @@ 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' || @@ -34,51 +34,56 @@ sub handler { $uri eq '/pr0n.ico' || $uri =~ m#^/usage/([a-zA-Z0-9_.]+)$#) { $uri =~ s#^/##; - my $fname = Sesse::pr0n::Common::get_base($r) . 'files/' . $uri; + my $fname = $Sesse::pr0n::Config::image_base . '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->set_content_length($size); - $r->set_last_modified($mtime); + my $res = Plack::Response->new(200); + $res->content_type(Sesse::pr0n::Common::get_mimetype_from_filename($uri)); + $res->content_length($size); + Sesse::pr0n::Common::set_last_modified($res, $mtime); - if((my $rc = $r->meets_conditions) != Apache2::Const::OK) { - return $rc; - } + #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; + $res->content(IO::File::WithPath->new($Sesse::pr0n::Config::image_base . 'files/' . $uri)); + return $res; } elsif ($uri eq '/newevent.html') { - $r->content_type('text/html; charset=utf-8'); - $r->sendfile(Sesse::pr0n::Common::get_base($r) . "files/newevent.html"); - return Apache2::Const::OK; + my $res = Plack::Response->new(200); + $res->content_type('text/html; charset=utf-8'); + $res->content(IO::File::WithPath->new($Sesse::pr0n::Config::image_base . 'files/newevent.html')); + return $res; } elsif ($uri =~ m#^/webdav#) { return Sesse::pr0n::WebDAV::handler($r); } elsif ($uri =~ m#^/usage/([a-zA-Z0-9.-]+)$#) { - $r->sendfile(Sesse::pr0n::Common::get_base($r) . "usage/$1"); - return Apache2::Const::OK; + my $res = Plack::Response->new(200); + $res->content(IO::File::WithPath->new($Sesse::pr0n::Config::image_base . "usage/$1")); + return $res; } elsif ($uri =~ m#^/rotate$#) { return Sesse::pr0n::Rotate::handler($r); } elsif ($uri =~ m#^/select$#) { return Sesse::pr0n::Select::handler($r); } elsif ($uri =~ m#^/newevent$#) { return Sesse::pr0n::NewEvent::handler($r); - } elsif ($uri =~ m#^/registry$#) { - return Sesse::pr0n::Registry::handler($r); - } elsif ($uri =~ m#^/wizard$#) { - return Sesse::pr0n::Wizard::handler($r); - } elsif ($uri =~ m#^/[a-zA-Z0-9-]+/?$# || - $uri =~ m#^/\+all/?$#) { + } elsif ($uri =~ /^\/[a-zA-Z0-9-]+\/?$/ || + $uri =~ /^\/\+all\/?$/) { 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+ ( \@\d+(\.\d+)? )? / | original/ )? + ((?:no)?box/)? + [a-zA-Z0-9._()-]+$#x) { return Sesse::pr0n::Image::handler($r); } - $r->status(404); - Sesse::pr0n::Common::header($r, "404 File Not Found"); - $r->print("

The file you requested was not found.

"); - Sesse::pr0n::Common::footer($r); - return Apache2::Const::OK; + my $res = Plack::Response->new(404); + my $io = IO::String->new; + Sesse::pr0n::Common::header($r, $io, "404 File Not Found"); + $io->print("

The file you requested was not found.

"); + Sesse::pr0n::Common::footer($r, $io); + $io->setpos(0); + $res->body($io); + return $res; } 1;