Completed work on RDP clipboard support.

This commit is contained in:
Ylian Saint-Hilaire 2022-05-16 12:44:51 -07:00
parent c20e60ee65
commit 0d723df2e8
3 changed files with 20 additions and 12 deletions

View File

@ -203,7 +203,6 @@ module.exports.CreateMstscRelay = function (parent, db, ws, req, args, domain) {
send(['rdp-bitmap', bitmap]); // Send the bitmap metadata seperately, without bitmap data. send(['rdp-bitmap', bitmap]); // Send the bitmap metadata seperately, without bitmap data.
}).on('clipboard', function (content) { }).on('clipboard', function (content) {
// Clipboard data changed // Clipboard data changed
console.log('RDP clipboard recv', content);
send(['rdp-clipboard', content]); send(['rdp-clipboard', content]);
}).on('close', function () { }).on('close', function () {
send(['rdp-close']); send(['rdp-close']);

View File

@ -15,6 +15,7 @@ var CreateRDPDesktop = function (canvasid) {
obj.Canvas = obj.CanvasId.getContext('2d'); obj.Canvas = obj.CanvasId.getContext('2d');
obj.ScreenWidth = obj.width = 1280; obj.ScreenWidth = obj.width = 1280;
obj.ScreenHeight = obj.height = 1024; obj.ScreenHeight = obj.height = 1024;
obj.m.onClipboardChanged = null;
function mouseButtonMap(button) { function mouseButtonMap(button) {
// Swap mouse buttons if needed // Swap mouse buttons if needed
@ -83,10 +84,7 @@ var CreateRDPDesktop = function (canvasid) {
obj.Stop(); obj.Stop();
break; break;
} }
case 'rdp-clipboard': { case 'rdp-clipboard': { obj.lastClipboardContent = msg[1]; if (obj.m.onClipboardChanged) { obj.m.onClipboardChanged(msg[1]); } break; }
console.log('clipboard', msg[1]);
break;
}
case 'ping': { obj.socket.send('["pong"]'); break; } case 'ping': { obj.socket.send('["pong"]'); break; }
case 'pong': { break; } case 'pong': { break; }
} }
@ -105,6 +103,7 @@ var CreateRDPDesktop = function (canvasid) {
} }
obj.m.setClipboard = function (content) { if (obj.socket) { obj.socket.send(JSON.stringify(['clipboard', content])); } } obj.m.setClipboard = function (content) { if (obj.socket) { obj.socket.send(JSON.stringify(['clipboard', content])); } }
obj.m.getClipboard = function () { return obj.lastClipboardContent; }
function changeState(newstate) { function changeState(newstate) {
if (obj.State == newstate) return; if (obj.State == newstate) return;

View File

@ -1371,6 +1371,7 @@
<label style="display:block"><input type="checkbox" id="d7rdp7" />Disable Cursor Settings</label> <label style="display:block"><input type="checkbox" id="d7rdp7" />Disable Cursor Settings</label>
<label style="display:block"><input type="checkbox" id="d7rdp8" />Enable Font Smooting</label> <label style="display:block"><input type="checkbox" id="d7rdp8" />Enable Font Smooting</label>
<label style="display:block"><input type="checkbox" id="d7rdp9" />Enable Desktop Composision</label> <label style="display:block"><input type="checkbox" id="d7rdp9" />Enable Desktop Composision</label>
<label style="display:block"><input type="checkbox" id="d7rdpclip" />Automatic Clipboard</label>
<label style="display:block"><input type="checkbox" id="d7rdpsmb" />Swap Mouse Buttons</label> <label style="display:block"><input type="checkbox" id="d7rdpsmb" />Swap Mouse Buttons</label>
</div> </div>
</div> </div>
@ -7559,8 +7560,13 @@
function deskClipboardInFunction() { function deskClipboardInFunction() {
if (desktop == null || desktop.State != 3) return; if (desktop == null || desktop.State != 3) return;
if (desktop.m.getClipboard) {
var text = desktop.m.getClipboard();
if ((text != null) && (navigator.clipboard != null)) { navigator.clipboard.writeText(text).then(function() { }).catch(function(err) { console.log(err); }) } // Put remote clipboard data into our clipboard
} else {
meshserver.send({ action: 'msg', type: 'getclip', nodeid: currentNode._id, tag: 2 }); meshserver.send({ action: 'msg', type: 'getclip', nodeid: currentNode._id, tag: 2 });
} }
}
// Called to lock or unlock remote desktop user input // Called to lock or unlock remote desktop user input
function deskInputLockFunction(value) { function deskInputLockFunction(value) {
@ -8339,7 +8345,6 @@
QE('connectbutton1h', hwonline); QE('connectbutton1h', hwonline);
QV('deskFocusBtn', (desktop != null) && (desktop.contype == 2) && (deskState != 0) && (desktopsettings.showfocus)); QV('deskFocusBtn', (desktop != null) && (desktop.contype == 2) && (deskState != 0) && (desktopsettings.showfocus));
QE('DeskClip', deskState == 3); QE('DeskClip', deskState == 3);
//QE('DeskClip', (deskState == 3) && (desktop.contype != 4));
QV('DeskClip', (inputAllowed) && (currentNode.agent) && ((features2 & 0x1800) != 0x1800) && (currentNode.agent.id != 11) && (currentNode.agent.id != 16) && ((desktop == null) || (desktop.contype != 2)) && ((desktopsettings.autoclipboard != true) || (navigator.clipboard == null) || (navigator.clipboard.readText == null))); // Clipboard not supported on macOS QV('DeskClip', (inputAllowed) && (currentNode.agent) && ((features2 & 0x1800) != 0x1800) && (currentNode.agent.id != 11) && (currentNode.agent.id != 16) && ((desktop == null) || (desktop.contype != 2)) && ((desktopsettings.autoclipboard != true) || (navigator.clipboard == null) || (navigator.clipboard.readText == null))); // Clipboard not supported on macOS
QE('DeskESC', (deskState == 3) && (desktop.contype != 4)); QE('DeskESC', (deskState == 3) && (desktop.contype != 4));
QV('DeskESC', browserfullscreen && inputAllowed); QV('DeskESC', browserfullscreen && inputAllowed);
@ -8352,10 +8357,10 @@
QV('DeskTimer', deskState == 3); QV('DeskTimer', deskState == 3);
// Enable browser clipboard read if supported // Enable browser clipboard read if supported
QV('DeskClipboardOutButton', online && inputAllowed && ((desktop == null) || (desktop.contype != 4)) && ((features2 & 0x1000) == 0) && (navigator.clipboard != null) && (navigator.clipboard.readText != null) && ((desktopsettings.autoclipboard != true) || (navigator.clipboard == null) || (navigator.clipboard.readText == null))); var autoclipboard = ((desktop) && (desktop.contype == 4)) ? desktopsettings.rdpautoclipboard : desktopsettings.autoclipboard;
QV('DeskClipboardOutButton', online && inputAllowed && (desktop != null) && ((features2 & 0x1000) == 0) && (navigator.clipboard != null) && (navigator.clipboard.readText != null) && ((autoclipboard != true) || (navigator.clipboard == null) || (navigator.clipboard.readText == null)));
QV('d7deskAutoClipboardLabel', (navigator.clipboard.readText != null) && ((features2 & 0x1000) == 0)); QV('d7deskAutoClipboardLabel', (navigator.clipboard.readText != null) && ((features2 & 0x1000) == 0));
QV('DeskClipboardInButton', online && inputAllowed && ((desktop == null) || (desktop.contype != 4)) && ((features2 & 0x0800) == 0) && (navigator.clipboard != null) && (navigator.clipboard.writeText != null) && ((desktopsettings.autoclipboard != true) || (navigator.clipboard == null) || (navigator.clipboard.readText == null))); QV('DeskClipboardInButton', online && inputAllowed && (desktop != null) && ((features2 & 0x0800) == 0) && (navigator.clipboard != null) && (navigator.clipboard.writeText != null) && ((autoclipboard != true) || (navigator.clipboard == null) || (navigator.clipboard.readText == null)));
if (deskState != 3) { if (deskState != 3) {
QV('DeskInputLockedButton', false); QV('DeskInputLockedButton', false);
QV('DeskInputUnLockedButton', false); QV('DeskInputUnLockedButton', false);
@ -8539,6 +8544,7 @@
desktop = CreateRDPDesktop('Desk'); desktop = CreateRDPDesktop('Desk');
desktop.onStateChanged = onDesktopStateChange; desktop.onStateChanged = onDesktopStateChange;
desktop.m.onScreenSizeChange = mdeskAdjust; desktop.m.onScreenSizeChange = mdeskAdjust;
desktop.m.onClipboardChanged = function(text) { if ((text != null) && (desktopsettings.rdpautoclipboard) && (navigator.clipboard != null)) { navigator.clipboard.writeText(text).then(function() { }).catch(function(err) { console.log(err); }) } } // Put remote clipboard data into our clipboard
if (desktopsettings.rdpsmb) { desktop.m.SwapMouse = desktopsettings.rdpsmb; } if (desktopsettings.rdpsmb) { desktop.m.SwapMouse = desktopsettings.rdpsmb; }
desktop.Start(desktopNode._id, currentNode.rdpport ? currentNode.rdpport : 3389, tsid); desktop.Start(desktopNode._id, currentNode.rdpport ? currentNode.rdpport : 3389, tsid);
desktop.contype = 4; desktop.contype = 4;
@ -8740,11 +8746,13 @@
if (desktop.latency && (desktop.latency.current >= 0)) { latencyStr = format('{0} ms, ', desktop.latency.current); } if (desktop.latency && (desktop.latency.current >= 0)) { latencyStr = format('{0} ms, ', desktop.latency.current); }
seconds = Math.floor((new Date() - desktop.startTime) / 1000); seconds = Math.floor((new Date() - desktop.startTime) / 1000);
QH('DeskTimer', latencyStr + zeroPad(Math.floor(seconds / 3600), 2) + ':' + zeroPad((Math.floor(seconds / 60) % 60), 2) + ':' + zeroPad((seconds % 60), 2)); QH('DeskTimer', latencyStr + zeroPad(Math.floor(seconds / 3600), 2) + ':' + zeroPad((Math.floor(seconds / 60) % 60), 2) + ':' + zeroPad((seconds % 60), 2));
if ((desktopsettings.autoclipboard === true) && (navigator.clipboard != null) && (navigator.clipboard.readText != null)) { // Auto-clipboard
if ((((desktop.contype != 4) && (desktopsettings.autoclipboard === true)) || ((desktop.contype == 4) && (desktopsettings.rdpautoclipboard === true))) && (navigator.clipboard != null) && (navigator.clipboard.readText != null)) {
try { try {
navigator.clipboard.readText().then(function(text) { navigator.clipboard.readText().then(function(text) {
if (desktop == null) return;
if ((text != null) && (deskLastClipboardSent != text)) { if ((text != null) && (deskLastClipboardSent != text)) {
if (desktop.m.setClipboard) { desktop.m.setClipboard(text); } else { meshserver.send({ action: 'msg', type: 'setclip', nodeid: currentNode._id, data: text }); } if (desktop.m.setClipboard) { desktop.m.setClipboard(text); } else { console.log('s3'); meshserver.send({ action: 'msg', type: 'setclip', nodeid: currentNode._id, data: text }); }
deskLastClipboardSent = text; deskLastClipboardSent = text;
} }
}).catch(function(err) { }); }).catch(function(err) { });
@ -8816,6 +8824,7 @@
desktopsettings.localkeymap = d7localKeyMap.checked; desktopsettings.localkeymap = d7localKeyMap.checked;
desktopsettings.rdpsize = d7rdpsize.value; desktopsettings.rdpsize = d7rdpsize.value;
desktopsettings.rdpsmb = d7rdpsmb.checked; desktopsettings.rdpsmb = d7rdpsmb.checked;
desktopsettings.rdpautoclipboard = d7rdpclip.checked;
var rdpflags = 0; var rdpflags = 0;
for (var i = 1; i < 10; i++) { if ((i != 5) && (Q('d7rdp' + i).checked)) { rdpflags |= (1 << (i - 1)); } } for (var i = 1; i < 10; i++) { if ((i != 5) && (Q('d7rdp' + i).checked)) { rdpflags |= (1 << (i - 1)); } }
desktopsettings.rdpflags = rdpflags; desktopsettings.rdpflags = rdpflags;
@ -8858,6 +8867,7 @@
if (desktopsettings.rdpsize != null) { d7rdpsize.value = desktopsettings.rdpsize; } if (desktopsettings.rdpsize != null) { d7rdpsize.value = desktopsettings.rdpsize; }
if (desktopsettings.rdpflags == null) { desktopsettings.rdpflags = 0x2F; } if (desktopsettings.rdpflags == null) { desktopsettings.rdpflags = 0x2F; }
if (desktopsettings.rdpsmb != null) { d7rdpsmb.checked = desktopsettings.rdpsmb; } if (desktopsettings.rdpsmb != null) { d7rdpsmb.checked = desktopsettings.rdpsmb; }
if (desktopsettings.rdpautoclipboard != null) { d7rdpclip.checked = desktopsettings.rdpautoclipboard; }
for (var i = 1; i < 10; i++) { if (i != 5) { Q('d7rdp' + i).checked = ((desktopsettings.rdpflags & (1 << (i - 1))) != 0); } } for (var i = 1; i < 10; i++) { if (i != 5) { Q('d7rdp' + i).checked = ((desktopsettings.rdpflags & (1 << (i - 1))) != 0); } }
} }