org.infinispan.configuration.cache.ClusteringConfigurationBuilder Maven / Gradle / Ivy
package org.infinispan.configuration.cache;
import static org.infinispan.configuration.cache.ClusteringConfiguration.CACHE_MODE;
import java.util.Arrays;
import org.infinispan.commons.configuration.Builder;
import org.infinispan.commons.configuration.attributes.AttributeSet;
import org.infinispan.configuration.global.GlobalConfiguration;
import org.infinispan.util.logging.Log;
import org.infinispan.util.logging.LogFactory;
/**
* Defines clustered characteristics of the cache.
*
* @author pmuir
*
*/
public class ClusteringConfigurationBuilder extends AbstractConfigurationChildBuilder implements
ClusteringConfigurationChildBuilder, Builder {
private static final Log log = LogFactory.getLog(ClusteringConfigurationBuilder.class, Log.class);
private final AsyncConfigurationBuilder asyncConfigurationBuilder;
private final HashConfigurationBuilder hashConfigurationBuilder;
private final L1ConfigurationBuilder l1ConfigurationBuilder;
private final StateTransferConfigurationBuilder stateTransferConfigurationBuilder;
private final SyncConfigurationBuilder syncConfigurationBuilder;
private final PartitionHandlingConfigurationBuilder partitionHandlingConfigurationBuilder;
private final AttributeSet attributes;
ClusteringConfigurationBuilder(ConfigurationBuilder builder) {
super(builder);
this.attributes = ClusteringConfiguration.attributeDefinitionSet();
this.asyncConfigurationBuilder = new AsyncConfigurationBuilder(this);
this.hashConfigurationBuilder = new HashConfigurationBuilder(this);
this.l1ConfigurationBuilder = new L1ConfigurationBuilder(this);
this.stateTransferConfigurationBuilder = new StateTransferConfigurationBuilder(this);
this.syncConfigurationBuilder = new SyncConfigurationBuilder(this);
this.partitionHandlingConfigurationBuilder = new PartitionHandlingConfigurationBuilder(this);
}
/**
* Cache mode. See {@link CacheMode} for information on the various cache modes available.
*/
public ClusteringConfigurationBuilder cacheMode(CacheMode cacheMode) {
attributes.attribute(CACHE_MODE).set(cacheMode);
return this;
}
public CacheMode cacheMode() {
return attributes.attribute(CACHE_MODE).get();
}
/**
* Configure async sub element. Once this method is invoked users cannot subsequently invoke
* configureSync()
as two are mutually exclusive
*/
@Override
public AsyncConfigurationBuilder async() {
if (cacheMode().isSynchronous())
throw log.asyncPropertiesConfigOnSyncCache();
return asyncConfigurationBuilder;
}
/**
* Configure hash sub element
*/
@Override
public HashConfigurationBuilder hash() {
return hashConfigurationBuilder;
}
/**
* This method allows configuration of the L1 cache for distributed
* caches. L1 should be explicitly enabled by calling {@link L1ConfigurationBuilder#enable()}
*/
@Override
public L1ConfigurationBuilder l1() {
return l1ConfigurationBuilder;
}
/**
* Configure the {@code stateTransfer} sub element for distributed and replicated caches.
* It doesn't have any effect on LOCAL or INVALIDATION-mode caches.
*/
@Override
public StateTransferConfigurationBuilder stateTransfer() {
return stateTransferConfigurationBuilder;
}
@Override
public SyncConfigurationBuilder sync() {
if (!cacheMode().isSynchronous())
throw log.syncPropertiesConfigOnAsyncCache();
return syncConfigurationBuilder;
}
@Override
public PartitionHandlingConfigurationBuilder partitionHandling() {
return partitionHandlingConfigurationBuilder;
}
@Override
public
void validate() {
for (Builder> validatable:
Arrays.asList(asyncConfigurationBuilder, hashConfigurationBuilder, l1ConfigurationBuilder,
syncConfigurationBuilder, stateTransferConfigurationBuilder, partitionHandlingConfigurationBuilder)) {
validatable.validate();
}
}
@Override
public void validate(GlobalConfiguration globalConfig) {
if (cacheMode().isClustered() && globalConfig.transport().transport() == null) {
throw log.missingTransportConfiguration();
}
for (ConfigurationChildBuilder validatable:
Arrays.asList(asyncConfigurationBuilder, hashConfigurationBuilder, l1ConfigurationBuilder,
syncConfigurationBuilder, stateTransferConfigurationBuilder, partitionHandlingConfigurationBuilder)) {
validatable.validate(globalConfig);
}
}
@Override
public
ClusteringConfiguration create() {
return new ClusteringConfiguration(attributes.protect(), asyncConfigurationBuilder.create(), hashConfigurationBuilder.create(),
l1ConfigurationBuilder.create(), stateTransferConfigurationBuilder.create(), syncConfigurationBuilder.create(), partitionHandlingConfigurationBuilder.create());
}
@Override
public ClusteringConfigurationBuilder read(ClusteringConfiguration template) {
attributes.read(template.attributes());
asyncConfigurationBuilder.read(template.async());
hashConfigurationBuilder.read(template.hash());
l1ConfigurationBuilder.read(template.l1());
stateTransferConfigurationBuilder.read(template.stateTransfer());
syncConfigurationBuilder.read(template.sync());
partitionHandlingConfigurationBuilder.read(template.partitionHandling());
return this;
}
@Override
public String toString() {
return "ClusteringConfigurationBuilder [asyncConfigurationBuilder=" + asyncConfigurationBuilder
+ ", hashConfigurationBuilder=" + hashConfigurationBuilder + ", l1ConfigurationBuilder="
+ l1ConfigurationBuilder + ", stateTransferConfigurationBuilder=" + stateTransferConfigurationBuilder
+ ", syncConfigurationBuilder=" + syncConfigurationBuilder + ", partitionHandlingConfigurationBuilder="
+ partitionHandlingConfigurationBuilder + ", attributes=" + attributes + "]";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy