Log4j2Logger.java
package com.jcraft.jsch;
import org.apache.logging.log4j.Level;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
public class Log4j2Logger implements com.jcraft.jsch.Logger {
private static final Logger logger = LogManager.getLogger(JSch.class);
public Log4j2Logger() {}
@Override
public boolean isEnabled(int level) {
return logger.isEnabled(getLevel(level));
}
@Override
public void log(int level, String message) {
logger.log(getLevel(level), message);
}
@Override
public void log(int level, String message, Throwable cause) {
if (cause == null) {
logger.log(getLevel(level), message);
return;
}
logger.log(getLevel(level), message, cause);
}
static Level getLevel(int level) {
switch (level) {
case com.jcraft.jsch.Logger.DEBUG:
return Level.DEBUG;
case com.jcraft.jsch.Logger.INFO:
return Level.INFO;
case com.jcraft.jsch.Logger.WARN:
return Level.WARN;
case com.jcraft.jsch.Logger.ERROR:
return Level.ERROR;
case com.jcraft.jsch.Logger.FATAL:
return Level.FATAL;
default:
return Level.TRACE;
}
}
}