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

cn.nukkit.plugin.PluginLogger Maven / Gradle / Ivy

There is a newer version: 1.20.40-r1
Show newest version
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