aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--binaries/nsjail2.5-alpine-x86_64 (renamed from binaries/nsjail)bin678704 -> 678704 bytes
-rw-r--r--binaries/nsjail2.6-ubuntu-x86_64bin0 -> 750328 bytes
-rw-r--r--docker/Dockerfile2
-rw-r--r--snekbox.py40
-rw-r--r--tests/test_snekbox.py10
5 files changed, 31 insertions, 21 deletions
diff --git a/binaries/nsjail b/binaries/nsjail2.5-alpine-x86_64
index 9af91fc..9af91fc 100644
--- a/binaries/nsjail
+++ b/binaries/nsjail2.5-alpine-x86_64
Binary files differ
diff --git a/binaries/nsjail2.6-ubuntu-x86_64 b/binaries/nsjail2.6-ubuntu-x86_64
new file mode 100644
index 0000000..d8df21b
--- /dev/null
+++ b/binaries/nsjail2.6-ubuntu-x86_64
Binary files differ
diff --git a/docker/Dockerfile b/docker/Dockerfile
index 52e6b25..2c707a1 100644
--- a/docker/Dockerfile
+++ b/docker/Dockerfile
@@ -19,7 +19,7 @@ WORKDIR /snekbox
RUN pipenv sync
-RUN cp binaries/nsjail /usr/sbin/nsjail
+RUN cp binaries/nsjail2.5-alpine-x86_64 /usr/sbin/nsjail
RUN chmod +x /usr/sbin/nsjail
CMD ["pipenv", "run", "snekbox"]
diff --git a/snekbox.py b/snekbox.py
index c19e463..7e1c4f6 100644
--- a/snekbox.py
+++ b/snekbox.py
@@ -9,6 +9,10 @@ from rmq import Rmq
class Snekbox(object):
+ def __init__(self, nsjail_binary='nsjail', python_binary='/usr/local/bin/python3.6'):
+ self.nsjail_binary = nsjail_binary
+ self.python_binary = python_binary
+
env = {
'PATH': '/snekbox/.venv/bin:/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin',
'LANG': 'en_US.UTF-8',
@@ -18,17 +22,17 @@ class Snekbox(object):
}
def python3(self, cmd):
- args = ["nsjail", "-Mo",
- "--rlimit_as", "700",
- "--chroot", "/",
- "-E", "LANG=en_US.UTF-8",
- "-R/usr", "-R/lib", "-R/lib64",
- "--user", "nobody",
- "--group", "nogroup",
- "--time_limit", "2",
- "--disable_proc",
- "--iface_no_lo",
- "--quiet", "--", "/usr/local/bin/python3.6", "-ISq", "-c", cmd]
+ args = [self.nsjail_binary, '-Mo',
+ '--rlimit_as', '700',
+ '--chroot', '/',
+ '-E', 'LANG=en_US.UTF-8',
+ '-R/usr', '-R/lib', '-R/lib64',
+ '--user', 'nobody',
+ '--group', 'nogroup',
+ '--time_limit', '2',
+ '--disable_proc',
+ '--iface_no_lo',
+ '--quiet', '--', self.python_binary, '-ISq', '-c', cmd]
proc = subprocess.Popen(args,
stdin=subprocess.PIPE,
@@ -53,15 +57,15 @@ class Snekbox(object):
def execute(self, body):
msg = body.decode('utf-8')
- log.info(f"incoming: {msg}")
- result = ""
+ log.info(f'incoming: {msg}')
+ result = ''
snek_msg = json.loads(msg)
snekid = snek_msg['snekid']
snekcode = snek_msg['message'].strip()
result = self.python3(snekcode)
- log.info(f"outgoing: {result}")
+ log.info(f'outgoing: {result}')
rmq.publish(result,
queue=snekid,
@@ -70,15 +74,15 @@ class Snekbox(object):
exit(0)
def stopwatch(self, process):
- log.debug(f"10 second timer started for process {process.pid}")
+ log.debug(f'10 second timer started for process {process.pid}')
for _ in range(10):
time.sleep(1)
if not process.is_alive():
- log.debug(f"Clean exit on process {process.pid}")
+ log.debug(f'Clean exit on process {process.pid}')
exit(0)
process.terminate()
- log.debug(f"Terminated process {process.pid} forcefully")
+ log.debug(f'Terminated process {process.pid} forcefully')
def message_handler(self, ch, method, properties, body, thread_ws=None):
p = multiprocessing.Process(target=self.execute, args=(body,))
@@ -97,5 +101,5 @@ if __name__ == '__main__':
snkbx = Snekbox()
rmq.consume(callback=snkbx.message_handler)
except KeyboardInterrupt:
- print("Exited")
+ print('Exited')
exit(0)
diff --git a/tests/test_snekbox.py b/tests/test_snekbox.py
index 5c4d1c7..cc02ef8 100644
--- a/tests/test_snekbox.py
+++ b/tests/test_snekbox.py
@@ -1,7 +1,13 @@
import unittest
import pytest
+import os
from snekbox import Snekbox
-snek = Snekbox()
-# Write some tests at some point
+nsjail = os.sep.join([os.getcwd(), f'binaries{os.sep}nsjail2.6-ubuntu-x86_64'])
+snek = Snekbox(nsjail_binary=nsjail, python_binary='/usr/bin/python3.6')
+
+class SnekTests(unittest.TestCase):
+ def test_nsjail(self):
+ result = snek.python3('print("test")')
+ self.assertEquals(result.strip(), 'test')