mirror of
https://github.com/Ylianst/MeshCentral.git
synced 2025-01-08 23:21:11 +03:00
Improved MSTSC.js support.
This commit is contained in:
parent
14c08ce461
commit
61582dbd17
@ -121,8 +121,7 @@
|
|||||||
<Compile Include="mqttbroker.js" />
|
<Compile Include="mqttbroker.js" />
|
||||||
<Compile Include="mstsc.js" />
|
<Compile Include="mstsc.js" />
|
||||||
<Compile Include="pluginHandler.js" />
|
<Compile Include="pluginHandler.js" />
|
||||||
<Compile Include="public\mstsc\js\canvas.js" />
|
<Compile Include="public\mstsc\client.js" />
|
||||||
<Compile Include="public\mstsc\js\client.js" />
|
|
||||||
<Compile Include="public\mstsc\js\keyboard.js" />
|
<Compile Include="public\mstsc\js\keyboard.js" />
|
||||||
<Compile Include="public\mstsc\js\mstsc.js" />
|
<Compile Include="public\mstsc\js\mstsc.js" />
|
||||||
<Compile Include="public\mstsc\js\rle.js" />
|
<Compile Include="public\mstsc\js\rle.js" />
|
||||||
@ -462,7 +461,6 @@
|
|||||||
<Content Include="public\images\mapmarker.png" />
|
<Content Include="public\images\mapmarker.png" />
|
||||||
<Content Include="public\images\meshicon50.png" />
|
<Content Include="public\images\meshicon50.png" />
|
||||||
<Content Include="public\images\trash.png" />
|
<Content Include="public\images\trash.png" />
|
||||||
<Content Include="public\mstsc\css\bootstrap.min.css" />
|
|
||||||
<Content Include="public\mstsc\css\signin.css" />
|
<Content Include="public\mstsc\css\signin.css" />
|
||||||
<Content Include="public\mstsc\index.html" />
|
<Content Include="public\mstsc\index.html" />
|
||||||
<Content Include="public\mstsc\keymap.html" />
|
<Content Include="public\mstsc\keymap.html" />
|
||||||
|
36
mstsc.js
36
mstsc.js
@ -58,8 +58,14 @@ module.exports.CreateMstscRelay = function (parent, db, ws, req, args, domain, u
|
|||||||
obj.relaySocket.on('end', function () { obj.close(0); });
|
obj.relaySocket.on('end', function () { obj.close(0); });
|
||||||
obj.relaySocket.on('error', function (err) { obj.close(0); });
|
obj.relaySocket.on('error', function (err) { obj.close(0); });
|
||||||
|
|
||||||
// TODO: Use correct URL with domain and use TLS only if needed.
|
// Setup the correct URL with domain and use TLS only if needed.
|
||||||
obj.wsClient = new WebSocket('wss://127.0.0.1/meshrelay.ashx?auth=' + obj.infos.ip, { rejectUnauthorized: false });
|
var options = { rejectUnauthorized: false };
|
||||||
|
if (domain.dns != null) { options.servername = domain.dns; }
|
||||||
|
var protocol = 'wss';
|
||||||
|
if (args.notls || args.tlsoffload) { protocol = 'ws'; }
|
||||||
|
var domainadd = '';
|
||||||
|
if ((domain.dns == null) && (domain.id != '')) { domainadd = domain.id + '/' }
|
||||||
|
obj.wsClient = new WebSocket(protocol + '://127.0.0.1/' + domainadd + 'meshrelay.ashx?auth=' + obj.infos.ip, options);
|
||||||
|
|
||||||
obj.wsClient.on('open', function () { });
|
obj.wsClient.on('open', function () { });
|
||||||
obj.wsClient.on('message', function (data) { if ((obj.relayActive == false) && (data == 'c')) { obj.relayActive = true; obj.relaySocket.resume(); } else { obj.relaySocket.write(data); } });
|
obj.wsClient.on('message', function (data) { if ((obj.relayActive == false) && (data == 'c')) { obj.relayActive = true; obj.relaySocket.resume(); } else { obj.relaySocket.write(data); } });
|
||||||
@ -72,6 +78,7 @@ module.exports.CreateMstscRelay = function (parent, db, ws, req, args, domain, u
|
|||||||
|
|
||||||
// Start the RDP client
|
// Start the RDP client
|
||||||
function startRdp(port) {
|
function startRdp(port) {
|
||||||
|
try {
|
||||||
rdpClient = require('node-rdpjs-2').createClient({
|
rdpClient = require('node-rdpjs-2').createClient({
|
||||||
logLevel: 'ERROR',
|
logLevel: 'ERROR',
|
||||||
domain: obj.infos.domain,
|
domain: obj.infos.domain,
|
||||||
@ -92,19 +99,28 @@ module.exports.CreateMstscRelay = function (parent, db, ws, req, args, domain, u
|
|||||||
}).on('error', function (err) {
|
}).on('error', function (err) {
|
||||||
send(['rdp-error', err]);
|
send(['rdp-error', err]);
|
||||||
}).connect('127.0.0.1', obj.tcpServerPort);
|
}).connect('127.0.0.1', obj.tcpServerPort);
|
||||||
|
} catch (ex) {
|
||||||
|
console.log('startRdpException', ex);
|
||||||
|
obj.close(0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// When data is received from the web socket
|
// When data is received from the web socket
|
||||||
// RDP default port is 3389
|
// RDP default port is 3389
|
||||||
ws.on('message', function (msg) {
|
ws.on('message', function (msg) {
|
||||||
msg = JSON.parse(msg);
|
try {
|
||||||
switch (msg[0]) {
|
msg = JSON.parse(msg);
|
||||||
case 'infos': { obj.infos = msg[1]; startTcpServer(); break; }
|
switch (msg[0]) {
|
||||||
case 'mouse': { if (rdpClient) { rdpClient.sendPointerEvent(msg[1], msg[2], msg[3], msg[4]); } break; }
|
case 'infos': { obj.infos = msg[1]; startTcpServer(); break; }
|
||||||
case 'wheel': { if (rdpClient) { rdpClient.sendWheelEvent(msg[1], msg[2], msg[3], msg[4]); } break; }
|
case 'mouse': { if (rdpClient) { rdpClient.sendPointerEvent(msg[1], msg[2], msg[3], msg[4]); } break; }
|
||||||
case 'scancode': { if (rdpClient) { rdpClient.sendKeyEventScancode(msg[1], msg[2]); } break; }
|
case 'wheel': { if (rdpClient) { rdpClient.sendWheelEvent(msg[1], msg[2], msg[3], msg[4]); } break; }
|
||||||
case 'unicode': { if (rdpClient) { rdpClient.sendKeyEventUnicode(msg[1], msg[2]); } break; }
|
case 'scancode': { if (rdpClient) { rdpClient.sendKeyEventScancode(msg[1], msg[2]); } break; }
|
||||||
case 'disconnect': { obj.close(0); break; }
|
case 'unicode': { if (rdpClient) { rdpClient.sendKeyEventUnicode(msg[1], msg[2]); } break; }
|
||||||
|
case 'disconnect': { obj.close(0); break; }
|
||||||
|
}
|
||||||
|
} catch (ex) {
|
||||||
|
console.log('RdpMessageException', msg, ex);
|
||||||
|
obj.close(0);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -47,36 +47,34 @@
|
|||||||
|
|
||||||
Client.prototype = {
|
Client.prototype = {
|
||||||
install : function () {
|
install : function () {
|
||||||
var self = this;
|
var self = this;
|
||||||
|
|
||||||
// Bind mouse move event
|
// Bind mouse move event
|
||||||
this.canvas.addEventListener('mousemove', function (e) {
|
this.canvas.addEventListener('mousemove', function (e) {
|
||||||
if (!self.socket || !self.activeSession) return;
|
if (!self.socket || !self.activeSession) return;
|
||||||
var offset = Mstsc.elementOffset(self.canvas);
|
var rect = e.target.getBoundingClientRect();
|
||||||
self.socket.send(JSON.stringify(['mouse', e.clientX - offset.left, e.clientY - offset.top, 0, false]));
|
self.socket.send(JSON.stringify(['mouse', e.clientX - rect.left, e.clientY - rect.top, 0, false]));
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
this.canvas.addEventListener('mousedown', function (e) {
|
this.canvas.addEventListener('mousedown', function (e) {
|
||||||
if (!self.socket || !self.activeSession) return;
|
if (!self.socket || !self.activeSession) return;
|
||||||
|
var rect = e.target.getBoundingClientRect();
|
||||||
var offset = Mstsc.elementOffset(self.canvas);
|
self.socket.send(JSON.stringify(['mouse', e.clientX - rect.left, e.clientY - rect.top, mouseButtonMap(e.button), true]));
|
||||||
self.socket.send(JSON.stringify(['mouse', e.clientX - offset.left, e.clientY - offset.top, mouseButtonMap(e.button), true]));
|
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
this.canvas.addEventListener('mouseup', function (e) {
|
this.canvas.addEventListener('mouseup', function (e) {
|
||||||
if (!self.socket || !self.activeSession) return;
|
if (!self.socket || !self.activeSession) return;
|
||||||
|
var rect = e.target.getBoundingClientRect();
|
||||||
var offset = Mstsc.elementOffset(self.canvas);
|
self.socket.send(JSON.stringify(['mouse', e.clientX - rect.left, e.clientY - rect.top, mouseButtonMap(e.button), false]));
|
||||||
self.socket.send(JSON.stringify(['mouse', e.clientX - offset.left, e.clientY - offset.top, mouseButtonMap(e.button), false]));
|
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
this.canvas.addEventListener('contextmenu', function (e) {
|
this.canvas.addEventListener('contextmenu', function (e) {
|
||||||
if (!self.socket || !self.activeSession) return;
|
if (!self.socket || !self.activeSession) return;
|
||||||
var offset = Mstsc.elementOffset(self.canvas);
|
var rect = e.target.getBoundingClientRect();
|
||||||
self.socket.send(JSON.stringify(['mouse', e.clientX - offset.left, e.clientY - offset.top, mouseButtonMap(e.button), false]));
|
self.socket.send(JSON.stringify(['mouse', e.clientX - rect.left, e.clientY - rect.top, mouseButtonMap(e.button), false]));
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
@ -85,8 +83,8 @@
|
|||||||
var isHorizontal = false;
|
var isHorizontal = false;
|
||||||
var delta = e.detail;
|
var delta = e.detail;
|
||||||
var step = Math.round(Math.abs(delta) * 15 / 8);
|
var step = Math.round(Math.abs(delta) * 15 / 8);
|
||||||
var offset = Mstsc.elementOffset(self.canvas);
|
var rect = e.target.getBoundingClientRect();
|
||||||
self.socket.send(JSON.stringify(['wheel', e.clientX - offset.left, e.clientY - offset.top, step, delta > 0, isHorizontal]));
|
self.socket.send(JSON.stringify(['wheel', e.clientX - rect.left, e.clientY - rect.top, step, delta > 0, isHorizontal]));
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
@ -95,8 +93,8 @@
|
|||||||
var isHorizontal = Math.abs(e.deltaX) > Math.abs(e.deltaY);
|
var isHorizontal = Math.abs(e.deltaX) > Math.abs(e.deltaY);
|
||||||
var delta = isHorizontal?e.deltaX:e.deltaY;
|
var delta = isHorizontal?e.deltaX:e.deltaY;
|
||||||
var step = Math.round(Math.abs(delta) * 15 / 8);
|
var step = Math.round(Math.abs(delta) * 15 / 8);
|
||||||
var offset = Mstsc.elementOffset(self.canvas);
|
var rect = e.target.getBoundingClientRect();
|
||||||
self.socket.send(JSON.stringify(['wheel', e.clientX - offset.left, e.clientY - offset.top, step, delta > 0, isHorizontal]));
|
self.socket.send(JSON.stringify(['wheel', e.clientX - rect.left, e.clientY - rect.top, step, delta > 0, isHorizontal]));
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
@ -126,12 +124,12 @@
|
|||||||
* @param next {function} asynchrone end callback
|
* @param next {function} asynchrone end callback
|
||||||
*/
|
*/
|
||||||
connect : function (ip, domain, username, password, next) {
|
connect : function (ip, domain, username, password, next) {
|
||||||
// start connection
|
// Start connection
|
||||||
var self = this;
|
var self = this;
|
||||||
this.socket = new WebSocket("wss://" + window.location.host + "/mstsc/relay.ashx");
|
this.socket = new WebSocket("wss://" + window.location.host + "/mstsc/relay.ashx");
|
||||||
this.socket.binaryType = 'arraybuffer';
|
this.socket.binaryType = 'arraybuffer';
|
||||||
this.socket.onopen = function () {
|
this.socket.onopen = function () {
|
||||||
console.log("WS-OPEN");
|
//console.log("WS-OPEN");
|
||||||
self.socket.send(JSON.stringify(['infos', {
|
self.socket.send(JSON.stringify(['infos', {
|
||||||
ip: ip,
|
ip: ip,
|
||||||
port: 3389,
|
port: 3389,
|
||||||
@ -184,12 +182,12 @@
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
this.socket.onclose = function () {
|
this.socket.onclose = function () {
|
||||||
console.log("WS-CLOSE");
|
//console.log("WS-CLOSE");
|
||||||
self.activeSession = false;
|
self.activeSession = false;
|
||||||
next(null);
|
next(null);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Mstsc.client = { create : function (canvas) { return new Client(canvas); } }
|
MstscClient = { create : function (canvas) { return new Client(canvas); } }
|
||||||
})();
|
})();
|
7271
public/mstsc/css/bootstrap.min.css
vendored
7271
public/mstsc/css/bootstrap.min.css
vendored
File diff suppressed because it is too large
Load Diff
@ -1,46 +0,0 @@
|
|||||||
body {
|
|
||||||
overflow:hidden;
|
|
||||||
}
|
|
||||||
|
|
||||||
.form-signin {
|
|
||||||
max-width: 330px;
|
|
||||||
padding: 15px;
|
|
||||||
margin: 0 auto;
|
|
||||||
}
|
|
||||||
.form-signin .form-signin-heading,
|
|
||||||
.form-signin .checkbox {
|
|
||||||
margin-bottom: 10px;
|
|
||||||
}
|
|
||||||
.form-signin .checkbox {
|
|
||||||
font-weight: normal;
|
|
||||||
}
|
|
||||||
.form-signin .form-control {
|
|
||||||
position: relative;
|
|
||||||
height: auto;
|
|
||||||
-webkit-box-sizing: border-box;
|
|
||||||
-moz-box-sizing: border-box;
|
|
||||||
box-sizing: border-box;
|
|
||||||
padding: 10px;
|
|
||||||
font-size: 16px;
|
|
||||||
}
|
|
||||||
.form-signin .form-control:focus {
|
|
||||||
z-index: 2;
|
|
||||||
}
|
|
||||||
.form-signin input[type="text"] {
|
|
||||||
margin-bottom: -1px;
|
|
||||||
border-bottom-right-radius: 0;
|
|
||||||
border-bottom-left-radius: 0;
|
|
||||||
}
|
|
||||||
.form-signin input[type="password"] {
|
|
||||||
margin-bottom: 10px;
|
|
||||||
border-top-left-radius: 0;
|
|
||||||
border-top-right-radius: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.logo {
|
|
||||||
width : 200px;
|
|
||||||
margin-left : auto;
|
|
||||||
margin-right : auto;
|
|
||||||
display : block;
|
|
||||||
margin-bottom: 10px;
|
|
||||||
}
|
|
@ -4,62 +4,131 @@
|
|||||||
<meta charset="utf-8">
|
<meta charset="utf-8">
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
<!-- The above 3 meta tags *must* come first in the head; any other head content must come *after* these tags -->
|
|
||||||
<meta name="description" content="">
|
|
||||||
<meta name="author" content="">
|
|
||||||
<link rel="icon" href="/favicon.ico">
|
<link rel="icon" href="/favicon.ico">
|
||||||
<title>RDP</title>
|
<title>RDP</title>
|
||||||
<!-- Bootstrap core CSS -->
|
<script type="text/javascript" src="mstsc.js"></script>
|
||||||
<link href="./css/bootstrap.min.css" rel="stylesheet">
|
<script type="text/javascript" src="keyboard.js"></script>
|
||||||
<!-- Custom styles for this template -->
|
<script type="text/javascript" src="rle.js"></script>
|
||||||
<link href="./css/signin.css" rel="stylesheet">
|
<script type="text/javascript" src="client.js"></script>
|
||||||
<script type="text/javascript" src="./js/mstsc.js"></script>
|
<script type="text/javascript" src="canvas.js"></script>
|
||||||
<script type="text/javascript" src="./js/mstsc.js"></script>
|
<style>
|
||||||
<script type="text/javascript" src="./js/keyboard.js"></script>
|
body {
|
||||||
<script type="text/javascript" src="./js/rle.js"></script>
|
font-family:sans-serif;
|
||||||
<script type="text/javascript" src="./js/client.js"></script>
|
margin: 0;
|
||||||
<script type="text/javascript" src="./js/canvas.js"></script>
|
xoverflow: hidden;
|
||||||
|
background-color: black;
|
||||||
|
}
|
||||||
|
|
||||||
|
.container {
|
||||||
|
background-color:cadetblue;
|
||||||
|
background: linear-gradient(to bottom right, #003366, #0055AA);
|
||||||
|
}
|
||||||
|
|
||||||
|
.middleContainer {
|
||||||
|
color: lightgray;
|
||||||
|
position: absolute;
|
||||||
|
top: 50%;
|
||||||
|
left: 50%;
|
||||||
|
-moz-transform: translateX(-50%) translateY(-50%);
|
||||||
|
-webkit-transform: translateX(-50%) translateY(-50%);
|
||||||
|
transform: translateX(-50%) translateY(-50%);
|
||||||
|
}
|
||||||
|
|
||||||
|
.signinform {
|
||||||
|
width: 330px;
|
||||||
|
margin: 0 auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.formLabel { }
|
||||||
|
|
||||||
|
.formControl {
|
||||||
|
width: 210px;
|
||||||
|
font-size: 17px;
|
||||||
|
border-radius: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.connectButton {
|
||||||
|
margin-top: 6px;
|
||||||
|
width: 100%;
|
||||||
|
padding: 6px;
|
||||||
|
font-size: 16px;
|
||||||
|
border-radius: 5px;
|
||||||
|
cursor:pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mainCanvas {
|
||||||
|
position: absolute;
|
||||||
|
top: 50%;
|
||||||
|
left: 50%;
|
||||||
|
-moz-transform: translateX(-50%) translateY(-50%);
|
||||||
|
-webkit-transform: translateX(-50%) translateY(-50%);
|
||||||
|
transform: translateX(-50%) translateY(-50%);
|
||||||
|
}
|
||||||
|
</style>
|
||||||
<script language="javascript">
|
<script language="javascript">
|
||||||
var client = null;
|
var client = null;
|
||||||
|
var canvas = null;
|
||||||
var urlargs = parseUriArgs();
|
var urlargs = parseUriArgs();
|
||||||
if (urlargs.name) { document.title = urlargs.name + ' - ' + document.title; }
|
if (urlargs.name) { document.title = urlargs.name + ' - ' + document.title; }
|
||||||
console.log(urlargs.ws);
|
|
||||||
|
|
||||||
function load(canvas) {
|
function load() {
|
||||||
client = Mstsc.client.create(Mstsc.$(canvas));
|
if (urlargs.name) { QH('computerName', urlargs.name); }
|
||||||
|
client = MstscClient.create(Q('myCanvas'));
|
||||||
|
Q('inputDomain').focus();
|
||||||
|
canvas = Q('myCanvas');
|
||||||
}
|
}
|
||||||
|
|
||||||
function connect(domain, username, password) {
|
function connect(domain, username, password) {
|
||||||
Mstsc.$("main").style.display = 'none';
|
var domain = Q('inputDomain').value;
|
||||||
var canvas = Mstsc.$("myCanvas");
|
var username = Q('inputUsername').value;
|
||||||
canvas.style.display = 'inline';
|
var password = Q('inputPassword').value;
|
||||||
|
QV('myCanvas', true);
|
||||||
|
QV('main', false);
|
||||||
canvas.width = window.innerWidth;
|
canvas.width = window.innerWidth;
|
||||||
canvas.height = window.innerHeight;
|
canvas.height = window.innerHeight;
|
||||||
client.connect(urlargs.ws, domain, username, password, function (err) {
|
console.log('CanvasSize', canvas.width, canvas.height);
|
||||||
Mstsc.$("myCanvas").style.display = 'none';
|
client.connect(urlargs.ws, domain, username, password, function (err) { QV('myCanvas', false); QV('main', true); });
|
||||||
Mstsc.$("main").style.display = 'inline';
|
return false;
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function Q(x) { return document.getElementById(x); } // "Q"
|
||||||
|
function QS(x) { try { return Q(x).style; } catch (x) { } } // "Q" style
|
||||||
|
function QE(x, y) { try { Q(x).disabled = !y; } catch (x) { } } // "Q" enable
|
||||||
|
function QV(x, y) { try { QS(x).display = (y ? '' : 'none'); } catch (x) { } } // "Q" visible
|
||||||
|
function QA(x, y) { Q(x).innerHTML += y; } // "Q" append
|
||||||
|
function QH(x, y) { Q(x).innerHTML = y; } // "Q" html
|
||||||
|
function QC(x) { try { return Q(x).classList; } catch (x) { } } // "Q" class
|
||||||
function parseUriArgs() { var href = window.document.location.href; if (href.endsWith('#')) { href = href.substring(0, href.length - 1); } var name, r = {}, parsedUri = href.split(/[\?&|\=]/); parsedUri.splice(0, 1); for (x in parsedUri) { switch (x % 2) { case 0: { name = decodeURIComponent(parsedUri[x]); break; } case 1: { r[name] = decodeURIComponent(parsedUri[x]); var x = parseInt(r[name]); if (x == r[name]) { r[name] = x; } break; } default: { break; } } } return r; }
|
function parseUriArgs() { var href = window.document.location.href; if (href.endsWith('#')) { href = href.substring(0, href.length - 1); } var name, r = {}, parsedUri = href.split(/[\?&|\=]/); parsedUri.splice(0, 1); for (x in parsedUri) { switch (x % 2) { case 0: { name = decodeURIComponent(parsedUri[x]); break; } case 1: { r[name] = decodeURIComponent(parsedUri[x]); var x = parseInt(r[name]); if (x == r[name]) { r[name] = x; } break; } default: { break; } } } return r; }
|
||||||
|
function EscapeHtml(x) { if (typeof x == 'string') return x.replace(/&/g, '&').replace(/>/g, '>').replace(/</g, '<').replace(/"/g, '"').replace(/'/g, '''); if (typeof x == 'boolean') return x; if (typeof x == 'number') return x; }
|
||||||
|
function EscapeHtmlBreaks(x) { if (typeof x == 'string') return x.replace(/&/g, '&').replace(/>/g, '>').replace(/</g, '<').replace(/"/g, '"').replace(/'/g, ''').replace(/\r/g, '<br />').replace(/\n/g, '').replace(/\t/g, ' '); if (typeof x == 'boolean') return x; if (typeof x == 'number') return x; }
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body onload='load("myCanvas")'>
|
<body onload='load()' style="position:absolute;top:0px;right:0;left:0;bottom:0px">
|
||||||
<div id="main" class="container">
|
<div id="main" class="container" style="position:absolute;top:0px;right:0;left:0;bottom:0px">
|
||||||
<form class="form-signin" onSubmit="connect(this.elements['inputDomain'].value, this.elements['inputUsername'].value, this.elements['inputPassword'].value);return false;">
|
<div class="middleContainer">
|
||||||
<!--<img class='logo' src="./img/mstsc.js.svg"></img>-->
|
<div id="computerName" style="width:100%;text-align:center;font-size:24px"></div>
|
||||||
<!--<label for="inputIpAddress" class="sr-only">IP Address</label>-->
|
<table class="signinform">
|
||||||
<!--<input type="text" id="inputIpAddress" class="form-control" placeholder="IP Address" required autofocus>-->
|
<tr>
|
||||||
<label for="inputDomain" class="sr-only">Domain</label>
|
<td colspan="2"><hr style="color:gray;border:1px solid;" /></td>
|
||||||
<input type="text" id="inputDomain" class="form-control" placeholder="Domain">
|
</tr>
|
||||||
<label for="inputUsername" class="sr-only">Username</label>
|
<tr>
|
||||||
<input type="text" id="inputUsername" class="form-control" placeholder="Username">
|
<td><label for="inputDomain" class="formLabel">Domain</label></td>
|
||||||
<label for="inputPassword" class="sr-only">Password</label>
|
<td style="text-align:right"><input type="text" id="inputDomain" class="formControl" placeholder="Domain"></td>
|
||||||
<input type="password" id="inputPassword" class="form-control" placeholder="Password">
|
</tr>
|
||||||
|
<tr>
|
||||||
<button class="btn btn-lg btn-primary btn-block" type="submit" style="background-color: #34A6FF; border-color: #34A6FF">Connect</button>
|
<td><label for="inputUsername" class="formLabel">Username</label></td>
|
||||||
</form>
|
<td style="text-align:right"><input type="text" id="inputUsername" class="formControl" placeholder="Username"></td>
|
||||||
</div> <!-- /container -->
|
</tr>
|
||||||
<canvas id="myCanvas" style="display:none">
|
<tr>
|
||||||
|
<td><label for="inputPassword" class="formLabel">Password</label></td>
|
||||||
|
<td style="text-align:right"><input type="password" id="inputPassword" class="formControl" placeholder="Password"></td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td colspan="2"><button class="connectButton" onclick="return connect()">Connect</button></td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<canvas id="myCanvas" class="mainCanvas" style="display:none" />
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
2
public/scripts/amt-wsman-0.2.0-min.js
vendored
2
public/scripts/amt-wsman-0.2.0-min.js
vendored
File diff suppressed because one or more lines are too long
@ -14923,10 +14923,7 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"en": "Launch RDP session to this device",
|
"en": "Launch RDP session to this device"
|
||||||
"xloc": [
|
|
||||||
"default.handlebars->27->568"
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"en": "Launch noVNC session to this device",
|
"en": "Launch noVNC session to this device",
|
||||||
@ -14935,6 +14932,12 @@
|
|||||||
"default.handlebars->27->566"
|
"default.handlebars->27->566"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"en": "Launch web-based RDP session to this device",
|
||||||
|
"xloc": [
|
||||||
|
"default.handlebars->27->568"
|
||||||
|
]
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"en": "Leave blank for none.",
|
"en": "Leave blank for none.",
|
||||||
"es": "Deje en blanco para ninguno.",
|
"es": "Deje en blanco para ninguno.",
|
||||||
@ -16010,10 +16013,7 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"en": "MSTSC",
|
"en": "MSTSC"
|
||||||
"xloc": [
|
|
||||||
"default.handlebars->27->569"
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"cs": "macOS",
|
"cs": "macOS",
|
||||||
@ -28634,6 +28634,12 @@
|
|||||||
"default.handlebars->27->1795"
|
"default.handlebars->27->1795"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"en": "Web-RDP",
|
||||||
|
"xloc": [
|
||||||
|
"default.handlebars->27->569"
|
||||||
|
]
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"cs": "Vítejte",
|
"cs": "Vítejte",
|
||||||
"de": "Willkommen",
|
"de": "Willkommen",
|
||||||
|
@ -2202,7 +2202,6 @@
|
|||||||
var newWindow = window.open(vncurl, 'mcnovnc/' + message.nodeid);
|
var newWindow = window.open(vncurl, 'mcnovnc/' + message.nodeid);
|
||||||
newWindow.opener = null;
|
newWindow.opener = null;
|
||||||
} else if (message.tag == 'mstsc') {
|
} else if (message.tag == 'mstsc') {
|
||||||
//var rdpurl = window.location.origin + domainUrl + 'mstsc/index.html?ws=wss%3A%2F%2F' + window.location.host + '%2Fmeshrelay.ashx%3Fauth%3D' + message.cookie;
|
|
||||||
var rdpurl = window.location.origin + domainUrl + 'mstsc/index.html?ws=' + message.cookie;
|
var rdpurl = window.location.origin + domainUrl + 'mstsc/index.html?ws=' + message.cookie;
|
||||||
var node = getNodeFromId(message.nodeid);
|
var node = getNodeFromId(message.nodeid);
|
||||||
if (node != null) { rdpurl += '&name=' + encodeURIComponentEx(node.name); }
|
if (node != null) { rdpurl += '&name=' + encodeURIComponentEx(node.name); }
|
||||||
@ -5375,7 +5374,7 @@
|
|||||||
|
|
||||||
// MSTSC.js link
|
// MSTSC.js link
|
||||||
if (((connectivity & 1) != 0) && (node.agent) && ((meshrights & 8) != 0) && ((features & 0x40000000) == 0)) {
|
if (((connectivity & 1) != 0) && (node.agent) && ((meshrights & 8) != 0) && ((features & 0x40000000) == 0)) {
|
||||||
x += '<a href=# cmenu=rfbPortContextMenu id=mstscLink onclick=p10mstsc("' + node._id + '") title="' + "Launch RDP session to this device" + '.">' + "MSTSC" + '</a> ';
|
x += '<a href=# cmenu=rfbPortContextMenu id=mstscLink onclick=p10mstsc("' + node._id + '") title="' + "Launch web-based RDP session to this device" + '.">' + "Web-RDP" + '</a> ';
|
||||||
}
|
}
|
||||||
|
|
||||||
// MQTT options
|
// MQTT options
|
||||||
|
Loading…
Reference in New Issue
Block a user