001/**
002 * Logback: the reliable, generic, fast and flexible logging framework.
003 * Copyright (C) 1999-2022, QOS.ch. All rights reserved.
004 *
005 * This program and the accompanying materials are dual-licensed under
006 * either the terms of the Eclipse Public License v1.0 as published by
007 * the Eclipse Foundation
008 *
009 *   or (per the licensee's choosing)
010 *
011 * under the terms of the GNU Lesser General Public License version 2.1
012 * as published by the Free Software Foundation.
013 */
014package ch.qos.logback.access.common.model.processor;
015
016import ch.qos.logback.access.common.model.ConfigurationModel;
017import ch.qos.logback.core.Context;
018import ch.qos.logback.core.model.Model;
019import ch.qos.logback.core.model.processor.ModelHandlerBase;
020import ch.qos.logback.core.model.processor.ModelHandlerException;
021import ch.qos.logback.core.model.processor.ModelInterpretationContext;
022import ch.qos.logback.core.status.OnConsoleStatusListener;
023import ch.qos.logback.core.util.OptionHelper;
024import ch.qos.logback.core.util.StatusListenerConfigHelper;
025
026public class ConfigurationModelHandler extends ModelHandlerBase {
027    static final String DEBUG_SYSTEM_PROPERTY_KEY = "logback-access.debug";
028
029    public ConfigurationModelHandler(Context context) {
030        super(context);
031    }
032
033    static public ModelHandlerBase makeInstance(Context context, ModelInterpretationContext ic) {
034        return new ConfigurationModelHandler(context);
035    }
036
037    protected Class<ConfigurationModel> getSupportedModelClass() {
038        return ConfigurationModel.class;
039    }
040
041    @Override
042    public void handle(ModelInterpretationContext mic, Model model) throws ModelHandlerException {
043        ConfigurationModel configurationModel = (ConfigurationModel) model;
044        // See LBCLASSIC-225 (the system property is looked up first). Thus, it overrides
045        // the equivalent property in the config file. This reversal of scope priority
046        // is justified
047        // by the use case: the admin trying to chase rogue config file
048        String debug = System.getProperty(DEBUG_SYSTEM_PROPERTY_KEY);
049        if (debug == null) {
050            debug = configurationModel.getDebug();
051        }
052        if (OptionHelper.isNullOrEmpty(debug) || debug.equals("false") || debug.equals("null")) {
053            addInfo(ConfigurationModel.INTERNAL_DEBUG_ATTR + " attribute not set");
054        } else {
055            StatusListenerConfigHelper.addOnConsoleListenerInstance(context, new OnConsoleStatusListener());
056        }
057
058    }
059}