/*
* Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
*
* WSO2 Inc. licenses this file to you 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 org.apache.synapse;
import org.apache.commons.lang.StringUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.log4j.PatternLayout;
import org.apache.log4j.spi.LoggingEvent;
import org.apache.synapse.transport.customlogsetter.CustomLogSetter;
import java.lang.reflect.Field;
public class AppenderWrapper extends PatternLayout {
private static final Log log = LogFactory.getLog(AppenderWrapper.class);
public AppenderWrapper() {
super();
}
public AppenderWrapper(String pattern) {
super(pattern);
}
@Override
public String format(LoggingEvent event) {
if (event.getMessage() != null && event.getMessage() instanceof String) {
String logMessage = event.getMessage().toString();
logMessage = StringUtils.trim(
((CustomLogSetter.getInstance().getLogAppenderContent() != null) ?
CustomLogSetter.getInstance().getLogAppenderContent() : "") + logMessage);
try {
Field field = LoggingEvent.class.getDeclaredField("message");
field.setAccessible(true);
field.set(event, logMessage);
} catch (Exception ex) {
log.error("Error Setting the Logging Event: " + ex);
}
}
return super.format(event);
}
}