my $log = undef;
sub run {
- my ($self, $urls) = @_;
+ my ($self, $urls, $synch_callback) = @_;
+ my $initialized = 0;
+
+ while (1) {
+ if (!$initialized) {
+ $synch_callback->();
+ $initialized = 1;
+ }
- while (my $con = $self->accept) {
+ my $con = $self->accept();
+ print STDERR "Accepted a new connection\n" if $log;
while (my $req = $con->get_request) {
my $url_path = $req->url->path;
- if ($url_path =~ m{/$}) {
+ if ($url_path =~ m{/$}) { # append 'index.html'
$url_path .= 'index.html';
}
+ #if ($url_path =~ m{^/}) { # remove trailing '/'
+ # $url_path = substr ($url_path, 1);
+ #}
if ($log) {
print STDERR "Method: ", $req->method, "\n";
print STDERR "Path: ", $url_path, "\n";
$con->send_basic_header($tmp->{code}, $resp->message, $resp->protocol);
print $con $resp->headers_as_string($CRLF);
print $con $CRLF;
- print $con $tmp->{content};
+ print $con $tmp->{content};
+ next;
+ }
+ if ($req->header("Range")) {
+ $req->header("Range") =~ m/bytes=(\d*)-(\d*)/;
+ my $content_len = length($tmp->{content});
+ my $start = $1 ? $1 : 0;
+ my $end = $2 ? $2 : ($content_len - 1);
+ my $len = $2 ? ($2 - $start) : ($content_len - $start);
+ $resp->header("Accept-Ranges" => "bytes");
+ $resp->header("Content-Length" => $len);
+ $resp->header("Content-Range" => "bytes $start-$end/$content_len");
+ $resp->header("Keep-Alive" => "timeout=15, max=100");
+ $resp->header("Connection" => "Keep-Alive");
+ $con->send_basic_header(206, "Partial Content", $resp->protocol);
+ print $con $resp->headers_as_string($CRLF);
+ print $con $CRLF;
+ print $con substr($tmp->{content}, $start, $len);
next;
}
# fill in content
} else {
print STDERR "Requested wrong URL: ", $url_path, "\n" if $log;
$con->send_error($HTTP::Status::RC_FORBIDDEN);
- }
+ last;
+ }
}
+ print STDERR "Closing connection\n" if $log;
$con->close;
- undef($con);
}
}