package Gruntmaster::Page::Pb::Entry;
-use 5.014000;
-use strict;
-use warnings;
-use parent qw/Exporter/;
-our @EXPORT_OK = qw/generate/;
-our $VERSION = '0.001';
-
-use Fcntl qw/:flock/;
-use HTML::Template::Compiled;
-use IO::File;
-use POSIX qw/strftime/;
-use File::Basename qw/fileparse/;
-use Gruntmaster::Page::Common qw/header footer/;
-use Gruntmaster::Data qw/contest_start contest_end problem_name problem_statement/;
-
-use constant FORMATS => [qw/CPP/];
-use constant TITLE => '<tmpl_var name>';
-
-my %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
-);
-
-$templates{$_} = header($_, TITLE) . $templates{$_} for keys %templates;
-$templates{$_} .= footer $_ for keys %templates;
-
-sub generate{
- $_[0] =~ m,(?:ct/([^/])+/)?log/(\w+)\.html$,;
-
- my ($contest, $id) = ($1, $2);
- my $htc = HTML::Template::Compiled->new(scalarref => \$templates{$_[1]});
+use Gruntmaster::Page::Base pb_entry => '<tmpl_var name>';
+
+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 (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 = ($_[0] =~ m,(?:ct/([^/])+/)?,)[0];
+ local $Gruntmaster::Data::contest = $contest if $contest;
$htc->param(name => problem_name $id);
- $htc->param(statement => problem_statement $id, $_[2]);
- $htc->output
+ $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