use HTTP::Response;
our @ISA=qw(HTTP::Daemon);
+my $VERSION = 0.01;
my $CRLF = "\015\012"; # "\r\n" is not portable
+my $log = undef;
sub run {
my ($self, $urls) = @_;
while (my $con = $self->accept) {
while (my $req = $con->get_request) {
- # print STDERR "method: ", $req->method, "\n";
+ print STDERR "Method: ", $req->method, "\n" if $log;
+ print STDERR "Path: ", $req->url->path, "\n" if $log;
+ foreach my $key (keys %{HTTPServer::urls}) {
+ print STDERR $key, '\n';
+ }
if (exists($urls->{$req->url->path})) {
+ print STDERR "Serving requested URL: ", $req->url->path, "\n" if $log;
next unless ($req->method eq "HEAD" || $req->method eq "GET");
- # print STDERR "requested URL: ", $req->url->path, "\n";
-
+
# create response
my $tmp = $urls->{$req->url->path};
my $resp = HTTP::Response->new ($tmp->{code},
$tmp->{msg});
- # print STDERR "HTTP::Response: \n", $resp->as_string;
+ print STDERR "HTTP::Response: \n", $resp->as_string if $log;
- # fill in headers
- while (my ($name, $value) = each %{$tmp->{headers}}) {
- # print STDERR "setting header: $name = $value\n";
- $resp->header($name => $value);
- }
- # print STDERR "HTTP::Response with headers: \n", $resp->as_string;
-
- if ($req->method eq "GET") {
- if (exists($tmp->{headers}{"Content-Length"})) {
- # Content-Length and length($tmp->{content}) don't match
- # manually prepare the HTTP response
- $con->send_basic_header($tmp->{code}, $resp->message, $resp->protocol);
- print $con $resp->headers_as_string($CRLF);
- print $con $CRLF;
- print $con $tmp->{content};
- next;
+ #if (is_dynamic_url) { # dynamic resource
+ #} else { # static resource
+ # fill in headers
+ while (my ($name, $value) = each %{$tmp->{headers}}) {
+ # print STDERR "setting header: $name = $value\n";
+ $resp->header($name => $value);
+ }
+ print STDERR "HTTP::Response with headers: \n", $resp->as_string if $log;
+
+ if ($req->method eq "GET") {
+ if (exists($tmp->{headers}{"Content-Length"})) {
+ # Content-Length and length($tmp->{content}) don't match
+ # manually prepare the HTTP response
+ $con->send_basic_header($tmp->{code}, $resp->message, $resp->protocol);
+ print $con $resp->headers_as_string($CRLF);
+ print $con $CRLF;
+ print $con $tmp->{content};
+ next;
+ }
+ # fill in content
+ $resp->content($tmp->{content});
+ print STDERR "HTTP::Response with content: \n", $resp->as_string if $log;
}
- # fill in content
- $resp->content($tmp->{content});
- # print STDERR "HTTP::Response with content: \n", $resp->as_string;
- }
+ #}
$con->send_response($resp);
- # print STDERR "HTTP::Response sent: \n", $resp->as_string;
+ print STDERR "HTTP::Response sent: \n", $resp->as_string if $log;
} else {
- # print STDERR "requested wrong URL: ", $req->url->path, "\n";
+ print STDERR "Requested wrong URL: ", $req->url->path, "\n" if $log;
$con->send_error($HTTP::Status::RC_FORBIDDEN);
}
}