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

org.springframework.web.context.request.FacesRequestAttributes Maven / Gradle / Ivy

/*
 * Copyright 2002-2018 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
 *
 *      https://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.springframework.web.context.request;

import java.lang.reflect.Method;
import java.util.Map;

import javax.faces.context.ExternalContext;
import javax.faces.context.FacesContext;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

import org.springframework.util.Assert;
import org.springframework.util.ReflectionUtils;
import org.springframework.util.StringUtils;
import org.springframework.web.util.WebUtils;

/**
 * {@link RequestAttributes} adapter for a JSF {@link javax.faces.context.FacesContext}.
 * Used as default in a JSF environment, wrapping the current FacesContext.
 *
 * 

NOTE: In contrast to {@link ServletRequestAttributes}, this variant does * not support destruction callbacks for scoped attributes, neither for the * request scope nor for the session scope. If you rely on such implicit destruction * callbacks, consider defining a Spring {@link RequestContextListener} in your * {@code web.xml}. * *

Requires JSF 2.0 or higher, as of Spring 4.0. * * @author Juergen Hoeller * @since 2.5.2 * @see javax.faces.context.FacesContext#getExternalContext() * @see javax.faces.context.ExternalContext#getRequestMap() * @see javax.faces.context.ExternalContext#getSessionMap() * @see RequestContextHolder#currentRequestAttributes() */ public class FacesRequestAttributes implements RequestAttributes { /** * We'll create a lot of these objects, so we don't want a new logger every time. */ private static final Log logger = LogFactory.getLog(FacesRequestAttributes.class); private final FacesContext facesContext; /** * Create a new FacesRequestAttributes adapter for the given FacesContext. * @param facesContext the current FacesContext * @see javax.faces.context.FacesContext#getCurrentInstance() */ public FacesRequestAttributes(FacesContext facesContext) { Assert.notNull(facesContext, "FacesContext must not be null"); this.facesContext = facesContext; } /** * Return the JSF FacesContext that this adapter operates on. */ protected final FacesContext getFacesContext() { return this.facesContext; } /** * Return the JSF ExternalContext that this adapter operates on. * @see javax.faces.context.FacesContext#getExternalContext() */ protected final ExternalContext getExternalContext() { return getFacesContext().getExternalContext(); } /** * Return the JSF attribute Map for the specified scope. * @param scope constant indicating request or session scope * @return the Map representation of the attributes in the specified scope * @see #SCOPE_REQUEST * @see #SCOPE_SESSION */ protected Map getAttributeMap(int scope) { if (scope == SCOPE_REQUEST) { return getExternalContext().getRequestMap(); } else { return getExternalContext().getSessionMap(); } } @Override public Object getAttribute(String name, int scope) { return getAttributeMap(scope).get(name); } @Override public void setAttribute(String name, Object value, int scope) { getAttributeMap(scope).put(name, value); } @Override public void removeAttribute(String name, int scope) { getAttributeMap(scope).remove(name); } @Override public String[] getAttributeNames(int scope) { return StringUtils.toStringArray(getAttributeMap(scope).keySet()); } @Override public void registerDestructionCallback(String name, Runnable callback, int scope) { if (logger.isWarnEnabled()) { logger.warn("Could not register destruction callback [" + callback + "] for attribute '" + name + "' because FacesRequestAttributes does not support such callbacks"); } } @Override public Object resolveReference(String key) { if (REFERENCE_REQUEST.equals(key)) { return getExternalContext().getRequest(); } else if (REFERENCE_SESSION.equals(key)) { return getExternalContext().getSession(true); } else if ("application".equals(key)) { return getExternalContext().getContext(); } else if ("requestScope".equals(key)) { return getExternalContext().getRequestMap(); } else if ("sessionScope".equals(key)) { return getExternalContext().getSessionMap(); } else if ("applicationScope".equals(key)) { return getExternalContext().getApplicationMap(); } else if ("facesContext".equals(key)) { return getFacesContext(); } else if ("cookie".equals(key)) { return getExternalContext().getRequestCookieMap(); } else if ("header".equals(key)) { return getExternalContext().getRequestHeaderMap(); } else if ("headerValues".equals(key)) { return getExternalContext().getRequestHeaderValuesMap(); } else if ("param".equals(key)) { return getExternalContext().getRequestParameterMap(); } else if ("paramValues".equals(key)) { return getExternalContext().getRequestParameterValuesMap(); } else if ("initParam".equals(key)) { return getExternalContext().getInitParameterMap(); } else if ("view".equals(key)) { return getFacesContext().getViewRoot(); } else if ("viewScope".equals(key)) { return getFacesContext().getViewRoot().getViewMap(); } else if ("flash".equals(key)) { return getExternalContext().getFlash(); } else if ("resource".equals(key)) { return getFacesContext().getApplication().getResourceHandler(); } else { return null; } } @Override public String getSessionId() { Object session = getExternalContext().getSession(true); try { // HttpSession has a getId() method. Method getIdMethod = session.getClass().getMethod("getId"); return String.valueOf(ReflectionUtils.invokeMethod(getIdMethod, session)); } catch (NoSuchMethodException ex) { throw new IllegalStateException("Session object [" + session + "] does not have a getId() method"); } } @Override public Object getSessionMutex() { // Enforce presence of a session first to allow listeners to create the mutex attribute ExternalContext externalContext = getExternalContext(); Object session = externalContext.getSession(true); Object mutex = externalContext.getSessionMap().get(WebUtils.SESSION_MUTEX_ATTRIBUTE); if (mutex == null) { mutex = (session != null ? session : externalContext); } return mutex; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy