def pocThreads(): """ @function multiThread executing """ kb.pCollect = set() while not kb.targets.empty() and kb.threadContinue: target, poc, pocname = kb.targets.get() infoMsg = "poc:'%s' target:'%s'" % (pocname, target) logger.log(CUSTOM_LOGGING.SYSINFO, infoMsg) # TODO json if isinstance(poc, dict): pocInfo = poc['pocInfo'] result = execReq(poc, conf.mode, target) output = (target, pocname, pocInfo["vulID"], pocInfo["appName"], pocInfo["appVersion"], "success" if result else "failed", time.strftime("%Y-%m-%d %X", time.localtime()), str(result.result)) else: kb.pCollect.add(poc.__module__) result = poc.execute(target, headers=conf.httpHeaders, mode=conf.mode, params=conf.params, verbose=True) if not result: continue output = (target, pocname, result.vulID, result.appName, result.appVersion, "success" if result.is_success() else result.error, time.strftime("%Y-%m-%d %X", time.localtime()), str(result.result)) result.show_result() kb.results.add(output) if isinstance(conf.delay, (int, float)) and conf.delay > 0: time.sleep(conf.delay / 1000)
def pocThreads(): """ @function multiThread executing """ while not kb.targets.empty() and kb.threadContinue: target, poc, pocname = kb.targets.get() infoMsg = "poc:'%s' target:'%s'" % (pocname, target) logger.log(CUSTOM_LOGGING.SYSINFO, infoMsg) # TODO json if isinstance(poc, dict): pocInfo, pocDevil = poc['pocInfo'], poc["pocExecute"] result = execReq(poc, conf.mode, target) output = (target, pocname, pocInfo["vulID"], pocInfo["appName"], pocInfo["appVersion"], "success" if result else "failed", time.strftime("%Y-%m-%d %X", time.localtime())) else: result = poc.execute(target, headers=conf.httpHeaders, mode=conf.mode, params=conf.params, verbose=True) output = (target, pocname, result.vulID, result.appName, result.appVersion, "success" if result.is_success() else "failed", time.strftime("%Y-%m-%d %X", time.localtime())) result.show_result() kb.results.add(output)