Package org.apache.tomcat.jdbc.pool
Class JdbcInterceptor
- java.lang.Object
- 
- org.apache.tomcat.jdbc.pool.JdbcInterceptor
 
- 
- All Implemented Interfaces:
- InvocationHandler
 - Direct Known Subclasses:
- AbstractCreateStatementInterceptor,- ConnectionState,- DisposableConnectionFacade,- ProxyConnection,- TrapException
 
 public abstract class JdbcInterceptor extends Object implements InvocationHandler Abstract class that is to be extended for implementations of interceptors. Everytime an operation is called on theConnectionobject theinvoke(Object, Method, Object[])method on the interceptor will be called. Interceptors are useful to change or improve behavior of the connection pool.
 Interceptors can receive a set of properties. Each sub class is responsible for parsing the properties during runtime when they are needed or simply override thesetProperties(Map)method. Properties arrive in a key-value pair of Strings as they were received through the configuration. This method is called once per cached connection object when the object is first configured.
- 
- 
Field SummaryFields Modifier and Type Field Description static StringCLOSE_VALConnection.close()method namestatic StringEQUALS_VALstatic StringGETCONNECTION_VALPooledConnection.getConnection()method namestatic StringHASHCODE_VALstatic StringISCLOSED_VALConnection.isClosed()method namestatic StringISVALID_VALConnection.isValid(int)method namestatic StringISWRAPPERFOR_VALWrapper.isWrapperFor(Class)method nameprotected Map<String,PoolProperties.InterceptorProperty>propertiesProperties for this interceptor.static StringTOSTRING_VALObject.toString()method namestatic StringUNWRAP_VALWrapper.unwrap(Class)method name
 - 
Constructor SummaryConstructors Constructor Description JdbcInterceptor()Public constructor for instantiation through reflection
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description booleancompare(String methodName, Method method)Compares a method name (String) to a method (Method)compare(String,String)Uses reference comparison unless the useEquals property is set to truebooleancompare(String name1, String name2)Performs a string comparison, using references unless the useEquals property is set to true.voiddisconnected(ConnectionPool parent, PooledConnection con, boolean finalizing)Called whenConnection.close()is called on the underlying connection.JdbcInterceptorgetNext()Returns the next interceptor in the chainMap<String,PoolProperties.InterceptorProperty>getProperties()Returns the properties configured for this interceptorObjectinvoke(Object proxy, Method method, Object[] args)Gets invoked each time an operation onConnectionis invoked.booleanisUseEquals()voidpoolClosed(ConnectionPool pool)This method is invoked by a connection pool when the pool is closed.voidpoolStarted(ConnectionPool pool)This method is invoked by a connection pool when the pool is first started up, usually when the first connection is requested.abstract voidreset(ConnectionPool parent, PooledConnection con)Gets called each time the connection is borrowed from the pool This means that if an interceptor holds a reference to the connection the interceptor can be reused for another connection.voidsetNext(JdbcInterceptor next)configures the next interceptor in the chainvoidsetProperties(Map<String,PoolProperties.InterceptorProperty> properties)Called during the creation of an interceptor The properties can be set during the configuration of an interceptor Override this method to perform type casts between string values and object propertiesvoidsetUseEquals(boolean useEquals)Set to true if string comparisons (for thecompare(String, Method)andcompare(String, String)methods) should use the Object.equals(Object) method The default is false
 
- 
- 
- 
Field Detail- 
CLOSE_VALpublic static final String CLOSE_VAL Connection.close()method name- See Also:
- Constant Field Values
 
 - 
TOSTRING_VALpublic static final String TOSTRING_VAL Object.toString()method name- See Also:
- Constant Field Values
 
 - 
ISCLOSED_VALpublic static final String ISCLOSED_VAL Connection.isClosed()method name- See Also:
- Constant Field Values
 
 - 
GETCONNECTION_VALpublic static final String GETCONNECTION_VAL PooledConnection.getConnection()method name- See Also:
- Constant Field Values
 
 - 
UNWRAP_VALpublic static final String UNWRAP_VAL Wrapper.unwrap(Class)method name- See Also:
- Constant Field Values
 
 - 
