Skip to content
Credentials.java 3.24 KiB
Newer Older
package it.inaf.oats.ia2.tapschemamanager.datalayer;
Sonia Zorba's avatar
Sonia Zorba committed

import java.io.Serializable;
Sonia Zorba's avatar
Sonia Zorba committed
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import javax.xml.bind.annotation.XmlAttribute;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
Sonia Zorba's avatar
Sonia Zorba committed

/**
 *
 * @author Sonia Zorba <zorba at oats.inaf.it>
 */
public class Credentials implements Serializable {
    private static final long serialVersionUID = 1153912575502196261L;
    private static final Logger log = LoggerFactory.getLogger(Credentials.class);

Sonia Zorba's avatar
Sonia Zorba committed
    private String hostname;
    private int port;
    private String username;
    private String password;
    private String database;
Sonia Zorba's avatar
Sonia Zorba committed

    private DatabaseType databaseType;

Sonia Zorba's avatar
Sonia Zorba committed
    public Credentials() {
        this(DatabaseType.MYSQL);
Sonia Zorba's avatar
Sonia Zorba committed
    }

    public Credentials(DatabaseType dbType) {
        this.databaseType = dbType;
        this.setDefaults();
    }

    @XmlAttribute(name = "hostname", required = true)
Sonia Zorba's avatar
Sonia Zorba committed
    public String getHostname() {
        return this.hostname;
    }

    public void setHostname(String hostname) {
        this.hostname = hostname;
    }

    @XmlAttribute(name = "port", required = true)
Sonia Zorba's avatar
Sonia Zorba committed
    public int getPort() {
        return this.port;
    }

    public void setPort(int port) {
        this.port = port;
    }

    @XmlAttribute(name = "username", required = true)
Sonia Zorba's avatar
Sonia Zorba committed
    public String getUsername() {
        return this.username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    @XmlAttribute(name = "password", required = true)
Sonia Zorba's avatar
Sonia Zorba committed
    public String getPassword() {
        return this.password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    @XmlAttribute(name = "database-type", required = true)
    public DatabaseType getDatabaseType() {
        return databaseType;
    }

    public void setDatabaseType(DatabaseType databaseType) {
        this.databaseType = databaseType;
    }

    /**
     * Only for POSTGRES
     */
    @XmlAttribute(name = "database")
    public String getDatabase() {
        return database;
    }

    /**
     * Only for POSTGRES
     */
    public void setDatabase(String database) {
        this.database = database;
    }

    public final void setDefaults() {
        if (databaseType == DatabaseType.MYSQL) {
            this.port = 3306;
            this.database = null;
        } else if (databaseType == DatabaseType.POSTGRES) {
            this.port = 5432;
            this.database = "postgres";
        }
    }

    public String getDatabaseDriverClass() {
        switch (getDatabaseType()) {
            case MYSQL:
                return "com.mysql.jdbc.Driver";
            case POSTGRES:
                return "org.postgresql.Driver";
Sonia Zorba's avatar
Sonia Zorba committed
    public Connection getConnection() throws SQLException {
            Class.forName(getDatabaseDriverClass());
        } catch (ClassNotFoundException e) {
            e.printStackTrace(System.err);
        }

        String connectionString = "jdbc:mysql://" + this.hostname + ":" + this.port + "/";
        log.debug("Connecting to {} with username '{}'", connectionString, this.username);
        return DriverManager.getConnection(connectionString, this.username, this.password);
Sonia Zorba's avatar
Sonia Zorba committed
    }
}