/*
* Copyright 2014 NAVER Corp.
*
* 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.navercorp.pinpoint.bootstrap.interceptor;
import com.navercorp.pinpoint.common.util.logger.CommonLogger;
import com.navercorp.pinpoint.common.util.logger.StdoutCommonLoggerFactory;
import java.util.Arrays;
/**
* @author emeroad
*/
public class LoggingInterceptor implements StaticAroundInterceptor, AroundInterceptor, AroundInterceptor0, AroundInterceptor1, AroundInterceptor2, AroundInterceptor3, AroundInterceptor4, AroundInterceptor5, ApiIdAwareAroundInterceptor {
private final CommonLogger logger;
public LoggingInterceptor(String loggerName) {
this.logger = StdoutCommonLoggerFactory.INSTANCE.getLogger(loggerName);
}
@Override
public void before(Object target, String className, String methodName, String parameterDescription, Object[] args) {
if (logger.isTraceEnabled()) {
logger.trace("before " + defaultString(target) + " " + className + "." + methodName + parameterDescription + " args:" + Arrays.toString(args));
}
}
@Override
public void after(Object target, String className, String methodName, String parameterDescription, Object[] args, Object result, Throwable throwable) {
if (logger.isTraceEnabled()) {
logger.trace("after " + defaultString(target) + " " + className + "." + methodName + parameterDescription + " args:" + Arrays.toString(args) + " result:" + result + " Throwable:" + throwable);
}
}
@Override
public void before(Object target, Object[] args) {
if (logger.isTraceEnabled()) {
logger.trace("before " + defaultString(target) + " args:" + Arrays.toString(args) );
}
}
@Override
public void after(Object target, Object[] args, Object result, Throwable throwable) {
if (logger.isTraceEnabled()) {
logger.trace("after " + defaultString(target) + " args:" + Arrays.toString(args) + " result:" + result + " Throwable:" + throwable);
}
}
public static String defaultString(final Object object) {
return String.valueOf(object);
}
@Override
public void before(Object target, int apiId, Object[] args) {
}
@Override
public void after(Object target, int apiId, Object[] args, Object result, Throwable throwable) {
}
@Override
public void before(Object target) {
}
@Override
public void after(Object target, Object result, Throwable throwable) {
}
@Override
public void before(Object target, Object arg0) {
}
@Override
public void after(Object target, Object arg0, Object result, Throwable throwable) {
}
@Override
public void before(Object target, Object arg0, Object arg1) {
}
@Override
public void after(Object target, Object arg0, Object arg1, Object result, Throwable throwable) {
}
@Override
public void before(Object target, Object arg0, Object arg1, Object arg2) {
}
@Override
public void after(Object target, Object arg0, Object arg1, Object arg2, Object result, Throwable throwable) {
}
@Override
public void before(Object target, Object arg0, Object arg1, Object arg2, Object arg3) {
}
@Override
public void after(Object target, Object arg0, Object arg1, Object arg2, Object arg3, Object result, Throwable throwable) {
}
@Override
public void before(Object target, Object arg0, Object arg1, Object arg2, Object arg3, Object arg4) {
}
@Override
public void after(Object target, Object arg0, Object arg1, Object arg2, Object arg3, Object arg4, Object result, Throwable throwable) {
}
}