]> iEval git - gruntmaster-page.git/blobdiff - lib/Gruntmaster/Page/Pb/Entry.pm
Fix problem open
[gruntmaster-page.git] / lib / Gruntmaster / Page / Pb / Entry.pm
index dbfbe18ca42b86c6c2f0b7fd3a6b21de6518b503..8b770efe3a24bcc5f193675171a685e364480227 100644 (file)
@@ -3,58 +3,37 @@ package Gruntmaster::Page::Pb::Entry;
 use 5.014000;
 use strict;
 use warnings;
-use parent qw/Exporter/;
-our @EXPORT_OK = qw/generate/;
+use Gruntmaster::Page::Base pb_entry => '<tmpl_var name>';
+our @ISA = qw/Gruntmaster::Page::Base/;
 our $VERSION = '0.001';
 
-use HTML::Template::Compiled;
-use POSIX qw/strftime/;
-use Gruntmaster::Page::Common qw/cook_templates reload_templates/;
-use Gruntmaster::Data qw/contest_start contest_end problem_name problem_statement/;
+use constant FORMATS => [qw/C CPP JAVA PERL PYTHON/];
 
-use constant FORMATS => [qw/CPP/];
-
-my %orig_templates = (
-       en => <<'HTML',
-<tmpl_var statement>
-
-<tmpl_if cansubmit>
-<h1>Submit solution</h1>
-<form action="https://gm.ieval.ro/action/submit" method="POST" enctype="multipart/form-data">
-<input type="hidden" name="problem" value="<tmpl_var id>">
-<tmpl_if_defined contest><input type="hidden" name="contest" value="<tmpl_var contest>"></tmpl_if_defined>
-<label>File: <input name="prog" required type="file"></label>
-
-<label>File format: <select name="prog_format" required>
-<tmpl_loop formats><option value="<tmpl_var _>"><tmpl_var _></option>
-</tmpl_loop></select></label>
-
-<input type="submit" value="Submit job">
-</form>
-</tmpl_if>
-HTML
-);
-
-my %templates = cook_templates %orig_templates, pb_entry => '<tmpl_var name>';
-
-sub generate{
-       %templates = cook_templates %orig_templates, pb_entry => '<tmpl_var name>' if reload_templates;
-       $_[0] =~ m,(?:ct/([^/])+/)?pb/(\w+)\.html$,;
-
-       my ($contest, $id) = ($1, $2);
-       my $htc = HTML::Template::Compiled->new(scalarref => \$templates{$_[1]});
+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) {
+               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 (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 => FORMATS);
        $htc->param(id => $id);
        local $Gruntmaster::Data::contest = $contest if $contest;
        $htc->param(name => problem_name $id);
+       $htc->param(author => problem_author $id);
+       $htc->param(owner => problem_owner $id);
        $htc->param(statement => problem_statement $id);
-       $htc->output
 }
 
+sub vary { 'Authorization' }
+sub max_age { 600 }
+
 1
This page took 0.022031 seconds and 4 git commands to generate.