/* * See the NOTICE file distributed with this work for additional * information regarding copyright ownership. * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of * the License, or (at your option) any later version. * * This software is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */ package org.xwiki.container.servlet.internal; import javax.inject.Inject; import javax.inject.Singleton; import javax.servlet.ServletContext; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.xwiki.component.annotation.Component; import org.xwiki.component.manager.ComponentManager; import org.xwiki.container.ApplicationContext; import org.xwiki.container.ApplicationContextListenerManager; import org.xwiki.container.Container; import org.xwiki.container.RequestInitializerManager; import org.xwiki.container.servlet.ServletApplicationContext; import org.xwiki.container.servlet.ServletContainerException; import org.xwiki.container.servlet.ServletContainerInitializer; import org.xwiki.container.servlet.ServletRequest; import org.xwiki.container.servlet.ServletResponse; import org.xwiki.container.servlet.ServletSession; import org.xwiki.context.Execution; import org.xwiki.context.ExecutionContext; import org.xwiki.context.ExecutionContextManager; @Component @Singleton public class DefaultServletContainerInitializer implements ServletContainerInitializer { // Implementation note: It's important that we don't use @Inject annotations here // for RequestInitializerManager and ExecutionContextManager since we can have // RequestInitializer and ExecutionContextInitializer components which try to access // the Application Context in their initialize() method and we need it to be available // (i.e. initializeApplicationContext() needs to have been called) before they are // looked up (and thus initialized). @Inject private ApplicationContextListenerManager applicationContextListenerManager; @Inject private Container container; @Inject private Execution execution; @Inject private ComponentManager componentManager; /** * @deprecated starting with 3.5M1, use the notion of Environment instead */ @Deprecated @Override public void initializeApplicationContext(ServletContext servletContext) { ApplicationContext applicationContext = new ServletApplicationContext(servletContext, this.componentManager); this.container.setApplicationContext(applicationContext); this.applicationContextListenerManager.initializeApplicationContext(applicationContext); } @Override public void initializeRequest(HttpServletRequest httpServletRequest, Object xwikiContext) throws ServletContainerException { // 1) Create an empty request. From this point forward request initializers can use the // Container object to get any data they want from the Request. this.container.setRequest(new ServletRequest(httpServletRequest)); // 2) Create an empty Execution context so that the Container initializers can put things in the // execution context when they execute. this.execution.setContext(new ExecutionContext()); // 3) Bridge with old code to play well with new components. Old code relies on the // XWikiContext object whereas new code uses the Container component. if (xwikiContext != null) { ExecutionContext ec = this.execution.getContext(); String key = "xwikicontext"; if (ec.hasProperty(key)) { ec.setProperty(key, xwikiContext); } else { ec.newProperty(key).inherited().initial(xwikiContext).declare(); } } // 4) Call the request initializers to populate the Request further. try { RequestInitializerManager manager = this.componentManager.getInstance(RequestInitializerManager.class); manager.initializeRequest(this.container.getRequest()); } catch (Exception e) { throw new ServletContainerException("Failed to initialize request", e); } // 5) Call Execution Context initializers to perform further Execution Context initializations try { ExecutionContextManager manager = this.componentManager.getInstance(ExecutionContextManager.class); manager.initialize(this.execution.getContext()); } catch (Exception e) { throw new ServletContainerException("Failed to initialize Execution Context", e); } } @Override public void initializeRequest(HttpServletRequest httpServletRequest) throws ServletContainerException { initializeRequest(httpServletRequest, null); } @Override public void initializeResponse(HttpServletResponse httpServletResponse) { this.container.setResponse(new ServletResponse(httpServletResponse)); } @Override public void initializeSession(HttpServletRequest httpServletRequest) { this.container.setSession(new ServletSession(httpServletRequest)); } }