lighttpd 1.4.x
https://www.lighttpd.net/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
115 lines
2.9 KiB
115 lines
2.9 KiB
#!/usr/bin/env perl |
|
BEGIN { |
|
# add current source dir to the include-path |
|
# we need this for make distcheck |
|
(my $srcdir = $0) =~ s,/[^/]+$,/,; |
|
unshift @INC, $srcdir; |
|
} |
|
|
|
use strict; |
|
use IO::Socket; |
|
use Test::More tests => 10; |
|
use LightyTest; |
|
|
|
my $tf = LightyTest->new(); |
|
my $t; |
|
my $docroot = "$tf->{'SRCDIR'}/tmp/lighttpd/servers/www.example.org/pages/"; |
|
|
|
sub init_testbed { |
|
return 0 unless eval { symlink("",""); 1 }; |
|
my $f = "$docroot/index.html"; |
|
my $l = "$docroot/index.xhtml"; |
|
my $rc = undef; |
|
unless (-l $l) { |
|
return 0 unless symlink($f,$l); |
|
}; |
|
$f = "$docroot/expire"; |
|
$l = "$docroot/symlinked"; |
|
$rc = undef; |
|
unless (-l $l) { |
|
return 0 unless symlink($f,$l); |
|
}; |
|
return 1; |
|
}; |
|
|
|
SKIP: { |
|
skip "perl does not support symlinking or setting up the symlinks failed.", 10 unless init_testbed; |
|
ok($tf->start_proc == 0, "Starting lighttpd") or die(); |
|
|
|
# allow case |
|
# simple file |
|
$t->{REQUEST} = ( <<EOF |
|
GET /index.html HTTP/1.0 |
|
Host: symlink.example.org |
|
EOF |
|
); |
|
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200 } ]; |
|
ok($tf->handle_http($t) == 0, 'allow: simple file'); |
|
|
|
# symlinked file |
|
$t->{REQUEST} = ( <<EOF |
|
GET /index.xhtml HTTP/1.0 |
|
Host: symlink.example.org |
|
EOF |
|
); |
|
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200 } ]; |
|
ok($tf->handle_http($t) == 0, 'allow: symlinked file'); |
|
|
|
# directly symlinked dir |
|
$t->{REQUEST} = ( <<EOF |
|
GET /symlinked/ HTTP/1.0 |
|
Host: symlink.example.org |
|
EOF |
|
); |
|
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200 } ]; |
|
ok($tf->handle_http($t) == 0, 'allow: directly symlinked dir'); |
|
|
|
# symlinked dir in path |
|
$t->{REQUEST} = ( <<EOF |
|
GET /symlinked/access.txt HTTP/1.0 |
|
Host: symlink.example.org |
|
EOF |
|
); |
|
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200 } ]; |
|
ok($tf->handle_http($t) == 0, 'allow: symlinked dir in path'); |
|
|
|
# deny case |
|
# simple file |
|
$t->{REQUEST} = ( <<EOF |
|
GET /index.html HTTP/1.0 |
|
Host: nosymlink.example.org |
|
EOF |
|
); |
|
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200 } ]; |
|
ok($tf->handle_http($t) == 0, 'deny: simple file'); |
|
|
|
# symlinked file |
|
$t->{REQUEST} = ( <<EOF |
|
GET /index.xhtml HTTP/1.0 |
|
Host: nosymlink.example.org |
|
EOF |
|
); |
|
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 403 } ]; |
|
ok($tf->handle_http($t) == 0, 'deny: symlinked file'); |
|
|
|
# directly symlinked dir |
|
$t->{REQUEST} = ( <<EOF |
|
GET /symlinked/ HTTP/1.0 |
|
Host: nosymlink.example.org |
|
EOF |
|
); |
|
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 403 } ]; |
|
ok($tf->handle_http($t) == 0, 'deny: directly symlinked dir'); |
|
|
|
# symlinked dir in path |
|
$t->{REQUEST} = ( <<EOF |
|
GET /symlinked/access.txt HTTP/1.0 |
|
Host: nosymlink.example.org |
|
EOF |
|
); |
|
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 403 } ]; |
|
ok($tf->handle_http($t) == 0, 'deny: symlinked dir in path'); |
|
|
|
# cleanup |
|
ok($tf->stop_proc == 0, "Stopping lighttpd"); |
|
};
|
|
|