Skip to content

Commit

Permalink
Enhancing OOP, fixing major bugs, implemente sublister as a module wh…
Browse files Browse the repository at this point in the history
…ere you can call it from other programs
  • Loading branch information
Ibrahim committed Oct 27, 2016
1 parent 7b1657e commit 5823d9e
Showing 1 changed file with 33 additions and 200 deletions.
233 changes: 33 additions & 200 deletions sublist3r.py
Original file line number Diff line number Diff line change
Expand Up @@ -432,7 +432,6 @@ def generate_query(self):
query = "domain:{domain} -www.{domain}".format(domain=self.domain)
return query


class BaiduEnum(enumratorBaseThreaded):
def __init__(self, domain, subdomains=None, q=None, silent=False, verbose=True):
subdomains = subdomains or []
Expand Down Expand Up @@ -491,35 +490,14 @@ def generate_query(self):
query = "site:{domain} -site:www.{domain}".format(domain=self.domain)
return query

class NetcraftEnum(multiprocessing.Process):
def __init__(self, domain, subdomains=None, q=None, lock=threading.Lock(), silent=False, verbose=True):
class NetcraftEnum(enumratorBaseThreaded):
def __init__(self, domain, subdomains=None, q=None, silent=False, verbose=True):
subdomains = subdomains or []
self.base_url = 'http://searchdns.netcraft.com/?restriction=site+ends+with&host={domain}'
self.domain = urlparse.urlparse(domain).netloc
self.subdomains = []
self.session = requests.Session()
self.engine_name = "Netcraft"
multiprocessing.Process.__init__(self)
self.lock = lock
self.lock = threading.Lock()
super(NetcraftEnum, self).__init__(self.base_url, self.engine_name, domain, subdomains, q=q, silent=silent, verbose=verbose)
self.q = q
self.timeout = 10
self.silent = silent
self.verbose=verbose
self.print_banner()
return

def print_(self, text):
if not self.silent:
print text

def run(self):
domain_list = self.enumerate()
for domain in domain_list:
self.q.append(domain)
return

def print_banner(self):
self.print_(G+"[-] Searching now in %s.." %(self.engine_name)+W)
return

def req(self, url, cookies=None):
Expand All @@ -536,14 +514,6 @@ def req(self, url, cookies=None):
resp = None
return resp

def get_response(self,response):
if response is None:
return 0
if hasattr(response, "text"):
return response.text
else:
return response.content

def get_next(self, resp):
link_regx = re.compile('<A href="(.*?)"><b>Next page</b></a>')
link = link_regx.findall(resp)
Expand Down Expand Up @@ -594,38 +564,17 @@ def extract_domains(self, resp):
pass
return links_list


class DNSdumpster(multiprocessing.Process):
def __init__(self, domain, subdomains=None, q=None, lock=threading.Lock(), silent=False, verbose=True):
class DNSdumpster(enumratorBaseThreaded):
def __init__(self, domain, subdomains=None, q=None, silent=False, verbose=True):
subdomains = subdomains or []
self.base_url = 'https://dnsdumpster.com/'
self.domain = urlparse.urlparse(domain).netloc
self.subdomains = []
base_url = 'https://dnsdumpster.com/'
self.live_subdomains = []
self.session = requests.Session()
self.engine_name = "DNSdumpster"
multiprocessing.Process.__init__(self)
self.threads = 70
self.lock = threading.BoundedSemaphore(value=self.threads)
self.q = q
self.timeout = 25
self.silent = silent
self.verbose = verbose
self.print_banner()
return

def print_(self, text):
if not self.silent:
print text

def run(self):
domain_list = self.enumerate()
for domain in domain_list:
self.q.append(domain)
return

def print_banner(self):
self.print_(G+"[-] Searching now in %s.." %(self.engine_name)+W)
super(DNSdumpster, self).__init__(base_url, self.engine_name, domain, subdomains, q=q, silent=silent, verbose=verbose)
return

def check_host(self,host):
Expand Down Expand Up @@ -664,14 +613,6 @@ def req(self, req_method, url, params=None):
resp = None
return self.get_response(resp)

def get_response(self,response):
if response is None:
return 0
if hasattr(response, "text"):
return response.text
else:
return response.content

def get_csrftoken(self, resp):
csrf_regex = re.compile("<input type='hidden' name='csrfmiddlewaretoken' value='(.*?)' />",re.S)
token = csrf_regex.findall(resp)[0]
Expand All @@ -689,7 +630,6 @@ def enumerate(self):
t.join()
return self.live_subdomains


def extract_domains(self, resp):
tbl_regex = re.compile('<a name="hostanchor"><\/a>Host Records.*?<table.*?>(.*?)</table>',re.S)
link_regex = re.compile('<td class="col-md-4">(.*?)<br>',re.S)
Expand All @@ -708,38 +648,19 @@ def extract_domains(self, resp):
self.subdomains.append(subdomain.strip())
return links

class Virustotal(multiprocessing.Process):
def __init__(self, domain, subdomains=None, q=None, lock=threading.Lock(), silent=False, verbose=True):
class Virustotal(enumratorBaseThreaded):
def __init__(self, domain, subdomains=None, q=None, silent=False, verbose=True):
subdomains = subdomains or []
self.base_url = 'https://www.virustotal.com/en/domain/{domain}/information/'
self.domain = urlparse.urlparse(domain).netloc
self.subdomains = []
self.session = requests.Session()
base_url = 'https://www.virustotal.com/en/domain/{domain}/information/'
self.engine_name = "Virustotal"
self.silent = silent
multiprocessing.Process.__init__(self)
self.lock = lock
self.lock = threading.Lock()
self.q = q
self.timeout = 10
self.verbose = verbose
self.print_banner()
return

def run(self):
domain_list = self.enumerate()
for domain in domain_list:
self.q.append(domain)
super(Virustotal, self).__init__(base_url, self.engine_name, domain, subdomains, q=q, silent=silent, verbose=verbose)
return

def print_(self, text):
if not self.silent:
print text

def print_banner(self):
self.print_(G+"[-] Searching now in %s.." %(self.engine_name)+W)
return

def req(self, url):
#the main send_req need to be rewritten
def send_req(self, url):
headers = {'User-Agent': 'Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:38.0) Gecko/20100101 Firefox/40.0',
'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8',
'Accept-Language': 'en-GB,en;q=0.5',
Expand All @@ -754,17 +675,10 @@ def req(self, url):

return self.get_response(resp)

def get_response(self,response):
if response is None:
return 0
if hasattr(response, "text"):
return response.text
else:
return response.content

#once the send_req is rewritten we don't need to call this function, the stock one should be ok
def enumerate(self):
url = self.base_url.format(domain=self.domain)
resp = self.req(url)
resp = self.send_req(url)
self.extract_domains(resp)
return self.subdomains

Expand All @@ -784,34 +698,15 @@ def extract_domains(self, resp):
pass


class ThreatCrowd(multiprocessing.Process):
def __init__(self, domain, subdomains=None, q=None, lock=threading.Lock(), silent=False, verbose=True):
class ThreatCrowd(enumratorBaseThreaded):
def __init__(self, domain, subdomains=None, q=None, silent=False, verbose=True):
subdomains = subdomains or []
self.base_url = 'https://www.threatcrowd.org/searchApi/v2/domain/report/?domain={domain}'
self.domain = urlparse.urlparse(domain).netloc
self.subdomains = []
self.session = requests.Session()
base_url = 'https://www.threatcrowd.org/searchApi/v2/domain/report/?domain={domain}'
self.engine_name = "ThreatCrowd"
multiprocessing.Process.__init__(self)
self.lock = lock
self.lock = threading.Lock()
self.q = q
self.timeout = 20
self.silent = silent
self.verbose = verbose
self.print_banner()
return

def run(self):
domain_list = self.enumerate()
for domain in domain_list:
self.q.append(domain)
return

def print_(self, text):
if not self.silent:
print text
def print_banner(self):
self.print_(G+"[-] Searching now in %s.." %(self.engine_name)+W)
super(ThreatCrowd, self).__init__(base_url, self.engine_name, domain, subdomains, q=q, silent=silent, verbose=verbose)
return

def req(self, url):
Expand All @@ -828,14 +723,6 @@ def req(self, url):

return self.get_response(resp)

def get_response(self,response):
if response is None:
return 0
if hasattr(response, "text"):
return response.text
else:
return response.content

def enumerate(self):
url = self.base_url.format(domain=self.domain)
resp = self.req(url)
Expand Down Expand Up @@ -863,35 +750,15 @@ def extract_domains(self, resp):
except Exception as e:
pass

class CrtSearch(multiprocessing.Process):
def __init__(self, domain, subdomains=None, q=None, lock=threading.Lock(), silent=False, verbose=True):
class CrtSearch(enumratorBaseThreaded):
def __init__(self, domain, subdomains=None, q=None, silent=False, verbose=True):
subdomains = subdomains or []
self.base_url = 'https://crt.sh/?q=%25.{domain}'
self.domain = urlparse.urlparse(domain).netloc
self.subdomains = []
self.session = requests.Session()
base_url = 'https://crt.sh/?q=%25.{domain}'
self.engine_name = "SSL Certificates"
multiprocessing.Process.__init__(self)
self.lock = lock
self.lock = threading.Lock()
self.q = q
self.timeout = 25
self.silent = silent
self.verbose = verbose
self.print_banner()
return

def run(self):
domain_list = self.enumerate()
for domain in domain_list:
self.q.append(domain)
return

def print_(self, text):
if not self.silent:
print text

def print_banner(self):
self.print_(G+"[-] Searching now in %s.." %(self.engine_name)+W)
super(CrtSearch, self).__init__(base_url, self.engine_name, domain, subdomains, q=q, silent=silent, verbose=verbose)
return

def req(self, url):
Expand All @@ -908,14 +775,6 @@ def req(self, url):

return self.get_response(resp)

def get_response(self,response):
if response is None:
return 0
if hasattr(response, "text"):
return response.text
else:
return response.content

def enumerate(self):
url = self.base_url.format(domain=self.domain)
resp = self.req(url)
Expand All @@ -938,36 +797,17 @@ def extract_domains(self, resp):
except Exception as e:
pass

class PassiveDNS(multiprocessing.Process):
def __init__(self, domain, subdomains=None, q=None, lock=threading.Lock(), silent=False, verbose=True):
class PassiveDNS(enumratorBaseThreaded):
def __init__(self, domain, subdomains=None, q=None, silent=False, verbose=True):
subdomains = subdomains or []
self.base_url = 'http://ptrarchive.com/tools/search.htm?label={domain}'
self.domain = urlparse.urlparse(domain).netloc
self.subdomains = []
self.session = requests.Session()
base_url = 'http://ptrarchive.com/tools/search.htm?label={domain}'
self.engine_name = "PassiveDNS"
multiprocessing.Process.__init__(self)
self.lock = lock
self.lock = threading.Lock()
self.q = q
self.timeout = 25
self.silent = silent
self.verbose = verbose
self.print_banner()
return

def run(self):
domain_list = self.enumerate()
for domain in domain_list:
self.q.append(domain)
super(PassiveDNS, self).__init__(base_url, self.engine_name, domain, subdomains, q=q, silent=silent, verbose=verbose)
return

def print_(self, text):
if not self.silent:
print text

def print_banner(self):
self.print_(G+"[-] Searching now in %s.." %(self.engine_name)+W)
return

def req(self, url):
headers = {'User-Agent': 'Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:38.0) Gecko/20100101 Firefox/40.0',
Expand All @@ -984,13 +824,6 @@ def req(self, url):

return self.get_response(resp)

def get_response(self,response):
if response is None:
return 0
if hasattr(response, "text"):
return response.text
else:
return response.content

def enumerate(self):
url = self.base_url.format(domain=self.domain)
Expand Down Expand Up @@ -1133,4 +966,4 @@ def main(domain, threads, savefile, ports, silent, verbose, enable_bruteforce):


banner()
res = main(domain, threads, savefile, ports, silent=True, verbose=verbose, enable_bruteforce=enable_bruteforce)
res = main(domain, threads, savefile, ports, silent=False, verbose=verbose, enable_bruteforce=enable_bruteforce)

0 comments on commit 5823d9e

Please sign in to comment.