mirror of https://github.com/huashengdun/webssh
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
108 lines
2.4 KiB
108 lines
2.4 KiB
jQuery(function($){ |
|
|
|
var status = $('#status'), |
|
btn = $('.btn-primary'); |
|
|
|
$('form#connect').submit(function(event) { |
|
event.preventDefault(); |
|
|
|
var form = $(this), |
|
url = form.attr('action'), |
|
type = form.attr('type'), |
|
data = new FormData(this); |
|
|
|
if (!data.get('hostname') || !data.get('port') || !data.get('username')) { |
|
status.text('Hostname, port and username are required.'); |
|
return; |
|
} |
|
|
|
var pk = data.get('privatekey'); |
|
if (pk && pk.size > 16384) { |
|
status.text('Key size exceeds maximum value.'); |
|
return; |
|
} |
|
|
|
status.text(''); |
|
btn.prop('disabled', true); |
|
|
|
$.ajax({ |
|
url: url, |
|
type: type, |
|
data: data, |
|
success: callback, |
|
cache: false, |
|
contentType: false, |
|
processData: false |
|
}); |
|
|
|
}); |
|
|
|
|
|
function current_geometry() { |
|
cols = parseInt(window.innerWidth / 10); |
|
rows = parseInt(window.innerHeight / 24); |
|
return [cols, rows]; |
|
} |
|
|
|
|
|
function callback(msg) { |
|
// console.log(msg); |
|
if (msg.status) { |
|
status.text(msg.status); |
|
setTimeout(function(){ |
|
btn.prop('disabled', false); |
|
}, 3000); |
|
return; |
|
} |
|
|
|
var ws_url = window.location.href.replace('http', 'ws'), |
|
join = (ws_url[ws_url.length-1] == '/' ? '' : '/'), |
|
url = ws_url + join + 'ws?id=' + msg.id, |
|
socket = new WebSocket(url), |
|
terminal = document.getElementById('#terminal'), |
|
geometry = current_geometry(); |
|
term = new Terminal({ |
|
cursorBlink: true, |
|
cols: geometry[0], |
|
rows: geometry[1] |
|
}); |
|
|
|
console.log(url); |
|
term.on('data', function(data) { |
|
// console.log(data); |
|
socket.send(data); |
|
}); |
|
|
|
socket.onopen = function(e) { |
|
$('.container').hide(); |
|
term.open(terminal, true); |
|
term.toggleFullscreen(true); |
|
}; |
|
|
|
socket.onmessage = function(msg) { |
|
// console.log(msg); |
|
term.write(msg.data); |
|
}; |
|
|
|
socket.onerror = function(e) { |
|
console.log(e); |
|
}; |
|
|
|
socket.onclose = function(e) { |
|
console.log(e); |
|
term.destroy(); |
|
$('.container').show(); |
|
status.text(e.reason); |
|
btn.prop('disabled', false); |
|
}; |
|
} |
|
|
|
$(window).resize(function(){ |
|
if (typeof term != "undefined") { |
|
geometry = current_geometry(); |
|
term.geometry = geometry; |
|
term.resize(geometry[0], geometry[1]); |
|
} |
|
}); |
|
|
|
});
|
|
|