/* * Copyright 2002-2007 the original author or authors. * * 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 org.springframework.aop.interceptor; import java.lang.reflect.Method; import org.aopalliance.intercept.MethodInvocation; /** * Base class for monitoring interceptors, such as performance monitors. * Provides <code>prefix</code> and <code>suffix</code> properties * that help to classify/group performance monitoring results. * * <p>Subclasses should call the <code>createInvocationTraceName(MethodInvocation)</code> * method to create a name for the given trace that includes information about the * method invocation under trace along with the prefix and suffix added as appropriate. * * @author Rob Harrop * @author Juergen Hoeller * @since 1.2.7 * @see #setPrefix * @see #setSuffix * @see #createInvocationTraceName */ public abstract class AbstractMonitoringInterceptor extends AbstractTraceInterceptor { private String prefix = ""; private String suffix = ""; private boolean logTargetClassInvocation = false; /** * Set the text that will get appended to the trace data. * <p>Default is none. */ public void setPrefix(String prefix) { this.prefix = (prefix != null ? prefix : ""); } /** * Return the text that will get appended to the trace data. */ protected String getPrefix() { return this.prefix; } /** * Set the text that will get prepended to the trace data. * <p>Default is none. */ public void setSuffix(String suffix) { this.suffix = (suffix != null ? suffix : ""); } /** * Return the text that will get prepended to the trace data. */ protected String getSuffix() { return this.suffix; } /** * Set whether to log the invocation on the target class, if applicable * (i.e. if the method is actually delegated to the target class). * <p>Default is "false", logging the invocation based on the proxy * interface/class name. */ public void setLogTargetClassInvocation(boolean logTargetClassInvocation) { this.logTargetClassInvocation = logTargetClassInvocation; } /** * Create a <code>String</code> name for the given <code>MethodInvocation</code> * that can be used for trace/logging purposes. This name is made up of the * configured prefix, followed by the fully-qualified name of the method being * invoked, followed by the configured suffix. * @see #setPrefix * @see #setSuffix */ protected String createInvocationTraceName(MethodInvocation invocation) { StringBuffer sb = new StringBuffer(getPrefix()); Method method = invocation.getMethod(); Class clazz = method.getDeclaringClass(); if (this.logTargetClassInvocation && clazz.isInstance(invocation.getThis())) { clazz = invocation.getThis().getClass(); } sb.append(clazz.getName()); sb.append('.').append(method.getName()); sb.append(getSuffix()); return sb.toString(); } }