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

org.kawanfw.sql.tomcat.util.jdbc.ConnectionCreator 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.tomcat.util.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.util.Objects;

/**
 * Allows to crate a JDBC standalone Connection. Main purpose is for password
 * testing.
 * 
 * @author Nicolas de Pomereu
 *
 */
public class ConnectionCreator {

    private String driverClassName;
    private String url;
    private String username;
    private String password;
    private Exception exception;

    /**
     * Constructor.
     * 
     * @param driverClassName
     * @param url
     * @param username
     * @param password
     */
    public ConnectionCreator(String driverClassName, String url, String username, String password) {
	this.driverClassName = Objects.requireNonNull(driverClassName, "driverClassName cannot be null!");
	this.url = Objects.requireNonNull(url, "url cannot be null!");
	this.username = Objects.requireNonNull(username, "username cannot be null!");
	this.password = Objects.requireNonNull(password, "password cannot be null!");
    }

    /**
     * Tests if a Connection can be created with parameters passed to constructor
     * 
     * @return true if a Connection can be created, else false
     */
    public boolean canCreateConnection() {
	try {
	    Class.forName(driverClassName).newInstance();
	    DriverManager.setLoginTimeout(10); // to set login timeout
	    Connection connection = DriverManager.getConnection(url, username, password);
	    return connection == null ? false : true;
	} catch (Exception e) {
	    this.exception = e;
	    return false;
	}
    }

    /**
     * @return the Exception throwed by canCreateConnection if any
     */
    public Exception getException() {
	return exception;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy