X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=app.psgi;h=20c8cb56f57a73f3c17f44ce03535e6aff9267bb;hb=refs%2Fheads%2Fnewmc;hp=6a1125a4f283b3d7d976f561c11a0707c12dc295;hpb=b0201bcc83ed8e81b0842e06c282386fd0d0ed85;p=gruntmaster-page.git diff --git a/app.psgi b/app.psgi index 6a1125a..20c8cb5 100644 --- a/app.psgi +++ b/app.psgi @@ -23,15 +23,11 @@ CSP $csp =~ s/\n/; /gr; } -my $db; - sub add_database { my $app = $_[0]; sub { - my ($env) = @_; - $db //= Gruntmaster::Data->connect($ENV{GRUNTMASTER_DSN} // 'dbi:Pg:'); - $env->{'gruntmaster.dbic'} = $db; - $app->($env) + dbinit $ENV{GRUNTMASTER_DSN} // 'dbi:Pg:' unless db; + $app->(@_) } } @@ -41,7 +37,7 @@ sub add_headers { my $resp = $app->($_[0]); my $hdrs = Plack::Util::headers($resp->[1]); $hdrs->set('Content-Security-Policy', CONTENT_SECURITY_POLICY); - $hdrs->set('Link', '; rel=stylesheet') if $hdrs->get('Content-Type') =~ m,^text/html,; + $hdrs->set('Cache-Control', 'public, max-age=604800') if $_[0]->{PATH_INFO} =~ qr,^/static/,; $resp->[1] = $hdrs->headers; $resp; } @@ -54,6 +50,7 @@ builder { enable_if { $_[0]->{PATH_INFO} eq '/ok' } sub { sub{ [200, [], []] }}; enable 'ContentLength'; enable \&add_headers; + enable 'Static', path => qr,^/static/,; enable 'Log4perl', category => 'plack'; enable \&add_database; enable '+Plack::App::Gruntmaster::Auth',