Skip to content

Commit

Permalink
Merge pull request #1 from B3EF/master
Browse files Browse the repository at this point in the history
Arbitrary Code execution fix
  • Loading branch information
JamieSlome authored Jan 25, 2021
2 parents 3bf502f + 9c84492 commit 0269233
Showing 1 changed file with 27 additions and 1 deletion.
28 changes: 27 additions & 1 deletion cup/services/heartbeat.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,10 +11,35 @@
import pickle
import platform
import threading
import io
import builtins

from cup import log
from cup import net
from cup.util import conf
safe_builtins = {
'range',
'complex',
'set',
'frozenset',
'slice',
}


class RestrictedUnpickler(pickle.Unpickler):

def find_class(self, module, name):
"""Only allow safe classes from builtins"""
if module == "builtins" and name in safe_builtins:
return getattr(builtins, name)
"""Forbid everything else"""
raise pickle.UnpicklingError("global '%s.%s' is forbidden" %
(module, name))

def restricted_loads(s):
"""Helper function analogous to pickle.loads()"""
return RestrictedUnpickler(io.BytesIO(s)).load()

if platform.system() == 'Linux':
from cup.res import linux

Expand Down Expand Up @@ -63,7 +88,7 @@ def deserilize(self, binary):
deserilize it from binary
"""
try:
self._dict_info = pickle.loads(binary)
self._dict_info = pickle.loads(pickle.loads(restricted_loads(binary))
return True
# pylint: disable=W0703
except Exception as error:
Expand Down Expand Up @@ -374,6 +399,7 @@ def _test():
localhost = LinuxHost(name='localhost', init_this_host=True)
binary = localhost.serilize()
print('binary:{0}'.format(binary))
restricted_loads(binary)
print(pickle.loads(binary))


Expand Down

0 comments on commit 0269233

Please sign in to comment.