summaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authordusoleil <howcansocksbereal@gmail.com>2022-03-13 23:15:42 -0400
committerdusoleil <howcansocksbereal@gmail.com>2022-03-13 23:28:11 -0400
commitafdc128959004fc630382debf29d47f367463d7e (patch)
tree654f82c85af008433415e7d93c15205ad30d4579 /tools
parent4bf40b9d27dbb471b7b18be502deacfb12540120 (diff)
downloadlib-des-gnux-afdc128959004fc630382debf29d47f367463d7e.tar.gz
lib-des-gnux-afdc128959004fc630382debf29d47f367463d7e.zip
sploit: Filter all magic python members by default in mem module
In the various __getattribute__() overloads in the mem module, we should filter all of the built-in magic members to do the default object.__getattribute__() behavior. This is opposed to the earlier stance of just caring about the ones that I saw as realistically being called. Signed-off-by: dusoleil <howcansocksbereal@gmail.com>
Diffstat (limited to 'tools')
-rw-r--r--tools/sploit/sploit/mem.py9
1 files changed, 6 insertions, 3 deletions
diff --git a/tools/sploit/sploit/mem.py b/tools/sploit/sploit/mem.py
index 3ad0c50..c953fce 100644
--- a/tools/sploit/sploit/mem.py
+++ b/tools/sploit/sploit/mem.py
@@ -12,7 +12,7 @@ class Symtbl:
self.off = off
self.tbl = tbl
def __getattribute__(self,sym):
- if(sym in ['off','tbl','__class__']):
+ if(sym in (['off','tbl'] + __attr_filter__)):
return object.__getattribute__(self,sym)
addr = getattr(self.tbl,sym)
if(type(addr)==int):
@@ -30,7 +30,8 @@ class Symtbl:
def __getattribute__(self, sym):
addr = object.__getattribute__(self,sym)
- if(sym == '__subs__'):return addr
+ if(sym in (['__subs__'] + __attr_filter__)):
+ return addr
if(sym == 'base'):return 0
if(sym in self.__subs__):
return self.__InnerTable__(addr,self.__subs__[sym])
@@ -51,7 +52,7 @@ class Memmap:
self.base = addr - sym
def __getattribute__(self, sym):
- if(sym in ['__tbl__','base']):
+ if(sym in (['__tbl__','base'] + __attr_filter__)):
return object.__getattribute__(self, sym)
addr = getattr(self.__tbl__, sym)
if(type(addr)==Symtbl.__InnerTable__):
@@ -83,3 +84,5 @@ def __str__(self,tbl):
else:
s += __tbl_format__.format(hex(addr),sym)
return s
+
+__attr_filter__ = ['__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__']