X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FPage%2FPb%2FEntry.pm;h=8877ce54cd9774934e364dec26d5e41ba0e24a07;hb=137683e17847654370c1ecf716905222e8a36d1a;hp=771808b7b022a47d7a6a53af924294a20a191325;hpb=9e1979aeb2725b7548115832fa696393772340bd;p=plack-app-gruntmaster.git diff --git a/lib/Gruntmaster/Page/Pb/Entry.pm b/lib/Gruntmaster/Page/Pb/Entry.pm index 771808b..8877ce5 100644 --- a/lib/Gruntmaster/Page/Pb/Entry.pm +++ b/lib/Gruntmaster/Page/Pb/Entry.pm @@ -1,56 +1,22 @@ package Gruntmaster::Page::Pb::Entry; -use 5.014000; -use strict; -use warnings; use Gruntmaster::Page::Base pb_entry => ''; -our @ISA = qw/Gruntmaster::Page::Base/; -our $VERSION = '0.001'; -use constant TEMPLATES => { - en => <<'HTML', -
-
- -
- -
- - -

Problem information

-
-
Author
-
Owner
-
- - -

Submit solution

-
- - - -
-
-
- - -
-
-
-HTML -}; - -use constant FORMATS => [qw/C CPP MONO JAVA PASCAL PERL PYTHON/]; +use constant FORMATS => [qw/C CPP JAVA PASCAL PERL PYTHON/]; sub _generate{ my ($self, $htc, $lang, $env, $contest, $id) = @_; debug $env => "language is '$lang', contest is '$contest', id is '$id'"; + my $user = $env->{REMOTE_USER}; + if ($contest && $user && time >= contest_start $contest) { + local $Gruntmaster::Data::contest = $contest; + mark_open $id, $user; + debug $env => "Marking problem $id of contest $contest open by $user"; + } $htc->param(cansubmit => 1); if ($contest) { - $htc->param(cansubmit => time <= contest_end $contest); + $htc->param(cansubmit => (time <= contest_end $contest)); $htc->param(contest => $contest); } $htc->param(formats => FORMATS); @@ -59,7 +25,12 @@ sub _generate{ $htc->param(name => problem_name $id); $htc->param(author => problem_author $id); $htc->param(owner => problem_owner $id); + $htc->param(owner_name => do{ local $Gruntmaster::Data::contest; user_name $htc->param('owner')} ); $htc->param(statement => problem_statement $id); + $htc->param(timelimit => problem_timeout $id); } +sub vary { 'Authorization' } +sub max_age { 600 } + 1