sub job { db->job ($_{job}) }
sub user { db->user ($_{user}) }
-sub redirect { [301, ['X-Forever' => 1, 'Location' => $_[0]], []] }
+sub redirect { [301, ['X-Forever' => 1, 'Cache-Control' => 'public, max-age=86400', 'Location' => $_[0]], []] }
sub reply { [200, ['Content-Type' => 'text/plain; charset=utf-8'], \@_] }
sub response {
my ($template, $title, $params, $maxage) = @_;
}
$params->{time} = time;
$params->{args} = {%_};
- bless {template => $template, title => $title, params => $params, maxage => ($maxage // 1)}, __PACKAGE__.'::Response'
+ bless {template => $template, title => $title, params => $params, maxage => ($maxage // 3600)}, __PACKAGE__.'::Response'
}
sub forbid {
sub (/ed/:contest) {
forbid !contest->is_finished;
my $pblist = db->problem_list(contest => $_{contest}, solution => 1);
- response ed => 'Editorial of ' . contest->name, {%$pblist, editorial => contest->editorial};
+ response ed => 'Editorial of ' . contest->name, {%$pblist, editorial => contest->editorial}, contest->is_finished(time - 86400) ? 60 : ();
},
sub (/login) {
sub (/ct/:contest/log/st) { redirect "/st/$_{contest}" },
sub (/us/) { response us => 'Users', {us => db->user_list} },
- sub (/ct/ + ?:owner~) { response ct => 'Contests', db->contest_list(%_) },
+ sub (/ct/ + ?:owner~) { response ct => 'Contests', db->contest_list(%_), 300 },
sub (/log/ + ?:contest~&:owner~&:page~&:problem~&:private~&:result~) {
forbid $_{private};
- response log => 'Job list', {%{db->job_list(%_)}, maybe contest => $_{contest},}
+ response log => 'Job list', {%{db->job_list(%_)}, maybe contest => $_{contest},}, 5
},
sub (/pb/ + ?:owner~&:contest~&:private~) {
forbid $_{private};
},
sub (/us/:user) { response us_entry => user->name, db->user_entry($_{user}) },
- sub (/ct/:contest) { response ct_entry => contest->name, db->contest_entry($_{contest}) },
+ sub (/ct/:contest) { response ct_entry => contest->name, db->contest_entry($_{contest}), 60 },
sub (/log/:job) {
forbid job->private;
- response log_entry => "Job $_{job}", db->job_entry($_{job})
+ response log_entry => "Job $_{job}", db->job_entry($_{job}), 10
},
sub (/pb/:problem + ?contest~) {
my (undef, undef, $contest) = @_;
forbid !remote_user;
$privacy = 'private';
}
- response pb_entry => problem->name, {%{db->problem_entry($_{problem}, $_{contest}, remote_user && remote_user->id)}, maybe contest => $_{contest}};
+ response pb_entry => problem->name, {%{db->problem_entry($_{problem}, $_{contest}, remote_user && remote_user->id)}, maybe contest => $_{contest}}, $_{contest} ? 10 : ();
},
sub (/sol/:problem) {
forbid problem->private;
sub (/) { redispatch_to '/index' },
sub (/favicon.ico) { redirect '/static/favicon.ico' },
- sub (/:article) { [200, ['Content-Type' => 'text/html; charset=utf-8', 'Cache-Control' => 'public, max-age=60', 'X-Forever' => 1], [render_article $_{article}, 'en']] }
+ sub (/:article) { [200, ['Content-Type' => 'text/html; charset=utf-8', 'Cache-Control' => 'public, max-age=3600', 'X-Forever' => 1], [render_article $_{article}, 'en']] }
},
sub (POST) {