X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FPage%2FPb%2FEntry.pm;h=9fcefe5ac30e3d65b58e0121441bc5ad47c1892d;hb=c86e504ed5be25093c1579e736c05dce02901555;hp=0516053f7db69bcdeed547bd9e4c4f432a68f90e;hpb=2ee6edcf1262d2a3059dd0859d9b750c4a2ff02b;p=gruntmaster-page.git diff --git a/lib/Gruntmaster/Page/Pb/Entry.pm b/lib/Gruntmaster/Page/Pb/Entry.pm index 0516053..9fcefe5 100644 --- a/lib/Gruntmaster/Page/Pb/Entry.pm +++ b/lib/Gruntmaster/Page/Pb/Entry.pm @@ -7,40 +7,23 @@ use Gruntmaster::Page::Base pb_entry => ''; our @ISA = qw/Gruntmaster::Page::Base/; our $VERSION = '0.001'; -use constant TEMPLATES => { - en => <<'HTML', - - - -

Submit solution

-
- - - - - - - -
-
-HTML -}; +use constant FORMATS => [qw/C CPP JAVA PERL PYTHON/]; sub _generate{ - my ($self, $htc, $path, $lang) = @_; - - $path =~ m,(?:ct/([^/])+/)?pb/(\w+)\.html$,; - - my ($contest, $id) = ($1, $2); + 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) { + mark_open $id, $user; + debug $env => "Marking problem $id of contest $contest open by $user"; + } $htc->param(cansubmit => 1); - if (defined $contest) { - $htc->param(cansubmit => time >= contest_start $contest && time <= contest_end $contest); + if ($contest) { + $htc->param(cansubmit => time <= contest_end $contest); $htc->param(contest => $contest); } - $htc->param(formats => Gruntmaster::Page::Submit::FORMATS); + $htc->param(formats => FORMATS); $htc->param(id => $id); local $Gruntmaster::Data::contest = $contest if $contest; $htc->param(name => problem_name $id); @@ -49,4 +32,7 @@ sub _generate{ $htc->param(statement => problem_statement $id); } +sub vary { 'Authorization' } +sub max_age { 600 } + 1