psiprobe.tools.logging.jdk.Jdk14HandlerAccessor Maven / Gradle / Ivy
/*
* Licensed under the GPL License. You may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.gnu.org/licenses/old-licenses/gpl-2.0.html
*
* THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING,
* WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR
* PURPOSE.
*/
package psiprobe.tools.logging.jdk;
import org.apache.commons.lang3.reflect.MethodUtils;
import psiprobe.tools.logging.AbstractLogDestination;
/**
* The Class Jdk14HandlerAccessor.
*/
public class Jdk14HandlerAccessor extends AbstractLogDestination {
/** The logger accessor. */
private Jdk14LoggerAccessor loggerAccessor;
/** The index. */
private String index;
/**
* Gets the logger accessor.
*
* @return the logger accessor
*/
public Jdk14LoggerAccessor getLoggerAccessor() {
return loggerAccessor;
}
/**
* Sets the logger accessor.
*
* @param loggerAccessor the new logger accessor
*/
public void setLoggerAccessor(Jdk14LoggerAccessor loggerAccessor) {
this.loggerAccessor = loggerAccessor;
}
@Override
public boolean isContext() {
return getLoggerAccessor().isContext();
}
@Override
public boolean isRoot() {
return getLoggerAccessor().isRoot();
}
@Override
public String getName() {
return getLoggerAccessor().getName();
}
@Override
public String getIndex() {
return index;
}
/**
* Sets the index.
*
* @param index the new index
*/
public void setIndex(String index) {
this.index = index;
}
@Override
public String getLogType() {
return "jdk";
}
@Override
public String getLevel() {
return getLoggerAccessor().getLevel();
}
/**
* Sets the level.
*
* @param newLevelStr the new level
*/
public void setLevel(String newLevelStr) {
try {
Object level = MethodUtils.invokeMethod(getTarget(), "getLevel");
Object newLevel = MethodUtils.invokeMethod(level, "parse", newLevelStr);
MethodUtils.invokeMethod(getTarget(), "setLevel", newLevel);
} catch (Exception e) {
logger.error("{}#setLevel('{}') failed", getTarget().getClass().getName(), newLevelStr, e);
}
}
@Override
public String[] getValidLevels() {
return new String[] {"OFF", "SEVERE", "WARNING", "INFO", "CONFIG", "FINE", "FINER", "FINEST",
"ALL"};
}
}