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

org.kawanfw.sql.util.reflection.ReflectionCaller Maven / Gradle / Ivy

Go to download

AceQL HTTP is a framework of REST like http APIs that allow to access to remote SQL databases over http from any device that supports http. AceQL HTTP is provided with four client SDK: - The AceQL C# Client SDK allows to wrap the HTTP APIs using Microsoft SQL Server like calls in their code, just like they would for a local database. - The AceQL Java Client SDK allows to wrap the HTTP APIs using JDBC calls in their code, just like they would for a local database. - The AceQL Python Client SDK allows SQL calls to be encoded with standard unmodified DB-API 2.0 syntax

There is a newer version: 12.2
Show newest version
/*
 * Copyright (c)2022 KawanSoft S.A.S. All rights reserved.
 * 
 * Use of this software is governed by the Business Source License included
 * in the LICENSE.TXT file in the project's root directory.
 *
 * Change Date: 2026-11-01
 *
 * On the date above, in accordance with the Business Source License, use
 * of this software will be governed by version 2.0 of the Apache License.
 */
package org.kawanfw.sql.util.reflection;

import java.sql.SQLException;

import org.kawanfw.sql.api.server.DatabaseConfigurator;

/**
 * @author Nicolas de Pomereu
 *
 *         A class that allows to call DatabaseConfigurator methods per
 *         reflection using Invoker.
 */
public class ReflectionCaller {

    /**
     * Protected constructor
     */
    protected ReflectionCaller() {

    }

    /**
     * Return the result of getDelayBeforeNextLogin method of
     * DatabaseConfigurator
     *
     * @param databaseConfigurator
     *            the DatabaseConfigurator instance
     * @return the maximum of attempts before login delay
     *
     * @throws SQLException
     *             if any Exception occurs, it is wrapped into an SQLException
     */
    public static int getMaxLoginAttemptsBeforeDelay(
	    DatabaseConfigurator databaseConfigurator) throws SQLException {
	String methodName = new Object() {
	}.getClass().getEnclosingMethod().getName();

	if (!Invoker.existsMethod(
		DatabaseConfigurator.class.getName(),
		methodName)) {
	    return 0;
	}

	Object result = null;

	try {
	    result = Invoker.getMethodResult(databaseConfigurator, methodName);
	} catch (Exception e) {
	    throw new SQLException(e);
	}

	if (result == null) {
	    return 0;
	} else {
	    return (Integer) result;
	}
    }

    /**
     * Return the result of getDelayBeforeNextLogin method of
     * DatabaseConfigurator
     *
     * @param databaseConfigurator
     *            the DatabaseConfigurator instance
     * @return the delay in seconds before the next authorized login
     *
     * @throws SQLException
     *             if any Exception occurs, it is wrapped into an SQLException
     */
    public static int getDelayBeforeNextLogin(
	    DatabaseConfigurator databaseConfigurator) throws SQLException {
	String methodName = new Object() {
	}.getClass().getEnclosingMethod().getName();

	if (!Invoker.existsMethod(
		DatabaseConfigurator.class.getName(),
		methodName)) {
	    return 0;
	}

	Object result = null;

	try {
	    result = Invoker.getMethodResult(databaseConfigurator, methodName);
	} catch (Exception e) {
	    throw new SQLException(e);
	}

	if (result == null) {
	    return 0;
	} else {
	    return (Integer) result;
	}
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy