com.stardog.ext.spring.DataSourceFactoryBean Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of stardog-spring Show documentation
Show all versions of stardog-spring Show documentation
Stardog Spring bindings for using Stardog with the Springframework
The newest version!
/*
* Copyright (c) the original 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.stardog.ext.spring;
import com.complexible.common.base.Pair;
import com.complexible.stardog.api.ConnectionCredentials;
import com.complexible.stardog.api.ConnectionConfiguration;
import com.complexible.stardog.api.ConnectionPoolConfig;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.DisposableBean;
import org.springframework.beans.factory.FactoryBean;
import org.springframework.beans.factory.InitializingBean;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties;
import java.util.concurrent.TimeUnit;
import java.util.function.Supplier;
/**
* StardogConnectionFactoryBean
*
* This class implements the Spring interfaces for FactoryBean for a DataSource,
* InitializingBean, and DisposableBean, so it is a fully Spring-aware factory
*
* The objective is to configure one of these per Spring application context, and be
* able to reference DataSource objects in the SnarlTemplate, so a SnarlTemplate always
* gets a connection from the pool (via DataSource wrapper) injected in to it.
*
* Configuration for this object matches both the parameters in ConnectionConfiguration and
* ConnectionPoolConfiguration, and then inspects what has been injected to create the
* connection pool.
*
* @author Clark and Parsia, LLC
* @author Al Baker
*
*/
public class DataSourceFactoryBean implements FactoryBean, InitializingBean, DisposableBean {
final Logger log = LoggerFactory.getLogger(DataSourceFactoryBean.class);
/**
* Properties used by the ConnectionConfig
*/
private String url;
private String username;
private String password;
private boolean reasoningType = false;
private String to;
private Supplier supplier;
private Properties connectionProperties;
/**
* Properties used by the ConnectionPoolConfig
*
* TimeUnits default to miliseconds, but can be configured in Spring
*
*/
private long blockCapacityTime = 900;
private TimeUnit blockCapacityTimeUnit = TimeUnit.SECONDS;
private long expirationTime = 300;
private TimeUnit expirationTimeUnit = TimeUnit.SECONDS;
private boolean failAtCapacity = false;
private boolean growAtCapacity = true;
private int maxIdle = 100;
private int maxPool = 200;
private int minPool = 10;
private boolean noExpiration = false;
private Provider provider;
/**
* Private references to the pools and configurations that get
* constructed - see afterPropertiesSet()
*/
private DataSource dataSource;
@Override
public DataSource getObject() throws Exception {
return dataSource;
}
@Override
public Class> getObjectType() {
return DataSource.class;
}
@Override
public boolean isSingleton() {
return true;
}
/**
* destroy
* Called by Spring
*/
public void destroy() {
log.debug("Destroying dataSourceFactory bean");
dataSource.destroy();
dataSource = null;
}
/**
* afterProperiesSet
*
* Spring interface for performing an action after the properties have been set on the bean
*
* In this case, all configuration information will be passed to this object, and we can
* initialize the connection pool here
*
* Alternative method would be to declare a separate init method, and tell Spring about it
*
* @throws Exception on Stardog create, e.g. database down
*/
@Override
public void afterPropertiesSet() throws Exception {
log.debug("Initializing Stardog connection configuration");
ConnectionConfiguration connectionConfig;
ConnectionPoolConfig poolConfig;
connectionConfig = ConnectionConfiguration.to(to);
if (url != null) {
connectionConfig = connectionConfig.server(url);
}
if (provider != null) {
if (supplier != null) {
provider.execute(to, url, supplier);
} else {
provider.execute(to, url, username, password);
}
}
if (connectionProperties != null) {
List> aOptionsList = new ArrayList>();
for (String key : connectionProperties.stringPropertyNames()) {
aOptionsList.add(Pair.create(key, connectionProperties.getProperty(key)));
}
connectionConfig.with((new OptionParser()).getOptions(aOptionsList));
}
if (supplier != null) {
connectionConfig = connectionConfig.credentialSupplier(supplier);
} else {
connectionConfig = connectionConfig.credentials(username, password);
}
connectionConfig.reasoning(reasoningType);
poolConfig = ConnectionPoolConfig
.using(connectionConfig)
.minPool(minPool)
.maxPool(maxPool)
.expiration(expirationTime, expirationTimeUnit)
.blockAtCapacity(blockCapacityTime, blockCapacityTimeUnit);
dataSource = new DataSource(connectionConfig, poolConfig);
dataSource.afterPropertiesSet();
}
/**********************************************************
* Getters and Setters
**********************************************************/
/**
* @return the url
*/
public String getUrl() {
return url;
}
/**
* @param url the url to set
*/
public void setUrl(String url) {
this.url = url;
}
/**
* @return the reasoningType
*/
public boolean getReasoningType() {
return reasoningType;
}
/**
* @param reasoningType the reasoningType to set
*/
public void setReasoningType(boolean reasoningType) {
this.reasoningType = reasoningType;
}
/**
* @return the to
*/
public String getTo() {
return to;
}
/**
* @param to the to to set
*/
public void setTo(String to) {
this.to = to;
}
/**
* @return the connectionProperties
*/
public Properties getConnectionProperties() {
return connectionProperties;
}
/**
* @param connectionProperties the connectionProperties to set
*/
public void setConnectionProperties(Properties connectionProperties) {
this.connectionProperties = connectionProperties;
}
/**
* @return the blockCapacityTime
*/
public long getBlockCapacityTime() {
return blockCapacityTime;
}
/**
* @param blockCapacityTime the blockCapacityTime to set
*/
public void setBlockCapacityTime(long blockCapacityTime) {
this.blockCapacityTime = blockCapacityTime;
}
/**
* @return the blockCapacityTimeUnit
*/
public TimeUnit getBlockCapacityTimeUnit() {
return blockCapacityTimeUnit;
}
/**
* @param blockCapacityTimeUnit the blockCapacityTimeUnit to set
*/
public void setBlockCapacityTimeUnit(TimeUnit blockCapacityTimeUnit) {
this.blockCapacityTimeUnit = blockCapacityTimeUnit;
}
/**
* @return the expirationTime
*/
public long getExpirationTime() {
return expirationTime;
}
/**
* @param expirationTime the expirationTime to set
*/
public void setExpirationTime(long expirationTime) {
this.expirationTime = expirationTime;
}
/**
* @return the expirationTimeUnit
*/
public TimeUnit getExpirationTimeUnit() {
return expirationTimeUnit;
}
/**
* @param expirationTimeUnit the expirationTimeUnit to set
*/
public void setExpirationTimeUnit(TimeUnit expirationTimeUnit) {
this.expirationTimeUnit = expirationTimeUnit;
}
/**
* @return the failAtCapacity
*/
public boolean isFailAtCapacity() {
return failAtCapacity;
}
/**
* @param failAtCapacity the failAtCapacity to set
*/
public void setFailAtCapacity(boolean failAtCapacity) {
this.failAtCapacity = failAtCapacity;
}
/**
* @return the growAtCapacity
*/
public boolean isGrowAtCapacity() {
return growAtCapacity;
}
/**
* @param growAtCapacity the growAtCapacity to set
*/
public void setGrowAtCapacity(boolean growAtCapacity) {
this.growAtCapacity = growAtCapacity;
}
/**
* @return the maxIdle
*/
public int getMaxIdle() {
return maxIdle;
}
/**
* @param maxIdle the maxIdle to set
*/
public void setMaxIdle(int maxIdle) {
this.maxIdle = maxIdle;
}
/**
* @return the maxPool
*/
public int getMaxPool() {
return maxPool;
}
/**
* @param maxPool the maxPool to set
*/
public void setMaxPool(int maxPool) {
this.maxPool = maxPool;
}
/**
* @return the minPool
*/
public int getMinPool() {
return minPool;
}
/**
* @param minPool the minPool to set
*/
public void setMinPool(int minPool) {
this.minPool = minPool;
}
/**
* @return the noExpiration
*/
public boolean isNoExpiration() {
return noExpiration;
}
/**
* @param noExpiration the noExpiration to set
*/
public void setNoExpiration(boolean noExpiration) {
this.noExpiration = noExpiration;
}
/**
* @return the username
*/
public String getUsername() {
return username;
}
/**
* @param username the username to set
*/
public void setUsername(String username) {
this.username = username;
}
/**
* @return the password
*/
public String getPassword() {
return password;
}
/**
* @param password the password to set
*/
public void setPassword(String password) {
this.password = password;
}
public Provider getProvider() {
return provider;
}
public void setProvider(Provider provider) {
this.provider = provider;
}
public Supplier getSupplier() {
return supplier;
}
public void setSupplier(Supplier supplier) {
this.supplier = supplier;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy