blob: 1a821647d76c41c1cfe061ddeff6667c755c31b7 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
|
#!/bin/bash
# ////////////////////////////////////////////////////////////////////////////////
# //BOCA Online Contest Administrator
# // Copyright (C) 2003-2014 by BOCA System (bocasystem@gmail.com)
# //
# // This program is free software: you can redistribute it and/or modify
# // it under the terms of the GNU General Public License as published by
# // the Free Software Foundation, either version 3 of the License, or
# // (at your option) any later version.
# //
# // This program is distributed in the hope that it will be useful,
# // but WITHOUT ANY WARRANTY; without even the implied warranty of
# // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# // GNU General Public License for more details.
# // You should have received a copy of the GNU General Public License
# // along with this program. If not, see <http://www.gnu.org/licenses/>.
# ////////////////////////////////////////////////////////////////////////////////
#Last modified: 04/nov/2014 by cassio@ime.usp.br
#Last modified: 06/sep/2016 by brunoribas@utfpr.edu.br
#
# parameters are:
# $1 main_class
# $2 input_file
# $3 timelimit (limit to run all the repetitions, by default only one repetition)
# $4 number_of_repetitions_to_run (optional, can be used for better tuning the timelimit)
# $5 maximum allowed memory (in MBytes)
# $6 maximum allowed output size (in KBytes)
#
# the output of the submission should be directed to the standard output
#
# the return code show what happened (according to safeexec):
# 0 ok
# 1 compile error
# 2 runtime error
# 3 timelimit exceeded
# 4 internal error
# 5 parameter error
# 6 internal error
# 7 memory limit exceeded
# 8 security threat
# 9 runtime error
# other_codes are unknown to boca: in this case BOCA will present the
# last line of standard output to the judge
umask 0022
id -u bocajail >/dev/null 2>/dev/null
if [ $? == 0 ]; then
bocau=`id -u bocajail`
bocag=`id -g bocajail`
chown bocajail.nogroup .
else
bocau=`id -u nobody`
bocag=`id -g nobody`
chown nobody.nogroup .
fi
if [ "$bocau" == "" -o "$bocag" == "" ]; then
echo "error finding user to run script"
exit 43
fi
# this script makes use of safeexec to execute the code with less privilegies
# make sure that directories below are correct.
sf=`which safeexec`
[ -x "$sf" ] || sf=/usr/bin/safeexec
if [ "$1" == "" -o "$2" == "" -o "$3" == "" ]; then
echo "parameter problem"
exit 43
fi
name=`basename "$1"`
if [ ! -r "$2" ]; then
echo "$2 not found (or is not in the current dir) or it's not readable"
exit 45
fi
if [ ! -x "$sf" ]; then
echo "$sf not found or it's not executable"
exit 46
fi
time=$3
if [ "$time" -gt "0" ]; then
let "ttime = $time + 30"
else
time=1
ttime=30
fi
nruns=1
if [ "$4" != "" ]; then
if [ "$4" -gt "0" ]; then
nruns=$4
fi
fi
maxm=512000
if [ "$5" != "" ]; then
if [ "$5" -gt "0" ]; then
maxm=${5}000
fi
fi
let "maxms = $maxm / 10"
maxf=1024
if [ "$6" != "" ]; then
if [ "$6" -gt "0" ]; then
maxf=${6}
fi
fi
rm -f runit.retcode 2>/dev/null
cp "$2" stdin0 2>/dev/null
cdir=`pwd`
echo "Current directory is $cdir" >&2
echo $cdir | grep -q "/bocajail"
if [ $? == 0 ]; then
cdir=`echo $cdir | sed "s/.*\/bocajail//"`
cat <<EOF > runit.sh
#!/bin/bash
cd "$cdir"
[ -f /proc/cpuinfo ] || /bin/mount -t proc proc /proc
#/bin/mount --bind /dev /dev
[ -d /sys/kernel ] || /bin/mount -t sysfs sysfs /sys
python2=`which python2`
[ -x "\$python2" ] || python2=/usr/bin/python2
if [ ! -x "\$python2" ]; then
echo "\$python2 not found or it's not executable"
exit 47
fi
"$sf" -r$nruns -t$time -T$ttime -istdin0 -F256 -u256 -ostdout0 -estderr0 -U$bocau -G$bocag -n0 -C. -f$maxf -d$maxm -m$maxm -- "\$python2" "$name"
retval=\$?
echo \$retval > runit.retcode
if [ ! -d /bocajail ]; then
/bin/umount /proc 2>/dev/null
#/bin/umount /dev
/bin/umount /sys 2>/dev/null
fi
EOF
chmod 755 runit.sh
chroot /bocajail "$cdir/runit.sh"
if [ -r runit.retcode ]; then
ret=`cat runit.retcode`
fi
if [ "$ret" == "" ]; then
echo "Execution error - check autojudging"
exit 49
fi
else
echo "CODE NOT BEING CHROOTED. DO NOT RUN THIS ON THE MAIN SERVER" >&2
echo "CODE NOT BEING CHROOTED. DO NOT RUN THIS ON THE MAIN SERVER" >&2
echo "CODE NOT BEING CHROOTED. DO NOT RUN THIS ON THE MAIN SERVER" >&2
python2=`which python2`
[ -x "$python2" ] || python2=/usr/bin/python2
if [ ! -x "$python2" ]; then
echo "$python2 not found or it's not executable"
exit 47
fi
"$sf" -r$nruns -t$time -T$ttime -istdin0 -F256 -u256 -U$bocau -G$bocag -ostdout0 -estderr0 -n0 -C. -d$maxm -m$maxm -f$maxf -- "$python2" "$name"
ret=$?
fi
if [ $ret -gt 10 ]; then
echo "> > > > > > > Nonzero return code - possible runtime error - I'M GUESSING IT IS RUNTIME ERROR < < < < < < < <"
ret=9
fi
if [ -f stdout0 ]; then
cat stdout0
fi
exit $ret
|