From cf91e9c7521db30af88e92d7668882ec358e1adb Mon Sep 17 00:00:00 2001 From: Stanley Hsu Date: Tue, 29 Mar 2022 15:41:51 +0200 Subject: [PATCH] Fixed search params encoded twice issue --- core/src/utilities/helpers/routing-helpers.js | 8 ++------ core/test/core-api/routing.spec.js | 13 +++++++++++- .../tests/0-fiddle/fiddle-navigation.spec.js | 4 ++-- .../microfrontends/luigi-client-test.html | 20 +++++++++++++------ 4 files changed, 30 insertions(+), 15 deletions(-) diff --git a/core/src/utilities/helpers/routing-helpers.js b/core/src/utilities/helpers/routing-helpers.js index 98e50b85c1..4af58a30c1 100644 --- a/core/src/utilities/helpers/routing-helpers.js +++ b/core/src/utilities/helpers/routing-helpers.js @@ -511,11 +511,7 @@ class RoutingHelpersClass { if (!GenericHelpers.isObject(localSearchParams)) { return; } - Object.keys(localSearchParams).forEach(key => { - if (localSearchParams[key] !== undefined) { - localSearchParams[key] = encodeURIComponent(localSearchParams[key]); - } - }); + if (currentNode && currentNode.clientPermissions && currentNode.clientPermissions.urlParameters) { const filteredObj = {}; Object.keys(currentNode.clientPermissions.urlParameters).forEach(key => { @@ -622,7 +618,7 @@ class RoutingHelpersClass { this.modifySearchParams(params, searchParams, paramPrefix); localhash = hashValue; if (searchParams.toString() !== '') { - localhash += `?${decodeURIComponent(searchParams.toString())}`; + localhash += `?${searchParams.toString()}`; } return localhash; } diff --git a/core/test/core-api/routing.spec.js b/core/test/core-api/routing.spec.js index 94d7c0da6f..27868e57fb 100644 --- a/core/test/core-api/routing.spec.js +++ b/core/test/core-api/routing.spec.js @@ -112,6 +112,17 @@ describe('Luigi routing', function() { 'http://some.url.de/#/?test=tets&foo=bar' ); }); + it('add search params to hash routing with special characters', () => { + window.state = {}; + global.location = 'http://some.url.de/#/?test=tets'; + LuigiRouting.addSearchParams({ foo: '%bar#foo@bar&foo' }, true); + sinon.assert.calledWithExactly( + window.history.pushState, + window.state, + '', + 'http://some.url.de/#/?test=tets&foo=%25bar%23foo%40bar%26foo' + ); + }); it('add search params to hash routing', () => { window.state = {}; global.location = 'http://some.url.de/#/?~luigi=rocks'; @@ -120,7 +131,7 @@ describe('Luigi routing', function() { window.history.pushState, window.state, '', - 'http://some.url.de/#/?~luigi=rocks&foo=bar' + 'http://some.url.de/#/?%7Eluigi=rocks&foo=bar' ); }); it('call addSearchParams with wrong argument hash routing', () => { diff --git a/test/e2e-test-application/e2e/tests/0-fiddle/fiddle-navigation.spec.js b/test/e2e-test-application/e2e/tests/0-fiddle/fiddle-navigation.spec.js index 01f8e52908..8bdedbf6bf 100644 --- a/test/e2e-test-application/e2e/tests/0-fiddle/fiddle-navigation.spec.js +++ b/test/e2e-test-application/e2e/tests/0-fiddle/fiddle-navigation.spec.js @@ -994,7 +994,7 @@ describe('Fiddle', () => { .contains('add node params') .click(); }); - cy.expectPathToBe('/home/mynode?~q=test&~luigi=rocks'); + cy.expectPathToBe('/home/mynode?%7Eq=test&%7Eluigi=rocks'); cy.getIframeBody().then($body => { cy.wrap($body) .find('[data-testid="lui-delete-node-params"]') @@ -1003,7 +1003,7 @@ describe('Fiddle', () => { .contains('delete node params') .click(); }); - cy.expectPathToBe('/home/mynode?~luigi=rocks'); + cy.expectPathToBe('/home/mynode?%7Eluigi=rocks'); }); }); describe('LuigiClient add and delete node and search paramstest', () => { diff --git a/website/fiddle/public/examples/microfrontends/luigi-client-test.html b/website/fiddle/public/examples/microfrontends/luigi-client-test.html index 9dd8c3e9fe..517078838a 100644 --- a/website/fiddle/public/examples/microfrontends/luigi-client-test.html +++ b/website/fiddle/public/examples/microfrontends/luigi-client-test.html @@ -6,17 +6,21 @@ - - - - -