001package ch.qos.logback.classic.servlet;
002
003import static ch.qos.logback.core.CoreConstants.DISABLE_SERVLET_CONTAINER_INITIALIZER_KEY;
004
005import java.util.Set;
006
007import javax.servlet.ServletContainerInitializer;
008import javax.servlet.ServletContext;
009import javax.servlet.ServletException;
010
011import ch.qos.logback.classic.util.StatusViaSLF4JLoggerFactory;
012import ch.qos.logback.core.util.OptionHelper;
013
014/**
015 * Attaches a new instance of {@link LogbackServletContextListener} to the
016 * current web-applications {@link ServletContext}.
017 * 
018 * @author Ceki Gulcu
019 * @since 1.1.10
020 */
021public class LogbackServletContainerInitializer implements ServletContainerInitializer {
022
023    @Override
024    public void onStartup(Set<Class<?>> c, ServletContext ctx) throws ServletException {
025
026        if (isDisabledByConfiguration(ctx)) {
027            StatusViaSLF4JLoggerFactory.addInfo("Due to deployment instructions will NOT register an instance of "
028                    + LogbackServletContextListener.class + " to the current web-app", this);
029
030            return;
031        }
032
033        StatusViaSLF4JLoggerFactory.addInfo(
034                "Adding an instance of  " + LogbackServletContextListener.class + " to the current web-app", this);
035        LogbackServletContextListener lscl = new LogbackServletContextListener();
036        ctx.addListener(lscl);
037    }
038
039    /**
040     * Search for value of DISABLE_SERVLET_CONTAINER_INITIALIZER_KEY in the web-app
041     * first, then as a system property and as an environment variable last.
042     *
043     * @param ctx
044     * @return True if value of DISABLE_SERVLET_CONTAINER_INITIALIZER_KEY is
045     *         available and set to "true", false otherwise.
046     */
047    boolean isDisabledByConfiguration(ServletContext ctx) {
048        String disableAttributeStr = null;
049        Object disableAttribute = ctx.getInitParameter(DISABLE_SERVLET_CONTAINER_INITIALIZER_KEY);
050        if (disableAttribute instanceof String) {
051            disableAttributeStr = (String) disableAttribute;
052        }
053
054        if (OptionHelper.isNullOrEmpty(disableAttributeStr)) {
055            disableAttributeStr = OptionHelper.getSystemProperty(DISABLE_SERVLET_CONTAINER_INITIALIZER_KEY);
056        }
057
058        if (OptionHelper.isNullOrEmpty(disableAttributeStr)) {
059            disableAttributeStr = OptionHelper.getEnv(DISABLE_SERVLET_CONTAINER_INITIALIZER_KEY);
060        }
061
062        return Boolean.parseBoolean(disableAttributeStr);
063    }
064
065}