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

reactor.netty.http.logging.HttpMessageLogUtils Maven / Gradle / Ivy

/*
 * Copyright (c) 2022 VMware, Inc. or its affiliates, All Rights Reserved.
 *
 * 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
 *
 *   https://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 reactor.netty.http.logging;

import io.netty.handler.codec.DecoderResult;
import io.netty.handler.codec.http.HttpHeaders;
import io.netty.util.internal.StringUtil;

import java.util.Map;
import java.util.function.Function;

/**
 * Utilities for creating log message based on a given {@link HttpMessageArgProvider}.
 *
 * @author Violeta Georgieva
 * @since 1.0.4
 */
public final class HttpMessageLogUtils {

	/**
	 * Creates a log message based on the provided {@link HttpMessageArgProvider}.
	 *
	 * @param argProvider           the provided {@link HttpMessageArgProvider}
	 * @param uriValueFunction      a function for sanitizing the uri
	 * @param decoderResultFunction a function for sanitizing the decoding result
	 * @param headerValueFunction   a function for sanitizing the headers values
	 * @return a log message for the given {@link HttpMessageArgProvider}
	 */
	public static String logHttpMessage(
			HttpMessageArgProvider argProvider,
			Function uriValueFunction,
			Function decoderResultFunction,
			Function, String> headerValueFunction) {
		switch (argProvider.httpMessageType()) {
			case REQUEST:
				return logRequest(argProvider, uriValueFunction, decoderResultFunction, headerValueFunction);
			case FULL_REQUEST:
				return logFullRequest(argProvider, uriValueFunction, decoderResultFunction, headerValueFunction);
			case RESPONSE:
				return logResponse(argProvider, decoderResultFunction, headerValueFunction);
			case FULL_RESPONSE:
				return logFullResponse(argProvider, decoderResultFunction, headerValueFunction);
			case CONTENT:
				return logContent(argProvider, decoderResultFunction);
			case LAST_CONTENT:
				return logLastContent(argProvider, decoderResultFunction, headerValueFunction);
			default:
				throw new IllegalArgumentException("Unknown HttpMessageType: " + argProvider.httpMessageType());
		}
	}

	static String logContent(
			HttpMessageArgProvider argProvider,
			Function decoderResultFunction) {
		StringBuilder buf = new StringBuilder(256);
		logContent(buf, argProvider, decoderResultFunction);
		removeLastNewLine(buf);
		return buf.toString();
	}

	static String logFullRequest(
			HttpMessageArgProvider argProvider,
			Function uriValueFunction,
			Function decoderResultFunction,
			Function, String> headerValueFunction) {
		StringBuilder buf = new StringBuilder(256);
		logFullCommon(buf, argProvider, decoderResultFunction);
		logInitialLine(buf, argProvider, uriValueFunction);
		logHeaders(buf, argProvider.headers(), headerValueFunction);
		logHeaders(buf, argProvider.trailingHeaders(), headerValueFunction);
		removeLastNewLine(buf);
		return buf.toString();
	}

	static String logFullResponse(
			HttpMessageArgProvider argProvider,
			Function decoderResultFunction,
			Function, String> headerValueFunction) {
		StringBuilder buf = new StringBuilder(256);
		logFullCommon(buf, argProvider, decoderResultFunction);
		logInitialLine(buf, argProvider);
		logHeaders(buf, argProvider.headers(), headerValueFunction);
		logHeaders(buf, argProvider.trailingHeaders(), headerValueFunction);
		removeLastNewLine(buf);
		return buf.toString();
	}

	static String logLastContent(
			HttpMessageArgProvider argProvider,
			Function decoderResultFunction,
			Function, String> headerValueFunction) {
		StringBuilder buf = new StringBuilder(256);
		logContent(buf, argProvider, decoderResultFunction);
		logHeaders(buf, argProvider.trailingHeaders(), headerValueFunction);
		removeLastNewLine(buf);
		return buf.toString();
	}

	static String logRequest(
			HttpMessageArgProvider argProvider,
			Function uriValueFunction,
			Function decoderResultFunction,
			Function, String> headerValueFunction) {
		StringBuilder buf = new StringBuilder(256);
		logCommon(buf, argProvider, decoderResultFunction);
		logInitialLine(buf, argProvider, uriValueFunction);
		logHeaders(buf, argProvider.headers(), headerValueFunction);
		removeLastNewLine(buf);
		return buf.toString();
	}

	static String logResponse(
			HttpMessageArgProvider argProvider,
			Function decoderResultFunction,
			Function, String> headerValueFunction) {
		StringBuilder buf = new StringBuilder(256);
		logCommon(buf, argProvider, decoderResultFunction);
		logInitialLine(buf, argProvider);
		logHeaders(buf, argProvider.headers(), headerValueFunction);
		removeLastNewLine(buf);
		return buf.toString();
	}

	static void logCommon(
			StringBuilder buf,
			HttpMessageArgProvider argProvider,
			Function decoderResultFunction) {
		buf.append(argProvider.httpMessageType());
		buf.append("(decodeResult: ");
		buf.append(decoderResultFunction.apply(argProvider.decoderResult()));
		buf.append(", version: ");
		buf.append(argProvider.protocol());
		buf.append(')');
		buf.append(StringUtil.NEWLINE);
	}

	static void logContent(
			StringBuilder buf,
			HttpMessageArgProvider argProvider,
			Function decoderResultFunction) {
		buf.append(argProvider.httpMessageType());
		buf.append("(decodeResult: ");
		buf.append(decoderResultFunction.apply(argProvider.decoderResult()));
		buf.append(", content: ");
		buf.append(argProvider.content());
		buf.append(')');
		buf.append(StringUtil.NEWLINE);
	}

	static void logFullCommon(
			StringBuilder buf,
			HttpMessageArgProvider argProvider,
			Function decoderResultFunction) {
		buf.append(argProvider.httpMessageType());
		buf.append("(decodeResult: ");
		buf.append(decoderResultFunction.apply(argProvider.decoderResult()));
		buf.append(", version: ");
		buf.append(argProvider.protocol());
		buf.append(", content: ");
		buf.append(argProvider.content());
		buf.append(')');
		buf.append(StringUtil.NEWLINE);
	}

	static void logHeaders(
			StringBuilder buf,
			HttpHeaders headers,
			Function, String> headerValueFunction) {
		for (Map.Entry e : headers) {
			buf.append(e.getKey());
			buf.append(": ");
			buf.append(headerValueFunction.apply(e));
			buf.append(StringUtil.NEWLINE);
		}
	}

	static void logInitialLine(StringBuilder buf, HttpMessageArgProvider argProvider) {
		buf.append(argProvider.protocol());
		buf.append(' ');
		buf.append(argProvider.status());
		buf.append(StringUtil.NEWLINE);
	}

	static void logInitialLine(
			StringBuilder buf,
			HttpMessageArgProvider argProvider,
			Function uriValueFunction) {
		buf.append(argProvider.method());
		buf.append(' ');
		buf.append(uriValueFunction.apply(argProvider.uri()));
		buf.append(' ');
		buf.append(argProvider.protocol());
		buf.append(StringUtil.NEWLINE);
	}

	static void removeLastNewLine(StringBuilder buf) {
		buf.setLength(buf.length() - StringUtil.NEWLINE.length());
	}

	private HttpMessageLogUtils() {
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy