All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.geomajas.project.profiling.jdbc.ConnectionInvocationHandler Maven / Gradle / Ivy

The newest version!
/*
 * This is part of Geomajas, a GIS framework, http://www.geomajas.org/.
 *
 * Copyright 2008-2013 Geosparc nv, http://www.geosparc.com/, Belgium.
 *
 * The program is available in open source according to the Apache
 * License, Version 2.0. All contributions in this program are covered
 * by the Geomajas Contributors License Agreement. For full licensing
 * details, see LICENSE.txt in the project root.
 */

package org.geomajas.project.profiling.jdbc;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.Statement;

/**
 * Wrapping JDBC connection which can be used to profile the time spent communicating with the database.
 *
 * @author Joachim Van der Auwera
 */
public class ConnectionInvocationHandler implements InvocationHandler {

	private Connection delegate;

	/**
	 * Constructor.
	 *
	 * @param delegate the "real" connection which is profiled.
	 */
	public ConnectionInvocationHandler(Connection delegate) {
		this.delegate = delegate;
	}

	@Override
	// CHECKSTYLE THROWS_THROWABLE: OFF
	public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
		long start = System.currentTimeMillis();
		try {
			if ("prepareCall".equals(method.getName())) {
				CallableStatement callableStatement = (CallableStatement) method.invoke(delegate, args);
				return Proxy.newProxyInstance(callableStatement.getClass().getClassLoader(),
						new Class[] {PreparedStatement.class},
						new ProfilingInvocationHandler("CallableStatement.", callableStatement));
			} else if ("prepareStatement".equals(method.getName())) {
				PreparedStatement preparedStatement = (PreparedStatement) method.invoke(delegate, args);
				return Proxy.newProxyInstance(preparedStatement.getClass().getClassLoader(),
						new Class[] {PreparedStatement.class},
						new ProfilingInvocationHandler("PreparedStatement.", preparedStatement));
			} else if ("createStatement".equals(method.getName())) {
				Statement statement = (Statement) method.invoke(delegate, args);
				return Proxy.newProxyInstance(statement.getClass().getClassLoader(),
						new Class[] {PreparedStatement.class},
						new ProfilingInvocationHandler("Statement.", statement));
			}
			return method.invoke(delegate, args);
		} finally {
			ProfilingDriver.register("Connection." + method.getName(), System.currentTimeMillis() - start);
		}
	}
	// CHECKSTYLE THROWS_THROWABLE: ON
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy