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

com.cisco.oss.foundation.logging.LoggingHelper Maven / Gradle / Ivy

/*
 * Copyright 2015 Cisco Systems, Inc.
 *
 *  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 com.cisco.oss.foundation.logging;

import org.apache.log4j.Level;
import org.apache.log4j.Logger;

import java.text.MessageFormat;

/**
 * Helper class for formatting log messages.
 *
 * @author Yair Ogen
 * @author Jethro Revill
 */
/**
 * @author Yair Ogen
 *
 */

/**
 * @author Yair Ogen
 */
public final class LoggingHelper { // NOPMD

	/**
	 * Formatter for communication messages.
	 */
	private static final MessageFormat COMM_MESSAGE_FORMAT = new MessageFormat("protocol[{0}] source[{1}] destination[{2}] {3}");

	/**
	 * Formatter for communication messages with addition of in out mode.
	 */
	private static final MessageFormat COMM_MESSAGE_FORMAT_IN_OUT = new MessageFormat("{0}: protocol[{1}] source[{2}] destination[{3}] {4}"); // NOPMD

	/**
	 * Formatter for connection establishment messages.
	 */
	private static final MessageFormat CON_ESTABLISHMENT_FORMAT = new MessageFormat("[{0}] remote host[{1}] {2}");

	/**
	 * Formatter for connection termination messages.
	 */
	private static final MessageFormat CON_TERMINATION_FORMAT = new MessageFormat("[{0}] remote host[{1}] {2} - {3}");

	/**
	 * Private constructor ensures LoggingHelper cannot be instantiated.
	 */
	private LoggingHelper() {
	}

	/**
	 * Enable logging using String.format internally only if debug level is
	 * enabled.
	 * 
	 * @param logger
	 *            the logger that will be used to log the message
	 * @param format
	 *            the format string (the template string)
	 * @param converter
	 *            the converter used to convert the param arguments in case the
	 *            trace level is enabled
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void trace(final Logger logger, final String format, final AbstractLoggingHelperConverter converter, final Object... params) {
		trace(logger, format, null, converter, params);
	}

	/**
	 * Enable logging using String.format internally only if debug level is
	 * enabled.
	 * 
	 * @param logger
	 *            the logger that will be used to log the message
	 * @param format
	 *            the format string (the template string)
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void trace(final Logger logger, final String format, final Object... params) {
		trace(logger, format, null, null, params);
	}

	/**
	 * Enable logging using String.format internally only if debug level is
	 * enabled.
	 * 
	 * @param logger
	 *            the logger that will be used to log the message
	 * @param format
	 *            the format string (the template string)
	 * @param throwable
	 *            a throwable object that holds the throwable information
	 * @param converter
	 *            the converter used to convert the param arguments in case the
	 *            trace level is enabled
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void trace(final Logger logger, final String format, final Throwable throwable, final AbstractLoggingHelperConverter converter, final Object... params) {
		if (logger.isTraceEnabled()) {
			Object[] formatParams = params;
			if (converter != null) {
				formatParams = converter.convert(params);
			}
			final String message = String.format(format, formatParams);
			logger.trace(message, throwable);
		}
	}

	/**
	 * Enable logging using String.format internally only if debug level is
	 * enabled.
	 * 
	 * @param logger
	 *            the logger that will be used to log the message
	 * @param format
	 *            the format string (the template string)
	 * @param throwable
	 *            a throwable object that holds the throable information
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void trace(final Logger logger, final String format, final Throwable throwable, final Object... params) {
		trace(logger, format, throwable, null, params);
	}

	/**
	 * Enable logging using String.format internally only if debug level is
	 * enabled.
	 * 
	 * @param logger
	 *            the logger that will be used to log the message
	 * @param format
	 *            the format string (the template string)
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void debug(final Logger logger, final String format, final Object... params) {
		debug(logger, format, null, null, params);
	}

	/**
	 * Enable logging using String.format internally only if debug level is
	 * enabled.
	 * 
	 * @param logger
	 *            the logger that will be used to log the message
	 * @param format
	 *            the format string (the template string)
	 * @param converter
	 *            the converter used to convert the param arguments in case the
	 *            debug level is enabled
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void debug(final Logger logger, final String format, final AbstractLoggingHelperConverter converter, final Object... params) {
		debug(logger, format, null, converter, params);
	}

	/**
	 * Enable logging using String.format internally only if debug level is
	 * enabled.
	 * 
	 * @param logger
	 *            the logger that will be used to log the message
	 * @param format
	 *            the format string (the template string)
	 * @param throwable
	 *            a throwable object that holds the throable information
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void debug(final Logger logger, final String format, final Throwable throwable, final AbstractLoggingHelperConverter converter, final Object... params) {
		if (logger.isDebugEnabled()) {
			Object[] formatParams = params;
			if (converter != null) {
				formatParams = converter.convert(params);
			}
			final String message = String.format(format, formatParams);
			logger.debug(message, throwable);
		}
	}

	/**
	 * Enable logging using String.format internally only if info level is
	 * enabled.
	 * 
	 * @param logger
	 *            the logger that will be used to log the message
	 * @param format
	 *            the format string (the template string)
	 * @param throwable
	 *            the throwable object to be logged
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void debug(final Logger logger, final String format, final Throwable throwable, final Object... params) {
		debug(logger, format, throwable, null, params);
	}

	/**
	 * Enable logging using String.format internally only if info level is
	 * enabled.
	 * 
	 * @param logger
	 *            the logger that will be used to log the message
	 * @param format
	 *            the format string (the template string)
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void info(final Logger logger, final String format, final Object... params) {
		info(logger, format, null, params);
	}

	/**
	 * Enable logging using String.format internally only if info level is
	 * enabled.
	 * 
	 * @param logger
	 *            the logger that will be used to log the message
	 * @param format
	 *            the format string (the template string)
	 * @param throwable
	 *            a throwable object that holds the throable information
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void info(final Logger logger, final String format, final Throwable throwable, final Object... params) {
		if (logger.isInfoEnabled()) {
			final String message = String.format(format, params);
			logger.info(message, throwable);
		}
	}

	/**
	 * log message using the String.format API
	 * 
	 * @param logger
	 *            the logger that will be used to log the message
	 * @param format
	 *            the format string (the template string)
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void warn(final Logger logger, final String format, final Object... params) {
		warn(logger, format, null, params);
	}

	/**
	 * log message using the String.format API
	 * 
	 * @param logger
	 *            the logger that will be used to log the message
	 * @param format
	 *            the format string (the template string)
	 * @param throwable
	 *            a throwable object that holds the throable information
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void warn(final Logger logger, final String format, final Throwable throwable, final Object... params) {
		final String message = String.format(format, params);
		logger.warn(message, throwable);
	}

	/**
	 * log message using the String.format API
	 * 
	 * @param logger
	 *            the logger that will be used to log the message
	 * @param format
	 *            the format string (the template string)
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void error(final Logger logger, final String format, final Object... params) {
		error(logger, format, null, params);
	}

	/**
	 * log message using the String.format API
	 * 
	 * @param logger
	 *            the logger that will be used to log the message
	 * @param format
	 *            the format string (the template string)
	 * @param throwable
	 *            a throwable object that holds the throable information
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void error(final Logger logger, final String format, final Throwable throwable, final Object... params) {
		final String message = String.format(format, params);
		logger.error(message, throwable);
	}

	/**
	 * log message using the String.format API.
	 * 
	 * @param logger
	 *            the logger that will be used to log the message
	 * @param format
	 *            the format string (the template string)
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void fatal(final Logger logger, final String format, final Object... params) {
		fatal(logger, format, null, params);
	}

	/**
	 * log message using the String.format API.
	 * 
	 * @param logger
	 *            the logger that will be used to log the message
	 * @param format
	 *            the format string (the template string)
	 * @param throwable
	 *            a throwable object that holds the throable information
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void fatal(final Logger logger, final String format, final Throwable throwable, final Object... params) {
		final String message = String.format(format, params);
		logger.fatal(message, throwable);
	}

	/**
	 * log message using the String.format API.
	 * 
	 * @param logger
	 *            a logger object that will be used for the actual log.
	 * @param level
	 *            the level of the requested log
	 * @param throwable
	 *            a throwable object if applicable
	 * @param format
	 *            the format string (the template string)
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void log(final Logger logger, final Level level, final Throwable throwable, final String format, final Object... params) {
		if (level.isGreaterOrEqual(logger.getEffectiveLevel())) {
			logger.log(level, String.format(format, params), throwable);
		}

	}

	/**
	 * log message using the String.format API.
	 * 
	 * @param logger
	 *            a logger object that will be used for the actual log.
	 * @param level
	 *            the level of the requested log
	 * @param format
	 *            the format string (the template string)
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void log(final Logger logger, final Level level, final String format, final Object... params) {
		if (level.isGreaterOrEqual(logger.getEffectiveLevel())) {
			logger.log(level, String.format(format, params));
		}
	}

	/**
	 * log message using the String.format API.
	 * 
	 * @param logger
	 *            a logger object that will be used for the actual log.
	 * @param callerFQCN
	 *            The wrapper class' fully qualified class name.
	 * @param level
	 *            the level of the requested log
	 * @param throwable
	 *            a throwable object if applicable
	 * @param format
	 *            the format string (the template string)
	 * @param params
	 *            the parameters to be formatted into it the string format
	 */
	public static void log(final Logger logger, final String callerFQCN, final Level level, final Throwable throwable, final String format, final Object... params) {
		if (level.isGreaterOrEqual(logger.getEffectiveLevel())) {
			logger.log(callerFQCN, level, String.format(format, params), throwable);
		}
	}

