X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FHandlers.pm;fp=lib%2FGruntmaster%2FHandlers.pm;h=41ccfb45ef5d249539bcda8647ef2f5b21e8f844;hb=69ae93bf8c2c07eefbd4692d7b7b420e49eb7b12;hp=f0281f2826f939da53e258a279818821d7e934b0;hpb=f0ae016ea9a4816b5fb37095f079e2e9ac46ac97;p=gruntmaster-handlers.git diff --git a/lib/Gruntmaster/Handlers.pm b/lib/Gruntmaster/Handlers.pm index f0281f2..41ccfb4 100644 --- a/lib/Gruntmaster/Handlers.pm +++ b/lib/Gruntmaster/Handlers.pm @@ -43,9 +43,13 @@ sub aputs{ sub submit{ my $r = shift; my $req = Apache2::Request->new($r); - my ($problem, $format, $contest, $private) = map {scalar $req->param($_)} 'problem', 'prog_format', 'contest', 'private'; - my $prog; - $req->upload('prog')->slurp($prog); + my ($problem, $format, $contest, $private, $prog) = map {scalar $req->param($_)} 'problem', 'prog_format', 'contest', 'private', 'source_code'; + my $upload = $req->upload('prog'); + if (defined $upload) { + my $temp; + $upload->slurp($temp); + $prog = $temp if $temp + } die if defined $contest && $contest !~ /^\w+$/ ; die if defined $contest && (time < contest_start $contest || time > contest_end $contest);