package org.jboss.as.clustering.infinispan.subsystem;
import java.util.concurrent.TimeUnit;
import org.infinispan.server.commons.service.Builder;
import org.infinispan.server.infinispan.spi.service.CacheContainerServiceName;
import org.infinispan.server.jgroups.spi.ChannelFactory;
import org.infinispan.server.jgroups.spi.service.ChannelServiceName;
import org.jboss.as.clustering.infinispan.subsystem.EmbeddedCacheManagerConfigurationService.TransportConfiguration;
import org.jboss.msc.service.ServiceBuilder;
import org.jboss.msc.service.ServiceController;
import org.jboss.msc.service.ServiceName;
import org.jboss.msc.service.ServiceTarget;
import org.jboss.msc.service.ValueService;
import org.jboss.msc.value.InjectedValue;
import org.jboss.msc.value.Value;
import org.jgroups.JChannel;
public class TransportConfigurationBuilder implements Builder<TransportConfiguration>, Value<TransportConfiguration>, TransportConfiguration {
private final InjectedValue<JChannel> channel = new InjectedValue<>();
private final InjectedValue<ChannelFactory> factory = new InjectedValue<>();
private final String name;
private Long lockTimeout;
private boolean strictPeerToPeer;
private int initialClusterSize;
private long initialClusterTimeout;
public TransportConfigurationBuilder(String name) {
this.name = name;
}
TransportConfigurationBuilder setLockTimeout(long lockTimeout, TimeUnit timeUnit) {
this.lockTimeout = timeUnit.toMillis(lockTimeout);
return this;
}
TransportConfigurationBuilder setStrictPeerToPeer(boolean strictPeerToPeer) {
this.strictPeerToPeer = strictPeerToPeer;
return this;
}
TransportConfigurationBuilder setInitialClusterSize(int initialClusterSize) {
this.initialClusterSize = initialClusterSize;
return this;
}
TransportConfigurationBuilder setInitialClusterTimeout(long initialClusterTimeout) {
this.initialClusterTimeout = initialClusterTimeout;
return this;
}
@Override
public ChannelFactory getChannelFactory() {
return this.factory.getValue();
}
@Override
public JChannel getChannel() {
return this.channel.getValue();
}
@Override
public boolean isStrictPeerToPeer() {
return this.strictPeerToPeer;
}
@Override
public Long getLockTimeout() {
return this.lockTimeout;
}
@Override
public int getInitialClusterSize() {
return this.initialClusterSize;
}
@Override
public long getInitialClusterTimeout() {
return this.initialClusterTimeout;
}
@Override
public TransportConfiguration getValue() throws IllegalStateException, IllegalArgumentException {
return this;
}
@Override
public ServiceName getServiceName() {
return CacheContainerServiceName.CACHE_CONTAINER.getServiceName(this.name).append("transport");
}
@Override
public ServiceBuilder<TransportConfiguration> build(ServiceTarget target) {
ServiceBuilder<TransportConfiguration> builder = target.addService(this.getServiceName(), new ValueService<>(this))
.addDependency(ChannelServiceName.CHANNEL.getServiceName(this.name), JChannel.class, this.channel)
.addDependency(ChannelServiceName.FACTORY.getServiceName(this.name), ChannelFactory.class, this.factory)
;
return builder.setInitialMode(ServiceController.Mode.ON_DEMAND);
}
}