	/**
	 * Helper method for formatting transmission and reception messages.
	 * 
	 * @param protocol
	 *            The protocol used
	 * @param source
	 *            Message source
	 * @param destination
	 *            Message destination
	 * @param message
	 *            The message
	 * @return A formatted message in the format:
	 *         "protocol[<protocol>] source[<source>] destination[<destination>] <message>"
	 * 
* e.g. protocol[OpenCAS] source[234.234.234.234:4321] * destination[123.123.123.123:4567] 0x0a0b0c0d0e0f */ public static String formatCommunicationMessage(final String protocol, final String source, final String destination, final String message) { return COMM_MESSAGE_FORMAT.format(new Object[] { protocol, source, destination, message }); } /** * Helper method for formatting transmission and reception messages. * * @param protocol * The protocol used * @param source * Message source * @param destination * Message destination * @param message * The message * @param inOutMODE * - Enum the designates if this communication protocol is in * coming (received) or outgoing (transmitted) * @return A formatted message in the format: * "Rx: / Tx: protocol[<protocol>] source[<source>] destination[<destination>] <message>" *
* e.g. Rx: protocol[OpenCAS] source[234.234.234.234:4321] * destination[123.123.123.123:4567] 0x0a0b0c0d0e0f */ public static String formatCommunicationMessage(final String protocol, final String source, final String destination, final String message, final IN_OUT_MODE inOutMODE) { return COMM_MESSAGE_FORMAT_IN_OUT.format(new Object[] { inOutMODE, protocol, source, destination, message }); } /** * Helper method for formatting connection establishment messages. * * @param connectionName * The name of the connection * @param host * The remote host * @param connectionReason * The reason for establishing the connection * @return A formatted message in the format: * "[<connectionName>] remote host[<host>] <connectionReason>" *
* e.g. [con1] remote host[123.123.123.123] connection to ECMG. */ public static String formatConnectionEstablishmentMessage(final String connectionName, final String host, final String connectionReason) { return CON_ESTABLISHMENT_FORMAT.format(new Object[] { connectionName, host, connectionReason }); } /** * Helper method for formatting connection termination messages. * * @param connectionName * The name of the connection * @param host * The remote host * @param connectionReason * The reason for establishing the connection * @param terminationReason * The reason for terminating the connection * @return A formatted message in the format: * "[<connectionName>] remote host[<host>] <connectionReason> - <terminationReason>" *
* e.g. [con1] remote host[123.123.123.123] connection to ECMG - * terminated by remote host. */ public static String formatConnectionTerminationMessage(final String connectionName, final String host, final String connectionReason, final String terminationReason) { return CON_TERMINATION_FORMAT.format(new Object[] { connectionName, host, connectionReason, terminationReason }); } /** * Enum defining backword support for Tx and Rx prints in Communication * Logging Formats, * * @author Yair Ogen */ public static enum IN_OUT_MODE { /** * To be used with receipt of message. Rendered as 'Rx' in the log * entry. */ IN("Rx"), /** * To be used with transmission of message. Rendered as 'Tx' in the log * entry. */ OUT("Tx"); private String value; private IN_OUT_MODE(final String value) { this.value = value; } /** * @see Enum#toString() */ @Override public String toString() { return value; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy