com.cisco.oss.foundation.logging.transactions.SchedulerLogger Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of logging-log4j Show documentation
Show all versions of logging-log4j Show documentation
This project is the logging log4j implementation library in the cisco vss foundation runtime
package com.cisco.oss.foundation.logging.transactions;
import java.util.HashMap;
import java.util.Map;
import org.apache.log4j.Level;
import org.slf4j.Logger;
import org.springframework.util.CollectionUtils;
/**
* Class for internal scheduler transactions logging
*
* @author abrandwi
*/
public class SchedulerLogger extends TransactionLogger {
private enum SchedulerPropertyKey {SchedulerName, HandledType, HandledNumber, Failures, SchedulerResult};
private Map resultMap = new HashMap();
private String handledItemsType; // Type of DB items that where handled in scheduler, e.g. catalogItem, pvr...
private int handledItemsNumber = 0; // Number of DB items that where handled in scheduler
private int failures = 0; // Number of failed actions in scheduler
public static void start(final Logger logger, final Logger auditor, final String schedulerName) {
if (!createLoggingAction(logger, auditor, new SchedulerLogger())) {
return;
}
SchedulerLogger schedulerLogger = (SchedulerLogger) getInstance();
if (schedulerLogger == null) {
return;
}
schedulerLogger.startInstance(schedulerName);
}
public static void success() {
SchedulerLogger schedulerLogger = (SchedulerLogger) getInstance();
if (schedulerLogger == null) {
return;
}
schedulerLogger.successInstance();
}
public static void failure(final Exception exception) {
SchedulerLogger schedulerLogger = (SchedulerLogger) getInstance();
if (schedulerLogger == null) {
return;
}
schedulerLogger.failureInstance(exception);
}
public static void failure(final String errorMessage) {
SchedulerLogger schedulerLogger = (SchedulerLogger) getInstance();
if (schedulerLogger == null) {
return;
}
schedulerLogger.failureInstance(errorMessage);
}
public static void failureAsync(final String errorMessage, SchedulerLogger schedulerLogger) {
schedulerLogger.failureInstance(errorMessage);
}
public static void addItemsHandledAsync(String handledItemsType, int handledItemsNumber, SchedulerLogger schedulerLogger) {
schedulerLogger.addItemsHandledInstance(handledItemsType, handledItemsNumber);
}
public static void addItemsHandled(String handledItemsType, int handledItemsNumber) {
SchedulerLogger schedulerLogger = (SchedulerLogger) getInstance();
if (schedulerLogger == null) {
return;
}
schedulerLogger.addItemsHandledInstance(handledItemsType, handledItemsNumber);
}
public static void addFailure() {
SchedulerLogger schedulerLogger = (SchedulerLogger) getInstance();
if (schedulerLogger == null) {
return;
}
schedulerLogger.addFailureInstance(1);
}
public static void addFailureAsync(SchedulerLogger schedulerLogger) {
schedulerLogger.addFailureInstance(1);
}
public static void addFailures(int num) {
SchedulerLogger schedulerLogger = (SchedulerLogger) getInstance();
if (schedulerLogger == null) {
return;
}
schedulerLogger.addFailureInstance(num);
}
public static void addFailuresAsync(int num, SchedulerLogger schedulerLogger) {
schedulerLogger.addFailureInstance(num);
}
public static void addProperty(String propertyName, String propertyValue) {
SchedulerLogger schedulerLogger = (SchedulerLogger) getInstance();
if (schedulerLogger != null) {
schedulerLogger.properties.put(propertyName, propertyValue);
}
}
public static void addPropertyAsync(String propertyName, String propertyValue, SchedulerLogger schedulerLogger) {
schedulerLogger.properties.put(propertyName, propertyValue);
}
public static void addToResult(String resultType) {
addToResult(resultType, 1);
}
public static void addToResult(String resultType, int number) {
SchedulerLogger schedulerLogger = (SchedulerLogger) getInstance();
if (schedulerLogger == null) {
return;
}
schedulerLogger.addToResultInstance(resultType, number);
}
protected void startInstance(String schedulerName) {
try {
addPropertiesStart(schedulerName);
writePropertiesToLog(this.logger, Level.DEBUG);
} catch (Exception e) {
logger.error("Failed logging Scheduler transaction start: " + e.getMessage(), e);
}
}
protected void successInstance() {
try {
end();
addPropertiesSuccess();
addPropertiesProcessingTime();
writePropertiesToLog(this.auditor, Level.INFO);
} catch (Exception e) {
logger.error("Failed logging Scheduler transaction success: " + e.getMessage(), e);
}
}
private void failureInstance(Exception exception) {
try {
end();
addPropertiesFailure(exception, null);
addPropertiesProcessingTime();
writePropertiesToLog(this.auditor, Level.ERROR);
} catch (Exception e) {
logger.error("Failed logging Scheduler transaction failure: " + e.getMessage(), e);
}
}
private void failureInstance(String errorMessage) {
try {
end();
addPropertiesFailure(null, errorMessage);
addPropertiesProcessingTime();
writePropertiesToLog(this.auditor, Level.ERROR);
} catch (Exception e) {
logger.error("Failed logging Scheduler transaction failure: " + errorMessage);
}
}
private void addItemsHandledInstance(String handledItemsType, int handledItemsNumber) {
this.handledItemsType = handledItemsType;
this.handledItemsNumber += handledItemsNumber;
}
private void addFailureInstance(int num) {
this.failures += num;
}
private void addToResultInstance(String resultType, int number) {
Integer currentNumber = this.resultMap.get(resultType);
if (currentNumber == null) {
currentNumber = 0;
}
this.resultMap.put(resultType, currentNumber+number);
}
protected void addPropertiesStart(String schedulerName) {
addPropertiesStart("Scheduler", SchedulerPropertyKey.SchedulerName.name(), schedulerName);
}
protected void addPropertiesStart(String type, String nameFieldName, String name) {
super.addPropertiesStart(type);
this.properties.put(nameFieldName, name);
}
protected void addPropertiesSuccess() {
super.addPropertiesSuccess();
if (!CollectionUtils.isEmpty(this.resultMap)) {
this.properties.put(SchedulerPropertyKey.SchedulerResult.name(), JsonUtil.getObjectAsJson(this.resultMap));
}
if (handledItemsType != null) {
this.properties.put(SchedulerPropertyKey.HandledType.name(), this.handledItemsType);
this.properties.put(SchedulerPropertyKey.HandledNumber.name(), String.valueOf(this.handledItemsNumber));
}
this.properties.put(SchedulerPropertyKey.Failures.name(), String.valueOf(this.failures));
}
private void addPropertiesFailure(Exception exception, String errorMessage) {
super.addPropertiesFailure();
if (errorMessage == null) {
errorMessage = exception.getMessage();
}
if (handledItemsType != null) {
this.properties.put(SchedulerPropertyKey.HandledType.name(), this.handledItemsType);
this.properties.put(SchedulerPropertyKey.HandledNumber.name(), String.valueOf(this.handledItemsNumber));
}
this.properties.put(SchedulerPropertyKey.Failures.name(), String.valueOf(this.failures));
this.properties.put(PropertyKey.ErrorMessage.name(), errorMessage);
if (exception != null) {
this.exception = exception;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy