org.stuartgunter.dropwizard.cassandra.pooling.PoolingOptionsFactory Maven / Gradle / Ivy
/*
* Copyright 2014 Stuart Gunter
*
* 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 org.stuartgunter.dropwizard.cassandra.pooling;
import com.datastax.driver.core.HostDistance;
import com.datastax.driver.core.PoolingOptions;
import com.fasterxml.jackson.annotation.JsonProperty;
import javax.validation.Valid;
/**
* A factory for configuring and building {@link PoolingOptions} instances.
*
* Configuration Parameters:
*
*
* Name
* Default
* Description
*
*
* local
* No default. You must specify local pooling options.
* Specifies connection {@link HostDistanceOptions pooling options} for local hosts.
*
*
* remote
* No default. You must specify remote pooling options.
* Specifies connection {@link HostDistanceOptions pooling options} for remote hosts.
*
*
*/
public class PoolingOptionsFactory {
@Valid
private HostDistanceOptions remote;
@Valid
private HostDistanceOptions local;
@JsonProperty
public HostDistanceOptions getRemote() {
return remote;
}
@JsonProperty
public void setRemote(HostDistanceOptions remote) {
this.remote = remote;
}
@JsonProperty
public HostDistanceOptions getLocal() {
return local;
}
@JsonProperty
public void setLocal(HostDistanceOptions local) {
this.local = local;
}
public PoolingOptions build() {
PoolingOptions poolingOptions = new PoolingOptions();
if (local != null) {
setPoolingOptions(poolingOptions, HostDistance.LOCAL, local);
}
if (remote != null) {
setPoolingOptions(poolingOptions, HostDistance.REMOTE, remote);
}
return poolingOptions;
}
private void setPoolingOptions(PoolingOptions poolingOptions, HostDistance hostDistance, HostDistanceOptions options) {
if (options.getCoreConnections() != null) {
poolingOptions.setCoreConnectionsPerHost(hostDistance, options.getCoreConnections());
}
if (options.getMaxConnections() != null) {
poolingOptions.setMaxConnectionsPerHost(hostDistance, options.getMaxConnections());
}
if (options.getMaxSimultaneousRequests() != null) {
poolingOptions.setMaxSimultaneousRequestsPerConnectionThreshold(hostDistance, options.getMaxSimultaneousRequests());
}
if (options.getMinSimultaneousRequests() != null) {
poolingOptions.setMinSimultaneousRequestsPerConnectionThreshold(hostDistance, options.getMinSimultaneousRequests());
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy