This is an automated email from the ASF dual-hosted git repository. deepak pushed a commit to branch release18.12 in repository https://gitbox.apache.org/repos/asf/ofbiz-framework.git
commit 6c3b0068a99bb3b93321fdb983a0046b0679c86d Author: Deepak Dixit <deepak.di...@hotwax.co> AuthorDate: Fri Jul 19 17:10:39 2024 +0530 Revert "Improved: Added support to allow direct view rendering in override view functionality (OFBIZ-13117)" This reverts commit 8b1ee1b3a5da79ae669aee324c51d073e4ba8b1f. --- .../content/webapp/content/WEB-INF/controller.xml | 2 +- framework/webapp/dtd/site-conf.xsd | 19 ------------------- .../ofbiz/webapp/control/ConfigXMLReader.java | 4 ---- .../ofbiz/webapp/control/RequestHandler.java | 22 +++++----------------- .../ofbiz/webapp/control/RequestHandlerTests.java | 5 +---- 5 files changed, 7 insertions(+), 45 deletions(-) diff --git a/applications/content/webapp/content/WEB-INF/controller.xml b/applications/content/webapp/content/WEB-INF/controller.xml index 63c443e77a..f3d8e58e82 100644 --- a/applications/content/webapp/content/WEB-INF/controller.xml +++ b/applications/content/webapp/content/WEB-INF/controller.xml @@ -1993,7 +1993,7 @@ under the License. <view-map name="EditWebSitePathAlias" type="screen" page="component://content/widget/WebSiteScreens.xml#EditWebSitePathAlias"/> <view-map name="WebSiteContent" type="screen" page="component://content/widget/WebSiteScreens.xml#WebSiteContent"/> <view-map name="WebSiteCMS" type="screen" page="component://content/widget/WebSiteScreens.xml#WebSiteCMS"/> - <view-map name="WebSiteCMSContent" type="screen" page="component://content/widget/WebSiteScreens.xml#WebSiteCMSContent" allow-direct-view-rendering="true"/> + <view-map name="WebSiteCMSContent" type="screen" page="component://content/widget/WebSiteScreens.xml#WebSiteCMSContent"/> <view-map name="WebSiteCMSEditor" type="screen" page="component://content/widget/WebSiteScreens.xml#WebSiteCMSEditor"/> <view-map name="WebSiteCMSMetaInfo" type="screen" page="component://content/widget/WebSiteScreens.xml#WebSiteCMSMetaInfo"/> <view-map name="WebSiteCMSPathAlias" type="screen" page="component://content/widget/WebSiteScreens.xml#WebSiteCMSPathAlias"/> diff --git a/framework/webapp/dtd/site-conf.xsd b/framework/webapp/dtd/site-conf.xsd index 6f42552f8e..fc9a966615 100644 --- a/framework/webapp/dtd/site-conf.xsd +++ b/framework/webapp/dtd/site-conf.xsd @@ -719,25 +719,6 @@ under the License. </xs:documentation> </xs:annotation> </xs:attribute> - <xs:attribute type="xs:boolean" name="allow-direct-view-rendering" default="false"> - <xs:annotation> - <xs:documentation> - This attribute determines whether direct rendering of the view is allowed when using the override view functionality. - If set to true, - the system permits the view to be rendered directly using the override view functionality. - If false or not specified, - direct rendering is not allowed, and system throws Unknown request exception. - </xs:documentation> - </xs:annotation> - </xs:attribute> - <xs:attribute type="xs:boolean" name="direct-view-rendering-with-auth" default="false"> - <xs:annotation> - <xs:documentation> - If direct-view-rendering-with-auth=true, direct rendering of the view is only allowed with an active login when using the override view functionality. - If direct-view-rendering-with-auth=false, no active login is required. - </xs:documentation> - </xs:annotation> - </xs:attribute> <xs:attribute name="x-frame-options" default="sameorigin"> <xs:annotation> <xs:documentation> diff --git a/framework/webapp/src/main/java/org/apache/ofbiz/webapp/control/ConfigXMLReader.java b/framework/webapp/src/main/java/org/apache/ofbiz/webapp/control/ConfigXMLReader.java index cb15c385b4..8181eb860e 100644 --- a/framework/webapp/src/main/java/org/apache/ofbiz/webapp/control/ConfigXMLReader.java +++ b/framework/webapp/src/main/java/org/apache/ofbiz/webapp/control/ConfigXMLReader.java @@ -573,8 +573,6 @@ public class ConfigXMLReader { public String strictTransportSecurity; public String description; public boolean noCache = false; - public boolean allowDirectViewRendering = false; - public boolean directViewRenderingWithAuth = false; public ViewMap(Element viewMapElement) { this.name = viewMapElement.getAttribute("name"); @@ -583,8 +581,6 @@ public class ConfigXMLReader { this.info = viewMapElement.getAttribute("info"); this.contentType = viewMapElement.getAttribute("content-type"); this.noCache = "true".equals(viewMapElement.getAttribute("no-cache")); - this.allowDirectViewRendering = "true".equals(viewMapElement.getAttribute("allow-direct-view-rendering")); - this.directViewRenderingWithAuth = "true".equals(viewMapElement.getAttribute("direct-view-rendering-with-auth")); this.encoding = viewMapElement.getAttribute("encoding"); this.xFrameOption = viewMapElement.getAttribute("x-frame-options"); this.strictTransportSecurity = viewMapElement.getAttribute("strict-transport-security"); diff --git a/framework/webapp/src/main/java/org/apache/ofbiz/webapp/control/RequestHandler.java b/framework/webapp/src/main/java/org/apache/ofbiz/webapp/control/RequestHandler.java index 98f205aeec..59daed237d 100644 --- a/framework/webapp/src/main/java/org/apache/ofbiz/webapp/control/RequestHandler.java +++ b/framework/webapp/src/main/java/org/apache/ofbiz/webapp/control/RequestHandler.java @@ -194,20 +194,15 @@ public class RequestHandler { */ static Collection<RequestMap> resolveURI(ControllerConfig ccfg, HttpServletRequest req) { Map<String, List<RequestMap>> requestMapMap = ccfg.getRequestMapMap(); + Map<String, ConfigXMLReader.ViewMap> viewMapMap = ccfg.getViewMapMap(); String defaultRequest = ccfg.getDefaultRequest(); String path = req.getPathInfo(); String requestUri = getRequestUri(path); - String overrideViewUri = getOverrideViewUri(path); - boolean allowDirectViewRendering = false; + String viewUri = getOverrideViewUri(path); Collection<RequestMap> rmaps; - // Ensure that overridden view exists and direct view rendering is allowed. - if (UtilValidate.isNotEmpty(overrideViewUri)) { - ConfigXMLReader.ViewMap overrideViewMap = ccfg.getViewMapMap().get(overrideViewUri); - allowDirectViewRendering = (overrideViewMap != null && overrideViewMap.allowDirectViewRendering); - } if (requestMapMap.containsKey(requestUri) // Ensure that overridden view exists. - && (allowDirectViewRendering + && (viewUri == null || viewMapMap.containsKey(viewUri) || ("SOAPService".equals(requestUri) && "wsdl".equalsIgnoreCase(req.getQueryString())))){ rmaps = requestMapMap.get(requestUri); } else if (defaultRequest != null) { @@ -482,14 +477,9 @@ public class RequestHandler { if (Debug.verboseOn()) Debug.logVerbose("[Processing Request]: " + requestMap.uri + showSessionId(request), module); request.setAttribute("thisRequestUri", requestMap.uri); // store the actual request URI - boolean directViewRenderingWithAuth = false; - // Check if direct view rendering requires authentication. - if (UtilValidate.isNotEmpty(overrideViewUri)) { - ConfigXMLReader.ViewMap overrideViewMap = ccfg.getViewMapMap().get(overrideViewUri); - directViewRenderingWithAuth = (overrideViewMap != null && overrideViewMap.directViewRenderingWithAuth); - } + // Perform security check. - if (requestMap.securityAuth || directViewRenderingWithAuth) { + if (requestMap.securityAuth) { // Invoke the security handler // catch exceptions and throw RequestHandlerException if failed. if (Debug.verboseOn()) Debug.logVerbose("[RequestHandler]: AuthRequired. Running security check. " + showSessionId(request), module); @@ -510,8 +500,6 @@ public class RequestHandler { } else { requestMap = ccfg.getRequestMapMap().getFirst("ajaxCheckLogin"); } - // overrideViewUri needs to be deleted, as there is no authentication - overrideViewUri = null; } } else if (requestUri != null) { String[] loginUris = EntityUtilProperties.getPropertyValue("security", "login.uris", delegator).split(","); diff --git a/framework/webapp/src/test/java/org/apache/ofbiz/webapp/control/RequestHandlerTests.java b/framework/webapp/src/test/java/org/apache/ofbiz/webapp/control/RequestHandlerTests.java index 812756fb62..acf941d374 100644 --- a/framework/webapp/src/test/java/org/apache/ofbiz/webapp/control/RequestHandlerTests.java +++ b/framework/webapp/src/test/java/org/apache/ofbiz/webapp/control/RequestHandlerTests.java @@ -40,7 +40,6 @@ import org.apache.ofbiz.webapp.control.ConfigXMLReader.RequestMap; import org.apache.ofbiz.webapp.control.ConfigXMLReader.ViewMap; import org.junit.Before; import org.junit.Test; -import org.mockito.Mockito; import org.w3c.dom.Element; public class RequestHandlerTests { @@ -127,12 +126,10 @@ public class RequestHandlerTests { reqMaps.putSingle("foo", foo); reqMaps.putSingle("bar", bar); - //viewMaps.put("baz", new ViewMap(dummyElement)); - viewMaps.put("baz", Mockito.mock(ViewMap.class)); // Mock the ViewMap + viewMaps.put("baz", new ViewMap(dummyElement)); when(req.getPathInfo()).thenReturn("/foo/baz"); when(ccfg.getDefaultRequest()).thenReturn("bar"); - when(viewMaps.get("baz").allowDirectViewRendering).thenReturn(true); assertThat(RequestHandler.resolveURI(ccfg, req), hasItem(foo)); }