net.anwiba.commons.logging.LoggingUtilities Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of anwiba-commons-core Show documentation
Show all versions of anwiba-commons-core Show documentation
anwiba commons core library project
/*
* #%L
* anwiba commons core
* %%
* Copyright (C) 2007 - 2016 Andreas Bartels
* %%
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation, either version 2.1 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Lesser Public License for more details.
*
* You should have received a copy of the GNU General Lesser Public
* License along with this program. If not, see
* .
* #L%
*/
package net.anwiba.commons.logging;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStream;
import java.text.MessageFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashSet;
import java.util.List;
import java.util.Properties;
import java.util.Set;
import java.util.StringTokenizer;
import java.util.logging.ConsoleHandler;
import java.util.logging.FileHandler;
import java.util.logging.Formatter;
import java.util.logging.Handler;
import java.util.logging.Level;
import java.util.logging.SimpleFormatter;
import org.apache.log4j.LogManager;
import org.apache.log4j.PropertyConfigurator;
import org.apache.log4j.xml.DOMConfigurator;
public class LoggingUtilities {
private static final String CONSOLE = "console"; //$NON-NLS-1$
private static final String DEFAULT_XML_LOG_CONFIGURATION_FILE = "log4j.xml"; //$NON-NLS-1$
private static final String DEFAULT_PROPERTIES_LOG_CONFIGURATION_FILE = "log.properties"; //$NON-NLS-1$
private static final String NET_ANWIBA_LOGGING_CONFIGURATION = "net.anwiba.logging.configuration"; //$NON-NLS-1$
private static final String CONSOLE_HANDLER = CONSOLE;
private static final String NET_ANWIBA = "net.anwiba"; //$NON-NLS-1$
private static final String FILE = "file"; //$NON-NLS-1$
private static final String FILE_HANDLER = "FILE"; //$NON-NLS-1$
private static final String HANDLER = "handler"; //$NON-NLS-1$
private static final String LEVEL = "level"; //$NON-NLS-1$
public static void initialize() {
final String loggingConfigurationFileName = getLoggingConfigurationFileName();
initialize(loggingConfigurationFileName);
}
private static String getLoggingConfigurationFileName() {
final String loggingConfigurationFileName = System.getProperty(NET_ANWIBA_LOGGING_CONFIGURATION);
if (loggingConfigurationFileName != null && new File(loggingConfigurationFileName).exists()) {
return loggingConfigurationFileName;
}
final File xmlFile = getFile(DEFAULT_XML_LOG_CONFIGURATION_FILE);
if (xmlFile.exists()) {
return xmlFile.getAbsolutePath();
}
final File propertiesFile = getFile(DEFAULT_PROPERTIES_LOG_CONFIGURATION_FILE);
if (propertiesFile.exists()) {
return propertiesFile.getAbsolutePath();
}
return null;
}
public static File getFile(final String name) {
final String classpath = System.getProperty("java.class.path"); //$NON-NLS-1$
final StringTokenizer tokenizer = new StringTokenizer(classpath, File.pathSeparator);
if (tokenizer.hasMoreTokens()) {
final String pathName = tokenizer.nextToken();
final File path = new File(pathName);
if (new File(path.getParentFile(), name).exists()) {
return new File(path.getParentFile(), name);
}
}
return new File(new File(System.getProperty("user.dir")), name); //$NON-NLS-1$
}
public static void initialize(final InputStream inputStream) {
try {
new DOMConfigurator().doConfigure(inputStream, LogManager.getLoggerRepository());
final ILogger logger = Logging.getLogger(LoggingUtilities.class.getName());
logger.log(ILevel.DEBUG, "initialized logging by inputstream"); //$NON-NLS-1$
} catch (final SecurityException exception) {
exception.printStackTrace();
}
}
public static void initialize(final String loggingConfigurationFileName) {
try {
final boolean log4jAvailable = isLog4JAvailable();
if (!log4jAvailable) {
initializeJavaLogging(loggingConfigurationFileName);
return;
}
if (loggingConfigurationFileName == null || loggingConfigurationFileName.trim().isEmpty()) {
final Properties properties = createDefaultLogging("INFO", create(CONSOLE, FILE)); //$NON-NLS-1$
PropertyConfigurator.configure(properties);
return;
}
if (loggingConfigurationFileName.trim().toLowerCase().endsWith(".xml")) { //$NON-NLS-1$
DOMConfigurator.configure(loggingConfigurationFileName);
final ILogger logger = Logging.getLogger(LoggingUtilities.class.getName());
logger.log(ILevel.DEBUG, "initialized logging by file " + loggingConfigurationFileName); //$NON-NLS-1$
return;
}
Properties properties = loadProperties(loggingConfigurationFileName);
properties = properties.isEmpty() ? createDefaultLogging("INFO", create(CONSOLE, FILE)) : properties; //$NON-NLS-1$
PropertyConfigurator.configure(properties);
final ILogger logger = Logging.getLogger(LoggingUtilities.class.getName());
logger.log(ILevel.DEBUG, "initialized logging by file " + loggingConfigurationFileName); //$NON-NLS-1$
logger.log(
ILevel.DEBUG,
MessageFormat.format("for file {0}", properties.getProperty("log4j.appender.file.File", "none"))); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$
} catch (final SecurityException exception) {
exception.printStackTrace();
} catch (final IOException exception) {
exception.printStackTrace();
}
}
private static Set create(final String... values) {
return new HashSet<>(Arrays.asList(values));
}
private static boolean isLog4JAvailable() {
try {
Class.forName("org.apache.log4j.Logger"); //$NON-NLS-1$
return true;
} catch (final Throwable exception) {
// System.err.println("Class not found: org.apache.log4j.Logger"); //$NON-NLS-1$
return false;
}
}
public static void initalize(final String level, final String... namespaces) {
final Properties properties = createDefaultLogging(level, create(CONSOLE), namespaces);
PropertyConfigurator.configure(properties);
}
@SuppressWarnings("nls")
private static Properties createDefaultLogging(
final String level,
final Set appenders,
final String... namespaces) {
final Properties properties = new Properties();
for (final String namespace : namespaces) {
properties.put("log4j.logger." + namespace, level);
}
if (appenders.contains(CONSOLE)) {
properties.put("log4j.logger.net.anwiba", level);
properties.put("log4j.appender.SYSTEM_OUT", "org.apache.log4j.ConsoleAppender");
properties.put("log4j.appender.SYSTEM_OUT.layout", "org.apache.log4j.PatternLayout");
properties.put("log4j.appender.SYSTEM_OUT.layout.ConversionPattern", "%d{ISO8601} %-5p [%t] %-25.25c - %m%n");
properties.put("log4j.rootLogger", MessageFormat.format("{0}, SYSTEM_OUT, FILE", level));
}
if (appenders.contains(FILE)) {
properties.put("log4j.appender.file", "org.apache.log4j.RollingFileAppender");
properties.put("log4j.appender.file.File", getLogFileName(null));
properties.put("log4j.appender.file.DatePattern", "'_'yyyy-MM-dd'.log'");
properties.put("log4j.appender.file.layout", "org.apache.log4j.PatternLayout");
properties.put("log4j.appender.file.layout.ConversionPattern", "[%p] [%d{dd.MM.yyyy-HH:mm:ss}] %m%n");
}
return properties;
}
public static void initializeJavaLogging(final String propertiesFileName) {
try {
if (propertiesFileName == null || propertiesFileName.trim().isEmpty()) {
return;
}
final Properties properties = loadProperties(propertiesFileName);
final SimpleFormatter formatter = new SimpleFormatter();
final Handler[] handlers = createHandler(properties, formatter);
final String levelName = (String) properties.get(LEVEL);
initializeLogger(levelName == null ? ILevel.DEBUG : Level.parse(levelName), handlers);
final ILogger logger = Logging.getLogger(LoggingUtilities.class.getName());
logger.log(ILevel.DEBUG, "initialized logging by file " + propertiesFileName); //$NON-NLS-1$
logger.log(ILevel.DEBUG, "for file " + properties.getProperty("log4j.appender.file.File", "none")); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$
logger.log(ILevel.DEBUG, "initialized logging level " + levelName); //$NON-NLS-1$
} catch (final SecurityException exception) {
exception.printStackTrace();
} catch (final IOException exception) {
exception.printStackTrace();
}
}
private static Handler[] createDefaultHandler(final Formatter formatter) throws IOException {
final Handler fileHandler = new FileHandler(getLogFileName(null), false);
fileHandler.setFormatter(formatter);
return new Handler[]{ fileHandler };
}
private static Properties loadProperties(final String propertiesFileName) throws IOException, FileNotFoundException {
final Properties properties = new Properties();
final File propertiesFile = new File(propertiesFileName);
if (!propertiesFile.exists()) {
return properties;
}
try (FileReader reader = new FileReader(propertiesFile);) {
properties.load(reader);
}
return properties;
}
private static void initializeLogger(final Level level, final Handler... handlers) {
Logging.setHandler(handlers);
Logging.setLevel(level, NET_ANWIBA);
}
private static Handler[] createHandler(final Properties properties, final Formatter formatter)
throws SecurityException,
IOException {
final String handlerList = (String) properties.get(HANDLER);
if (handlerList == null) {
return createDefaultHandler(formatter);
}
final List handlers = new ArrayList<>();
final StringTokenizer tokenizer = new StringTokenizer(handlerList, ","); //$NON-NLS-1$
while (tokenizer.hasMoreElements()) {
final String handlerType = (String) tokenizer.nextElement();
final Handler handler;
if (handlerType.equalsIgnoreCase(FILE_HANDLER)) {
final String file = (String) properties.get(FILE);
handler = new FileHandler(getLogFileName(file), false);
} else if (handlerType.equalsIgnoreCase(CONSOLE_HANDLER)) {
handler = new ConsoleHandler();
} else {
continue;
}
handler.setFormatter(formatter);
handlers.add(handler);
}
return handlers.toArray(new Handler[handlers.size()]);
}
private static String getLogFileName(final String file) {
if (file == null) {
return getPathName() + File.separator + "viewer.log.%u"; //$NON-NLS-1$
}
return file;
}
private static String getPathName() {
final String pathName = System.getProperty("user.home") + File.separator + ".anwiba"; //$NON-NLS-1$ //$NON-NLS-2$
final File file = new File(pathName);
if (!file.exists()) {
if (!file.mkdirs()) {
return System.getProperty("user.home"); //$NON-NLS-1$
}
}
return pathName;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy