removed: responder3 depedencies now responder need to installed by default for use

added: binary exec mode plugin options, moved: captiveflask and
pumpkinproxy to console script on setup.py installation
This commit is contained in:
mh4x0f 2022-06-27 21:25:28 -03:00
parent fa5512c415
commit 9bcac0b76a
10 changed files with 65 additions and 70 deletions

View File

@ -84,7 +84,7 @@ skip_inactivity_poll=1
generic=light-white, #000000 generic=light-white, #000000
pumpkinproxy=light-red, #000000 pumpkinproxy=light-red, #000000
pydns_server=light-blue, #000000 pydns_server=light-blue, #000000
responder3=light-green, #000000 responder=light-green, #000000
sniffkin3=light-yellow, #000000 sniffkin3=light-yellow, #000000
captiveflask=light-cyan, #000000 captiveflask=light-cyan, #000000
pydhcp_server=light-magenta, #000000 pydhcp_server=light-magenta, #000000
@ -119,8 +119,7 @@ iptables_D_accept=-w -A OUTPUT --out-interface $inet -j ACCEPT
iptables_E_accpet=-w -A INPUT --in-interface $wlan -j ACCEPT iptables_E_accpet=-w -A INPUT --in-interface $wlan -j ACCEPT
[mitm_modules] [mitm_modules]
responder3=false responder=false
responder3_config=/.config/wifipumpkin3/config/plugins/responder3/examples/config.py
sniffkin3=true sniffkin3=true
[proxy_plugins] [proxy_plugins]

View File

@ -1,26 +1,2 @@
netifaces==0.10.9
netaddr==0.7.19
dhcplib==0.1.1
scapy_http==1.8.2
tabulate==0.8.5
urwid==1.1.2
termcolor==1.1.0
twisted==19.7.0
PyQt5>=5.14
PyQt5-sip
pyOpenSSL==19.0.0
Responder3==0.0.1
dnslib==0.9.17
loguru>=0.4.0
scapy==2.4.3
isc_dhcp_leases==0.9.1
dnspython==1.16.0
Flask==1.1.4
requests>=2.18.4
beautifulsoup4>=4.9.1
black black
coverage==5.1 coverage==5.1
PyJWT==2.1.0
flask-restx>=0.5.1
markupsafe==2.0.1
Werkzeug<2.0,>=0.15

View File

@ -4,20 +4,18 @@ dhcplib==0.1.1
tabulate>=0.8.5 tabulate>=0.8.5
urwid==2.1.2 urwid==2.1.2
termcolor>=1.1.0 termcolor>=1.1.0
twisted==19.7.0 twisted>=19.7.0
PyQt5>=5.14 PyQt5>=5.14
PyQt5-sip PyQt5-sip
pyOpenSSL==19.0.0 pyOpenSSL==19.0.0
Responder3>=0.0.1
dnslib==0.9.17 dnslib==0.9.17
loguru>=0.4.0 loguru>=0.4.0
scapy>=2.4.4 scapy>=2.4.4
isc_dhcp_leases>=0.9.1 isc_dhcp_leases>=0.9.1
dnspython==1.16.0 dnspython==1.16.0
Flask==1.1.4 Flask>=1.1.1
requests>=2.18.4 requests>=2.18.4
beautifulsoup4>=4.9.1 beautifulsoup4>=4.9.1
asn1crypto>=1.0.0
PyJWT==2.1.0 PyJWT==2.1.0
flask-restx>=0.5.1 flask-restx>=0.5.1
markupsafe==2.0.1 markupsafe==2.0.1

View File

@ -36,6 +36,8 @@ with open("requirements.txt") as fp:
folders = ["config", "logs", "helps", "scripts", "exceptions"] folders = ["config", "logs", "helps", "scripts", "exceptions"]
config_dir = "/usr/share/wifipumpkin3" config_dir = "/usr/share/wifipumpkin3"
def create_user_dir_config(): def create_user_dir_config():
user_config_dir = config_dir user_config_dir = config_dir
if not os.path.isdir(user_config_dir): if not os.path.isdir(user_config_dir):
@ -61,17 +63,23 @@ setup(
license="apache 2.0", license="apache 2.0",
long_description=open("README.md").read(), long_description=open("README.md").read(),
install_requires=required, install_requires=required,
scripts=["bin/sslstrip3", "bin/captiveflask"],
include_package_data=True, include_package_data=True,
packages=find_packages(exclude=["*.tests", "*.tests.*", "tests.*", "tests"]), packages=find_packages(exclude=["*.tests", "*.tests.*", "tests.*", "tests"]),
python_requires=">=3.7", python_requires=">=3.7",
classifiers=[ classifiers=[
"Programming Language :: Python :: 3.7", "Programming Language :: Python :: 3",
"Development Status :: 5 - Production/Stable", "Development Status :: 5 - Production/Stable",
"License :: OSI Approved :: Apache Software License", "License :: OSI Approved :: Apache Software License",
"Natural Language :: English", "Natural Language :: English",
"Operating System :: POSIX :: Linux", "Operating System :: POSIX :: Linux",
"Environment :: Console", "Environment :: Console",
], ],
entry_points={"console_scripts": ["wifipumpkin3=wifipumpkin3.__main__:main",],}, entry_points={
"console_scripts": [
"wifipumpkin3=wifipumpkin3.__main__:main",
"wp3=wifipumpkin3.__main__:main",
"captiveflask=wifipumpkin3.plugins.bin.captiveflask:main",
"sslstrip3=wifipumpkin3.plugins.bin.sslstrip3:main",
],
},
) )

View File

@ -59,6 +59,7 @@ class MitmMode(Widget):
sendSingal_disable = QtCore.pyqtSignal(object) sendSingal_disable = QtCore.pyqtSignal(object)
config = None config = None
TypeButton = 1 # 0 for Switch, 1 for Radio TypeButton = 1 # 0 for Switch, 1 for Radio
Binary_exec = None # binary name of execuble command
def __init__(self, parent=None): def __init__(self, parent=None):
super(MitmMode, self).__init__(parent) super(MitmMode, self).__init__(parent)
@ -114,6 +115,10 @@ class MitmMode(Widget):
) )
) )
@property
def getBinaryExecPath(self):
return Linux.getBinaryPath(self.Binary_exec)
@property @property
def getPlugins(self): def getPlugins(self):
return None return None

View File

@ -24,15 +24,15 @@ import wifipumpkin3.core.utility.constants as C
class NetCredential(DockableWidget): class NetCredential(DockableWidget):
id = "Responder3" id = "Responder"
title = "Responder3" title = "Responder"
def __init__(self, parent=None, title="", info={}): def __init__(self, parent=None, title="", info={}):
super(NetCredential, self).__init__(parent, title, info) super(NetCredential, self).__init__(parent, title, info)
self.setObjectName(self.title) self.setObjectName(self.title)
def writeModeData(self, data): def writeModeData(self, data):
""" get data output and add on QtableWidgets """ """get data output and add on QtableWidgets"""
print(data) print(data)
# self.THeaders['Username'].append(data['POSTCreds']['User']) # self.THeaders['Username'].append(data['POSTCreds']['User'])
# self.THeaders['Password'].append(data['POSTCreds']['Pass']) # self.THeaders['Password'].append(data['POSTCreds']['Pass'])
@ -43,12 +43,12 @@ class NetCredential(DockableWidget):
pass pass
class Responder3(MitmMode): class Responder(MitmMode):
Name = "Responder 3" Name = "Responder"
ID = "responder3" ID = "responder"
Author = "PumpkinDev" Author = "PumpkinDev"
Description = "LLMNR, NBT-NS and MDNS poisoner, with built-in HTTP/SMB/MSSQL/FTP/LDAP rogue authentication server " Description = "LLMNR, NBT-NS and MDNS poisoner, with built-in HTTP/SMB/MSSQL/FTP/LDAP rogue authentication server "
LogFile = C.LOG_RESPONDER3 LogFile = C.LOG_RESPONDER
Hidden = False Hidden = False
ConfigMitmPath = None ConfigMitmPath = None
_cmd_array = [] _cmd_array = []
@ -56,9 +56,10 @@ class Responder3(MitmMode):
ModType = "server" # proxy or server ModType = "server" # proxy or server
config = None config = None
TypeButton = 0 # 0 for Switch, 1 for Radio TypeButton = 0 # 0 for Switch, 1 for Radio
Binary_exec = "responder"
def __init__(self, parent, FSettingsUI=None, main_method=None, **kwargs): def __init__(self, parent, FSettingsUI=None, main_method=None, **kwargs):
super(Responder3, self).__init__(parent) super(Responder, self).__init__(parent)
self.setID(self.ID) self.setID(self.ID)
self.setModType(self.ModType) self.setModType(self.ModType)
self.dockwidget = NetCredential(None, title=self.Name) self.dockwidget = NetCredential(None, title=self.Name)
@ -66,19 +67,22 @@ class Responder3(MitmMode):
@property @property
def CMD_ARRAY(self): def CMD_ARRAY(self):
iface = self.conf.get("accesspoint", "interface") iface = self.conf.get("accesspoint", "interface")
config_responder3_path = C.user_config_dir + self.conf.get( self._cmd_array = ["-I", iface, "-wd"]
"mitm_modules", "responder3_config"
)
self._cmd_array = ["-I", iface, "-4", "-p", config_responder3_path]
return self._cmd_array return self._cmd_array
def boot(self): def boot(self):
if self.CMD_ARRAY: binary_path = self.getBinaryExecPath
self.reactor = ProcessThread({"responder3": self.CMD_ARRAY}) if binary_path:
self.reactor = ProcessThread({binary_path: self.CMD_ARRAY})
self.reactor._ProcssOutput.connect(self.LogOutput) self.reactor._ProcssOutput.connect(self.LogOutput)
self.reactor.setObjectName(self.ID) return self.reactor.setObjectName(self.ID)
print(
display_messages(
"command not found: {}".format(self.Binary_exec), error=True
)
)
def parser_set_responder3(self, status, plugin_name): def parser_set_responder(self, status, plugin_name):
try: try:
# plugin_name = pumpkinproxy.no-cache # plugin_name = pumpkinproxy.no-cache
name_plugin, key_plugin = ( name_plugin, key_plugin = (
@ -89,7 +93,7 @@ class Responder3(MitmMode):
self.config.set("plugins", key_plugin, status) self.config.set("plugins", key_plugin, status)
print( print(
display_messages( display_messages(
"responder3: {} status: {}".format(key_plugin, status), "responder: {} status: {}".format(key_plugin, status),
sucess=True, sucess=True,
) )
) )

View File

@ -33,14 +33,14 @@ from shutil import copyfile
class ModPump(ModuleUI): class ModPump(ModuleUI):
""" Extra customs captiveflask templates """ """Extra customs captiveflask templates"""
name = "extra_captiveflask" name = "extra_captiveflask"
save_path = tempfile.gettempdir() + "/master.zip" save_path = tempfile.gettempdir() + "/master.zip"
extracted_filepath = tempfile.gettempdir() + "/extra-captiveflask-master" extracted_filepath = tempfile.gettempdir() + "/extra-captiveflask-master"
config_file_ini = tempfile.gettempdir() + "/extra-captiveflask-master/config.ini" config_file_ini = tempfile.gettempdir() + "/extra-captiveflask-master/config.ini"
captiveflask_path = C.wp3_setup_packager_path + "/plugins/captiveflask" captiveflask_path = C.wp3_setup_packager_path + "/plugins/captiveflask"
config_default = SettingsINI(C.CONFIG_CP_INI_ROOT) config_default = SettingsINI(C.CONFIG_CP_INI_ROOT)
@ -54,7 +54,7 @@ class ModPump(ModuleUI):
super(ModPump, self).__init__(parse_args=self.parse_args, root=self.root) super(ModPump, self).__init__(parse_args=self.parse_args, root=self.root)
def do_list(self, args): def do_list(self, args):
""" show all avaliable templates from github """ """show all avaliable templates from github"""
if not path.isfile(self.save_path): if not path.isfile(self.save_path):
print( print(
display_messages( display_messages(
@ -100,7 +100,7 @@ class ModPump(ModuleUI):
display_tabulate(self.table_headers, self.table_output) display_tabulate(self.table_headers, self.table_output)
def do_download(self, args): def do_download(self, args):
""" download all avaliable templates""" """download all avaliable templates"""
url = C.URL_EXTRA_CAPTIVEFLASK url = C.URL_EXTRA_CAPTIVEFLASK
chunk_size = 128 chunk_size = 128
print( print(
@ -148,11 +148,13 @@ class ModPump(ModuleUI):
print(display_messages("copy content file to {}".format(dest), info=True)) print(display_messages("copy content file to {}".format(dest), info=True))
folder_plugin = "{}/templates/{}".format(self.extracted_filepath, plugin_name) folder_plugin = "{}/templates/{}".format(self.extracted_filepath, plugin_name)
copy_tree(folder_plugin, C.config_dir + "/config/templates/{}".format(plugin_name)) copy_tree(
folder_plugin, C.config_dir + "/config/templates/{}".format(plugin_name)
)
print( print(
display_messages( display_messages(
"copy content directory to {}".format( "copy content directory to {}".format(
"{}/config/templates/{}".format( C.config_dir,plugin_name) "{}/config/templates/{}".format(C.config_dir, plugin_name)
), ),
info=True, info=True,
) )
@ -173,7 +175,7 @@ class ModPump(ModuleUI):
) )
def do_install(self, args): def do_install(self, args):
""" install custom captiveflask portals """ """install custom captiveflask portals"""
if not path.isdir(self.captiveflask_path): if not path.isdir(self.captiveflask_path):
print( print(
display_messages( display_messages(
@ -204,7 +206,7 @@ class ModPump(ModuleUI):
return self.show_help_command("help_extra_captiveflask") return self.show_help_command("help_extra_captiveflask")
def do_info(self, args): def do_info(self, args):
""" get info custom captiveflask portals """ """get info custom captiveflask portals"""
if args: if args:
plugin_name = args.split()[0] plugin_name = args.split()[0]
if not plugin_name in self.plugins_remote: if not plugin_name in self.plugins_remote:

View File

View File

@ -1,4 +1,3 @@
#!/usr/bin/python3
from flask import Flask, request, redirect, render_template from flask import Flask, request, redirect, render_template
from urllib.parse import urlencode, unquote from urllib.parse import urlencode, unquote
import os, sys import os, sys
@ -9,6 +8,8 @@ import argparse
# static_folder='templates/flask/static', # static_folder='templates/flask/static',
# template_folder='templates/flask') # template_folder='templates/flask')
app = Flask(__name__) app = Flask(__name__)
REDIRECT = None
FORCE_REDIRECT = None
def login_user(ip): def login_user(ip):
@ -65,20 +66,23 @@ def catch_all(path):
) )
#https://stackoverflow.com/questions/15008758/parsing-boolean-values-with-argparse # https://stackoverflow.com/questions/15008758/parsing-boolean-values-with-argparse
def str2bool(v): def str2bool(v):
if isinstance(v, bool): if isinstance(v, bool):
return v return v
if v.lower() in ('yes', 'true', 't', 'y', '1'): if v.lower() in ("yes", "true", "t", "y", "1"):
return True return True
elif v.lower() in ('no', 'false', 'f', 'n', '0'): elif v.lower() in ("no", "false", "f", "n", "0"):
return False return False
else: else:
raise argparse.ArgumentTypeError('Boolean value expected.') raise argparse.ArgumentTypeError("Boolean value expected.")
_version = "1.0.2" _version = "1.0.2"
if __name__ == "__main__":
def main():
global REDIRECT, FORCE_REDIRECT
print("[*] CaptiveFlask v{} - subtool from wifipumpkin3".format(_version)) print("[*] CaptiveFlask v{} - subtool from wifipumpkin3".format(_version))
parser = argparse.ArgumentParser( parser = argparse.ArgumentParser(
description="CaptiveFlask - \ description="CaptiveFlask - \

View File

@ -1,4 +1,3 @@
#!/usr/bin/python3
"""sslstrip is a MITM tool that implements Moxie Marlinspike's SSL stripping attacks.""" """sslstrip is a MITM tool that implements Moxie Marlinspike's SSL stripping attacks."""
__author__ = "Moxie Marlinspike" __author__ = "Moxie Marlinspike"
@ -134,7 +133,7 @@ def parseOptions(argv):
sys.exit(2) sys.exit(2)
def main(argv): def init(argv):
( (
logFile, logFile,
logLevel, logLevel,
@ -167,5 +166,5 @@ def main(argv):
reactor.run() reactor.run()
if __name__ == "__main__": def main():
main(sys.argv[1:]) init(sys.argv[1:])