org.pmw.tinylog.LoggingContext Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of tinylog-jboss Show documentation
Show all versions of tinylog-jboss Show documentation
tinylog adapter for outputting log entries via JBoss Logging
/*
* Copyright 2016 Martin Winandy
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
* an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
* specific language governing permissions and limitations under the License.
*/
package org.pmw.tinylog;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
import org.jboss.logging.Logger;
import org.jboss.logging.MDC;
/**
* Thread-based mapped diagnostic context for logging. A child thread automatically inherits a copy of the mapped
* diagnostic context of its parent.
*
*
* If logging context is used in a thread from a thread pool, {@link #clear()} should be called before putting the
* thread back to the pool.
*
*/
public final class LoggingContext {
private static final Logger logger = Logger.getLogger(LoggingContext.class.getName());
/** */
private LoggingContext() {
}
/**
* Get a read-only map with all context values.
*
* @return Read-only map
*/
public static Map getMapping() {
Set> entries = MDC.getMap().entrySet();
Map map = new HashMap(entries.size());
for (Entry entry : entries) {
map.put(entry.getKey(), entry.getValue() == null ? null : entry.getValue().toString());
}
return map;
}
/**
* Get the context value by a key.
*
* @param key
* Key of mapping
* @return Context value or {@code null}
*/
public static String get(final String key) {
Object value = MDC.get(key);
return value == null ? null : value.toString();
}
/**
* Put a new context value.
*
* @param key
* Key of mapping
* @param value
* New value
*/
public static void put(final String key, final Object value) {
MDC.put(key, value);
}
/**
* Remove a context value if existing.
*
* @param key
* Key of mapping
*/
public static void remove(final String key) {
MDC.remove(key);
}
/**
* Remove all existing context values.
*/
public static void clear() {
try {
MDC.clear();
} catch (NoSuchMethodError ex) {
logger.warn("Clearing thread-based mapped diagnostic context is not supported by underlying logging framework");
}
}
}