/* * Copyright 2004 The Apache Software Foundation. * * 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.apache.myfaces.webapp; import javax.faces.FactoryFinder; import javax.faces.context.ExternalContext; import javax.servlet.ServletContext; import javax.servlet.ServletContextEvent; import javax.servlet.ServletContextListener; import org.apache.myfaces.config.FacesConfigurator; import org.apache.myfaces.context.servlet.ServletExternalContextImpl; import org.apache.myfaces.shared_impl.util.StateUtils; import org.apache.myfaces.shared_impl.webapp.webxml.WebXml; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; /** * TODO: Add listener to myfaces-core.tld instead of web.xml * * @author Manfred Geiler (latest modification by $Author$) * @version $Revision$ $Date$ */ public class StartupServletContextListener implements ServletContextListener { private static final Log log = LogFactory.getLog(StartupServletContextListener.class); static final String FACES_INIT_DONE = StartupServletContextListener.class.getName() + ".FACES_INIT_DONE"; public void contextInitialized(ServletContextEvent event) { initFaces(event.getServletContext()); } public static void initFaces(ServletContext servletContext) { try { Boolean b = (Boolean)servletContext.getAttribute(FACES_INIT_DONE); if (b == null || b.booleanValue() == false) { log.trace("Initializing MyFaces"); //Load the configuration ExternalContext externalContext = new ServletExternalContextImpl(servletContext, null, null); //And configure everything new FacesConfigurator(externalContext).configure(); // parse web.xml WebXml.init(externalContext); servletContext.setAttribute(FACES_INIT_DONE, Boolean.TRUE); } else { log.info("MyFaces already initialized"); } } catch (Exception ex) { log.error("Error initializing ServletContext", ex); ex.printStackTrace(); } log.info("ServletContext '" + servletContext.getRealPath("/") + "' initialized."); if(servletContext.getInitParameter(StateUtils.INIT_SECRET) != null) StateUtils.initSecret(servletContext); } public void contextDestroyed(ServletContextEvent e) { FactoryFinder.releaseFactories(); } }