dec98dcc23c9113e357ee389cede24a47fc98ce4
1 package Gruntmaster
::Handlers
;
6 our $VERSION = '0.001';
9 use Apache2
::Authen
::Passphrase qw
/pwcheck pwset USER_REGEX/;
10 use Apache2
::AuthzCaps qw
/hascaps/;
11 use Apache2
::RequestRec
;
12 use Apache2
::RequestIO
;
14 use Apache2
::Const qw
/OK DECLINED/;
19 use File
::Basename qw
/fileparse/;
20 use File
::Temp qw
/tempdir/;
21 use File
::Copy qw
/move/;
22 use Gruntmaster
::Data qw
/contest_start contest_end push_job set_job_inmeta insert_user PUBLISH/;
23 use Gruntmaster
::Page
::Log
;
27 $r->set_content_length(length $str);
29 $r->content_type('text/plain');
35 my $req = Apache2
::Request
->new($r);
36 my ($problem, $format, $contest, $private) = map {scalar $req->param($_)} 'problem', 'prog_format', 'contest', 'private';
38 $req->upload('prog')->slurp($prog);
39 die if defined $contest && $contest !~ /^\w+$/ ;
40 die if defined $contest && (time < contest_start
$contest || time > contest_end
$contest);
46 defined $private ?
(private
=> $private) : (),
47 defined $contest ?
(contest
=> $contest, private
=> 1) : (),
48 filesize
=> length $prog,
49 extension
=> Gruntmaster
::Page
::Log
::FORMAT_EXTENSION
->{$format},
52 set_job_inmeta
$job, {
56 name
=> 'prog.' . Gruntmaster
::Page
::Log
::FORMAT_EXTENSION
->{$format},
63 $r->print("Job submitted");
69 my $req = Apache2
::Request
->new($r);
70 my ($username, $password, $confirm_password, $name, $email, $phone, $town, $university, $level) = map { die if length > 200; $_ } map {scalar $req->param($_)} qw
/username password confirm_password name email phone town university level/;
72 local $Apache2::Authen
::Passphrase
::rootdir
= $r->dir_config('AuthenPassphraseRootdir');
73 return aputs
$r, 'Bad username. Allowed characters are letters, digits and underscores, and the username must be between 2 and 20 characters long.' unless $username =~ USER_REGEX
;
74 return aputs
$r, 'Username already in use' if -e
"$Apache2::Authen::Passphrase::rootdir/$username.yml";
75 return aputs
$r, 'The two passwords do not match' unless $password eq $confirm_password;
76 return aputs
$r, 'All fields are required' if grep { !length } $username, $password, $confirm_password, $name, $email, $phone, $town, $university, $level;
77 pwset
$username, $password;
79 insert_user
$username, name
=> $name, email
=> $email, phone
=> $phone, town
=> $town, university
=> $university, level
=> $level;
81 aputs
$r, 'Registered successfully';
86 my $req = Apache2
::Request
->new($r);
87 my ($oldpass, $newpass, $confirm) = map {scalar $req->param($_)} 'password', 'new_password', 'confirm_new_password';
89 local $Apache2::Authen
::Passphrase
::rootdir
= $r->dir_config('AuthenPassphraseRootdir');
90 return aputs
$r, 'Incorrect password' unless eval { pwcheck
$r->user, $oldpass; 1 };
91 return aputs
$r, 'The two passwords do not match' unless $newpass eq $confirm;
93 pwset
$r->user, $newpass;
94 aputs
$r, 'Password changed successfully';
101 my $dir = (fileparse $r->uri)[1];
103 chdir $r->dir_config('root') . $dir;
105 for my $requirement (map { $_->{requirement} } @{$r->requires}) {
106 my ($command, @args) = split ' ', $requirement;
109 when('admin-if-private'){
110 my $meta = LoadFile 'meta.yml';
111 return OK if !$meta->{private} || ($r->user && hascaps $r->user, 'gmadm')
126 # Below is stub documentation for your module. You'd better edit it!
130 Gruntmaster::Handlers - Perl extension for blah blah blah
134 use Gruntmaster::Handlers;
139 Stub documentation for Gruntmaster::Handlers, created by h2xs. It looks like the
140 author of the extension was negligent enough to leave the stub
148 Mention other useful documentation such as the documentation of
149 related modules or operating system documentation (such as man pages
150 in UNIX), or any relevant external documentation such as RFCs or
153 If you have a mailing list set up for your module, mention it here.
155 If you have a web site set up for your module, mention it here.
159 Marius Gavrilescu, E<lt>marius@E<gt>
161 =head1 COPYRIGHT AND LICENSE
163 Copyright (C) 2013 by Marius Gavrilescu
165 This library is free software; you can redistribute it and/or modify
166 it under the same terms as Perl itself, either Perl version 5.18.1 or,
167 at your option, any later version of Perl 5 you may have available.
This page took 0.034434 seconds and 3 git commands to generate.