/*
* #%L
* P6Spy
* %%
* Copyright (C) 2002 - 2016 P6Spy
* %%
* 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.
* #L%
*/
package com.p6spy.engine.event;
import com.p6spy.engine.common.CallableStatementInformation;
import com.p6spy.engine.common.ConnectionInformation;
import com.p6spy.engine.common.PreparedStatementInformation;
import com.p6spy.engine.common.ResultSetInformation;
import com.p6spy.engine.common.StatementInformation;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class CompoundJdbcEventListener extends JdbcEventListener {
private final List<JdbcEventListener> eventListeners;
public CompoundJdbcEventListener() {
eventListeners = new ArrayList<JdbcEventListener>();
}
public CompoundJdbcEventListener(List<JdbcEventListener> eventListeners) {
this.eventListeners = eventListeners;
}
public void addListender(JdbcEventListener listener) {
eventListeners.add(listener);
}
/**
* Returns a read only view of the registered {@link JdbcEventListener}s
*
* @return a read only view of the registered {@link JdbcEventListener}s
*/
public List<JdbcEventListener> getEventListeners() {
return Collections.unmodifiableList(eventListeners);
}
@Override
public void onConnectionWrapped(ConnectionInformation connectionInformation) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onConnectionWrapped(connectionInformation);
}
}
@Override
public void onBeforeAddBatch(PreparedStatementInformation statementInformation) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onBeforeAddBatch(statementInformation);
}
}
@Override
public void onAfterAddBatch(PreparedStatementInformation statementInformation, long timeElapsedNanos, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterAddBatch(statementInformation, timeElapsedNanos, e);
}
}
@Override
public void onBeforeAddBatch(StatementInformation statementInformation, String sql) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onBeforeAddBatch(statementInformation, sql);
}
}
@Override
public void onAfterAddBatch(StatementInformation statementInformation, long timeElapsedNanos, String sql, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterAddBatch(statementInformation, timeElapsedNanos, sql, e);
}
}
@Override
public void onBeforeExecute(PreparedStatementInformation statementInformation) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onBeforeExecute(statementInformation);
}
}
@Override
public void onAfterExecute(PreparedStatementInformation statementInformation, long timeElapsedNanos, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterExecute(statementInformation, timeElapsedNanos, e);
}
}
@Override
public void onBeforeExecute(StatementInformation statementInformation, String sql) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onBeforeExecute(statementInformation, sql);
}
}
@Override
public void onAfterExecute(StatementInformation statementInformation, long timeElapsedNanos, String sql, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterExecute(statementInformation, timeElapsedNanos, sql, e);
}
}
@Override
public void onBeforeExecuteBatch(StatementInformation statementInformation) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onBeforeExecuteBatch(statementInformation);
}
}
@Override
public void onAfterExecuteBatch(StatementInformation statementInformation, long timeElapsedNanos, int[] updateCounts, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterExecuteBatch(statementInformation, timeElapsedNanos, updateCounts, e);
}
}
@Override
public void onBeforeExecuteUpdate(PreparedStatementInformation statementInformation) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onBeforeExecuteUpdate(statementInformation);
}
}
@Override
public void onAfterExecuteUpdate(PreparedStatementInformation statementInformation, long timeElapsedNanos, int rowCount, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterExecuteUpdate(statementInformation, timeElapsedNanos, rowCount, e);
}
}
@Override
public void onBeforeExecuteUpdate(StatementInformation statementInformation, String sql) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onBeforeExecuteUpdate(statementInformation, sql);
}
}
@Override
public void onAfterExecuteUpdate(StatementInformation statementInformation, long timeElapsedNanos, String sql, int rowCount, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterExecuteUpdate(statementInformation, timeElapsedNanos, sql, rowCount, e);
}
}
@Override
public void onBeforeExecuteQuery(PreparedStatementInformation statementInformation) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onBeforeExecuteQuery(statementInformation);
}
}
@Override
public void onAfterExecuteQuery(PreparedStatementInformation statementInformation, long timeElapsedNanos, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterExecuteQuery(statementInformation, timeElapsedNanos, e);
}
}
@Override
public void onBeforeExecuteQuery(StatementInformation statementInformation, String sql) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onBeforeExecuteQuery(statementInformation, sql);
}
}
@Override
public void onAfterExecuteQuery(StatementInformation statementInformation, long timeElapsedNanos, String sql, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterExecuteQuery(statementInformation, timeElapsedNanos, sql, e);
}
}
@Override
public void onAfterPreparedStatementSet(PreparedStatementInformation statementInformation, int parameterIndex, Object value, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterPreparedStatementSet(statementInformation, parameterIndex, value, e);
}
}
@Override
public void onAfterCallableStatementSet(CallableStatementInformation statementInformation, String parameterName, Object value, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterCallableStatementSet(statementInformation, parameterName, value, e);
}
}
@Override
public void onAfterGetResultSet(StatementInformation statementInformation, long timeElapsedNanos, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterGetResultSet(statementInformation, timeElapsedNanos, e);
}
}
@Override
public void onBeforeResultSetNext(ResultSetInformation resultSetInformation) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onBeforeResultSetNext(resultSetInformation);
}
}
@Override
public void onAfterResultSetNext(ResultSetInformation resultSetInformation, long timeElapsedNanos, boolean hasNext, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterResultSetNext(resultSetInformation, timeElapsedNanos, hasNext, e);
}
}
@Override
public void onAfterResultSetClose(ResultSetInformation resultSetInformation, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterResultSetClose(resultSetInformation, e);
}
}
@Override
public void onAfterResultSetGet(ResultSetInformation resultSetInformation, String columnLabel, Object value, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterResultSetGet(resultSetInformation, columnLabel, value, e);
}
}
@Override
public void onAfterResultSetGet(ResultSetInformation resultSetInformation, int columnIndex, Object value, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterResultSetGet(resultSetInformation, columnIndex, value, e);
}
}
@Override
public void onBeforeCommit(ConnectionInformation connectionInformation) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onBeforeCommit(connectionInformation);
}
}
@Override
public void onAfterCommit(ConnectionInformation connectionInformation, long timeElapsedNanos, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterCommit(connectionInformation, timeElapsedNanos, e);
}
}
@Override
public void onAfterConnectionClose(ConnectionInformation connectionInformation, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterConnectionClose(connectionInformation, e);
}
}
@Override
public void onBeforeRollback(ConnectionInformation connectionInformation) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onBeforeRollback(connectionInformation);
}
}
@Override
public void onAfterRollback(ConnectionInformation connectionInformation, long timeElapsedNanos, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterRollback(connectionInformation, timeElapsedNanos, e);
}
}
@Override
public void onAfterStatementClose(StatementInformation statementInformation, SQLException e) {
for (JdbcEventListener eventListener : eventListeners) {
eventListener.onAfterStatementClose(statementInformation, e);
}
}
}