PyNesca/MainPresenter.py

84 lines
2.8 KiB
Python
Raw Normal View History

2019-01-20 16:59:47 +00:00
import CoreModel
import Parser
import threading
import queue
import datetime
2019-01-20 16:59:47 +00:00
from PyQt5.Qt import *
from netaddr import IPNetwork
class MainPresenter:
def __init__(self, ui):
self.ui = ui
self.threads = []
self.isScanEnabled = False
self.queue = queue.Queue()
def startScan(self, ipRanges, portsStr, threadNumber, timeout):
if timeout == '':
timeout = '3'
cidrIPRanges = Parser.getCIDRFromRanges(ipRanges)
ports = Parser.getPortsFromString(portsStr)
ips = []
for cidr in cidrIPRanges[0]:
for ip in IPNetwork(cidr):
ips.append(str(ip))
for ip in ips:
self.queue.put(ip)
for i in range(int(threadNumber)):
self.threads.append(ScanThread(self.queue, ports, timeout, self))
2019-01-20 16:59:47 +00:00
self.setCurrentThreadsLabel(len(self.threads))
for thread in self.threads:
thread.signal.connect(self.setLogText)
thread.exit_signal.connect(self.on_thread_exit)
2019-01-20 16:59:47 +00:00
thread.start()
def on_thread_exit(self, thread):
self.threads.pop(self.threads.index(thread[0]))
self.setCurrentThreadsLabel(len(self.threads))
2019-01-20 16:59:47 +00:00
if len(self.threads) == 0:
self.isScanEnabled = False
2019-01-20 16:59:47 +00:00
self.ui.startButton.setText("Start")
def stopScan(self):
self.isScanEnabled = False
for thread in self.threads:
thread.exit_signal.emit(self.threads.index(thread))
thread.exit()
2019-01-20 16:59:47 +00:00
self.queue = queue.Queue()
def setLogText(self, string):
self.ui.dataText.append("[" + str(datetime.datetime.now()) + "] " + str(string))
2019-01-20 16:59:47 +00:00
def setCurrentThreadsLabel(self, threadNumber):
self.ui.currentThreadsLabel.setText(str(threadNumber))
class ScanThread(QThread):
signal = pyqtSignal(str)
exit_signal = pyqtSignal(list) # This signal for correct pop'ing from thread list
2019-01-20 16:59:47 +00:00
def __init__(self, scanQueue, ports, timeout, presenter, parent=None):
2019-01-20 16:59:47 +00:00
QThread.__init__(self, parent)
self.scanQueue = scanQueue
self.coreModel = CoreModel.CoreModel(timeout)
2019-01-20 16:59:47 +00:00
self.ports = ports
self._stop_event = threading.Event()
self.timeout = timeout
self.presenter = presenter
2019-01-20 16:59:47 +00:00
def run(self):
while True:
if self.scanQueue.empty():
self.exit_signal.emit([self])
2019-01-20 16:59:47 +00:00
self.exit(1)
hostObject = self.scanQueue.get()
open_ports = self.coreModel.scanIP(str(hostObject), self.ports)
2019-01-20 16:59:47 +00:00
signalStr = ''.join(str(x) for x in open_ports)
if(signalStr == ''):
self.signal.emit(str(hostObject) + ' has no open ports!')
else:
self.signal.emit(str(hostObject) + ' has open ports: ' + signalStr)
self.scanQueue.task_done()