package ch.qos.logback.classic.sift;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import ch.qos.logback.classic.spi.ILoggingEvent;
import ch.qos.logback.classic.util.DefaultNestedComponentRules;
import ch.qos.logback.core.Appender;
import ch.qos.logback.core.joran.action.ActionConst;
import ch.qos.logback.core.joran.action.AppenderAction;
import ch.qos.logback.core.joran.spi.DefaultNestedComponentRegistry;
import ch.qos.logback.core.joran.spi.ElementPath;
import ch.qos.logback.core.joran.spi.ElementSelector;
import ch.qos.logback.core.joran.spi.RuleStore;
import ch.qos.logback.core.sift.SiftingJoranConfiguratorBase;
public class SiftingJoranConfigurator extends SiftingJoranConfiguratorBase<ILoggingEvent> {
SiftingJoranConfigurator(String key, String value, Map<String, String> parentPropertyMap) {
super(key, value, parentPropertyMap);
}
@Override
protected ElementPath initialElementPath() {
return new ElementPath("configuration");
}
@Override
protected void addInstanceRules(RuleStore rs) {
super.addInstanceRules(rs);
rs.addRule(new ElementSelector("configuration/appender"), new AppenderAction<ILoggingEvent>());
}
@Override
protected void addDefaultNestedComponentRegistryRules(DefaultNestedComponentRegistry registry) {
DefaultNestedComponentRules.addDefaultNestedComponentRegistryRules(registry);
}
@Override
protected void buildInterpreter() {
super.buildInterpreter();
Map<String, Object> omap = interpreter.getInterpretationContext().getObjectMap();
omap.put(ActionConst.APPENDER_BAG, new HashMap<String, Appender<?>>());
Map<String, String> propertiesMap = new HashMap<String, String>();
propertiesMap.putAll(parentPropertyMap);
propertiesMap.put(key, value);
interpreter.setInterpretationContextPropertiesMap(propertiesMap);
}
@SuppressWarnings("unchecked")
public Appender<ILoggingEvent> getAppender() {
Map<String, Object> omap = interpreter.getInterpretationContext().getObjectMap();
HashMap<String, Appender<?>> appenderMap = (HashMap<String, Appender<?>>) omap.get(ActionConst.APPENDER_BAG);
oneAndOnlyOneCheck(appenderMap);
Collection<Appender<?>> values = appenderMap.values();
if (values.size() == 0) {
return null;
}
return (Appender<ILoggingEvent>) values.iterator().next();
}
}