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

io.dropwizard.servlets.tasks.LogConfigurationTask Maven / Gradle / Ivy

There is a newer version: 5.0.0-alpha.5
Show newest version
package io.dropwizard.servlets.tasks;

import ch.qos.logback.classic.Level;
import ch.qos.logback.classic.Logger;
import ch.qos.logback.classic.LoggerContext;
import org.checkerframework.checker.nullness.qual.NonNull;
import org.checkerframework.checker.nullness.qual.Nullable;
import org.slf4j.ILoggerFactory;
import org.slf4j.LoggerFactory;

import java.io.PrintWriter;
import java.time.Duration;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.Timer;
import java.util.TimerTask;
import java.util.concurrent.atomic.AtomicReference;
import java.util.function.Supplier;

/**
 * Sets the logging level for a number of loggers
 * 

* Parameters: *

* * * * * * * * * * * * * * * * * *
NameDescription
loggerOne or more logger names to be configured with the specified log level.
levelAn optional {@link Level} to configure. If not provided, the log level will be set to null.
durationAn optional {@link Duration} to configure the level. If not provided, the log level will be set forever.
*

*/ public class LogConfigurationTask extends Task { private final ILoggerFactory loggerContext; private final Supplier timerSupplier; private final AtomicReference timerReference = new AtomicReference<>(); /** * Creates a new LogConfigurationTask. */ public LogConfigurationTask() { this(LoggerFactory.getILoggerFactory()); } /** * Creates a new LogConfigurationTask with the given {@link ILoggerFactory} instance. *

* Use {@link LogConfigurationTask#LogConfigurationTask()} instead. * * @param loggerContext a {@link ILoggerFactory} instance */ public LogConfigurationTask(ILoggerFactory loggerContext) { this(loggerContext, () -> new Timer(LogConfigurationTask.class.getSimpleName(), true)); } /** * Creates a new LogConfigurationTask with the given {@link ILoggerFactory} instance and a custom {@link Timer}. *

* Use {@link LogConfigurationTask#LogConfigurationTask()} instead. * * @param loggerContext a {@link ILoggerFactory} instance * @param timerSupplier a {@link Supplier} supplying a {@link Timer} */ LogConfigurationTask(ILoggerFactory loggerContext, Supplier timerSupplier) { super("log-level"); this.loggerContext = loggerContext; this.timerSupplier = timerSupplier; } @Override public void execute(Map> parameters, PrintWriter output) throws Exception { final List loggerNames = getLoggerNames(parameters); final Level loggerLevel = getLoggerLevel(parameters); final Duration duration = getDuration(parameters); for (String loggerName : loggerNames) { Logger logger = ((LoggerContext) loggerContext).getLogger(loggerName); String message = String.format("Configured logging level for %s to %s", loggerName, loggerLevel); if (loggerLevel != null && duration != null) { final long millis = duration.toMillis(); getTimer().schedule(new TimerTask() { @Override public void run() { logger.setLevel(null); } }, millis); message += String.format(" for %s milliseconds", millis); } logger.setLevel(loggerLevel); output.println(message); output.flush(); } } private List getLoggerNames(Map> parameters) { return parameters.getOrDefault("logger", Collections.emptyList()); } @Nullable private Level getLoggerLevel(Map> parameters) { final List loggerLevels = parameters.getOrDefault("level", Collections.emptyList()); return loggerLevels.isEmpty() ? null : Level.valueOf(loggerLevels.get(0)); } @Nullable private Duration getDuration(Map> parameters) { final List durations = parameters.getOrDefault("duration", Collections.emptyList()); return durations.isEmpty() ? null : Duration.parse(durations.get(0)); } /** * Lazy create the timer to avoid unnecessary thread creation unless an expirable log configuration task is submitted */ @NonNull private Timer getTimer() { return timerReference.updateAndGet(timer -> timer == null ? timerSupplier.get() : timer); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy