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

io.quarkus.devui.runtime.logstream.MutinyLogHandler Maven / Gradle / Ivy

package io.quarkus.devui.runtime.logstream;

import java.util.List;

import org.jboss.logmanager.ExtHandler;
import org.jboss.logmanager.ExtLogRecord;

import io.quarkus.arc.Arc;
import io.quarkus.runtime.logging.DecorateStackUtil;
import io.vertx.core.json.JsonObject;

/**
 * Log handler for Logger Manager
 */
public class MutinyLogHandler extends ExtHandler {

    private LogStreamBroadcaster logStreamBroadcaster;
    private final boolean decorateStack;
    private final String srcMainJava;
    private final List knownClasses;

    public MutinyLogHandler(boolean decorateStack, String srcMainJava, List knownClasses) {
        this.decorateStack = decorateStack;
        this.srcMainJava = srcMainJava;
        this.knownClasses = knownClasses;
        setFormatter(new JsonFormatter());
    }

    @Override
    public final void doPublish(final ExtLogRecord record) {
        // Don't log empty messages
        if (record.getMessage() == null || record.getMessage().isEmpty()) {
            return;
        }

        if (isLoggable(record)) {
            LogStreamBroadcaster broadcaster = getBroadcaster();
            if (broadcaster != null) {
                JsonObject message = ((JsonFormatter) getFormatter()).toJsonObject(record);
                if (decorateStack) {
                    String decoratedString = DecorateStackUtil.getDecoratedString(record.getThrown(), this.srcMainJava,
                            knownClasses);
                    if (decoratedString != null) {
                        message.put("decoration", decoratedString);
                    }
                }

                broadcaster.onNext(message);
            }
        }
    }

    private LogStreamBroadcaster getBroadcaster() {
        synchronized (this) {
            if (this.logStreamBroadcaster == null && Arc.container() != null) {
                this.logStreamBroadcaster = Arc.container().instance(LogStreamBroadcaster.class).get();
            }
        }
        return this.logStreamBroadcaster;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy