Merge cd312e3dcc
into 729d649ec5
This commit is contained in:
commit
454e670d74
|
@ -371,7 +371,9 @@ def extract_hosts(data, hostname):
|
||||||
|
|
||||||
#Return a list of unique sub domains, sorted by frequency.
|
#Return a list of unique sub domains, sorted by frequency.
|
||||||
#Only match domains that have 3 or more sections subdomain.domain.tld
|
#Only match domains that have 3 or more sections subdomain.domain.tld
|
||||||
domain_match = re.compile("([a-zA-Z0-9_-]*\.[a-zA-Z0-9_-]*\.[a-zA-Z0-9_-]*)+")
|
domain_match = re.compile(r"([a-zA-Z0-9_-]*\.[a-zA-Z0-9_-]*\.[a-zA-Z0-9_-]*)+")
|
||||||
|
|
||||||
|
|
||||||
def extract_subdomains(file_name):
|
def extract_subdomains(file_name):
|
||||||
#Avoid re-compilation
|
#Avoid re-compilation
|
||||||
global domain_match
|
global domain_match
|
||||||
|
|
18
sublist3r.py
18
sublist3r.py
|
@ -592,8 +592,6 @@ class NetcraftEnum(enumratorBaseThreaded):
|
||||||
except Exception:
|
except Exception:
|
||||||
pass
|
pass
|
||||||
return links_list
|
return links_list
|
||||||
|
|
||||||
|
|
||||||
class DNSdumpster(enumratorBaseThreaded):
|
class DNSdumpster(enumratorBaseThreaded):
|
||||||
def __init__(self, domain, subdomains=None, q=None, silent=False, verbose=True):
|
def __init__(self, domain, subdomains=None, q=None, silent=False, verbose=True):
|
||||||
subdomains = subdomains or []
|
subdomains = subdomains or []
|
||||||
|
@ -637,14 +635,22 @@ class DNSdumpster(enumratorBaseThreaded):
|
||||||
return self.get_response(resp)
|
return self.get_response(resp)
|
||||||
|
|
||||||
def get_csrftoken(self, resp):
|
def get_csrftoken(self, resp):
|
||||||
csrf_regex = re.compile('<input type="hidden" name="csrfmiddlewaretoken" value="(.*?)">', re.S)
|
import re
|
||||||
token = csrf_regex.findall(resp)[0]
|
csrf_regex = re.compile(r'name="csrfmiddlewaretoken" value="([^"]+)"')
|
||||||
return token.strip()
|
matches = csrf_regex.findall(resp)
|
||||||
|
if matches:
|
||||||
|
return matches[0]
|
||||||
|
else:
|
||||||
|
print("[!] Warning: DNSdumpster token not found — skipping DNSdumpster engine.")
|
||||||
|
return None
|
||||||
|
|
||||||
def enumerate(self):
|
def enumerate(self):
|
||||||
self.lock = threading.BoundedSemaphore(value=70)
|
self.lock = threading.BoundedSemaphore(value=70)
|
||||||
resp = self.req('GET', self.base_url)
|
resp = self.req('GET', self.base_url)
|
||||||
token = self.get_csrftoken(resp)
|
token = self.get_csrftoken(resp)
|
||||||
|
if not token:
|
||||||
|
return []
|
||||||
|
|
||||||
params = {'csrfmiddlewaretoken': token, 'targetip': self.domain}
|
params = {'csrfmiddlewaretoken': token, 'targetip': self.domain}
|
||||||
post_resp = self.req('POST', self.base_url, params)
|
post_resp = self.req('POST', self.base_url, params)
|
||||||
self.extract_domains(post_resp)
|
self.extract_domains(post_resp)
|
||||||
|
@ -723,6 +729,8 @@ class Virustotal(enumratorBaseThreaded):
|
||||||
except Exception:
|
except Exception:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
git remote add origin https://github.com/SANJAY23CB50/Sublist3r.git
|
||||||
|
git branch -M main
|
||||||
|
|
||||||
class ThreatCrowd(enumratorBaseThreaded):
|
class ThreatCrowd(enumratorBaseThreaded):
|
||||||
def __init__(self, domain, subdomains=None, q=None, silent=False, verbose=True):
|
def __init__(self, domain, subdomains=None, q=None, silent=False, verbose=True):
|
||||||
|
|
Loading…
Reference in New Issue