|
version 1.1.1.1, 2013/10/14 10:32:47
|
version 1.1.1.2, 2016/11/02 10:35:00
|
|
Line 8 BEGIN {
|
Line 8 BEGIN {
|
| |
|
| use strict; |
use strict; |
| use IO::Socket; |
use IO::Socket; |
| use Test::More tests => 7; | use Test::More tests => 15; |
| use LightyTest; |
use LightyTest; |
| use Digest::MD5 qw(md5_hex); |
use Digest::MD5 qw(md5_hex); |
| |
use Digest::SHA qw(hmac_sha1 hmac_sha256); |
| |
use MIME::Base64 qw(encode_base64url); |
| |
|
| my $tf = LightyTest->new(); |
my $tf = LightyTest->new(); |
| my $t; |
my $t; |
|
Line 18 my $t;
|
Line 20 my $t;
|
| ok($tf->start_proc == 0, "Starting lighttpd") or die(); |
ok($tf->start_proc == 0, "Starting lighttpd") or die(); |
| |
|
| my $secret = "verysecret"; |
my $secret = "verysecret"; |
| my $f = "/index.html"; | my ($f, $thex, $m); |
| my $thex = sprintf("%08x", time); | |
| my $m = md5_hex($secret.$f.$thex); | |
| |
|
| $t->{REQUEST} = ( <<EOF |
$t->{REQUEST} = ( <<EOF |
| |
GET /index.html HTTP/1.0 |
| |
Host: www.example.org |
| |
EOF |
| |
); |
| |
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200 } ]; |
| |
|
| |
ok($tf->handle_http($t) == 0, 'skipping secdownload - direct access'); |
| |
|
| |
## MD5 |
| |
$f = "/index.html"; |
| |
$thex = sprintf("%08x", time); |
| |
$m = md5_hex($secret.$f.$thex); |
| |
|
| |
$t->{REQUEST} = ( <<EOF |
| GET /sec/$m/$thex$f HTTP/1.0 |
GET /sec/$m/$thex$f HTTP/1.0 |
| Host: vvv.example.org |
Host: vvv.example.org |
| EOF |
EOF |
| ); |
); |
| $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200 } ]; |
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200 } ]; |
| |
|
| ok($tf->handle_http($t) == 0, 'secdownload'); | ok($tf->handle_http($t) == 0, 'secdownload (md5)'); |
| |
|
| $thex = sprintf("%08x", time - 1800); |
$thex = sprintf("%08x", time - 1800); |
| $m = md5_hex($secret.$f.$thex); |
$m = md5_hex($secret.$f.$thex); |
|
Line 41 EOF
|
Line 55 EOF
|
| ); |
); |
| $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 410 } ]; |
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 410 } ]; |
| |
|
| ok($tf->handle_http($t) == 0, 'secdownload - gone (timeout)'); | ok($tf->handle_http($t) == 0, 'secdownload - gone (timeout) (md5)'); |
| |
|
| $t->{REQUEST} = ( <<EOF |
$t->{REQUEST} = ( <<EOF |
| GET /sec$f HTTP/1.0 |
GET /sec$f HTTP/1.0 |
|
Line 50 EOF
|
Line 64 EOF
|
| ); |
); |
| $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 404 } ]; |
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 404 } ]; |
| |
|
| ok($tf->handle_http($t) == 0, 'secdownload - direct access'); | ok($tf->handle_http($t) == 0, 'secdownload - direct access (md5)'); |
| |
|
| |
$f = "/noexists"; |
| |
$thex = sprintf("%08x", time); |
| |
$m = md5_hex($secret.$f.$thex); |
| |
|
| $t->{REQUEST} = ( <<EOF |
$t->{REQUEST} = ( <<EOF |
| GET $f HTTP/1.0 | GET /sec/$m/$thex$f HTTP/1.0 |
| Host: www.example.org | Host: vvv.example.org |
| EOF |
EOF |
| ); |
); |
| |
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 404 } ]; |
| |
|
| |
ok($tf->handle_http($t) == 0, 'secdownload - timeout (md5)'); |
| |
|
| |
## HMAC-SHA1 |
| |
$f = "/index.html"; |
| |
$thex = sprintf("%08x", time); |
| |
$m = encode_base64url(hmac_sha1("/$thex$f", $secret)); |
| |
|
| |
$t->{REQUEST} = ( <<EOF |
| |
GET /sec/$m/$thex$f HTTP/1.0 |
| |
Host: vvv-sha1.example.org |
| |
EOF |
| |
); |
| $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200 } ]; |
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200 } ]; |
| |
|
| ok($tf->handle_http($t) == 0, 'secdownload - conditional access'); | ok($tf->handle_http($t) == 0, 'secdownload (hmac-sha1)'); |
| |
|
| |
$thex = sprintf("%08x", time - 1800); |
| |
$m = encode_base64url(hmac_sha1("/$thex$f", $secret)); |
| |
|
| |
$t->{REQUEST} = ( <<EOF |
| |
GET /sec/$m/$thex$f HTTP/1.0 |
| |
Host: vvv-sha1.example.org |
| |
EOF |
| |
); |
| |
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 410 } ]; |
| |
|
| |
ok($tf->handle_http($t) == 0, 'secdownload - gone (timeout) (hmac-sha1)'); |
| |
|
| |
$t->{REQUEST} = ( <<EOF |
| |
GET /sec$f HTTP/1.0 |
| |
Host: vvv-sha1.example.org |
| |
EOF |
| |
); |
| |
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 404 } ]; |
| |
|
| |
ok($tf->handle_http($t) == 0, 'secdownload - direct access (hmac-sha1)'); |
| |
|
| |
|
| $f = "/noexists"; |
$f = "/noexists"; |
| $thex = sprintf("%08x", time); |
$thex = sprintf("%08x", time); |
| $m = md5_hex($secret.$f.$thex); | $m = encode_base64url(hmac_sha1("/$thex$f", $secret)); |
| |
|
| $t->{REQUEST} = ( <<EOF |
$t->{REQUEST} = ( <<EOF |
| GET /sec/$m/$thex$f HTTP/1.0 |
GET /sec/$m/$thex$f HTTP/1.0 |
| Host: vvv.example.org | Host: vvv-sha1.example.org |
| EOF |
EOF |
| ); |
); |
| $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 404 } ]; |
$t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 404 } ]; |
| |
|
| ok($tf->handle_http($t) == 0, 'secdownload - timeout'); | ok($tf->handle_http($t) == 0, 'secdownload - timeout (hmac-sha1)'); |
| | |
| | ## HMAC-SHA256 |
| | $f = "/index.html"; |
| | $thex = sprintf("%08x", time); |
| | $m = encode_base64url(hmac_sha256("/$thex$f", $secret)); |
| | |
| | $t->{REQUEST} = ( <<EOF |
| | GET /sec/$m/$thex$f HTTP/1.0 |
| | Host: vvv-sha256.example.org |
| | EOF |
| | ); |
| | $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200 } ]; |
| | |
| | ok($tf->handle_http($t) == 0, 'secdownload (hmac-sha256)'); |
| | |
| | $thex = sprintf("%08x", time - 1800); |
| | $m = encode_base64url(hmac_sha256("/$thex$f", $secret)); |
| | |
| | $t->{REQUEST} = ( <<EOF |
| | GET /sec/$m/$thex$f HTTP/1.0 |
| | Host: vvv-sha256.example.org |
| | EOF |
| | ); |
| | $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 410 } ]; |
| | |
| | ok($tf->handle_http($t) == 0, 'secdownload - gone (timeout) (hmac-sha256)'); |
| | |
| | $t->{REQUEST} = ( <<EOF |
| | GET /sec$f HTTP/1.0 |
| | Host: vvv-sha256.example.org |
| | EOF |
| | ); |
| | $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 404 } ]; |
| | |
| | ok($tf->handle_http($t) == 0, 'secdownload - direct access (hmac-sha256)'); |
| | |
| | |
| | $f = "/noexists"; |
| | $thex = sprintf("%08x", time); |
| | $m = encode_base64url(hmac_sha256("/$thex$f", $secret)); |
| | |
| | $t->{REQUEST} = ( <<EOF |
| | GET /sec/$m/$thex$f HTTP/1.0 |
| | Host: vvv-sha256.example.org |
| | EOF |
| | ); |
| | $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 404 } ]; |
| | |
| | ok($tf->handle_http($t) == 0, 'secdownload - timeout (hmac-sha256)'); |
| | |
| | ## THE END |
| |
|
| ok($tf->stop_proc == 0, "Stopping lighttpd"); |
ok($tf->stop_proc == 0, "Stopping lighttpd"); |
| |
|