org.jooq.tools.JooqLogger Maven / Gradle / Ivy
/*
* Copyright (c) 2009-2016, Data Geekery GmbH (http://www.datageekery.com)
* All rights reserved.
*
* Licensed 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.
*
* Other licenses:
* -----------------------------------------------------------------------------
* Commercial licenses for this work are available. These replace the above
* ASL 2.0 and offer limited warranties, support, maintenance, and commercial
* database integrations.
*
* For more information, please visit: http://www.jooq.org/licenses
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*/
package org.jooq.tools;
import org.jooq.Log;
/**
* The jOOQ logger abstraction.
*
* This logger provides abstraction over the three logger APIs supported
* optionally by jOOQ. These are (in order of preference):
*
* - slf4j
* - log4j
* - jav.util.logging
*
* JooqLogger
tries to instantiate any of the above loggers,
* catching potential {@link NoClassDefFoundError}'s in case any logger API
* cannot be found on the classpath.
*
* @author Lukas Eder
*/
public final class JooqLogger implements Log {
/**
* The global logger threshold.
*/
private static volatile Log.Level globalThreshold = Log.Level.TRACE;
/**
* The SLF4j Logger instance, if available.
*/
private org.slf4j.Logger slf4j;
/**
* The log4j Logger instance, if available.
*/
private org.apache.log4j.Logger log4j;
/**
* The JDK Logger instance, if available.
*/
private java.util.logging.Logger util;
/**
* Whether calls to {@link #trace(Object)} are possible.
*/
private boolean supportsTrace = true;
/**
* Whether calls to {@link #debug(Object)} are possible.
*/
private boolean supportsDebug = true;
/**
* Whether calls to {@link #info(Object)} are possible.
*/
private boolean supportsInfo = true;
/**
* Get a logger wrapper for a class.
*/
public static JooqLogger getLogger(Class> clazz) {
JooqLogger result = new JooqLogger();
// Prioritise slf4j
try {
result.slf4j = org.slf4j.LoggerFactory.getLogger(clazz);
}
// If that's not on the classpath, try log4j instead
catch (Throwable e1) {
try {
result.log4j = org.apache.log4j.Logger.getLogger(clazz);
}
// If that's not on the classpath either, ignore most of logging
catch (Throwable e2) {
result.util = java.util.logging.Logger.getLogger(clazz.getName());
}
}
// [#2085] Check if any of the INFO, DEBUG, TRACE levels might be
// unavailable, e.g. because client code isn't using the latest version
// of log4j or any other logger
try {
result.isInfoEnabled();
}
catch (Throwable e) {
result.supportsInfo = false;
}
try {
result.isDebugEnabled();
}
catch (Throwable e) {
result.supportsDebug = false;
}
try {
result.isTraceEnabled();
}
catch (Throwable e) {
result.supportsTrace = false;
}
return result;
}
/**
* Check if TRACE
level logging is enabled.
*/
@Override
public boolean isTraceEnabled() {
if (!globalThreshold.supports(Log.Level.TRACE))
return false;
else if (!supportsTrace)
return false;
else if (slf4j != null)
return slf4j.isTraceEnabled();
else if (log4j != null)
return log4j.isTraceEnabled();
else
return util.isLoggable(java.util.logging.Level.FINER);
}
/**
* Log a message in TRACE
level.
*
* @param message The log message
*/
@Override
public void trace(Object message) {
trace(message, (Object) null);
}
/**
* Log a message in TRACE
level.
*
* @param message The log message
* @param details The message details (padded to a constant-width message)
*/
@Override
public void trace(Object message, Object details) {
if (!globalThreshold.supports(Log.Level.TRACE))
return;
else if (slf4j != null)
slf4j.trace(getMessage(message, details));
else if (log4j != null)
log4j.trace(getMessage(message, details));
else
util.finer("" + getMessage(message, details));
}
/**
* Log a message in TRACE
level.
*
* @param message The log message
* @param throwable An exception whose stacktrace is logged along with the
* message
*/
@Override
public void trace(Object message, Throwable throwable) {
trace(message, null, throwable);
}
/**
* Log a message in TRACE
level.
*
* @param message The log message
* @param details The message details (padded to a constant-width message)
* @param throwable An exception whose stacktrace is logged along with the
* message
*/
@Override
public void trace(Object message, Object details, Throwable throwable) {
if (!globalThreshold.supports(Log.Level.TRACE))
return;
else if (slf4j != null)
slf4j.trace(getMessage(message, details), throwable);
else if (log4j != null)
log4j.trace(getMessage(message, details), throwable);
else
util.log(java.util.logging.Level.FINER, "" + getMessage(message, details), throwable);
}
/**
* Check if DEBUG
level logging is enabled.
*/
@Override
public boolean isDebugEnabled() {
if (!globalThreshold.supports(Log.Level.DEBUG))
return false;
else if (!supportsDebug)
return false;
else if (slf4j != null)
return slf4j.isDebugEnabled();
else if (log4j != null)
return log4j.isDebugEnabled();
else
return util.isLoggable(java.util.logging.Level.FINE);
}
/**
* Log a message in DEBUG
level.
*
* @param message The log message
*/
@Override
public void debug(Object message) {
debug(message, (Object) null);
}
/**
* Log a message in DEBUG
level.
*
* @param message The log message
* @param details The message details (padded to a constant-width message)
*/
@Override
public void debug(Object message, Object details) {
if (!globalThreshold.supports(Log.Level.DEBUG))
return;
else if (slf4j != null)
slf4j.debug(getMessage(message, details));
else if (log4j != null)
log4j.debug(getMessage(message, details));
else
util.fine("" + getMessage(message, details));
}
/**
* Log a message in DEBUG
level.
*
* @param message The log message
* @param throwable An exception whose stacktrace is logged along with the
* message
*/
@Override
public void debug(Object message, Throwable throwable) {
debug(message, null, throwable);
}
/**
* Log a message in DEBUG
level.
*
* @param message The log message
* @param details The message details (padded to a constant-width message)
* @param throwable An exception whose stacktrace is logged along with the
* message
*/
@Override
public void debug(Object message, Object details, Throwable throwable) {
if (!globalThreshold.supports(Log.Level.DEBUG))
return;
else if (slf4j != null)
slf4j.debug(getMessage(message, details), throwable);
else if (log4j != null)
log4j.debug(getMessage(message, details), throwable);
else
util.log(java.util.logging.Level.FINE, "" + getMessage(message, details), throwable);
}
/**
* Check if INFO
level logging is enabled.
*/
@Override
public boolean isInfoEnabled() {
if (!globalThreshold.supports(Log.Level.INFO))
return false;
if (!supportsInfo)
return false;
else if (slf4j != null)
return slf4j.isInfoEnabled();
else if (log4j != null)
return log4j.isInfoEnabled();
else
return util.isLoggable(java.util.logging.Level.INFO);
}
/**
* Log a message in INFO
level.
*
* @param message The log message
*/
@Override
public void info(Object message) {
info(message, (Object) null);
}
/**
* Log a message in INFO
level.
*
* @param message The log message
* @param details The message details (padded to a constant-width message)
*/
@Override
public void info(Object message, Object details) {
if (!globalThreshold.supports(Log.Level.INFO))
return;
else if (slf4j != null)
slf4j.info(getMessage(message, details));
else if (log4j != null)
log4j.info(getMessage(message, details));
else
util.info("" + getMessage(message, details));
}
/**
* Log a message in INFO
level.
*
* @param message The log message
* @param throwable An exception whose stacktrace is logged along with the
* message
*/
@Override
public void info(Object message, Throwable throwable) {
info(message, null, throwable);
}
/**
* Log a message in INFO
level.
*
* @param message The log message
* @param details The message details (padded to a constant-width message)
* @param throwable An exception whose stacktrace is logged along with the
* message
*/
@Override
public void info(Object message, Object details, Throwable throwable) {
if (!globalThreshold.supports(Log.Level.INFO))
return;
else if (slf4j != null)
slf4j.info(getMessage(message, details), throwable);
else if (log4j != null)
log4j.info(getMessage(message, details), throwable);
else
util.log(java.util.logging.Level.INFO, "" + getMessage(message, details), throwable);
}
/**
* Log a message in WARN
level.
*
* @param message The log message
*/
@Override
public void warn(Object message) {
warn(message, (Object) null);
}
/**
* Log a message in WARN
level.
*
* @param message The log message
* @param details The message details (padded to a constant-width message)
*/
@Override
public void warn(Object message, Object details) {
if (!globalThreshold.supports(Log.Level.WARN))
return;
else if (slf4j != null)
slf4j.warn(getMessage(message, details));
else if (log4j != null)
log4j.warn(getMessage(message, details));
else
util.warning("" + getMessage(message, details));
}
/**
* Log a message in WARN
level.
*
* @param message The log message
* @param throwable An exception whose stacktrace is logged along with the
* message
*/
@Override
public void warn(Object message, Throwable throwable) {
warn(message, null, throwable);
}
/**
* Log a message in WARN
level.
*
* @param message The log message
* @param details The message details (padded to a constant-width message)
* @param throwable An exception whose stacktrace is logged along with the
* message
*/
@Override
public void warn(Object message, Object details, Throwable throwable) {
if (!globalThreshold.supports(Log.Level.WARN))
return;
else if (slf4j != null)
slf4j.warn(getMessage(message, details), throwable);
else if (log4j != null)
log4j.warn(getMessage(message, details), throwable);
else
util.log(java.util.logging.Level.WARNING, "" + getMessage(message, details), throwable);
}
/**
* Log a message in ERROR
level.
*
* @param message The log message
*/
@Override
public void error(Object message) {
error(message, (Object) null);
}
/**
* Log a message in ERROR
level.
*
* @param message The log message
* @param details The message details (padded to a constant-width message)
*/
@Override
public void error(Object message, Object details) {
if (!globalThreshold.supports(Log.Level.ERROR))
return;
else if (slf4j != null)
slf4j.error(getMessage(message, details));
else if (log4j != null)
log4j.error(getMessage(message, details));
else
util.severe("" + getMessage(message, details));
}
/**
* Log a message in ERROR
level.
*
* @param message The log message
* @param throwable An exception whose stacktrace is logged along with the
* message
*/
@Override
public void error(Object message, Throwable throwable) {
error(message, null, throwable);
}
/**
* Log a message in ERROR
level.
*
* @param message The log message
* @param details The message details (padded to a constant-width message)
* @param throwable An exception whose stacktrace is logged along with the
* message
*/
@Override
public void error(Object message, Object details, Throwable throwable) {
if (!globalThreshold.supports(Log.Level.ERROR))
return;
else if (slf4j != null)
slf4j.error(getMessage(message, details), throwable);
else if (log4j != null)
log4j.error(getMessage(message, details), throwable);
else
util.log(java.util.logging.Level.SEVERE, "" + getMessage(message, details), throwable);
}
/**
* Get a formatted message.
*/
private String getMessage(Object message, Object details) {
StringBuilder sb = new StringBuilder();
sb.append(StringUtils.rightPad("" + message, 25));
if (details != null) {
sb.append(": ");
sb.append(details);
}
return sb.toString();
}
/**
* Set a global level threshold to all JooqLoggers.
*/
public static void globalThreshold(Level level) {
switch (level) {
case TRACE: globalThreshold(Log.Level.TRACE); break;
case DEBUG: globalThreshold(Log.Level.DEBUG); break;
case INFO: globalThreshold(Log.Level.INFO); break;
case WARN: globalThreshold(Log.Level.WARN); break;
case ERROR: globalThreshold(Log.Level.ERROR); break;
case FATAL: globalThreshold(Log.Level.FATAL); break;
}
}
/**
* Set a global level threshold to all JooqLoggers.
*/
public static void globalThreshold(Log.Level level) {
globalThreshold = level;
}
/**
* The log level.
*
* @deprecated - Use {@link org.jooq.Log.Level} instead
*/
@Deprecated
public static enum Level {
TRACE,
DEBUG,
INFO,
WARN,
ERROR,
FATAL;
public boolean supports(Level level) {
return ordinal() <= level.ordinal();
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy