X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FHandlers.pm;h=41ccfb45ef5d249539bcda8647ef2f5b21e8f844;hb=69ae93bf8c2c07eefbd4692d7b7b420e49eb7b12;hp=dec98dcc23c9113e357ee389cede24a47fc98ce4;hpb=f1df5335758abc1b815002b3ff415f349761256d;p=gruntmaster-handlers.git diff --git a/lib/Gruntmaster/Handlers.pm b/lib/Gruntmaster/Handlers.pm index dec98dc..41ccfb4 100644 --- a/lib/Gruntmaster/Handlers.pm +++ b/lib/Gruntmaster/Handlers.pm @@ -20,7 +20,17 @@ use File::Basename qw/fileparse/; use File::Temp qw/tempdir/; use File::Copy qw/move/; use Gruntmaster::Data qw/contest_start contest_end push_job set_job_inmeta insert_user PUBLISH/; -use Gruntmaster::Page::Log; + +use constant FORMAT_EXTENSION => { + C => 'c', + CPP => 'cpp', + MONO => 'cs', + JAVA => 'java', + PASCAL => 'pas', + PERL => 'pl', + PYTHON => 'py', + RUBY => 'rb', +}; sub aputs{ my ($r, $str) = @_; @@ -33,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); @@ -46,14 +60,14 @@ sub submit{ defined $private ? (private => $private) : (), defined $contest ? (contest => $contest, private => 1) : (), filesize => length $prog, - extension => Gruntmaster::Page::Log::FORMAT_EXTENSION->{$format}, + extension => FORMAT_EXTENSION->{$format}, ); set_job_inmeta $job, { files => { prog => { format => $format, - name => 'prog.' . Gruntmaster::Page::Log::FORMAT_EXTENSION->{$format}, + name => 'prog.' . FORMAT_EXTENSION->{$format}, content => $prog, } } @@ -78,6 +92,8 @@ sub register{ insert_user $username, name => $name, email => $email, phone => $phone, town => $town, university => $university, level => $level; + PUBLISH genpage => "us/index.html"; + PUBLISH genpage => "us/$username.html"; aputs $r, 'Registered successfully'; }