From 64c1f531d0a9e765e517e4013faf15d4fdb8f9bc Mon Sep 17 00:00:00 2001 From: Gustaf Blomqvist Date: Fri, 25 Mar 2022 23:08:52 +0100 Subject: [PATCH] Fixes #82 (incorrect URL encoding) --- index.html | 4 ++-- js/script.js | 35 +++++++++++++++++++++++++---------- 2 files changed, 27 insertions(+), 12 deletions(-) diff --git a/index.html b/index.html index c9316fd..237786d 100644 --- a/index.html +++ b/index.html @@ -275,8 +275,8 @@
diff --git a/js/script.js b/js/script.js index 303fd8f..6a6033c 100644 --- a/js/script.js +++ b/js/script.js @@ -82,6 +82,13 @@ const filterCommandData = function (data, { commandType, filter }) { const query = new URLSearchParams(location.hash.substring(1)); +// From https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/encodeURIComponent +const fixedEncodeURIComponent = function (str) { + return encodeURIComponent(str).replace(/[!'()*]/g, function(c) { + return '%' + c.charCodeAt(0).toString(16).toUpperCase(); + }); +} + const rsg = { ip: query.get('ip') || localStorage.getItem('ip') || '10.10.10.10', port: query.get('port') || localStorage.getItem('port') || 9001, @@ -124,7 +131,11 @@ const rsg = { } }, - escapeHTML: (text) => String(text).replace(/&/g, '&').replace(//g, '>'), + escapeHTML: (text) => { + let element = document.createElement('p'); + element.textContent = text; + return element.innerHTML; + }, getIP: () => rsg.ip, @@ -187,16 +198,20 @@ const rsg = { command = btoa(command) } else { function encoder(string) { - return (encoding === 'encodeURI' || encoding === 'encodeURIComponent') ? window[ - encoding](string) : string + let result = string; + switch (encoding) { + case 'encodeURLDouble': + result = fixedEncodeURIComponent(result); + // fall-through + case 'encodeURL': + result = fixedEncodeURIComponent(result); + break; + } + return result; } - - command = rsg.escapeHTML(command); - command = rsg.insertParameters( - rsg.highlightParameters( - encoder(command), encoder), - encoder - ) + command = rsg.escapeHTML(encoder(command)); + // NOTE: Assumes encoder doesn't produce HTML-escaped characters in parameters + command = rsg.insertParameters(rsg.highlightParameters(command, encoder), encoder); } return command;