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

org.apache.logging.log4j.core.config.status.StatusConfiguration Maven / Gradle / Ivy

There is a newer version: 3.0.0-beta2
Show 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.logging.log4j.core.config.status;

import edu.umd.cs.findbugs.annotations.Nullable;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.PrintStream;
import java.net.URI;
import java.net.URISyntaxException;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
import org.apache.logging.log4j.Level;
import org.apache.logging.log4j.core.util.FileUtils;
import org.apache.logging.log4j.core.util.NetUtils;
import org.apache.logging.log4j.status.StatusConsoleListener;
import org.apache.logging.log4j.status.StatusLogger;

/**
 * Configuration for setting up the {@link StatusLogger} fallback listener.
 */
public class StatusConfiguration {

    private static final StatusLogger LOGGER = StatusLogger.getLogger();

    private final Lock lock = new ReentrantLock();

    private volatile boolean initialized;

    @Nullable
    private PrintStream output;

    @Nullable
    private Level level;

    /**
     * Specifies how verbose the StatusLogger should be.
     * @deprecated This class is not used anymore and only kept for binary backward compatibility.
     */
    @Deprecated
    public enum Verbosity {
        QUIET,
        VERBOSE;

        /**
         * Parses the verbosity property into an enum.
         *
         * @param value property value to parse.
         * @return enum corresponding to value, or QUIET by default.
         * @deprecated This class is not used anymore and only kept for binary backward compatibility.
         */
        @Deprecated
        public static Verbosity toVerbosity(final String value) {
            return Boolean.parseBoolean(value) ? VERBOSE : QUIET;
        }
    }

    /**
     * Logs an error message to the {@link StatusLogger}.
     *
     * @param message error message to log
     * @deprecated Use {@link StatusLogger#getLogger()} and then {@link StatusLogger#error(String)} instead.
     */
    @Deprecated
    public void error(final String message) {
        LOGGER.error(message);
    }

    /**
     * Sets the output of the {@link StatusLogger} fallback listener.
     * 

* Accepted values are as follows: *

*
    *
  • {@code out} (i.e., {@link System#out})
  • *
  • {@code err} (i.e., {@link System#err})
  • *
  • a URI (e.g., {@code file:///path/to/log4j-status-logs.txt})
  • *
*

* Invalid values will be ignored. *

* * @param destination destination where {@link StatusLogger} messages should be output * @return {@code this} */ public StatusConfiguration withDestination(@Nullable final String destination) { try { this.output = parseStreamName(destination); } catch (final URISyntaxException error) { LOGGER.error("Could not parse provided URI: {}", destination, error); } catch (final FileNotFoundException error) { LOGGER.error("File could not be found: {}", destination, error); } return this; } @Nullable private static PrintStream parseStreamName(@Nullable final String name) throws URISyntaxException, FileNotFoundException { if (name != null) { if (name.equalsIgnoreCase("out")) { return System.out; } else if (name.equalsIgnoreCase("err")) { return System.err; } else { final URI destUri = NetUtils.toURI(name); final File output = FileUtils.fileFromUri(destUri); if (output != null) { final FileOutputStream fos = new FileOutputStream(output); return new PrintStream(fos, true); } } } return null; } /** * Sets the level of the {@link StatusLogger} fallback listener. * * @param level a level name * @return {@code this} */ public StatusConfiguration withStatus(@Nullable final String level) { this.level = Level.toLevel(level, null); if (this.level == null) { LOGGER.error("Invalid status level: {}", level); } return this; } /** * Sets the level of the {@link StatusLogger} fallback listener. * * @param level a level * @return {@code this} */ public StatusConfiguration withStatus(@Nullable final Level level) { this.level = level; return this; } /** * Specifies the verbosity level to log at. This only applies to classes configured by * {@link #withVerboseClasses(String...) verboseClasses}. * * @param verbosity basic filter for status logger messages. * @return {@code this} * @deprecated This method is ineffective and only kept for binary backward compatibility. */ @Deprecated public StatusConfiguration withVerbosity(final String verbosity) { return this; } /** * Specifies which class names to filter if the configured verbosity level is QUIET. * * @param verboseClasses names of classes to filter if not using VERBOSE. * @return {@code this} * @deprecated This method is ineffective and only kept for binary backward compatibility. */ @Deprecated public StatusConfiguration withVerboseClasses(final String... verboseClasses) { return this; } /** * Configures and initializes the StatusLogger using the configured options in this instance. */ public void initialize() { lock.lock(); try { if (!this.initialized) { final StatusConsoleListener fallbackListener = LOGGER.getFallbackListener(); if (output != null) { fallbackListener.setStream(output); } if (level != null) { fallbackListener.setLevel(level); } initialized = true; } } finally { lock.unlock(); } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy