36
from ivle import (chat, util)
39
trampoline_path = os.path.join(ivle.conf.lib_path, "trampoline")
41
python_path = "/usr/bin/python"
42
console_dir = os.path.join(ivle.conf.share_path, 'services')
43
console_path = os.path.join(console_dir, 'python-console')
35
from ivle import chat, interpret
45
37
class ConsoleError(Exception):
46
38
""" The console failed in some way. This is bad. """
47
def __init__(self, value):
50
return repr(self.value)
52
41
class ConsoleException(Exception):
53
42
""" The code being exectuted on the console returned an exception.
55
def __init__(self, value):
58
return repr(self.value)
60
46
class TruncateStringIO(StringIO.StringIO):
61
47
""" A class that wraps around StringIO and truncates the buffer when the
122
108
class Console(object):
123
109
""" Provides a nice python interface to the console
125
def __init__(self, uid, jail_path, working_dir):
111
def __init__(self, config, user, jail_path, working_dir):
126
112
"""Starts up a console service for user uid, inside chroot jail
127
113
jail_path with work directory of working_dir
129
115
super(Console, self).__init__()
132
119
self.jail_path = jail_path
133
120
self.working_dir = working_dir
157
self.magic = md5.new(uuid.uuid4().bytes).digest().encode('hex')
144
self.magic = hashlib.md5(uuid.uuid4().bytes).hexdigest()
159
146
# Try to find a free port on the server.
160
147
# Just try some random ports in the range [3000,8000)
165
152
# is (k / N) ** t (e.g. 3.2*10e-9).
169
157
self.port = int(random.uniform(3000, 8000))
171
# Start the console server (port, magic)
172
# trampoline usage: tramp uid jail_dir working_dir script_path args
173
# console usage: python-console port magic
174
res = os.spawnv(os.P_WAIT, trampoline_path, [
159
python_console = os.path.join(self.config['paths']['share'],
160
'services/python-console')
161
args = [python_console, str(self.port), str(self.magic)]
164
interpret.execute_raw(self.config, self.user, self.jail_path,
165
self.working_dir, "/usr/bin/python", args)
192
# If we can't start the console after 5 attemps (can't find a free port
193
# during random probing, syntax errors, segfaults) throw an exception.
168
except interpret.ExecutionError, e:
172
# If we can't start the console after 5 attemps (can't find a free
173
# port during random probing, syntax errors, segfaults) throw an
195
raise ConsoleError("Unable to start console service!")
176
raise ConsoleError('Unable to start console service: %s'%error)
197
178
def __chat(self, cmd, args):
198
179
""" A wrapper around chat.chat to comunicate directly with the
213
194
# Couldn't decode the JSON
214
195
raise ConsoleError(
215
196
"Could not understand the python console response")
197
except chat.ProtocolError, e:
198
raise ConsoleError(*e.args)
298
281
# Unpickle any exceptions
299
282
if 'exception' in execute:
300
return cPickle.loads(execute['exception'])
283
execute['exception'] = cPickle.loads(execute['exception'])
305
287
def set_vars(self, variables):