forked from the-c0d3r/admin-finder
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhttp-scanner.py
75 lines (57 loc) · 2.02 KB
/
http-scanner.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
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import argparse
import time
import queue
from lib.log import setupLogger
from lib.worker import WorkerThread
from lib.connection import URLFormatter
from lib.wordlist import WordListGenerator
def _get_parser() -> argparse.ArgumentParser:
parser = argparse.ArgumentParser(prog = "http-scanner.py", description = "HTTP scanner")
parser.add_argument("-u", "--url", help = "Target base url", required = True)
parser.add_argument("-w", "--wordlist", help = "Wordlist to use, default to 'wordlist.txt'", default = "wordlists/wordlist.txt")
parser.add_argument("-t", "--threadcount", help = "Number of threads to use, default 20", default = 20)
return parser
def main():
start = time.time()
logger = setupLogger()
parser = _get_parser()
args = parser.parse_args()
if not args.url:
parser.print_help()
exit()
args.url = URLFormatter(args.url).geturl()
try:
workQueue = queue.Queue()
workerPool = []
for _ in range(int(args.threadcount)):
thread = WorkerThread(workQueue)
thread.daemon = True
thread.start()
workerPool.append(thread)
wordcount = 0
for url in WordListGenerator(args.url, filename = args.wordlist):
wordcount += 1
workQueue.put(url)
logger.info(f"{wordcount} urls generated")
logger.info("Scanner started")
while not workQueue.empty():
pass
for worker in workerPool:
worker.join()
# prevents the main thread from exiting
end = time.time()
elapsed = int(end - start)
logger.info(f"Scanner completed in {elapsed} seconds")
except KeyboardInterrupt:
logger.info("Detected interrupt signal, terminating")
for worker in workerPool:
worker.work = False
def banner() -> None:
"""Prints the banner"""
print("HTTP Scanner")
print("- the-c0d3r")
if __name__ == '__main__':
banner()
main()