io.kahu.hawaii.util.call.log.CallLoggerImpl.java Source code

Java tutorial

Introduction

Here is the source code for io.kahu.hawaii.util.call.log.CallLoggerImpl.java

Source

/**
 * Copyright 2015 Q24
 *
 * 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 io.kahu.hawaii.util.call.log;

import io.kahu.hawaii.util.call.Request;
import io.kahu.hawaii.util.call.Response;
import io.kahu.hawaii.util.call.log.request.RequestLogger;
import io.kahu.hawaii.util.call.log.response.ResponseLogger;
import io.kahu.hawaii.util.logger.LogManager;
import io.kahu.hawaii.util.logger.LoggingContext.PopResource;
import org.apache.http.annotation.ThreadSafe;
import org.springframework.util.Assert;

@ThreadSafe
public class CallLoggerImpl<T> implements CallLogger<T> {
    protected LogManager logManager;
    protected RequestLogger requestLogger;
    protected ResponseLogger<T> responseLogger;

    public CallLoggerImpl(LogManager logManager, RequestLogger requestLogger, ResponseLogger<T> responseLogger) {
        Assert.notNull(logManager);
        this.logManager = logManager;
        this.requestLogger = requestLogger;
        this.responseLogger = responseLogger;
    }

    @Override
    public LogManager getLogManager() {
        return logManager;
    }

    @Override
    public void logRequest(Request<T> request) {
        if (requestLogger != null) {
            requestLogger.logRequest(logManager, request);
        }
    }

    @Override
    public void logResponse(Response<T> response) {
        if (!response.getAndSetLogged(true)) {
            try (PopResource pop = logManager.pushContext(response.getLoggingContext())) {
                if (responseLogger != null) {
                    responseLogger.logResponse(logManager, response);
                }
            }
        }
    }
}