feature: log to directory (not to pickle)

This commit is contained in:
Dobin
2024-02-09 21:45:50 +00:00
parent d2a81bd191
commit 1eba815e93
5 changed files with 39 additions and 29 deletions
+26 -8
View File
@@ -1,16 +1,34 @@
import json
import pprint
from capstone import Cs, CS_ARCH_X86, CS_MODE_64
from model import *
class Observer():
def __init__(self):
self.capabilities_a: ExeCapabilities = None
self.options: SourceStyle = None
self.main_c: str = ""
self.payload_asm_orig: bytes = ""
self.payload_asm_cleanup: bytes = ""
self.payload_asm_fixup: bytes = ""
self.loader_shellcode: bytes = b""
self.final_shellcode: bytes = b""
self.logs = []
self.idx = 0
def add_text(self, name, data):
self.write_to_file(name, data)
def add_code(self, name, data):
md = Cs(CS_ARCH_X86, CS_MODE_64)
# Disassemble the shellcode
ret = ""
for i in md.disasm(data, 0x0):
ret += "0x%x:\t%s\t%s\n" % (i.address, i.mnemonic, i.op_str)
self.write_to_file(name, ret)
def add_json(self, name, data):
self.write_to_file(name, pprint.pformat(data, indent=4))
def write_to_file(self, filename, data):
with open("logs/{}-{}.txt".format(self.idx, filename), "w") as f:
f.write(data)
self.idx += 1
def __str__(self):
s = ""