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