mirror of
https://github.com/Ylianst/MeshCentral.git
synced 2025-01-11 15:03:20 -05:00
Added context menu connection options to xterm.
This commit is contained in:
parent
9d3ac34ef9
commit
195c869ab5
@ -389,7 +389,7 @@
|
|||||||
"default.handlebars->23->597",
|
"default.handlebars->23->597",
|
||||||
"default.handlebars->23->627",
|
"default.handlebars->23->627",
|
||||||
"default.handlebars->23->639",
|
"default.handlebars->23->639",
|
||||||
"xterm.handlebars->3->6"
|
"xterm.handlebars->9->6"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -1863,7 +1863,8 @@
|
|||||||
"nl": "Beheerder PowerShell",
|
"nl": "Beheerder PowerShell",
|
||||||
"ru": "Админ PowerShell",
|
"ru": "Админ PowerShell",
|
||||||
"xloc": [
|
"xloc": [
|
||||||
"default.handlebars->termShellContextMenu->cxtermps"
|
"default.handlebars->termShellContextMenu->cxtermps",
|
||||||
|
"xterm.handlebars->termShellContextMenu->cxtermps"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -1886,7 +1887,8 @@
|
|||||||
"nl": "Beheerder Shell",
|
"nl": "Beheerder Shell",
|
||||||
"ru": "Админ Shell",
|
"ru": "Админ Shell",
|
||||||
"xloc": [
|
"xloc": [
|
||||||
"default.handlebars->termShellContextMenu->cxtermnorm->0"
|
"default.handlebars->termShellContextMenu->cxtermnorm->0",
|
||||||
|
"xterm.handlebars->termShellContextMenu->cxtermnorm->0"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -3998,7 +4000,7 @@
|
|||||||
"xloc": [
|
"xloc": [
|
||||||
"default-mobile.handlebars->9->4",
|
"default-mobile.handlebars->9->4",
|
||||||
"default.handlebars->23->11",
|
"default.handlebars->23->11",
|
||||||
"xterm.handlebars->3->4"
|
"xterm.handlebars->9->4"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -4048,7 +4050,7 @@
|
|||||||
"default.handlebars->23->220",
|
"default.handlebars->23->220",
|
||||||
"default.handlebars->23->678",
|
"default.handlebars->23->678",
|
||||||
"default.handlebars->23->9",
|
"default.handlebars->23->9",
|
||||||
"xterm.handlebars->3->2"
|
"xterm.handlebars->9->2"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -5482,7 +5484,7 @@
|
|||||||
"default.handlebars->container->column_l->p11->deskarea0->deskarea1->3->deskstatus",
|
"default.handlebars->container->column_l->p11->deskarea0->deskarea1->3->deskstatus",
|
||||||
"default.handlebars->container->column_l->p12->termTable->1->1->0->1->3->termstatus",
|
"default.handlebars->container->column_l->p12->termTable->1->1->0->1->3->termstatus",
|
||||||
"default.handlebars->container->column_l->p13->p13toolbar->1->0->1->3->p13Status",
|
"default.handlebars->container->column_l->p13->p13toolbar->1->0->1->3->p13Status",
|
||||||
"xterm.handlebars->3->1"
|
"xterm.handlebars->9->1"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -8154,7 +8156,7 @@
|
|||||||
"xloc": [
|
"xloc": [
|
||||||
"default-mobile.handlebars->9->5",
|
"default-mobile.handlebars->9->5",
|
||||||
"default.handlebars->23->12",
|
"default.handlebars->23->12",
|
||||||
"xterm.handlebars->3->5"
|
"xterm.handlebars->9->5"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -13851,7 +13853,8 @@
|
|||||||
"nl": "Root Shell",
|
"nl": "Root Shell",
|
||||||
"ru": "Root Shell",
|
"ru": "Root Shell",
|
||||||
"xloc": [
|
"xloc": [
|
||||||
"default.handlebars->termShellContextMenuLinux->cxtermnorm->0"
|
"default.handlebars->termShellContextMenuLinux->cxtermnorm->0",
|
||||||
|
"xterm.handlebars->termShellContextMenuLinux->cxtermnorm->0"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -14782,7 +14785,7 @@
|
|||||||
"default.handlebars->23->212",
|
"default.handlebars->23->212",
|
||||||
"default.handlebars->23->215",
|
"default.handlebars->23->215",
|
||||||
"default.handlebars->23->221",
|
"default.handlebars->23->221",
|
||||||
"xterm.handlebars->3->3"
|
"xterm.handlebars->9->3"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -17379,7 +17382,8 @@
|
|||||||
"nl": "Gebruiker PowerShell",
|
"nl": "Gebruiker PowerShell",
|
||||||
"ru": "Пользовательский PowerShell",
|
"ru": "Пользовательский PowerShell",
|
||||||
"xloc": [
|
"xloc": [
|
||||||
"default.handlebars->termShellContextMenu->cxtermups"
|
"default.handlebars->termShellContextMenu->cxtermups",
|
||||||
|
"xterm.handlebars->termShellContextMenu->cxtermups"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -17404,7 +17408,9 @@
|
|||||||
"ru": "Пользовательская оболочка",
|
"ru": "Пользовательская оболочка",
|
||||||
"xloc": [
|
"xloc": [
|
||||||
"default.handlebars->termShellContextMenu->cxtermunorm",
|
"default.handlebars->termShellContextMenu->cxtermunorm",
|
||||||
"default.handlebars->termShellContextMenuLinux->cxtermps"
|
"default.handlebars->termShellContextMenuLinux->cxtermps",
|
||||||
|
"xterm.handlebars->termShellContextMenu->cxtermunorm",
|
||||||
|
"xterm.handlebars->termShellContextMenuLinux->cxtermps"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -5297,7 +5297,7 @@
|
|||||||
var url = '/xterm?nodeid=' + encodeURIComponent(nodeid) + '&auto=1';
|
var url = '/xterm?nodeid=' + encodeURIComponent(nodeid) + '&auto=1';
|
||||||
var node = getNodeFromId(nodeid);
|
var node = getNodeFromId(nodeid);
|
||||||
if (node == null) return;
|
if (node == null) return;
|
||||||
//if ([1, 2, 3, 4, 21, 22].indexOf(node.agent.id) >= 0) { url += '&fixsize=1'; }
|
if ([1, 2, 3, 4, 21, 22].indexOf(node.agent.id) >= 0) { url += '&os=win'; } else { url += '&os=linux'; }
|
||||||
window.open(url, 'xterm:' + nodeid);
|
window.open(url, 'xterm:' + nodeid);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -16,7 +16,18 @@
|
|||||||
<script type="text/javascript" src="scripts/xterm-addon-fit.js"></script>
|
<script type="text/javascript" src="scripts/xterm-addon-fit.js"></script>
|
||||||
<title>{{{name}}}</title>
|
<title>{{{name}}}</title>
|
||||||
</head>
|
</head>
|
||||||
<body style="overflow:hidden;background-color:black">
|
<body style="overflow:hidden;background-color:black" oncontextmenu="handleContextMenu(event)">
|
||||||
|
<!-- right click menu -->
|
||||||
|
<div id="termShellContextMenu" class="contextMenu noselect" style="display:none;min-width:0px">
|
||||||
|
<div id="cxtermnorm" class="cmtext" onclick="cmtermaction(1,event)"><b>Admin Shell</b></div>
|
||||||
|
<div id="cxtermps" class="cmtext" onclick="cmtermaction(6,event)">Admin PowerShell</div>
|
||||||
|
<div id="cxtermunorm" class="cmtext" onclick="cmtermaction(8,event)">User Shell</div>
|
||||||
|
<div id="cxtermups" class="cmtext" onclick="cmtermaction(9,event)">User PowerShell</div>
|
||||||
|
</div>
|
||||||
|
<div id="termShellContextMenuLinux" class="contextMenu noselect" style="display:none;min-width:0px">
|
||||||
|
<div id="cxtermnorm" class="cmtext" onclick="cmtermaction(1,event)"><b>Root Shell</b></div>
|
||||||
|
<div id="cxtermps" class="cmtext" onclick="cmtermaction(8,event)">User Shell</div>
|
||||||
|
</div>
|
||||||
<div id=p11 class="noselect" style="overflow:hidden">
|
<div id=p11 class="noselect" style="overflow:hidden">
|
||||||
<div id=deskarea0 style="position:relative">
|
<div id=deskarea0 style="position:relative">
|
||||||
<div id=deskarea1 class="areaHead">
|
<div id=deskarea1 class="areaHead">
|
||||||
@ -89,9 +100,10 @@
|
|||||||
meshserver.Start();
|
meshserver.Start();
|
||||||
|
|
||||||
// When the user resizes the window, re-fit
|
// When the user resizes the window, re-fit
|
||||||
window.onresize = function () {
|
window.onresize = function () { if (termfit != null) { termfit.fit(); } }
|
||||||
if (termfit != null) { termfit.fit(); }
|
|
||||||
}
|
// Hide the context menu
|
||||||
|
document.onclick = function (e) { hideContextMenu(); }
|
||||||
|
|
||||||
// Update the terminal status and buttons
|
// Update the terminal status and buttons
|
||||||
QH('termstatus', StatusStrs[0]);
|
QH('termstatus', StatusStrs[0]);
|
||||||
@ -117,8 +129,9 @@
|
|||||||
function onMessage(server, message) { }
|
function onMessage(server, message) { }
|
||||||
|
|
||||||
// Handles a tunnel to a remote shell
|
// Handles a tunnel to a remote shell
|
||||||
function CreateRemoteTunnel(onTunnelUpdate) {
|
function CreateRemoteTunnel(onTunnelUpdate, options) {
|
||||||
var obj = { protocol: 1 };
|
var obj = { protocol: 1 };
|
||||||
|
if ((options != null) && (typeof options.protocol == 'number')) { obj.protocol = options.protocol; }
|
||||||
obj.onTunnelUpdate = onTunnelUpdate;
|
obj.onTunnelUpdate = onTunnelUpdate;
|
||||||
obj.xxStateChange = function (state) { }
|
obj.xxStateChange = function (state) { }
|
||||||
obj.ProcessBinaryData = function (data) { obj.onTunnelUpdate(data); }
|
obj.ProcessBinaryData = function (data) { obj.onTunnelUpdate(data); }
|
||||||
@ -133,7 +146,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Called when the connect/disconnect button is pressed
|
// Called when the connect/disconnect button is pressed
|
||||||
function connectButton() {
|
function connectButton(options) {
|
||||||
if (!tunnel) {
|
if (!tunnel) {
|
||||||
// Setup the terminal with auto-fit
|
// Setup the terminal with auto-fit
|
||||||
if (term != null) { term.dispose(); }
|
if (term != null) { term.dispose(); }
|
||||||
@ -150,7 +163,7 @@
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Setup a terminal tunnel to the agent
|
// Setup a terminal tunnel to the agent
|
||||||
tunnel = CreateAgentRedirect(meshserver, CreateRemoteTunnel(tunnelUpdate), serverPublicNamePort, authCookie, authRelayCookie, domainUrl);
|
tunnel = CreateAgentRedirect(meshserver, CreateRemoteTunnel(tunnelUpdate, options), serverPublicNamePort, authCookie, authRelayCookie, domainUrl);
|
||||||
tunnel.options = { cols: term.cols, rows: term.rows };
|
tunnel.options = { cols: term.cols, rows: term.rows };
|
||||||
tunnel.Start(args.nodeid);
|
tunnel.Start(args.nodeid);
|
||||||
tunnel.onStateChanged = onTunnelStateChange;
|
tunnel.onStateChanged = onTunnelStateChange;
|
||||||
@ -197,6 +210,52 @@
|
|||||||
function clearConsoleMsg() { QV('TermConsoleMsg', false); if (termConsoleMsgTimer) { clearTimeout(termConsoleMsgTimer); termConsoleMsgTimer = null; } }
|
function clearConsoleMsg() { QV('TermConsoleMsg', false); if (termConsoleMsgTimer) { clearTimeout(termConsoleMsgTimer); termConsoleMsgTimer = null; } }
|
||||||
function setConsoleMsg(msg) { QH('TermConsoleMsg', EscapeHtml(msg).split('\n').join('<br />')); QV('TermConsoleMsg', true); termConsoleMsgTimer = setTimeout(clearConsoleMsg, 8000); }
|
function setConsoleMsg(msg) { QH('TermConsoleMsg', EscapeHtml(msg).split('\n').join('<br />')); QV('TermConsoleMsg', true); termConsoleMsgTimer = setTimeout(clearConsoleMsg, 8000); }
|
||||||
|
|
||||||
|
//
|
||||||
|
// CONTEXT MENU
|
||||||
|
//
|
||||||
|
|
||||||
|
var contextelement = null;
|
||||||
|
function handleContextMenu(event) {
|
||||||
|
hideContextMenu();
|
||||||
|
var scrollLeft = (window.pageXOffset !== null) ? window.pageXOffset : (document.documentElement || document.body.parentNode || document.body).scrollLeft;
|
||||||
|
var scrollTop = (window.pageYOffset !== null) ? window.pageYOffset : (document.documentElement || document.body.parentNode || document.body).scrollTop;
|
||||||
|
var elem = document.elementFromPoint(event.pageX - scrollLeft, event.pageY - scrollTop);
|
||||||
|
if (elem && elem != null && elem.id == 'ConnectButton') {
|
||||||
|
contextelement = elem;
|
||||||
|
var contextmenudiv;
|
||||||
|
if (args.os == 'win') {
|
||||||
|
contextmenudiv = document.getElementById('termShellContextMenu');
|
||||||
|
} else {
|
||||||
|
contextmenudiv = document.getElementById('termShellContextMenuLinux');
|
||||||
|
}
|
||||||
|
showContextMenuDiv(contextmenudiv, event.pageX, event.pageY);
|
||||||
|
}
|
||||||
|
return haltEvent(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
function showContextMenuDiv(element, x, y) {
|
||||||
|
var clientRect = document.documentElement.getBoundingClientRect();
|
||||||
|
var docHeight = clientRect.height;
|
||||||
|
var docWidth = clientRect.width;
|
||||||
|
element.style.left = element.style.right = element.style.top = element.style.bottom = null;
|
||||||
|
if (x > (docWidth / 2)) { element.style.right = (docWidth - event.pageX) + 'px'; } else { element.style.left = event.pageX + 'px'; }
|
||||||
|
if (y > (docHeight / 2)) { element.style.bottom = (docHeight - event.pageY) + 'px'; } else { element.style.top = event.pageY + 'px'; }
|
||||||
|
element.style.display = 'block';
|
||||||
|
}
|
||||||
|
|
||||||
|
function cmtermaction(action) {
|
||||||
|
//console.log('cmtermaction', action);
|
||||||
|
connectButton({ protocol: action })
|
||||||
|
//connectTerminal(null, 1, { protocol: action });
|
||||||
|
}
|
||||||
|
|
||||||
|
function hideContextMenu() {
|
||||||
|
QV('contextMenu', false);
|
||||||
|
QV('termShellContextMenu', false);
|
||||||
|
QV('termShellContextMenuLinux', false);
|
||||||
|
contextelement = null;
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// POPUP DIALOG
|
// POPUP DIALOG
|
||||||
//
|
//
|
||||||
|
Loading…
Reference in New Issue
Block a user