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

nl.talsmasoftware.context.log4j2.threadcontext.Log4j2ThreadContextSnapshot Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2016-2022 Talsma ICT
 *
 * 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 nl.talsmasoftware.context.log4j2.threadcontext;

import org.apache.logging.log4j.ThreadContext;

import java.util.Map;

/**
 * Snapshot of the data from the Log4j 2 {@link ThreadContext} of a specific thread at a certain point in the past.
 */
public class Log4j2ThreadContextSnapshot {
    private final Map contextMap;
    private final ThreadContext.ContextStack contextStack;

    private Log4j2ThreadContextSnapshot(Map contextMap, ThreadContext.ContextStack contextStack) {
        this.contextMap = contextMap;
        this.contextStack = contextStack;
    }

    /**
     * Captures a snapshot of the {@code ThreadContext} data from the current thread.
     *
     * @return Log4j 2 {@code ThreadContext} snapshot from the current thread.
     */
    public static Log4j2ThreadContextSnapshot captureFromCurrentThread() {
        // Get a copy of context map and context stack
        return new Log4j2ThreadContextSnapshot(ThreadContext.getImmutableContext(), ThreadContext.getImmutableStack());
    }

    /**
     * Apply the Log4j 2 {@code ThreadContext} snapshot data to the current thread.
     * 

* This method does not clear the current {@code ThreadContext} values before applying * this context. If you want that to happen, please call {@link ThreadContext#clearAll()} before applying * the snapshot. * * @see ThreadContext#clearAll() */ public void applyToCurrentThread() { ThreadContext.putAll(this.contextMap); for (String element : this.contextStack) { ThreadContext.push(element); } } /** * Returns an unmodifiable view of the {@code ThreadContext} map contained in this snapshot. * * @return {@code ThreadContext} map contained in this snapshot */ public Map getContextMap() { return contextMap; } /** * Returns an unmodifiable view of the {@code ThreadContext} stack contained * in this snapshot. * * @return {@code ThreadContext} stack contained in this snapshot */ public ThreadContext.ContextStack getContextStack() { return contextStack; } @Override public String toString() { return getClass().getSimpleName() + "{contextMap=" + contextMap + ", contextStack=" + contextStack + '}'; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy