All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.impalaframework.web.integration.ModuleIntegrationUtils Maven / Gradle / Ivy

There is a newer version: 1.0.3
Show newest version
/*
 * Copyright 2007-2010 the original author or authors.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
 * in compliance with the License. You may obtain a copy of the License at
 * 
 * http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software distributed under the License
 * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
 * or implied. See the License for the specific language governing permissions and limitations under
 * the License.
 */

package org.impalaframework.web.integration;

import javax.servlet.ServletContext;
import javax.servlet.http.HttpServletRequest;

import org.impalaframework.facade.ModuleManagementFacade;
import org.impalaframework.util.ObjectUtils;
import org.impalaframework.web.WebConstants;
import org.impalaframework.web.helper.WebServletUtils;
import org.impalaframework.web.servlet.wrapper.HttpRequestWrapper;
import org.impalaframework.web.servlet.wrapper.RequestModuleMapping;

public class ModuleIntegrationUtils {

    /**
     * Request attribute key which is used to denote that request includes or forwards should not reuse the existing 
     * Impala {@link HttpServletRequest} wrapper and {@link RequestModuleMapping} when doing a forward or include.
     * This is to allow forwards and includes to forward or include resources which are not contained within the current module.
     * For most applications, setting this parameter should not be necessary, for a single REQUEST-RESPONSE invocation.
     */
    public static final String EXTERNAL_REQUEST_INCLUDES_OR_FORWARDS = ModuleIntegrationUtils.class.getName() + ".external_request_includes_or_forwards";

    /**
     * Convenience helper method to obtain a potentially wrapped {@link HttpServletRequest} for the specified application and module mapping
     */
    public static HttpServletRequest getWrappedRequest(
            HttpServletRequest request,
            ServletContext servletContext, 
            RequestModuleMapping moduleMapping, 
            String applicationId) {
        
        final ModuleManagementFacade moduleManagementFactory = WebServletUtils.getModuleManagementFacade(servletContext);
        HttpServletRequest wrappedRequest = null;
        
        if (moduleManagementFactory != null) {
            HttpRequestWrapper factory = ObjectUtils.cast(moduleManagementFactory.getBean(WebConstants.REQUEST_WRAPPER_FACTORY_BEAN_NAME), HttpRequestWrapper.class);
            if (factory != null) {
                wrappedRequest = factory.getWrappedRequest(request, servletContext, moduleMapping, applicationId);
            } else {
                wrappedRequest = request;
            }
        } else {
            wrappedRequest = request;
        }
        return wrappedRequest;
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy