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

org.jooq.tools.JooqLogger Maven / Gradle / Ivy

/**
 * Copyright (c) 2009-2014, Data Geekery GmbH (http://www.datageekery.com)
 * All rights reserved.
 *
 * This work is dual-licensed
 * - under the Apache Software License 2.0 (the "ASL")
 * - under the jOOQ License and Maintenance Agreement (the "jOOQ License")
 * =============================================================================
 * You may choose which license applies to you:
 *
 * - If you're using this work with Open Source databases, you may choose
 *   either ASL or jOOQ License.
 * - If you're using this work with at least one commercial database, you must
 *   choose jOOQ License
 *
 * For more information, please visit http://www.jooq.org/licenses
 *
 * Apache Software License 2.0:
 * -----------------------------------------------------------------------------
 * 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.
 *
 * jOOQ License and Maintenance Agreement:
 * -----------------------------------------------------------------------------
 * Data Geekery grants the Customer the non-exclusive, timely limited and
 * non-transferable license to install and use the Software under the terms of
 * the jOOQ License and Maintenance Agreement.
 *
 * This library is distributed with a LIMITED WARRANTY. See the jOOQ License
 * and Maintenance Agreement for more details: http://www.jooq.org/licensing
 */
package org.jooq.tools;

import java.util.logging.Level;

/**
 * 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 { /** * 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. */ public boolean isTraceEnabled() { if (!supportsTrace) { return false; } else if (slf4j != null) { return slf4j.isTraceEnabled(); } else if (log4j != null) { return log4j.isTraceEnabled(); } else { return util.isLoggable(Level.FINER); } } /** * Log a message in TRACE level. * * @param message The log message */ 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) */ public void trace(Object message, Object details) { 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 */ 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 */ public void trace(Object message, Object details, Throwable throwable) { if (slf4j != null) { slf4j.trace(getMessage(message, details), throwable); } else if (log4j != null) { log4j.trace(getMessage(message, details), throwable); } else { util.log(Level.FINER, "" + getMessage(message, details), throwable); } } /** * Check if DEBUG level logging is enabled. */ public boolean isDebugEnabled() { if (!supportsDebug) { return false; } else if (slf4j != null) { return slf4j.isDebugEnabled(); } else if (log4j != null) { return log4j.isDebugEnabled(); } else { return util.isLoggable(Level.FINE); } } /** * Log a message in DEBUG level. * * @param message The log message */ 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) */ public void debug(Object message, Object details) { 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 */ 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 */ public void debug(Object message, Object details, Throwable throwable) { if (slf4j != null) { slf4j.debug(getMessage(message, details), throwable); } else if (log4j != null) { log4j.debug(getMessage(message, details), throwable); } else { util.log(Level.FINE, "" + getMessage(message, details), throwable); } } /** * Check if INFO level logging is enabled. */ public boolean isInfoEnabled() { if (!supportsInfo) { return false; } else if (slf4j != null) { return slf4j.isInfoEnabled(); } else if (log4j != null) { return log4j.isInfoEnabled(); } else { return util.isLoggable(Level.INFO); } } /** * Log a message in INFO level. * * @param message The log message */ 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) */ public void info(Object message, Object details) { 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 */ 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 */ public void info(Object message, Object details, Throwable throwable) { if (slf4j != null) { slf4j.info(getMessage(message, details), throwable); } else if (log4j != null) { log4j.info(getMessage(message, details), throwable); } else { util.log(Level.INFO, "" + getMessage(message, details), throwable); } } /** * Log a message in WARN level. * * @param message The log message */ 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) */ public void warn(Object message, Object details) { 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 */ 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 */ public void warn(Object message, Object details, Throwable throwable) { if (slf4j != null) { slf4j.warn(getMessage(message, details), throwable); } else if (log4j != null) { log4j.warn(getMessage(message, details), throwable); } else { util.log(Level.WARNING, "" + getMessage(message, details), throwable); } } /** * Log a message in ERROR level. * * @param message The log message */ 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) */ public void error(Object message, Object details) { 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 */ 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 */ public void error(Object message, Object details, Throwable throwable) { if (slf4j != null) { slf4j.error(getMessage(message, details), throwable); } else if (log4j != null) { log4j.error(getMessage(message, details), throwable); } else { util.log(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(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy