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

io.tracee.contextlogger.contextprovider.javaee.TraceeErrorContextLoggingInterceptor Maven / Gradle / Ivy

package io.tracee.contextlogger.contextprovider.javaee;

import javax.interceptor.AroundInvoke;
import javax.interceptor.InvocationContext;

import io.tracee.contextlogger.MessagePrefixProvider;
import io.tracee.contextlogger.TraceeContextLogger;
import io.tracee.contextlogger.api.ErrorMessage;
import io.tracee.contextlogger.api.ImplicitContext;
import io.tracee.contextlogger.api.internal.MessageLogLevel;
import io.tracee.contextlogger.contextprovider.tracee.TraceeMessage;

/**
 * Message listener to detect exceptions that happened during javaee message processing.
 * In case of an exception contextual information will be written to the log.
 * Created by Tobias Gindler, holisticon AG on 13.03.14.
 */
public class TraceeErrorContextLoggingInterceptor {

    @SuppressWarnings("unused")
    public TraceeErrorContextLoggingInterceptor() {
    }

    @AroundInvoke
    public Object intercept(final InvocationContext ctx) throws Exception {
        try {
            return ctx.proceed();
        }
        catch (Exception e) {

            // try to get error message annotation
            ErrorMessage errorMessage = ctx.getMethod().getAnnotation(ErrorMessage.class);

            // now log context informations
            if (errorMessage == null) {
                TraceeContextLogger
                        .create()
                        .enforceOrder()
                        .apply()
                        .logWithPrefixedMessage(
                                MessagePrefixProvider.provideLogMessagePrefix(MessageLogLevel.ERROR, TraceeErrorContextLoggingInterceptor.class),
                                ImplicitContext.COMMON, ImplicitContext.TRACEE, ctx, e);
            }
            else {
                TraceeContextLogger
                        .create()
                        .enforceOrder()
                        .apply()
                        .logWithPrefixedMessage(
                                MessagePrefixProvider.provideLogMessagePrefix(MessageLogLevel.ERROR, TraceeErrorContextLoggingInterceptor.class),
                                TraceeMessage.wrap(errorMessage.value()), ImplicitContext.COMMON, ImplicitContext.TRACEE, ctx, e);
            }
            throw e;
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy