X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FPage%2FPb%2FEntry.pm;h=12f5e747bebc7452d25060b7a84c739204120b8b;hb=1ad43ccc6aec756b3f2cc47b9da57ba67de29165;hp=ebcf56eca506752b8cee8631a0c615d9defdc196;hpb=cd9af27e94244e6454c3db787a8ca6811f44fc16;p=gruntmaster-page.git diff --git a/lib/Gruntmaster/Page/Pb/Entry.pm b/lib/Gruntmaster/Page/Pb/Entry.pm index ebcf56e..12f5e74 100644 --- a/lib/Gruntmaster/Page/Pb/Entry.pm +++ b/lib/Gruntmaster/Page/Pb/Entry.pm @@ -1,64 +1,35 @@ 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 => ''; - -my %templates = ( - en => <<'HTML', - - - -

Submit solution

-
- - - - - - - -
-
-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 => ''; + +use constant FORMATS => [qw/C CPP JAVA 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); } +sub vary { 'Authorization' } +sub max_age { 600 } + 1