From 8c6196c39c7d182f350a05decb339939f3491376 Mon Sep 17 00:00:00 2001 From: erickgonzalez Date: Thu, 13 Jun 2024 22:08:27 -0600 Subject: [PATCH] #28089 include in 23.10.24 LTS --- dotCMS/hotfix_tracking.md | 3 ++- .../dotcms/filters/VanityUrlFilterTest.java | 8 +++--- .../vanityurl/business/VanityUrlAPIImpl.java | 3 +++ .../java/com/dotmarketing/util/URLUtils.java | 26 ++++++++++++------- 4 files changed, 27 insertions(+), 13 deletions(-) diff --git a/dotCMS/hotfix_tracking.md b/dotCMS/hotfix_tracking.md index 8aa811a407ba..270f0d27dd4f 100644 --- a/dotCMS/hotfix_tracking.md +++ b/dotCMS/hotfix_tracking.md @@ -105,4 +105,5 @@ This maintenance release includes the following code fixes: 98. https://github.com/dotCMS/core/issues/26660 : Fix Menu label if we are missing the translation key #26660 99. https://github.com/dotCMS/core/issues/26283 : Relationship throwing error when the child content is a copy of original child content #26283 100. https://github.com/dotCMS/core/issues/26597 : Textareas need to be embiggened. #26597 -101. https://github.com/dotCMS/core/issues/28360 : Move Async Email Actionlet to Core #28360 \ No newline at end of file +101. https://github.com/dotCMS/core/issues/28360 : Move Async Email Actionlet to Core #28360 +102. https://github.com/dotCMS/core/issues/28089 : Pound char not decoded when using Rules or Vanity URLs #28089 \ No newline at end of file diff --git a/dotCMS/src/integration-test/java/com/dotcms/filters/VanityUrlFilterTest.java b/dotCMS/src/integration-test/java/com/dotcms/filters/VanityUrlFilterTest.java index 684f59c3b229..24cd6359df07 100644 --- a/dotCMS/src/integration-test/java/com/dotcms/filters/VanityUrlFilterTest.java +++ b/dotCMS/src/integration-test/java/com/dotcms/filters/VanityUrlFilterTest.java @@ -238,16 +238,18 @@ public void test_that_vanity_url_filter_handles_redirects() throws Exception { forwardTo, action, order, defaultLanguage.getId()); filtersUtil.publishVanityUrl(contentlet1); - final String testURI = baseURI + "/test redirect 301"; + final String resource = "/test redirect 301".replaceAll(" ", "%20"); + final String queryWithFragment = "?param1=value 1¶m2=value 2#test-fragment" + .replaceAll(" ", "+"); + final String testURI = baseURI + resource + queryWithFragment; final HttpServletRequest request = new MockHttpRequestIntegrationTest(defaultHost.getHostname(), testURI).request(); final HttpServletResponse response = new MockHttpStatusResponse(new MockHeaderResponse(new MockHttpResponse().response()).response()).response(); - VanityURLFilter filter = new VanityURLFilter(); filter.doFilter(request, response, null); - final String expectedLocation = forwardBaseURI + "/test%20redirect%20301"; + final String expectedLocation = forwardBaseURI + resource + queryWithFragment; Assert.assertEquals(expectedLocation, response.getHeader("Location")); Assert.assertEquals(301,response.getStatus()); Assert.assertNotNull(response.getHeader("X-DOT-VanityUrl")); diff --git a/dotCMS/src/main/java/com/dotcms/vanityurl/business/VanityUrlAPIImpl.java b/dotCMS/src/main/java/com/dotcms/vanityurl/business/VanityUrlAPIImpl.java index d3ec510cd0f3..772381f18254 100644 --- a/dotCMS/src/main/java/com/dotcms/vanityurl/business/VanityUrlAPIImpl.java +++ b/dotCMS/src/main/java/com/dotcms/vanityurl/business/VanityUrlAPIImpl.java @@ -441,6 +441,9 @@ private String encodeRedirectURL(final String uri) { } } } + if (UtilMethods.isSet(urlToEncode.getFragment())) { + uriBuilder.setFragment(urlToEncode.getFragment()); + } return uriBuilder.build().toASCIIString(); } catch (URISyntaxException e) { throw new RuntimeException(e); diff --git a/dotCMS/src/main/java/com/dotmarketing/util/URLUtils.java b/dotCMS/src/main/java/com/dotmarketing/util/URLUtils.java index a9952b74f2df..0aa894af1f49 100644 --- a/dotCMS/src/main/java/com/dotmarketing/util/URLUtils.java +++ b/dotCMS/src/main/java/com/dotmarketing/util/URLUtils.java @@ -12,16 +12,20 @@ public class URLUtils { + private URLUtils() { + throw new IllegalStateException("Utility class"); + } public static class ParsedURL { private String protocol; private String host; private int port; - private String URI; + private String uri; private String path; private String resource; private String queryString; private Map parameters; + private String fragment; public String getProtocol() { return protocol; @@ -66,15 +70,22 @@ public void setParameters(Map parameters) { this.parameters = parameters; } public void setURI(String uRI) { - URI = uRI; + uri = uRI; } public String getURI() { - return URI; + return uri; + } + public String getFragment() { + return fragment; + } + public void setFragment(String fragment) { + this.fragment = fragment; } - } + } - private static Pattern regexPattern = Pattern.compile("((\\w+)://([^/\\p{Cntrl}:]+)(?::([0-9]+))?)?(((?:/[^/\\p{Cntrl}]+)*)(?:/([^/\\p{Cntrl}?]+)?))?\\??(.*)?"); + private static final Pattern regexPattern = Pattern.compile( + "((\\w+)://([^/\\p{Cntrl}:]+)(?::(\\d+))?)?(((?:/[^/\\p{Cntrl}]+)*)(?:/([^/\\p{Cntrl}?#]+)?))?\\??([^#]*)?(?:#(.*))?"); public static ParsedURL parseURL(String url) throws IllegalArgumentException { @@ -91,6 +102,7 @@ public static ParsedURL parseURL(String url) throws IllegalArgumentException { parsedUrl.setPath(matcher.group(6)); parsedUrl.setResource(matcher.group(7)); parsedUrl.setQueryString(matcher.group(8)); + parsedUrl.setFragment(matcher.group(9)); Map> parameters = new HashMap<>(); String[] queryStringSplitted = parsedUrl.queryString.split("&"); @@ -125,8 +137,4 @@ public static ParsedURL parseURL(String url) throws IllegalArgumentException { return parsedUrl; } - - public static String addSlashIfNeeded (final String uri) { - return (uri.length() > 0 && '/' == uri.charAt(0)) ? uri : ("/" + uri); - } }