-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.pl
executable file
·59 lines (47 loc) · 1.8 KB
/
server.pl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
#!/usr/bin/env perl
# start_server --port 127.0.0.1:5000 -- starman --workers 4 server.pl
# ./server.pl -E production -s Starman -o 0.0.0.0 -p 5000 --workers 4
# mkdir /tmp/static
# echo "Test (static) OK" > /tmp/static/test.txt
# curl -s localhost:5000/|python -mjson.tool
# curl -v localhost:5000/static/test.txt
use Plack::Middleware::AccessLog;
use Plack::Middleware::LogDispatch;
use Plack::Middleware::Static;
use JSON;
use Log::Dispatch;
use Scalar::Util qw(reftype);
my $logger = Log::Dispatch->new(
outputs => [
[
'Syslog',
min_level => 'info',
ident => 'server (starman)'
]
]
);
my $app = Plack::Middleware::AccessLog->wrap(sub {
my $env = shift;
my @filtered_keys = grep { reftype(\$env->{$_}) eq 'SCALAR' } keys %$env;
my %filtered_hash = map { $_ => $env->{$_} } grep { exists $env->{$_} } @filtered_keys;
my $json = JSON->new->allow_nonref();
my $body = $json->encode(\%filtered_hash) . "\n";
$env->{'psgix.logger'}->({ level => "info", message => "$env->{PATH_INFO} called" });
if ($env->{PATH_INFO} eq '/') {
return [ 200, [ 'Content-Type' => 'application/json' ], [ $body ] ];
} elsif ($env->{PATH_INFO} eq '/uol.jpg') {
open my $fh, "<:raw", "/home/irocha/perl/psgi/uol.jpg" or die $!;
return [ 200, ['Content-Type' => 'image/jpeg'], $fh ];
} else {
return [ 404, [ 'Content-Type' => 'application/json' ], [ $body ] ];
}
}, format => "combined");
$app = Plack::Middleware::LogDispatch->wrap($app, logger => $logger);
$app = Plack::Middleware::Static->wrap($app, path => qr{^/static/}, root => '/tmp/');
unless (caller) {
require Plack::Runner;
my $runner = Plack::Runner->new;
$runner->parse_options(@ARGV);
return $runner->run($app);
}
return $app;