ISWRAPPERFOR_VALpublic static final String ISWRAPPERFOR_VAL Wrapper.isWrapperFor(Class)method name- See Also:
- Constant Field Values
 
 - 
ISVALID_VALpublic static final String ISVALID_VAL Connection.isValid(int)method name- See Also:
- Constant Field Values
 
 - 
EQUALS_VALpublic static final String EQUALS_VAL - See Also:
- Constant Field Values
 
 - 
HASHCODE_VALpublic static final String HASHCODE_VAL - See Also:
- Constant Field Values
 
 - 
propertiesprotected Map<String,PoolProperties.InterceptorProperty> properties Properties for this interceptor.
 
- 
 - 
Method Detail- 
invokepublic Object invoke(Object proxy, Method method, Object[] args) throws Throwable Gets invoked each time an operation onConnectionis invoked.- Specified by:
- invokein interface- InvocationHandler
- Throws:
- Throwable
 
 - 
getNextpublic JdbcInterceptor getNext() Returns the next interceptor in the chain- Returns:
- the next interceptor in the chain
 
 - 
setNextpublic void setNext(JdbcInterceptor next) configures the next interceptor in the chain- Parameters:
- next- The next chain item
 
 - 
comparepublic boolean compare(String name1, String name2) Performs a string comparison, using references unless the useEquals property is set to true.- Parameters:
- name1- The first name
- name2- The second name
- Returns:
- true if name1 is equal to name2 based on useEquals
 
 - 
comparepublic boolean compare(String methodName, Method method) Compares a method name (String) to a method (Method)compare(String,String)Uses reference comparison unless the useEquals property is set to true- Parameters:
- methodName- The method name
- method- The method
- Returns:
- trueif the name matches
 
 - 
resetpublic abstract void reset(ConnectionPool parent, PooledConnection con) Gets called each time the connection is borrowed from the pool This means that if an interceptor holds a reference to the connection the interceptor can be reused for another connection.
 This method may be called with null as both arguments when we are closing down the connection.- Parameters:
- parent- - the connection pool owning the connection
- con- - the pooled connection
 
 - 
disconnectedpublic void disconnected(ConnectionPool parent, PooledConnection con, boolean finalizing) Called whenConnection.close()is called on the underlying connection. This is to notify the interceptors, that the physical connection has been released. Implementation of this method should be thought through with care, as no actions should trigger an exception.- Parameters:
- parent- - the connection pool that this connection belongs to
- con- - the pooled connection that holds this connection
- finalizing- - if this connection is finalizing. True means that the pooled connection will not reconnect the underlying connection
 
 - 
getPropertiespublic Map<String,PoolProperties.InterceptorProperty> getProperties() Returns the properties configured for this interceptor- Returns:
- the configured properties for this interceptor
 
 - 
setPropertiespublic void setProperties(Map<String,PoolProperties.InterceptorProperty> properties) Called during the creation of an interceptor The properties can be set during the configuration of an interceptor Override this method to perform type casts between string values and object properties- Parameters:
- properties- The properties
 
 - 
isUseEqualspublic boolean isUseEquals() - Returns:
- true if the compare method uses the Object.equals(Object) method false if comparison is done on a reference level
 
 - 
setUseEqualspublic void setUseEquals(boolean useEquals) Set to true if string comparisons (for thecompare(String, Method)andcompare(String, String)methods) should use the Object.equals(Object) method The default is false- Parameters:
- useEquals-- trueif equals will be used for comparisons
 
 - 
poolClosedpublic void poolClosed(ConnectionPool pool) This method is invoked by a connection pool when the pool is closed. Interceptor classes can override this method if they keep static variables or other tracking means around. This method is only invoked on a single instance of the interceptor, and not on every instance created.- Parameters:
- pool- - the pool that is being closed.
 
 - 
poolStartedpublic void poolStarted(ConnectionPool pool) This method is invoked by a connection pool when the pool is first started up, usually when the first connection is requested. Interceptor classes can override this method if they keep static variables or other tracking means around. This method is only invoked on a single instance of the interceptor, and not on every instance created.- Parameters:
- pool- - the pool that is being closed.
 
 
- 
 
-