edu.internet2.middleware.grouperInstaller.util.GrouperInstallerLog Maven / Gradle / Ivy
/*******************************************************************************
* Copyright 2012 Internet2
*
* 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.
******************************************************************************/
/*
* @author mchyzer
* $Id: GrouperClientLog.java,v 1.1 2008-12-04 07:51:39 mchyzer Exp $
*/
package edu.internet2.middleware.grouperInstaller.util;
import org.apache.commons.logging.Log;
/**
*
*/
public class GrouperInstallerLog implements Log {
/** debug to console */
private static ThreadLocal debugToConsole = new ThreadLocal();
/**
* if we should debug to console
* @param theDebugToConsole
*/
public static void assignDebugToConsole(boolean theDebugToConsole) {
debugToConsole.set(theDebugToConsole);
}
/**
* if we should debug to console
* @return if debug to console
*/
public static boolean debugToConsole() {
Boolean debugToConsoleBoolean = debugToConsole.get();
return GrouperInstallerUtils.defaultIfNull(debugToConsoleBoolean, false);
}
/**
* debug to console if needed
* @param prefix
* @param message
* @param t
*/
private static void debugToConsoleIfNeeded(String prefix, Object message, Throwable t) {
if (debugToConsole()) {
System.err.print(prefix);
System.err.println(message);
if (t != null) {
t.printStackTrace();
}
}
}
/** wrap this log */
private Log enclosedLog;
/**
* wrap a logger
* @param theLog
*/
public GrouperInstallerLog(Log theLog) {
this.enclosedLog = theLog;
}
/**
* @see org.apache.commons.logging.Log#debug(java.lang.Object)
*/
public void debug(Object message) {
debugToConsoleIfNeeded("DEBUG: ", message, null);
this.enclosedLog.debug(message);
}
/**
* @see org.apache.commons.logging.Log#debug(java.lang.Object, java.lang.Throwable)
*/
public void debug(Object message, Throwable t) {
debugToConsoleIfNeeded("DEBUG: ", message, t);
this.enclosedLog.debug(message, t);
}
/**
* @see org.apache.commons.logging.Log#error(java.lang.Object)
*/
public void error(Object message) {
debugToConsoleIfNeeded("ERROR: ", message, null);
this.enclosedLog.error(message);
}
/**
* @see org.apache.commons.logging.Log#error(java.lang.Object, java.lang.Throwable)
*/
public void error(Object message, Throwable t) {
debugToConsoleIfNeeded("ERROR: ", message, t);
this.enclosedLog.error(message, t);
}
/**
* @see org.apache.commons.logging.Log#fatal(java.lang.Object)
*/
public void fatal(Object message) {
debugToConsoleIfNeeded("FATAL: ", message, null);
this.enclosedLog.fatal(message);
}
/**
* @see org.apache.commons.logging.Log#fatal(java.lang.Object, java.lang.Throwable)
*/
public void fatal(Object message, Throwable t) {
debugToConsoleIfNeeded("FATAL: ", message, t);
this.enclosedLog.fatal(message, t);
}
/**
* @see org.apache.commons.logging.Log#info(java.lang.Object)
*/
public void info(Object message) {
debugToConsoleIfNeeded("INFO: ", message, null);
this.enclosedLog.info(message);
}
/**
* @see org.apache.commons.logging.Log#info(java.lang.Object, java.lang.Throwable)
*/
public void info(Object message, Throwable t) {
debugToConsoleIfNeeded("INFO: ", message, t);
this.enclosedLog.info(message, t);
}
/**
* @see org.apache.commons.logging.Log#isDebugEnabled()
*/
public boolean isDebugEnabled() {
return this.enclosedLog.isDebugEnabled();
}
/**
* @see org.apache.commons.logging.Log#isErrorEnabled()
*/
public boolean isErrorEnabled() {
return this.enclosedLog.isErrorEnabled();
}
/**
* @see org.apache.commons.logging.Log#isFatalEnabled()
*/
public boolean isFatalEnabled() {
return this.enclosedLog.isFatalEnabled();
}
/**
* @see org.apache.commons.logging.Log#isInfoEnabled()
*/
public boolean isInfoEnabled() {
return this.enclosedLog.isInfoEnabled();
}
/**
* @see org.apache.commons.logging.Log#isTraceEnabled()
*/
public boolean isTraceEnabled() {
return this.enclosedLog.isTraceEnabled();
}
/**
* @see org.apache.commons.logging.Log#isWarnEnabled()
*/
public boolean isWarnEnabled() {
return this.enclosedLog.isWarnEnabled();
}
/**
* @see org.apache.commons.logging.Log#trace(java.lang.Object)
*/
public void trace(Object message) {
debugToConsoleIfNeeded("TRACE: ", message, null);
this.enclosedLog.trace(message);
}
/**
* @see org.apache.commons.logging.Log#trace(java.lang.Object, java.lang.Throwable)
*/
public void trace(Object message, Throwable t) {
debugToConsoleIfNeeded("TRACE: ", message, t);
this.enclosedLog.trace(message, t);
}
/**
* @see org.apache.commons.logging.Log#warn(java.lang.Object)
*/
public void warn(Object message) {
debugToConsoleIfNeeded("WARN: ", message, null);
this.enclosedLog.warn(message);
}
/**
* @see org.apache.commons.logging.Log#warn(java.lang.Object, java.lang.Throwable)
*/
public void warn(Object message, Throwable t) {
debugToConsoleIfNeeded("WARN: ", message, t);
this.enclosedLog.warn(message, t);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy