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

com.github.yongchristophertang.database.guice.provider.DataSourceFactory Maven / Gradle / Ivy

/*
 * Copyright 2014-2015 the original author or authors.
 *
 * 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.
 */

package com.github.yongchristophertang.database.guice.provider;

import com.github.yongchristophertang.database.annotations.SqlDB;
import com.zaxxer.hikari.HikariDataSource;
import org.apache.commons.lang3.StringUtils;

import javax.sql.DataSource;
import java.io.IOException;
import java.util.Properties;

/**
 * Factory to create {@link javax.sql.DataSource}s via {@link SqlDB}s.
 *
 * @author Yong Tang
 * @since 0.4
 */
public class DataSourceFactory extends AnnotationClientFactory {

    public DataSourceFactory(SqlDB[] annos) {
        super(annos);
    }

    @Override
    protected DataSource createClient(SqlDB anno) {
        String config = anno.config();
        String user = anno.userName();
        String url = anno.url();
        String password = anno.password();

        if (StringUtils.isBlank(config)) {
            if (StringUtils.isBlank(user) || StringUtils.isBlank(url) || StringUtils.isBlank(password)) {
                throw new IllegalArgumentException("Not all necessary configuration are specified.");
            }
        } else {
            Properties prop = new Properties();
            try {
                prop.load(this.getClass().getClassLoader().getResourceAsStream(config));
                url = prop.getProperty("sql.jdbc.url");
                user = prop.getProperty("sql.jdbc.userName");
                password = prop.getProperty("sql.jdbc.password");
            } catch (IOException e) {
                return null;
            }
        }

        HikariDataSource ds = new HikariDataSource();
        ds.setJdbcUrl(url);
        ds.setUsername(user);
        ds.setPassword(password);
        return ds;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy