cn.nukkit.plugin.PluginLogger Maven / Gradle / Ivy
package cn.nukkit.plugin;
import cn.nukkit.utils.LogLevel;
import cn.nukkit.utils.Logger;
import org.apache.logging.log4j.Level;
import org.apache.logging.log4j.LogManager;
/**
* @author MagicDroidX (Nukkit Project)
*/
public class PluginLogger implements Logger {
private final String pluginName;
private final org.apache.logging.log4j.Logger log;
public PluginLogger(Plugin context) {
String prefix = context.getDescription().getPrefix();
log = LogManager.getLogger(context.getDescription().getMain());
this.pluginName = prefix != null ? prefix : context.getDescription().getName();
}
@Override
public void emergency(String message) {
this.log(LogLevel.EMERGENCY, message);
}
@Override
public void alert(String message) {
this.log(LogLevel.ALERT, message);
}
@Override
public void critical(String message) {
this.log(LogLevel.CRITICAL, message);
}
@Override
public void error(String message) {
this.log(LogLevel.ERROR, message);
}
@Override
public void warning(String message) {
this.log(LogLevel.WARNING, message);
}
@Override
public void notice(String message) {
this.log(LogLevel.NOTICE, message);
}
@Override
public void info(String message) {
this.log(LogLevel.INFO, message);
}
@Override
public void debug(String message) {
this.log(LogLevel.DEBUG, message);
}
private Level toApacheLevel(LogLevel level) {
switch (level) {
case NONE:
return Level.OFF;
case EMERGENCY:
case CRITICAL:
return Level.FATAL;
case ALERT:
case WARNING:
case NOTICE:
return Level.WARN;
case ERROR:
return Level.ERROR;
case DEBUG:
return Level.DEBUG;
default:
return Level.INFO;
}
}
@Override
public void log(LogLevel level, String message) {
log.log(toApacheLevel(level), "[{}]: {}", this.pluginName, message);
}
@Override
public void emergency(String message, Throwable t) {
this.log(LogLevel.EMERGENCY, message, t);
}
@Override
public void alert(String message, Throwable t) {
this.log(LogLevel.ALERT, message, t);
}
@Override
public void critical(String message, Throwable t) {
this.log(LogLevel.CRITICAL, message, t);
}
@Override
public void error(String message, Throwable t) {
this.log(LogLevel.ERROR, message, t);
}
@Override
public void warning(String message, Throwable t) {
this.log(LogLevel.WARNING, message, t);
}
@Override
public void notice(String message, Throwable t) {
this.log(LogLevel.NOTICE, message, t);
}
@Override
public void info(String message, Throwable t) {
this.log(LogLevel.INFO, message, t);
}
@Override
public void debug(String message, Throwable t) {
this.log(LogLevel.DEBUG, message, t);
}
@Override
public void log(LogLevel level, String message, Throwable t) {
log.log(toApacheLevel(level), "[{}]: {}", this.pluginName, message, t);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy