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

org.wildfly.swarm.config.infinispan.CacheContainer Maven / Gradle / Ivy

There is a newer version: 2.7.0
Show newest version
package org.wildfly.swarm.config.infinispan;

import org.wildfly.swarm.config.runtime.AttributeDocumentation;
import org.wildfly.swarm.config.runtime.ResourceDocumentation;
import org.wildfly.swarm.config.runtime.SingletonResource;
import org.wildfly.swarm.config.runtime.Address;
import org.wildfly.swarm.config.runtime.ResourceType;
import java.beans.PropertyChangeSupport;
import java.beans.PropertyChangeListener;
import java.util.List;
import org.wildfly.swarm.config.runtime.Subresource;
import org.wildfly.swarm.config.infinispan.cache_container.InvalidationCacheConsumer;
import org.wildfly.swarm.config.infinispan.cache_container.InvalidationCacheSupplier;
import org.wildfly.swarm.config.infinispan.cache_container.InvalidationCache;
import org.wildfly.swarm.config.runtime.SubresourceInfo;
import org.wildfly.swarm.config.infinispan.cache_container.CacheConsumer;
import org.wildfly.swarm.config.infinispan.cache_container.CacheSupplier;
import org.wildfly.swarm.config.infinispan.cache_container.Cache;
import org.wildfly.swarm.config.infinispan.cache_container.LocalCacheConsumer;
import org.wildfly.swarm.config.infinispan.cache_container.LocalCacheSupplier;
import org.wildfly.swarm.config.infinispan.cache_container.LocalCache;
import org.wildfly.swarm.config.infinispan.cache_container.ReplicatedCacheConsumer;
import org.wildfly.swarm.config.infinispan.cache_container.ReplicatedCacheSupplier;
import org.wildfly.swarm.config.infinispan.cache_container.ReplicatedCache;
import org.wildfly.swarm.config.infinispan.cache_container.DistributedCacheConsumer;
import org.wildfly.swarm.config.infinispan.cache_container.DistributedCacheSupplier;
import org.wildfly.swarm.config.infinispan.cache_container.DistributedCache;
import org.wildfly.swarm.config.infinispan.cache_container.ScatteredCacheConsumer;
import org.wildfly.swarm.config.infinispan.cache_container.ScatteredCacheSupplier;
import org.wildfly.swarm.config.infinispan.cache_container.ScatteredCache;
import org.wildfly.swarm.config.infinispan.cache_container.RemoteCommandThreadPool;
import org.wildfly.swarm.config.infinispan.cache_container.RemoteCommandThreadPoolConsumer;
import org.wildfly.swarm.config.infinispan.cache_container.RemoteCommandThreadPoolSupplier;
import org.wildfly.swarm.config.infinispan.cache_container.JGroupsTransport;
import org.wildfly.swarm.config.infinispan.cache_container.JGroupsTransportConsumer;
import org.wildfly.swarm.config.infinispan.cache_container.JGroupsTransportSupplier;
import org.wildfly.swarm.config.infinispan.cache_container.AsyncOperationsThreadPool;
import org.wildfly.swarm.config.infinispan.cache_container.AsyncOperationsThreadPoolConsumer;
import org.wildfly.swarm.config.infinispan.cache_container.AsyncOperationsThreadPoolSupplier;
import org.wildfly.swarm.config.infinispan.cache_container.ExpirationThreadPool;
import org.wildfly.swarm.config.infinispan.cache_container.ExpirationThreadPoolConsumer;
import org.wildfly.swarm.config.infinispan.cache_container.ExpirationThreadPoolSupplier;
import org.wildfly.swarm.config.infinispan.cache_container.TransportThreadPool;
import org.wildfly.swarm.config.infinispan.cache_container.TransportThreadPoolConsumer;
import org.wildfly.swarm.config.infinispan.cache_container.TransportThreadPoolSupplier;
import org.wildfly.swarm.config.infinispan.cache_container.NoneTransport;
import org.wildfly.swarm.config.infinispan.cache_container.NoneTransportConsumer;
import org.wildfly.swarm.config.infinispan.cache_container.NoneTransportSupplier;
import org.wildfly.swarm.config.infinispan.cache_container.PersistenceThreadPool;
import org.wildfly.swarm.config.infinispan.cache_container.PersistenceThreadPoolConsumer;
import org.wildfly.swarm.config.infinispan.cache_container.PersistenceThreadPoolSupplier;
import org.wildfly.swarm.config.infinispan.cache_container.ListenerThreadPool;
import org.wildfly.swarm.config.infinispan.cache_container.ListenerThreadPoolConsumer;
import org.wildfly.swarm.config.infinispan.cache_container.ListenerThreadPoolSupplier;
import org.wildfly.swarm.config.infinispan.cache_container.StateTransferThreadPool;
import org.wildfly.swarm.config.infinispan.cache_container.StateTransferThreadPoolConsumer;
import org.wildfly.swarm.config.infinispan.cache_container.StateTransferThreadPoolSupplier;
import org.wildfly.swarm.config.runtime.ModelNodeBinding;
import java.util.Arrays;
import java.util.stream.Collectors;

/**
 * The configuration of an infinispan cache container
 */
@Address("/subsystem=infinispan/cache-container=*")
@ResourceType("cache-container")
public class CacheContainer>
		implements
			org.wildfly.swarm.config.runtime.Keyed {

	private String key;
	private PropertyChangeSupport pcs;
	private CacheContainerResources subresources = new CacheContainerResources();
	@AttributeDocumentation("The list of aliases for this cache container")
	private List aliases;
	@AttributeDocumentation("The status of the cache manager component. May return null if the cache manager is not started.")
	private String cacheManagerStatus;
	@AttributeDocumentation("The name of the cluster this node belongs to. May return null if the cache manager is not started.")
	private String clusterName;
	@AttributeDocumentation("The logical address of the cluster's coordinator. May return null if the cache manager is not started.")
	private String coordinatorAddress;
	@AttributeDocumentation("The default infinispan cache")
	private String defaultCache;
	@AttributeDocumentation("The scheduled executor used for eviction")
	private String evictionExecutor;
	@AttributeDocumentation("Set to true if this node is the cluster's coordinator. May return null if the cache manager is not started.")
	private Boolean isCoordinator;
	@AttributeDocumentation("The jndi name to which to bind this cache container")
	private String jndiName;
	@AttributeDocumentation("The executor used for the replication queue")
	private String listenerExecutor;
	@AttributeDocumentation("The local address of the node. May return null if the cache manager is not started.")
	private String localAddress;
	@AttributeDocumentation("The module whose class loader should be used when building this cache container's configuration.")
	private String module;
	@AttributeDocumentation("The executor used for asynchronous cache operations")
	private String replicationQueueExecutor;
	@AttributeDocumentation("The cache container start mode, which can be EAGER (immediate start) or LAZY (on-demand start).")
	private String start;
	@AttributeDocumentation("If enabled, statistics will be collected for this cache container")
	private Boolean statisticsEnabled;

	public CacheContainer(java.lang.String key) {
		super();
		this.key = key;
	}

	public String getKey() {
		return this.key;
	}

	/**
	 * Adds a property change listener
	 */
	public void addPropertyChangeListener(PropertyChangeListener listener) {
		if (null == this.pcs)
			this.pcs = new PropertyChangeSupport(this);
		this.pcs.addPropertyChangeListener(listener);
	}

	/**
	 * Removes a property change listener
	 */
	public void removePropertyChangeListener(
			java.beans.PropertyChangeListener listener) {
		if (this.pcs != null)
			this.pcs.removePropertyChangeListener(listener);
	}

	public CacheContainerResources subresources() {
		return this.subresources;
	}

	/**
	 * Add all InvalidationCache objects to this subresource
	 * 
	 * @return this
	 * @param value
	 *            List of InvalidationCache objects.
	 */
	@SuppressWarnings("unchecked")
	public T invalidationCaches(java.util.List value) {
		this.subresources.invalidationCaches = value;
		return (T) this;
	}

	/**
	 * Add the InvalidationCache object to the list of subresources
	 * 
	 * @param value
	 *            The InvalidationCache to add
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T invalidationCache(InvalidationCache value) {
		this.subresources.invalidationCaches.add(value);
		return (T) this;
	}

	/**
	 * Create and configure a InvalidationCache object to the list of
	 * subresources
	 * 
	 * @param key
	 *            The key for the InvalidationCache resource
	 * @param config
	 *            The InvalidationCacheConsumer to use
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T invalidationCache(java.lang.String childKey,
			InvalidationCacheConsumer consumer) {
		InvalidationCache child = new InvalidationCache<>(
				childKey);
		if (consumer != null) {
			consumer.accept(child);
		}
		invalidationCache(child);
		return (T) this;
	}

	/**
	 * Create and configure a InvalidationCache object to the list of
	 * subresources
	 * 
	 * @param key
	 *            The key for the InvalidationCache resource
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T invalidationCache(java.lang.String childKey) {
		invalidationCache(childKey, null);
		return (T) this;
	}

	/**
	 * Install a supplied InvalidationCache object to the list of subresources
	 */
	@SuppressWarnings("unchecked")
	public T invalidationCache(InvalidationCacheSupplier supplier) {
		invalidationCache(supplier.get());
		return (T) this;
	}

	/**
	 * Add all Cache objects to this subresource
	 * 
	 * @return this
	 * @param value
	 *            List of Cache objects.
	 */
	@SuppressWarnings("unchecked")
	public T caches(java.util.List value) {
		this.subresources.caches = value;
		return (T) this;
	}

	/**
	 * Add the Cache object to the list of subresources
	 * 
	 * @param value
	 *            The Cache to add
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T cache(Cache value) {
		this.subresources.caches.add(value);
		return (T) this;
	}

	/**
	 * Create and configure a Cache object to the list of subresources
	 * 
	 * @param key
	 *            The key for the Cache resource
	 * @param config
	 *            The CacheConsumer to use
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T cache(java.lang.String childKey, CacheConsumer consumer) {
		Cache child = new Cache<>(childKey);
		if (consumer != null) {
			consumer.accept(child);
		}
		cache(child);
		return (T) this;
	}

	/**
	 * Create and configure a Cache object to the list of subresources
	 * 
	 * @param key
	 *            The key for the Cache resource
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T cache(java.lang.String childKey) {
		cache(childKey, null);
		return (T) this;
	}

	/**
	 * Install a supplied Cache object to the list of subresources
	 */
	@SuppressWarnings("unchecked")
	public T cache(CacheSupplier supplier) {
		cache(supplier.get());
		return (T) this;
	}

	/**
	 * Add all LocalCache objects to this subresource
	 * 
	 * @return this
	 * @param value
	 *            List of LocalCache objects.
	 */
	@SuppressWarnings("unchecked")
	public T localCaches(java.util.List value) {
		this.subresources.localCaches = value;
		return (T) this;
	}

	/**
	 * Add the LocalCache object to the list of subresources
	 * 
	 * @param value
	 *            The LocalCache to add
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T localCache(LocalCache value) {
		this.subresources.localCaches.add(value);
		return (T) this;
	}

	/**
	 * Create and configure a LocalCache object to the list of subresources
	 * 
	 * @param key
	 *            The key for the LocalCache resource
	 * @param config
	 *            The LocalCacheConsumer to use
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T localCache(java.lang.String childKey, LocalCacheConsumer consumer) {
		LocalCache child = new LocalCache<>(childKey);
		if (consumer != null) {
			consumer.accept(child);
		}
		localCache(child);
		return (T) this;
	}

	/**
	 * Create and configure a LocalCache object to the list of subresources
	 * 
	 * @param key
	 *            The key for the LocalCache resource
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T localCache(java.lang.String childKey) {
		localCache(childKey, null);
		return (T) this;
	}

	/**
	 * Install a supplied LocalCache object to the list of subresources
	 */
	@SuppressWarnings("unchecked")
	public T localCache(LocalCacheSupplier supplier) {
		localCache(supplier.get());
		return (T) this;
	}

	/**
	 * Add all ReplicatedCache objects to this subresource
	 * 
	 * @return this
	 * @param value
	 *            List of ReplicatedCache objects.
	 */
	@SuppressWarnings("unchecked")
	public T replicatedCaches(java.util.List value) {
		this.subresources.replicatedCaches = value;
		return (T) this;
	}

	/**
	 * Add the ReplicatedCache object to the list of subresources
	 * 
	 * @param value
	 *            The ReplicatedCache to add
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T replicatedCache(ReplicatedCache value) {
		this.subresources.replicatedCaches.add(value);
		return (T) this;
	}

	/**
	 * Create and configure a ReplicatedCache object to the list of subresources
	 * 
	 * @param key
	 *            The key for the ReplicatedCache resource
	 * @param config
	 *            The ReplicatedCacheConsumer to use
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T replicatedCache(java.lang.String childKey,
			ReplicatedCacheConsumer consumer) {
		ReplicatedCache child = new ReplicatedCache<>(
				childKey);
		if (consumer != null) {
			consumer.accept(child);
		}
		replicatedCache(child);
		return (T) this;
	}

	/**
	 * Create and configure a ReplicatedCache object to the list of subresources
	 * 
	 * @param key
	 *            The key for the ReplicatedCache resource
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T replicatedCache(java.lang.String childKey) {
		replicatedCache(childKey, null);
		return (T) this;
	}

	/**
	 * Install a supplied ReplicatedCache object to the list of subresources
	 */
	@SuppressWarnings("unchecked")
	public T replicatedCache(ReplicatedCacheSupplier supplier) {
		replicatedCache(supplier.get());
		return (T) this;
	}

	/**
	 * Add all DistributedCache objects to this subresource
	 * 
	 * @return this
	 * @param value
	 *            List of DistributedCache objects.
	 */
	@SuppressWarnings("unchecked")
	public T distributedCaches(java.util.List value) {
		this.subresources.distributedCaches = value;
		return (T) this;
	}

	/**
	 * Add the DistributedCache object to the list of subresources
	 * 
	 * @param value
	 *            The DistributedCache to add
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T distributedCache(DistributedCache value) {
		this.subresources.distributedCaches.add(value);
		return (T) this;
	}

	/**
	 * Create and configure a DistributedCache object to the list of
	 * subresources
	 * 
	 * @param key
	 *            The key for the DistributedCache resource
	 * @param config
	 *            The DistributedCacheConsumer to use
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T distributedCache(java.lang.String childKey,
			DistributedCacheConsumer consumer) {
		DistributedCache child = new DistributedCache<>(
				childKey);
		if (consumer != null) {
			consumer.accept(child);
		}
		distributedCache(child);
		return (T) this;
	}

	/**
	 * Create and configure a DistributedCache object to the list of
	 * subresources
	 * 
	 * @param key
	 *            The key for the DistributedCache resource
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T distributedCache(java.lang.String childKey) {
		distributedCache(childKey, null);
		return (T) this;
	}

	/**
	 * Install a supplied DistributedCache object to the list of subresources
	 */
	@SuppressWarnings("unchecked")
	public T distributedCache(DistributedCacheSupplier supplier) {
		distributedCache(supplier.get());
		return (T) this;
	}

	/**
	 * Add all ScatteredCache objects to this subresource
	 * 
	 * @return this
	 * @param value
	 *            List of ScatteredCache objects.
	 */
	@SuppressWarnings("unchecked")
	public T scatteredCaches(java.util.List value) {
		this.subresources.scatteredCaches = value;
		return (T) this;
	}

	/**
	 * Add the ScatteredCache object to the list of subresources
	 * 
	 * @param value
	 *            The ScatteredCache to add
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T scatteredCache(ScatteredCache value) {
		this.subresources.scatteredCaches.add(value);
		return (T) this;
	}

	/**
	 * Create and configure a ScatteredCache object to the list of subresources
	 * 
	 * @param key
	 *            The key for the ScatteredCache resource
	 * @param config
	 *            The ScatteredCacheConsumer to use
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T scatteredCache(java.lang.String childKey,
			ScatteredCacheConsumer consumer) {
		ScatteredCache child = new ScatteredCache<>(
				childKey);
		if (consumer != null) {
			consumer.accept(child);
		}
		scatteredCache(child);
		return (T) this;
	}

	/**
	 * Create and configure a ScatteredCache object to the list of subresources
	 * 
	 * @param key
	 *            The key for the ScatteredCache resource
	 * @return this
	 */
	@SuppressWarnings("unchecked")
	public T scatteredCache(java.lang.String childKey) {
		scatteredCache(childKey, null);
		return (T) this;
	}

	/**
	 * Install a supplied ScatteredCache object to the list of subresources
	 */
	@SuppressWarnings("unchecked")
	public T scatteredCache(ScatteredCacheSupplier supplier) {
		scatteredCache(supplier.get());
		return (T) this;
	}

	/**
	 * Defines a thread pool used to execute remote commands.
	 */
	@SuppressWarnings("unchecked")
	public T remoteCommandThreadPool(RemoteCommandThreadPool value) {
		this.subresources.remoteCommandThreadPool = value;
		return (T) this;
	}

	/**
	 * Defines a thread pool used to execute remote commands.
	 */
	@SuppressWarnings("unchecked")
	public T remoteCommandThreadPool(RemoteCommandThreadPoolConsumer consumer) {
		RemoteCommandThreadPool child = new RemoteCommandThreadPool<>();
		if (consumer != null) {
			consumer.accept(child);
		}
		this.subresources.remoteCommandThreadPool = child;
		return (T) this;
	}

	/**
	 * Defines a thread pool used to execute remote commands.
	 */
	@SuppressWarnings("unchecked")
	public T remoteCommandThreadPool() {
		RemoteCommandThreadPool child = new RemoteCommandThreadPool<>();
		this.subresources.remoteCommandThreadPool = child;
		return (T) this;
	}

	/**
	 * Defines a thread pool used to execute remote commands.
	 */
	@SuppressWarnings("unchecked")
	public T remoteCommandThreadPool(RemoteCommandThreadPoolSupplier supplier) {
		this.subresources.remoteCommandThreadPool = supplier.get();
		return (T) this;
	}

	/**
	 * The description of the transport used by this cache container
	 */
	@SuppressWarnings("unchecked")
	public T jgroupsTransport(JGroupsTransport value) {
		this.subresources.jgroupsTransport = value;
		return (T) this;
	}

	/**
	 * The description of the transport used by this cache container
	 */
	@SuppressWarnings("unchecked")
	public T jgroupsTransport(JGroupsTransportConsumer consumer) {
		JGroupsTransport child = new JGroupsTransport<>();
		if (consumer != null) {
			consumer.accept(child);
		}
		this.subresources.jgroupsTransport = child;
		return (T) this;
	}

	/**
	 * The description of the transport used by this cache container
	 */
	@SuppressWarnings("unchecked")
	public T jgroupsTransport() {
		JGroupsTransport child = new JGroupsTransport<>();
		this.subresources.jgroupsTransport = child;
		return (T) this;
	}

	/**
	 * The description of the transport used by this cache container
	 */
	@SuppressWarnings("unchecked")
	public T jgroupsTransport(JGroupsTransportSupplier supplier) {
		this.subresources.jgroupsTransport = supplier.get();
		return (T) this;
	}

	/**
	 * Defines a thread pool used for asynchronous operations.
	 */
	@SuppressWarnings("unchecked")
	public T asyncOperationsThreadPool(AsyncOperationsThreadPool value) {
		this.subresources.asyncOperationsThreadPool = value;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for asynchronous operations.
	 */
	@SuppressWarnings("unchecked")
	public T asyncOperationsThreadPool(
			AsyncOperationsThreadPoolConsumer consumer) {
		AsyncOperationsThreadPool child = new AsyncOperationsThreadPool<>();
		if (consumer != null) {
			consumer.accept(child);
		}
		this.subresources.asyncOperationsThreadPool = child;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for asynchronous operations.
	 */
	@SuppressWarnings("unchecked")
	public T asyncOperationsThreadPool() {
		AsyncOperationsThreadPool child = new AsyncOperationsThreadPool<>();
		this.subresources.asyncOperationsThreadPool = child;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for asynchronous operations.
	 */
	@SuppressWarnings("unchecked")
	public T asyncOperationsThreadPool(
			AsyncOperationsThreadPoolSupplier supplier) {
		this.subresources.asyncOperationsThreadPool = supplier.get();
		return (T) this;
	}

	/**
	 * Defines a thread pool used for for evictions.
	 */
	@SuppressWarnings("unchecked")
	public T expirationThreadPool(ExpirationThreadPool value) {
		this.subresources.expirationThreadPool = value;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for for evictions.
	 */
	@SuppressWarnings("unchecked")
	public T expirationThreadPool(ExpirationThreadPoolConsumer consumer) {
		ExpirationThreadPool child = new ExpirationThreadPool<>();
		if (consumer != null) {
			consumer.accept(child);
		}
		this.subresources.expirationThreadPool = child;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for for evictions.
	 */
	@SuppressWarnings("unchecked")
	public T expirationThreadPool() {
		ExpirationThreadPool child = new ExpirationThreadPool<>();
		this.subresources.expirationThreadPool = child;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for for evictions.
	 */
	@SuppressWarnings("unchecked")
	public T expirationThreadPool(ExpirationThreadPoolSupplier supplier) {
		this.subresources.expirationThreadPool = supplier.get();
		return (T) this;
	}

	/**
	 * Defines a thread pool used for asynchronous transport communication.
	 */
	@SuppressWarnings("unchecked")
	public T transportThreadPool(TransportThreadPool value) {
		this.subresources.transportThreadPool = value;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for asynchronous transport communication.
	 */
	@SuppressWarnings("unchecked")
	public T transportThreadPool(TransportThreadPoolConsumer consumer) {
		TransportThreadPool child = new TransportThreadPool<>();
		if (consumer != null) {
			consumer.accept(child);
		}
		this.subresources.transportThreadPool = child;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for asynchronous transport communication.
	 */
	@SuppressWarnings("unchecked")
	public T transportThreadPool() {
		TransportThreadPool child = new TransportThreadPool<>();
		this.subresources.transportThreadPool = child;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for asynchronous transport communication.
	 */
	@SuppressWarnings("unchecked")
	public T transportThreadPool(TransportThreadPoolSupplier supplier) {
		this.subresources.transportThreadPool = supplier.get();
		return (T) this;
	}

	/**
	 * A local-only transport used by this cache-container
	 */
	@SuppressWarnings("unchecked")
	public T noneTransport(NoneTransport value) {
		this.subresources.noneTransport = value;
		return (T) this;
	}

	/**
	 * A local-only transport used by this cache-container
	 */
	@SuppressWarnings("unchecked")
	public T noneTransport(NoneTransportConsumer consumer) {
		NoneTransport child = new NoneTransport<>();
		if (consumer != null) {
			consumer.accept(child);
		}
		this.subresources.noneTransport = child;
		return (T) this;
	}

	/**
	 * A local-only transport used by this cache-container
	 */
	@SuppressWarnings("unchecked")
	public T noneTransport() {
		NoneTransport child = new NoneTransport<>();
		this.subresources.noneTransport = child;
		return (T) this;
	}

	/**
	 * A local-only transport used by this cache-container
	 */
	@SuppressWarnings("unchecked")
	public T noneTransport(NoneTransportSupplier supplier) {
		this.subresources.noneTransport = supplier.get();
		return (T) this;
	}

	/**
	 * Defines a thread pool used for interacting with the persistent store.
	 */
	@SuppressWarnings("unchecked")
	public T persistenceThreadPool(PersistenceThreadPool value) {
		this.subresources.persistenceThreadPool = value;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for interacting with the persistent store.
	 */
	@SuppressWarnings("unchecked")
	public T persistenceThreadPool(PersistenceThreadPoolConsumer consumer) {
		PersistenceThreadPool child = new PersistenceThreadPool<>();
		if (consumer != null) {
			consumer.accept(child);
		}
		this.subresources.persistenceThreadPool = child;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for interacting with the persistent store.
	 */
	@SuppressWarnings("unchecked")
	public T persistenceThreadPool() {
		PersistenceThreadPool child = new PersistenceThreadPool<>();
		this.subresources.persistenceThreadPool = child;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for interacting with the persistent store.
	 */
	@SuppressWarnings("unchecked")
	public T persistenceThreadPool(PersistenceThreadPoolSupplier supplier) {
		this.subresources.persistenceThreadPool = supplier.get();
		return (T) this;
	}

	/**
	 * Defines a thread pool used for asynchronous cache listener notifications.
	 */
	@SuppressWarnings("unchecked")
	public T listenerThreadPool(ListenerThreadPool value) {
		this.subresources.listenerThreadPool = value;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for asynchronous cache listener notifications.
	 */
	@SuppressWarnings("unchecked")
	public T listenerThreadPool(ListenerThreadPoolConsumer consumer) {
		ListenerThreadPool child = new ListenerThreadPool<>();
		if (consumer != null) {
			consumer.accept(child);
		}
		this.subresources.listenerThreadPool = child;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for asynchronous cache listener notifications.
	 */
	@SuppressWarnings("unchecked")
	public T listenerThreadPool() {
		ListenerThreadPool child = new ListenerThreadPool<>();
		this.subresources.listenerThreadPool = child;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for asynchronous cache listener notifications.
	 */
	@SuppressWarnings("unchecked")
	public T listenerThreadPool(ListenerThreadPoolSupplier supplier) {
		this.subresources.listenerThreadPool = supplier.get();
		return (T) this;
	}

	/**
	 * Defines a thread pool used for for state transfer.
	 */
	@SuppressWarnings("unchecked")
	public T stateTransferThreadPool(StateTransferThreadPool value) {
		this.subresources.stateTransferThreadPool = value;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for for state transfer.
	 */
	@SuppressWarnings("unchecked")
	public T stateTransferThreadPool(StateTransferThreadPoolConsumer consumer) {
		StateTransferThreadPool child = new StateTransferThreadPool<>();
		if (consumer != null) {
			consumer.accept(child);
		}
		this.subresources.stateTransferThreadPool = child;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for for state transfer.
	 */
	@SuppressWarnings("unchecked")
	public T stateTransferThreadPool() {
		StateTransferThreadPool child = new StateTransferThreadPool<>();
		this.subresources.stateTransferThreadPool = child;
		return (T) this;
	}

	/**
	 * Defines a thread pool used for for state transfer.
	 */
	@SuppressWarnings("unchecked")
	public T stateTransferThreadPool(StateTransferThreadPoolSupplier supplier) {
		this.subresources.stateTransferThreadPool = supplier.get();
		return (T) this;
	}

	/**
	 * Child mutators for CacheContainer
	 */
	public static class CacheContainerResources {
		/**
		 * An invalidation cache
		 */
		@ResourceDocumentation("An invalidation cache")
		@SubresourceInfo("invalidationCache")
		private List invalidationCaches = new java.util.ArrayList<>();
		/**
		 * The configuration of the infinispan subsystem.
		 */
		@ResourceDocumentation("The configuration of the infinispan subsystem.")
		@SubresourceInfo("cache")
		private List caches = new java.util.ArrayList<>();
		/**
		 * A local cache configuration
		 */
		@ResourceDocumentation("A local cache configuration")
		@SubresourceInfo("localCache")
		private List localCaches = new java.util.ArrayList<>();
		/**
		 * A replicated cache configuration
		 */
		@ResourceDocumentation("A replicated cache configuration")
		@SubresourceInfo("replicatedCache")
		private List replicatedCaches = new java.util.ArrayList<>();
		/**
		 * A distributed cache configuration.
		 */
		@ResourceDocumentation("A distributed cache configuration.")
		@SubresourceInfo("distributedCache")
		private List distributedCaches = new java.util.ArrayList<>();
		/**
		 * A scattered cache configuration.
		 */
		@ResourceDocumentation("A scattered cache configuration.")
		@SubresourceInfo("scatteredCache")
		private List scatteredCaches = new java.util.ArrayList<>();
		@SingletonResource
		@ResourceDocumentation("Defines a thread pool used to execute remote commands.")
		private RemoteCommandThreadPool remoteCommandThreadPool;
		@SingletonResource
		@ResourceDocumentation("The description of the transport used by this cache container")
		private JGroupsTransport jgroupsTransport;
		@SingletonResource
		@ResourceDocumentation("Defines a thread pool used for asynchronous operations.")
		private AsyncOperationsThreadPool asyncOperationsThreadPool;
		@SingletonResource
		@ResourceDocumentation("Defines a thread pool used for for evictions.")
		private ExpirationThreadPool expirationThreadPool;
		@SingletonResource
		@ResourceDocumentation("Defines a thread pool used for asynchronous transport communication.")
		private TransportThreadPool transportThreadPool;
		@SingletonResource
		@ResourceDocumentation("A local-only transport used by this cache-container")
		private NoneTransport noneTransport;
		@SingletonResource
		@ResourceDocumentation("Defines a thread pool used for interacting with the persistent store.")
		private PersistenceThreadPool persistenceThreadPool;
		@SingletonResource
		@ResourceDocumentation("Defines a thread pool used for asynchronous cache listener notifications.")
		private ListenerThreadPool listenerThreadPool;
		@SingletonResource
		@ResourceDocumentation("Defines a thread pool used for for state transfer.")
		private StateTransferThreadPool stateTransferThreadPool;

		/**
		 * Get the list of InvalidationCache resources
		 * 
		 * @return the list of resources
		 */
		@Subresource
		public List invalidationCaches() {
			return this.invalidationCaches;
		}

		public InvalidationCache invalidationCache(java.lang.String key) {
			return this.invalidationCaches.stream()
					.filter(e -> e.getKey().equals(key)).findFirst()
					.orElse(null);
		}
		/**
		 * Get the list of Cache resources
		 * 
		 * @return the list of resources
		 */
		@Subresource
		public List caches() {
			return this.caches;
		}

		public Cache cache(java.lang.String key) {
			return this.caches.stream().filter(e -> e.getKey().equals(key))
					.findFirst().orElse(null);
		}
		/**
		 * Get the list of LocalCache resources
		 * 
		 * @return the list of resources
		 */
		@Subresource
		public List localCaches() {
			return this.localCaches;
		}

		public LocalCache localCache(java.lang.String key) {
			return this.localCaches.stream()
					.filter(e -> e.getKey().equals(key)).findFirst()
					.orElse(null);
		}
		/**
		 * Get the list of ReplicatedCache resources
		 * 
		 * @return the list of resources
		 */
		@Subresource
		public List replicatedCaches() {
			return this.replicatedCaches;
		}

		public ReplicatedCache replicatedCache(java.lang.String key) {
			return this.replicatedCaches.stream()
					.filter(e -> e.getKey().equals(key)).findFirst()
					.orElse(null);
		}
		/**
		 * Get the list of DistributedCache resources
		 * 
		 * @return the list of resources
		 */
		@Subresource
		public List distributedCaches() {
			return this.distributedCaches;
		}

		public DistributedCache distributedCache(java.lang.String key) {
			return this.distributedCaches.stream()
					.filter(e -> e.getKey().equals(key)).findFirst()
					.orElse(null);
		}
		/**
		 * Get the list of ScatteredCache resources
		 * 
		 * @return the list of resources
		 */
		@Subresource
		public List scatteredCaches() {
			return this.scatteredCaches;
		}

		public ScatteredCache scatteredCache(java.lang.String key) {
			return this.scatteredCaches.stream()
					.filter(e -> e.getKey().equals(key)).findFirst()
					.orElse(null);
		}
		/**
		 * Defines a thread pool used to execute remote commands.
		 */
		@Subresource
		public RemoteCommandThreadPool remoteCommandThreadPool() {
			return this.remoteCommandThreadPool;
		}

		/**
		 * The description of the transport used by this cache container
		 */
		@Subresource
		public JGroupsTransport jgroupsTransport() {
			return this.jgroupsTransport;
		}

		/**
		 * Defines a thread pool used for asynchronous operations.
		 */
		@Subresource
		public AsyncOperationsThreadPool asyncOperationsThreadPool() {
			return this.asyncOperationsThreadPool;
		}

		/**
		 * Defines a thread pool used for for evictions.
		 */
		@Subresource
		public ExpirationThreadPool expirationThreadPool() {
			return this.expirationThreadPool;
		}

		/**
		 * Defines a thread pool used for asynchronous transport communication.
		 */
		@Subresource
		public TransportThreadPool transportThreadPool() {
			return this.transportThreadPool;
		}

		/**
		 * A local-only transport used by this cache-container
		 */
		@Subresource
		public NoneTransport noneTransport() {
			return this.noneTransport;
		}

		/**
		 * Defines a thread pool used for interacting with the persistent store.
		 */
		@Subresource
		public PersistenceThreadPool persistenceThreadPool() {
			return this.persistenceThreadPool;
		}

		/**
		 * Defines a thread pool used for asynchronous cache listener
		 * notifications.
		 */
		@Subresource
		public ListenerThreadPool listenerThreadPool() {
			return this.listenerThreadPool;
		}

		/**
		 * Defines a thread pool used for for state transfer.
		 */
		@Subresource
		public StateTransferThreadPool stateTransferThreadPool() {
			return this.stateTransferThreadPool;
		}
	}

	/**
	 * The list of aliases for this cache container
	 */
	@ModelNodeBinding(detypedName = "aliases")
	public List aliases() {
		return this.aliases;
	}

	/**
	 * The list of aliases for this cache container
	 */
	@SuppressWarnings("unchecked")
	public T aliases(java.util.List value) {
		Object oldValue = this.aliases;
		this.aliases = value;
		if (this.pcs != null)
			this.pcs.firePropertyChange("aliases", oldValue, value);
		return (T) this;
	}

	/**
	 * The list of aliases for this cache container
	 */
	@SuppressWarnings("unchecked")
	public T alias(String value) {
		if (this.aliases == null) {
			this.aliases = new java.util.ArrayList<>();
		}
		this.aliases.add(value);
		return (T) this;
	}

	/**
	 * The list of aliases for this cache container
	 */
	@SuppressWarnings("unchecked")
	public T aliases(String... args) {
		aliases(Arrays.stream(args).collect(Collectors.toList()));
		return (T) this;
	}

	/**
	 * The status of the cache manager component. May return null if the cache
	 * manager is not started.
	 */
	@ModelNodeBinding(detypedName = "cache-manager-status")
	public String cacheManagerStatus() {
		return this.cacheManagerStatus;
	}

	/**
	 * The status of the cache manager component. May return null if the cache
	 * manager is not started.
	 */
	@SuppressWarnings("unchecked")
	public T cacheManagerStatus(java.lang.String value) {
		Object oldValue = this.cacheManagerStatus;
		this.cacheManagerStatus = value;
		if (this.pcs != null)
			this.pcs.firePropertyChange("cacheManagerStatus", oldValue, value);
		return (T) this;
	}

	/**
	 * The name of the cluster this node belongs to. May return null if the
	 * cache manager is not started.
	 */
	@ModelNodeBinding(detypedName = "cluster-name")
	public String clusterName() {
		return this.clusterName;
	}

	/**
	 * The name of the cluster this node belongs to. May return null if the
	 * cache manager is not started.
	 */
	@SuppressWarnings("unchecked")
	public T clusterName(java.lang.String value) {
		Object oldValue = this.clusterName;
		this.clusterName = value;
		if (this.pcs != null)
			this.pcs.firePropertyChange("clusterName", oldValue, value);
		return (T) this;
	}

	/**
	 * The logical address of the cluster's coordinator. May return null if the
	 * cache manager is not started.
	 */
	@ModelNodeBinding(detypedName = "coordinator-address")
	public String coordinatorAddress() {
		return this.coordinatorAddress;
	}

	/**
	 * The logical address of the cluster's coordinator. May return null if the
	 * cache manager is not started.
	 */
	@SuppressWarnings("unchecked")
	public T coordinatorAddress(java.lang.String value) {
		Object oldValue = this.coordinatorAddress;
		this.coordinatorAddress = value;
		if (this.pcs != null)
			this.pcs.firePropertyChange("coordinatorAddress", oldValue, value);
		return (T) this;
	}

	/**
	 * The default infinispan cache
	 */
	@ModelNodeBinding(detypedName = "default-cache")
	public String defaultCache() {
		return this.defaultCache;
	}

	/**
	 * The default infinispan cache
	 */
	@SuppressWarnings("unchecked")
	public T defaultCache(java.lang.String value) {
		Object oldValue = this.defaultCache;
		this.defaultCache = value;
		if (this.pcs != null)
			this.pcs.firePropertyChange("defaultCache", oldValue, value);
		return (T) this;
	}

	/**
	 * The scheduled executor used for eviction
	 * 
	 * @deprecated Deprecated. This will be replaced by thread pool
	 *             configuration embedded in the subsystem in a future release.
	 */
	@Deprecated
	@ModelNodeBinding(detypedName = "eviction-executor")
	public String evictionExecutor() {
		return this.evictionExecutor;
	}

	/**
	 * The scheduled executor used for eviction
	 * 
	 * @deprecated Deprecated. This will be replaced by thread pool
	 *             configuration embedded in the subsystem in a future release.
	 */
	@SuppressWarnings("unchecked")
	@Deprecated
	public T evictionExecutor(java.lang.String value) {
		Object oldValue = this.evictionExecutor;
		this.evictionExecutor = value;
		if (this.pcs != null)
			this.pcs.firePropertyChange("evictionExecutor", oldValue, value);
		return (T) this;
	}

	/**
	 * Set to true if this node is the cluster's coordinator. May return null if
	 * the cache manager is not started.
	 */
	@ModelNodeBinding(detypedName = "is-coordinator")
	public Boolean isCoordinator() {
		return this.isCoordinator;
	}

	/**
	 * Set to true if this node is the cluster's coordinator. May return null if
	 * the cache manager is not started.
	 */
	@SuppressWarnings("unchecked")
	public T isCoordinator(java.lang.Boolean value) {
		Object oldValue = this.isCoordinator;
		this.isCoordinator = value;
		if (this.pcs != null)
			this.pcs.firePropertyChange("isCoordinator", oldValue, value);
		return (T) this;
	}

	/**
	 * The jndi name to which to bind this cache container
	 * 
	 * @deprecated Deprecated. Will be ignored.
	 */
	@Deprecated
	@ModelNodeBinding(detypedName = "jndi-name")
	public String jndiName() {
		return this.jndiName;
	}

	/**
	 * The jndi name to which to bind this cache container
	 * 
	 * @deprecated Deprecated. Will be ignored.
	 */
	@SuppressWarnings("unchecked")
	@Deprecated
	public T jndiName(java.lang.String value) {
		Object oldValue = this.jndiName;
		this.jndiName = value;
		if (this.pcs != null)
			this.pcs.firePropertyChange("jndiName", oldValue, value);
		return (T) this;
	}

	/**
	 * The executor used for the replication queue
	 * 
	 * @deprecated Deprecated. This will be replaced by thread pool
	 *             configuration embedded in the subsystem in a future release.
	 */
	@Deprecated
	@ModelNodeBinding(detypedName = "listener-executor")
	public String listenerExecutor() {
		return this.listenerExecutor;
	}

	/**
	 * The executor used for the replication queue
	 * 
	 * @deprecated Deprecated. This will be replaced by thread pool
	 *             configuration embedded in the subsystem in a future release.
	 */
	@SuppressWarnings("unchecked")
	@Deprecated
	public T listenerExecutor(java.lang.String value) {
		Object oldValue = this.listenerExecutor;
		this.listenerExecutor = value;
		if (this.pcs != null)
			this.pcs.firePropertyChange("listenerExecutor", oldValue, value);
		return (T) this;
	}

	/**
	 * The local address of the node. May return null if the cache manager is
	 * not started.
	 */
	@ModelNodeBinding(detypedName = "local-address")
	public String localAddress() {
		return this.localAddress;
	}

	/**
	 * The local address of the node. May return null if the cache manager is
	 * not started.
	 */
	@SuppressWarnings("unchecked")
	public T localAddress(java.lang.String value) {
		Object oldValue = this.localAddress;
		this.localAddress = value;
		if (this.pcs != null)
			this.pcs.firePropertyChange("localAddress", oldValue, value);
		return (T) this;
	}

	/**
	 * The module whose class loader should be used when building this cache
	 * container's configuration.
	 */
	@ModelNodeBinding(detypedName = "module")
	public String module() {
		return this.module;
	}

	/**
	 * The module whose class loader should be used when building this cache
	 * container's configuration.
	 */
	@SuppressWarnings("unchecked")
	public T module(java.lang.String value) {
		Object oldValue = this.module;
		this.module = value;
		if (this.pcs != null)
			this.pcs.firePropertyChange("module", oldValue, value);
		return (T) this;
	}

	/**
	 * The executor used for asynchronous cache operations
	 * 
	 * @deprecated Deprecated. This will be replaced by thread pool
	 *             configuration embedded in the subsystem in a future release.
	 */
	@Deprecated
	@ModelNodeBinding(detypedName = "replication-queue-executor")
	public String replicationQueueExecutor() {
		return this.replicationQueueExecutor;
	}

	/**
	 * The executor used for asynchronous cache operations
	 * 
	 * @deprecated Deprecated. This will be replaced by thread pool
	 *             configuration embedded in the subsystem in a future release.
	 */
	@SuppressWarnings("unchecked")
	@Deprecated
	public T replicationQueueExecutor(java.lang.String value) {
		Object oldValue = this.replicationQueueExecutor;
		this.replicationQueueExecutor = value;
		if (this.pcs != null)
			this.pcs.firePropertyChange("replicationQueueExecutor", oldValue,
					value);
		return (T) this;
	}

	/**
	 * The cache container start mode, which can be EAGER (immediate start) or
	 * LAZY (on-demand start).
	 * 
	 * @deprecated Deprecated. Future releases will only support LAZY mode.
	 */
	@Deprecated
	@ModelNodeBinding(detypedName = "start")
	public String start() {
		return this.start;
	}

	/**
	 * The cache container start mode, which can be EAGER (immediate start) or
	 * LAZY (on-demand start).
	 * 
	 * @deprecated Deprecated. Future releases will only support LAZY mode.
	 */
	@SuppressWarnings("unchecked")
	@Deprecated
	public T start(java.lang.String value) {
		Object oldValue = this.start;
		this.start = value;
		if (this.pcs != null)
			this.pcs.firePropertyChange("start", oldValue, value);
		return (T) this;
	}

	/**
	 * If enabled, statistics will be collected for this cache container
	 */
	@ModelNodeBinding(detypedName = "statistics-enabled")
	public Boolean statisticsEnabled() {
		return this.statisticsEnabled;
	}

	/**
	 * If enabled, statistics will be collected for this cache container
	 */
	@SuppressWarnings("unchecked")
	public T statisticsEnabled(java.lang.Boolean value) {
		Object oldValue = this.statisticsEnabled;
		this.statisticsEnabled = value;
		if (this.pcs != null)
			this.pcs.firePropertyChange("statisticsEnabled", oldValue, value);
		return (T) this;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy