Terminal SSH improvements.

This commit is contained in:
Ylian Saint-Hilaire 2021-05-08 19:11:15 -07:00
parent e5579e7b84
commit 33364c4f4c

View File

@ -5270,7 +5270,7 @@
switch (cmenu) { switch (cmenu) {
case 'termConnectButton': { case 'termConnectButton': {
// Terminal connect button context menu // Terminal connect button context menu
if ((currentNode == null) || (currentNode.agent == null)) return true; if ((currentNode == null) || (currentNode.agent == null) || (currentNode.mtype == 3)) return true;
// If the server has a specific terminal shell mode, don't show connection options // If the server has a specific terminal shell mode, don't show connection options
if (serverinfo.linuxshell && (currentNode.agent.id > 4)) return; if (serverinfo.linuxshell && (currentNode.agent.id > 4)) return;
@ -8662,7 +8662,7 @@
var x = ''; var x = '';
x += addHtmlValue("Username", '<input id=dp2user style=width:230px maxlength=64 autocomplete=off onkeyup=sshAuthKeyUp(event) />'); x += addHtmlValue("Username", '<input id=dp2user style=width:230px maxlength=64 autocomplete=off onkeyup=sshAuthKeyUp(event) />');
x += addHtmlValue("Password", '<input type=password id=dp2pass style=width:230px maxlength=64 autocomplete=off onkeyup=sshAuthKeyUp(event) />'); x += addHtmlValue("Password", '<input type=password id=dp2pass style=width:230px maxlength=64 autocomplete=off onkeyup=sshAuthKeyUp(event) />');
setDialogMode(2, "Authentication", 3, sshConnectEx, x); setDialogMode(2, "Authentication", 11, sshConnectEx, x, 'ssh');
setTimeout(sshAuthKeyUp, 50); setTimeout(sshAuthKeyUp, 50);
} }
} }
@ -8671,7 +8671,13 @@
} }
function sshAuthKeyUp(e) { QE('idx_dlgOkButton', (Q('dp2user').value.length > 0) && (Q('dp2pass').value.length > 0)); } function sshAuthKeyUp(e) { QE('idx_dlgOkButton', (Q('dp2user').value.length > 0) && (Q('dp2pass').value.length > 0)); }
function sshConnectEx() { terminal.socket.send(JSON.stringify({ action: 'sshauth', username: Q('dp2user').value, password: Q('dp2pass').value, cols: xterm.cols, rows: xterm.rows, width: Q('termarea3xdiv').offsetWidth, height: Q('termarea3xdiv').offsetHeight })); } function sshConnectEx(b) {
if (b == 0) {
if (terminal != null) { connectTerminal(); } // Disconnect
} else {
terminal.socket.send(JSON.stringify({ action: 'sshauth', username: Q('dp2user').value, password: Q('dp2pass').value, cols: xterm.cols, rows: xterm.rows, width: Q('termarea3xdiv').offsetWidth, height: Q('termarea3xdiv').offsetHeight }));
}
}
// Send the new terminal size to the agent // Send the new terminal size to the agent
function xTermSendResize() { function xTermSendResize() {
@ -8814,6 +8820,7 @@
} }
} else { } else {
//QH('Term', ''); //QH('Term', '');
if (xxdialogTag == 'ssh') { setDialogMode(0); }
terminal.Stop(); terminal.Stop();
terminal = null; terminal = null;
if (fullscreen) { deskToggleFull(); } if (fullscreen) { deskToggleFull(); }