All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.log4j.builders.AbstractBuilder Maven / Gradle / Ivy

The newest version!
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements. See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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.log4j.builders;

import static org.apache.log4j.xml.XmlConfiguration.NAME_ATTR;
import static org.apache.log4j.xml.XmlConfiguration.VALUE_ATTR;

import java.util.HashMap;
import java.util.Map;
import java.util.Properties;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.concurrent.atomic.AtomicLong;
import java.util.concurrent.atomic.AtomicReference;

import org.apache.log4j.bridge.FilterAdapter;
import org.apache.log4j.bridge.FilterWrapper;
import org.apache.log4j.helpers.OptionConverter;
import org.apache.log4j.spi.Filter;
import org.apache.logging.log4j.Level;
import org.apache.logging.log4j.Logger;
import org.apache.logging.log4j.core.filter.ThresholdFilter;
import org.apache.logging.log4j.status.StatusLogger;
import org.apache.logging.log4j.util.Strings;
import org.w3c.dom.Element;

/**
 * Base class for Log4j 1 component builders.
 *
 * @param  The type to build.
 */
public abstract class AbstractBuilder implements Builder {

    private static Logger LOGGER = StatusLogger.getLogger();
    protected static final String FILE_PARAM = "File";
    protected static final String APPEND_PARAM = "Append";
    protected static final String BUFFERED_IO_PARAM = "BufferedIO";
    protected static final String BUFFER_SIZE_PARAM = "BufferSize";
    protected static final String IMMEDIATE_FLUSH_PARAM = "ImmediateFlush";
    protected static final String MAX_SIZE_PARAM = "MaxFileSize";
    protected static final String MAX_BACKUP_INDEX = "MaxBackupIndex";
    protected static final String RELATIVE = "RELATIVE";
    protected static final String NULL = "NULL";

    private final String prefix;
    private final Properties properties;

    public AbstractBuilder() {
        this(null, new Properties());
    }

    public AbstractBuilder(final String prefix, final Properties props) {
        this.prefix = prefix != null ? prefix + "." : null;
        this.properties = (Properties) props.clone();
        final Map map = new HashMap<>();
        System.getProperties().forEach((k, v) -> map.put(k.toString(), v.toString()));
        props.forEach((k, v) -> map.put(k.toString(), v.toString()));
        // normalize keys to lower case for case-insensitive access.
        props.forEach((k, v) -> map.put(toBeanKey(k.toString()), v.toString()));
        props.entrySet().forEach(e -> this.properties.put(toBeanKey(e.getKey().toString()), e.getValue()));
    }

    protected static org.apache.logging.log4j.core.Filter buildFilters(final String level, final Filter filter) {
        Filter head = null;
        if (level != null) {
            final org.apache.logging.log4j.core.Filter thresholdFilter = ThresholdFilter.createFilter(OptionConverter.convertLevel(level, Level.TRACE),
                org.apache.logging.log4j.core.Filter.Result.NEUTRAL, org.apache.logging.log4j.core.Filter.Result.DENY);
            head = new FilterWrapper(thresholdFilter);
        }
        if (filter != null) {
            head = FilterAdapter.addFilter(head, filter);
        }
        return FilterAdapter.adapt(head);
    }

    private String capitalize(final String value) {
        if (Strings.isEmpty(value) || Character.isUpperCase(value.charAt(0))) {
            return value;
        }
        final char[] chars = value.toCharArray();
        chars[0] = Character.toUpperCase(chars[0]);
        return new String(chars);
    }

    public boolean getBooleanProperty(final String key, final boolean defaultValue) {
        return Boolean.parseBoolean(getProperty(key, Boolean.toString(defaultValue)));
    }

    public boolean getBooleanProperty(final String key) {
        return getBooleanProperty(key, false);
    }

    protected boolean getBooleanValueAttribute(final Element element) {
        return Boolean.parseBoolean(getValueAttribute(element));
    }

    public int getIntegerProperty(final String key, final int defaultValue) {
        String value = null;
        try {
            value = getProperty(key);
            if (value != null) {
                return Integer.parseInt(value);
            }
        } catch (final Exception ex) {
            LOGGER.warn("Error converting value {} of {} to an integer: {}", value, key, ex.getMessage());
        }
        return defaultValue;
    }

    public long getLongProperty(final String key, final long defaultValue) {
        String value = null;
        try {
            value = getProperty(key);
            if (value != null) {
                return Long.parseLong(value);
            }
        } catch (final Exception ex) {
            LOGGER.warn("Error converting value {} of {} to a long: {}", value, key, ex.getMessage());
        }
        return defaultValue;
    }

    protected String getNameAttribute(final Element element) {
        return element.getAttribute(NAME_ATTR);
    }

    protected String getNameAttributeKey(final Element element) {
        return toBeanKey(element.getAttribute(NAME_ATTR));
    }

    public Properties getProperties() {
        return properties;
    }

    public String getProperty(final String key) {
        return getProperty(key, null);
    }

    public String getProperty(final String key, final String defaultValue) {
        String value = properties.getProperty(prefix + toJavaKey(key));
        value = value != null ? value : properties.getProperty(prefix + toBeanKey(key), defaultValue);
        value = value != null ? substVars(value) : defaultValue;
        return value != null ? value.trim() : defaultValue;
    }

    protected String getValueAttribute(final Element element) {
        return getValueAttribute(element, null);
    }

    protected String getValueAttribute(final Element element, final String defaultValue) {
        final String attribute = element.getAttribute(VALUE_ATTR);
        return substVars(attribute != null ? attribute.trim() : defaultValue);
    }

    protected String substVars(final String value) {
        return OptionConverter.substVars(value, properties);
    }

    String toBeanKey(final String value) {
        return capitalize(value);
    }

    String toJavaKey(final String value) {
        return uncapitalize(value);
    }

    private String uncapitalize(final String value) {
        if (Strings.isEmpty(value) || Character.isLowerCase(value.charAt(0))) {
            return value;
        }
        final char[] chars = value.toCharArray();
        chars[0] = Character.toLowerCase(chars[0]);
        return new String(chars);
    }

    protected void set(final String name, final Element element, AtomicBoolean ref) {
        final String value = getValueAttribute(element);
        if (value == null) {
            LOGGER.warn("No value for {} parameter, using default {}", name, ref);
        } else {
            ref.set(Boolean.parseBoolean(value));
        }
    }

    protected void set(final String name, final Element element, AtomicInteger ref) {
        final String value = getValueAttribute(element);
        if (value == null) {
            LOGGER.warn("No value for {} parameter, using default {}", name, ref);
        } else {
            try {
                ref.set(Integer.parseInt(value));
            } catch (NumberFormatException e) {
                LOGGER.warn("{} parsing {} parameter, using default {}: {}", e.getClass().getName(), name, ref, e.getMessage(), e);
            }
        }
    }

    protected void set(final String name, final Element element, AtomicLong ref) {
        final String value = getValueAttribute(element);
        if (value == null) {
            LOGGER.warn("No value for {} parameter, using default {}", name, ref);
        } else {
            try {
                ref.set(Long.parseLong(value));
            } catch (NumberFormatException e) {
                LOGGER.warn("{} parsing {} parameter, using default {}: {}", e.getClass().getName(), name, ref, e.getMessage(), e);
            }
        }
    }

    protected void set(final String name, final Element element, AtomicReference ref) {
        final String value = getValueAttribute(element);
        if (value == null) {
            LOGGER.warn("No value for {} parameter, using default {}", name, ref);
        } else {
            ref.set(value);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy