org.infinispan.configuration.parsing.Parser Maven / Gradle / Ivy
package org.infinispan.configuration.parsing;
import static org.infinispan.commons.util.StringPropertyReplacer.replaceProperties;
import static org.infinispan.factories.KnownComponentNames.ASYNC_NOTIFICATION_EXECUTOR;
import static org.infinispan.factories.KnownComponentNames.ASYNC_OPERATIONS_EXECUTOR;
import static org.infinispan.factories.KnownComponentNames.ASYNC_TRANSPORT_EXECUTOR;
import static org.infinispan.factories.KnownComponentNames.EXPIRATION_SCHEDULED_EXECUTOR;
import static org.infinispan.factories.KnownComponentNames.PERSISTENCE_EXECUTOR;
import static org.infinispan.factories.KnownComponentNames.REMOTE_COMMAND_EXECUTOR;
import static org.infinispan.factories.KnownComponentNames.STATE_TRANSFER_EXECUTOR;
import static org.infinispan.factories.KnownComponentNames.shortened;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import java.util.Properties;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.TimeUnit;
import javax.xml.stream.XMLStreamConstants;
import javax.xml.stream.XMLStreamException;
import org.infinispan.commons.api.BasicCacheContainer;
import org.infinispan.commons.configuration.BuiltBy;
import org.infinispan.commons.configuration.ConfiguredBy;
import org.infinispan.commons.equivalence.Equivalence;
import org.infinispan.commons.executors.BlockingThreadPoolExecutorFactory;
import org.infinispan.commons.executors.CachedThreadPoolExecutorFactory;
import org.infinispan.commons.executors.ScheduledThreadPoolExecutorFactory;
import org.infinispan.commons.executors.ThreadPoolExecutorFactory;
import org.infinispan.commons.marshall.AdvancedExternalizer;
import org.infinispan.commons.marshall.Marshaller;
import org.infinispan.commons.util.Util;
import org.infinispan.configuration.cache.AbstractStoreConfigurationBuilder;
import org.infinispan.configuration.cache.AsyncStoreConfigurationBuilder;
import org.infinispan.configuration.cache.AuthorizationConfigurationBuilder;
import org.infinispan.configuration.cache.BackupConfiguration;
import org.infinispan.configuration.cache.BackupConfigurationBuilder;
import org.infinispan.configuration.cache.BackupFailurePolicy;
import org.infinispan.configuration.cache.CacheMode;
import org.infinispan.configuration.cache.ClusterLoaderConfigurationBuilder;
import org.infinispan.configuration.cache.Configuration;
import org.infinispan.configuration.cache.ConfigurationBuilder;
import org.infinispan.configuration.cache.CustomStoreConfigurationBuilder;
import org.infinispan.configuration.cache.Index;
import org.infinispan.configuration.cache.InterceptorConfiguration;
import org.infinispan.configuration.cache.InterceptorConfigurationBuilder;
import org.infinispan.configuration.cache.MemoryConfigurationBuilder;
import org.infinispan.configuration.cache.PartitionHandlingConfigurationBuilder;
import org.infinispan.configuration.cache.SecurityConfigurationBuilder;
import org.infinispan.configuration.cache.SingleFileStoreConfigurationBuilder;
import org.infinispan.configuration.cache.StoreConfigurationBuilder;
import org.infinispan.configuration.cache.VersioningScheme;
import org.infinispan.configuration.global.GlobalAuthorizationConfigurationBuilder;
import org.infinispan.configuration.global.GlobalConfigurationBuilder;
import org.infinispan.configuration.global.GlobalRoleConfigurationBuilder;
import org.infinispan.configuration.global.GlobalStateConfigurationBuilder;
import org.infinispan.configuration.global.ShutdownHookBehavior;
import org.infinispan.configuration.global.ThreadPoolConfiguration;
import org.infinispan.configuration.global.ThreadPoolConfigurationBuilder;
import org.infinispan.configuration.global.TransportConfigurationBuilder;
import org.infinispan.container.DataContainer;
import org.infinispan.container.StorageType;
import org.infinispan.distribution.group.Grouper;
import org.infinispan.eviction.EvictionStrategy;
import org.infinispan.eviction.EvictionThreadPolicy;
import org.infinispan.eviction.EvictionType;
import org.infinispan.factories.threads.DefaultThreadFactory;
import org.infinispan.jmx.MBeanServerLookup;
import org.infinispan.persistence.cluster.ClusterLoader;
import org.infinispan.persistence.file.SingleFileStore;
import org.infinispan.persistence.spi.CacheLoader;
import org.infinispan.remoting.transport.Transport;
import org.infinispan.security.AuditLogger;
import org.infinispan.security.PrincipalRoleMapper;
import org.infinispan.security.impl.ClusterRoleMapper;
import org.infinispan.security.impl.CommonNameRoleMapper;
import org.infinispan.security.impl.IdentityRoleMapper;
import org.infinispan.transaction.LockingMode;
import org.infinispan.transaction.TransactionProtocol;
import org.infinispan.transaction.lookup.TransactionManagerLookup;
import org.infinispan.util.concurrent.IsolationLevel;
import org.infinispan.util.logging.Log;
import org.infinispan.util.logging.LogFactory;
import org.kohsuke.MetaInfServices;
/**
* This class implements the parser for Infinispan/AS7/EAP/JDG schema files
*
* @author Tristan Tarrant
* @author Galder Zamarreño
* @since 9.0
*/
@MetaInfServices
@Namespaces({
@Namespace(uri = "urn:infinispan:config:9.0", root = "infinispan"),
@Namespace(root = "infinispan"),
@Namespace(uri = "urn:infinispan:config:8.0", root = "infinispan"),
@Namespace(uri = "urn:infinispan:config:8.1", root = "infinispan"),
@Namespace(uri = "urn:infinispan:config:8.2", root = "infinispan"),
@Namespace(uri = "urn:infinispan:config:7.0", root = "infinispan"),
@Namespace(uri = "urn:infinispan:config:7.1", root = "infinispan"),
@Namespace(uri = "urn:infinispan:config:7.2", root = "infinispan"),
})
public class Parser implements ConfigurationParser {
static final Log log = LogFactory.getLog(Parser.class);
private final Map threadFactories = new HashMap();
private final Map threadPools = new HashMap();
private final Map threadPoolToThreadFactory = new HashMap();
public Parser() {
}
@Override
public void readElement(final XMLExtendedStreamReader reader, final ConfigurationBuilderHolder holder) throws XMLStreamException {
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case CACHE_CONTAINER: {
parseContainer(reader, holder);
break;
}
case JGROUPS: {
parseJGroups(reader, holder);
break;
}
case THREADS: {
parseThreads(reader, holder);
break;
}
default: {
throw ParseUtils.unexpectedElement(reader);
}
}
}
}
private void parseSerialization(final XMLExtendedStreamReader reader, final ConfigurationBuilderHolder holder)
throws XMLStreamException {
GlobalConfigurationBuilder builder = holder.getGlobalConfigurationBuilder();
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case MARSHALLER_CLASS: {
builder.serialization().marshaller(Util.getInstance(value, holder.getClassLoader()));
break;
}
case VERSION: {
builder.serialization().version(value);
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
parseAdvancedExternalizers(reader, holder);
}
private void parseAdvancedExternalizers(final XMLExtendedStreamReader reader, final ConfigurationBuilderHolder holder)
throws XMLStreamException {
GlobalConfigurationBuilder builder = holder.getGlobalConfigurationBuilder();
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case ADVANCED_EXTERNALIZER: {
int attributes = reader.getAttributeCount();
AdvancedExternalizer> advancedExternalizer = null;
Integer id = null;
ParseUtils.requireAttributes(reader, Attribute.CLASS.getLocalName());
for (int i = 0; i < attributes; i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case CLASS: {
advancedExternalizer = Util.getInstance(value, holder.getClassLoader());
break;
}
case ID: {
id = Integer.valueOf(value);
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ParseUtils.requireNoContent(reader);
if (id != null) {
builder.serialization().addAdvancedExternalizer(id, advancedExternalizer);
} else {
builder.serialization().addAdvancedExternalizer(advancedExternalizer);
}
break;
}
default: {
throw ParseUtils.unexpectedElement(reader);
}
}
}
}
private void parseThreads(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case THREAD_FACTORY: {
parseThreadFactory(reader);
break;
}
case CACHED_THREAD_POOL: {
parseCachedThreadPool(reader, holder);
break;
}
case SCHEDULED_THREAD_POOL: {
parseScheduledThreadPool(reader, holder);
break;
}
case BLOCKING_BOUNDED_QUEUE_THREAD_POOL: {
parseBlockingBoundedQueueThreadPool(reader, holder);
break;
}
default: {
throw ParseUtils.unexpectedElement(reader);
}
}
}
// Link up thread factories with the thread pools that have referenced them
for (Map.Entry entry : threadPools.entrySet()) {
String threadFactoryName = threadPoolToThreadFactory.get(entry.getKey());
if (threadFactoryName != null) {
ThreadFactory threadFactory = threadFactories.get(threadFactoryName);
entry.getValue().threadFactory(threadFactory);
}
}
}
private void parseBlockingBoundedQueueThreadPool(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
ThreadPoolConfigurationBuilder builder = new ThreadPoolConfigurationBuilder(holder.getGlobalConfigurationBuilder());
String name = null;
String threadFactoryName = null;
int maxThreads = 0;
int coreThreads = 0;
int queueLength = 0;
long keepAlive = 0;
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case NAME: {
name = value;
break;
}
case THREAD_FACTORY: {
threadFactoryName = value;
break;
}
case CORE_THREADS: {
coreThreads = Integer.valueOf(value);
break;
}
case MAX_THREADS: {
maxThreads = Integer.valueOf(value);
break;
}
case QUEUE_LENGTH: {
queueLength = Integer.valueOf(value);
break;
}
case KEEP_ALIVE_TIME: {
keepAlive = Long.valueOf(value);
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ThreadPoolExecutorFactory factory = new BlockingThreadPoolExecutorFactory(
maxThreads, coreThreads, queueLength, keepAlive);
builder.threadPoolFactory(factory);
// Keep track of the thread pool to thread factory name mapping,
// and wait until all threads section has been processed to link the
// actual thread factories with the thread pools.
threadPoolToThreadFactory.put(name, threadFactoryName);
threadPools.put(name, builder);
ParseUtils.requireNoContent(reader);
}
private void parseScheduledThreadPool(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
ThreadPoolConfigurationBuilder builder = new ThreadPoolConfigurationBuilder(holder.getGlobalConfigurationBuilder());
String name = null;
String threadFactoryName = null;
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case NAME: {
name = value;
break;
}
case THREAD_FACTORY: {
threadFactoryName = value;
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ThreadPoolExecutorFactory factory = ScheduledThreadPoolExecutorFactory.create();
builder.threadPoolFactory(factory);
// Keep track of the thread pool to thread factory name mapping,
// and wait until all threads section has been processed to link the
// actual thread factories with the thread pools.
threadPoolToThreadFactory.put(name, threadFactoryName);
threadPools.put(name, builder);
ParseUtils.requireNoContent(reader);
}
private void parseCachedThreadPool(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
ThreadPoolConfigurationBuilder builder = new ThreadPoolConfigurationBuilder(holder.getGlobalConfigurationBuilder());
String name = null;
String threadFactoryName = null;
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case NAME: {
name = value;
break;
}
case THREAD_FACTORY: {
threadFactoryName = value;
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ThreadPoolExecutorFactory factory = CachedThreadPoolExecutorFactory.create();
builder.threadPoolFactory(factory);
// Keep track of the thread pool to thread factory name mapping,
// and wait until all threads section has been processed to link the
// actual thread factories with the thread pools.
threadPoolToThreadFactory.put(name, threadFactoryName);
threadPools.put(name, builder);
ParseUtils.requireNoContent(reader);
}
private void parseThreadFactory(XMLExtendedStreamReader reader) throws XMLStreamException {
String name = null;
ThreadGroup threadGroup = null;
String threadNamePattern = null;
int priority = 1; // minimum priority
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case NAME: {
name = value;
break;
}
case GROUP_NAME: {
threadGroup = new ThreadGroup(value);
break;
}
case THREAD_NAME_PATTERN: {
threadNamePattern = value;
break;
}
case PRIORITY: {
priority = Integer.valueOf(value);
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
DefaultThreadFactory threadFactory = new DefaultThreadFactory(name,
threadGroup, priority, threadNamePattern, null, null);
threadFactories.put(name, threadFactory);
ParseUtils.requireNoContent(reader);
}
private void parseJGroups(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
Transport transport = null;
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case TRANSPORT:
transport = Util.getInstance(value, holder.getClassLoader());
break;
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
if (transport == null) {
// Set up default transport
holder.getGlobalConfigurationBuilder().transport().defaultTransport();
} else {
holder.getGlobalConfigurationBuilder().transport().transport(transport);
}
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case STACK_FILE: {
parseStackFile(reader, holder);
break;
}
default: {
throw ParseUtils.unexpectedElement(reader);
}
}
}
}
private void parseStackFile(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
String stackName = null;
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case NAME: {
stackName = value;
holder.getGlobalConfigurationBuilder().transport()
.addProperty("stack-" + stackName, value);
break;
}
case PATH: {
holder.getGlobalConfigurationBuilder().transport()
.addProperty("stackFilePath-" + stackName, value);
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ParseUtils.requireNoContent(reader);
}
private void parseContainer(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
holder.pushScope(ParserScope.CACHE_CONTAINER);
GlobalConfigurationBuilder builder = holder.getGlobalConfigurationBuilder();
if (!reader.getSchema().since(9, 0)) {
builder.defaultCacheName(BasicCacheContainer.DEFAULT_CACHE_NAME);
}
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case NAME: {
builder.globalJmxStatistics().cacheManagerName(value);
break;
}
case ALIASES: {
log.ignoreXmlAttribute(attribute);
break;
}
case DEFAULT_CACHE: {
builder.defaultCacheName(value);
break;
}
case JNDI_NAME: {
log.ignoreXmlAttribute(attribute);
break;
}
case START: {
log.ignoreXmlAttribute(attribute);
break;
}
case ASYNC_EXECUTOR: {
builder.asyncThreadPool().read(createThreadPoolConfiguration(value, ASYNC_OPERATIONS_EXECUTOR));
break;
}
case LISTENER_EXECUTOR: {
builder.listenerThreadPool().read(
createThreadPoolConfiguration(value, ASYNC_NOTIFICATION_EXECUTOR));
break;
}
case EVICTION_EXECUTOR:
log.evictionExecutorDeprecated();
// fallthrough
case EXPIRATION_EXECUTOR: {
builder.expirationThreadPool().read(
createThreadPoolConfiguration(value, EXPIRATION_SCHEDULED_EXECUTOR));
break;
}
case REPLICATION_QUEUE_EXECUTOR: {
if (reader.getSchema().since(9, 0)) {
throw ParseUtils.unexpectedAttribute(reader, attribute.getLocalName());
} else {
log.ignoredReplicationQueueAttribute(attribute.getLocalName(), reader.getLocation().getLineNumber());
}
break;
}
case PERSISTENCE_EXECUTOR: {
builder.persistenceThreadPool().read(
createThreadPoolConfiguration(value, PERSISTENCE_EXECUTOR));
break;
}
case STATE_TRANSFER_EXECUTOR: {
builder.stateTransferThreadPool().read(
createThreadPoolConfiguration(value, STATE_TRANSFER_EXECUTOR));
break;
}
case MODULE: {
log.ignoreXmlAttribute(attribute);
break;
}
case STATISTICS: {
builder.globalJmxStatistics().enabled(Boolean.valueOf(value));
break;
}
case SHUTDOWN_HOOK: {
builder.shutdown().hookBehavior(ShutdownHookBehavior.valueOf(value));
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case TRANSPORT: {
parseTransport(reader, holder);
break;
}
case LOCAL_CACHE: {
parseLocalCache(reader, holder, false);
break;
}
case LOCAL_CACHE_CONFIGURATION: {
parseLocalCache(reader, holder, true);
break;
}
case INVALIDATION_CACHE: {
parseInvalidationCache(reader, holder, false);
break;
}
case INVALIDATION_CACHE_CONFIGURATION: {
parseInvalidationCache(reader, holder, true);
break;
}
case REPLICATED_CACHE: {
parseReplicatedCache(reader, holder, false);
break;
}
case REPLICATED_CACHE_CONFIGURATION: {
parseReplicatedCache(reader, holder, true);
break;
}
case DISTRIBUTED_CACHE: {
parseDistributedCache(reader, holder, false);
break;
}
case DISTRIBUTED_CACHE_CONFIGURATION: {
parseDistributedCache(reader, holder, true);
break;
}
case SERIALIZATION: {
parseSerialization(reader, holder);
break;
}
case MODULES: {
if (reader.getSchema().since(9, 0)) {
throw ParseUtils.unexpectedElement(reader);
} else {
parseModules(reader, holder);
}
break;
}
case JMX: {
parseJmx(reader, holder);
break;
}
case SECURITY: {
parseGlobalSecurity(reader, holder);
break;
}
case GLOBAL_STATE: {
if (reader.getSchema().since(8, 1)) {
parseGlobalState(reader, holder);
} else {
throw ParseUtils.unexpectedElement(reader);
}
break;
}
default: {
reader.handleAny(holder);
}
}
}
holder.popScope();
}
private void parseGlobalSecurity(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
ParseUtils.requireNoAttributes(reader);
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case AUTHORIZATION: {
parseGlobalAuthorization(reader, holder);
break;
}
default: {
throw ParseUtils.unexpectedElement(reader);
}
}
}
}
private void parseGlobalAuthorization(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
GlobalAuthorizationConfigurationBuilder builder = holder.getGlobalConfigurationBuilder().security().authorization().enable();
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case AUDIT_LOGGER: {
builder.auditLogger(Util.getInstance(value, holder.getClassLoader()));
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
PrincipalRoleMapper roleMapper = null;
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case IDENTITY_ROLE_MAPPER:
if (roleMapper != null) {
throw ParseUtils.unexpectedElement(reader);
}
ParseUtils.requireNoAttributes(reader);
ParseUtils.requireNoContent(reader);
roleMapper = new IdentityRoleMapper();
break;
case COMMON_NAME_ROLE_MAPPER:
if (roleMapper != null) {
throw ParseUtils.unexpectedElement(reader);
}
ParseUtils.requireNoAttributes(reader);
ParseUtils.requireNoContent(reader);
roleMapper = new CommonNameRoleMapper();
break;
case CLUSTER_ROLE_MAPPER:
if (roleMapper != null) {
throw ParseUtils.unexpectedElement(reader);
}
ParseUtils.requireNoAttributes(reader);
ParseUtils.requireNoContent(reader);
roleMapper = new ClusterRoleMapper();
break;
case CUSTOM_ROLE_MAPPER:
if (roleMapper != null) {
throw ParseUtils.unexpectedElement(reader);
}
roleMapper = parseCustomMapper(reader, holder);
break;
case ROLE: {
parseGlobalRole(reader, builder);
break;
}
default: {
throw ParseUtils.unexpectedElement(reader);
}
}
}
if (roleMapper != null) {
builder.principalRoleMapper(roleMapper);
}
}
private PrincipalRoleMapper parseCustomMapper(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
String mapperClass = ParseUtils.requireSingleAttribute(reader, Attribute.CLASS.getLocalName());
ParseUtils.requireNoContent(reader);
return Util.getInstance(mapperClass, holder.getClassLoader());
}
private void parseGlobalRole(XMLExtendedStreamReader reader, GlobalAuthorizationConfigurationBuilder builder) throws XMLStreamException {
String[] attributes = ParseUtils.requireAttributes(reader, Attribute.NAME.getLocalName(), Attribute.PERMISSIONS.getLocalName());
GlobalRoleConfigurationBuilder role = builder.role(attributes[0]);
for(String permission : attributes[1].split("\\s+")) {
role.permission(permission);
}
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case NAME:
case PERMISSIONS: {
// Already handled
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ParseUtils.requireNoContent(reader);
}
private void parseJmx(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
GlobalConfigurationBuilder builder = holder.getGlobalConfigurationBuilder();
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case JMX_DOMAIN: {
builder.globalJmxStatistics().jmxDomain(value);
break;
}
case MBEAN_SERVER_LOOKUP: {
builder.globalJmxStatistics().mBeanServerLookup(Util.getInstance(value, holder.getClassLoader()));
break;
}
case ALLOW_DUPLICATE_DOMAINS: {
builder.globalJmxStatistics().allowDuplicateDomains(Boolean.valueOf(value));
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
Properties properties = parseProperties(reader);
builder.globalJmxStatistics().withProperties(properties);
}
private void parseModules(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder)
throws XMLStreamException {
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
reader.handleAny(holder);
}
}
private void parseTransport(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
GlobalConfigurationBuilder globalBuilder = holder.getGlobalConfigurationBuilder();
if (holder.getGlobalConfigurationBuilder().transport().getTransport() == null) {
holder.getGlobalConfigurationBuilder().transport().defaultTransport();
}
TransportConfigurationBuilder transport = holder.getGlobalConfigurationBuilder().transport();
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case STACK: {
boolean stackFound = transport.getProperty("stack-" + value) != null;
if (stackFound) {
String filePath = transport.getProperty("stackFilePath-" + value);
transport.addProperty("stack", value);
transport.addProperty("configurationFile", filePath);
}
break;
}
case UNKNOWN:
break;
case ACQUIRE_TIMEOUT:
break;
case AFTER:
break;
case ALIASES:
break;
case ALLOW_DUPLICATE_DOMAINS:
break;
case ASYNC_EXECUTOR:
break;
case ASYNC_MARSHALLING:
break;
case AUDIT_LOGGER:
break;
case AUTO_COMMIT:
break;
case AUTO_CONFIG:
break;
case AWAIT_INITIAL_TRANSFER:
break;
case BACKUP_FAILURE_POLICY:
break;
case BEFORE:
break;
case CAPACITY_FACTOR:
break;
case CHUNK_SIZE:
break;
case CLASS:
break;
case CLUSTER: {
globalBuilder.transport().clusterName(value);
break;
}
case COMPLETED_TX_TIMEOUT:
break;
case CONCURRENCY_LEVEL:
break;
case CONFIGURATION:
break;
case CONSISTENT_HASH_FACTORY:
break;
case CORE_THREADS:
break;
case DATA_CONTAINER:
break;
case DEFAULT_CACHE:
break;
case ENABLED:
break;
case EXECUTOR: {
globalBuilder.transport().transportThreadPool().read(
createThreadPoolConfiguration(value, ASYNC_TRANSPORT_EXECUTOR));
break;
}
case TOTAL_ORDER_EXECUTOR: {
if (reader.getSchema().since(9, 0)) {
throw ParseUtils.unexpectedAttribute(reader, attribute.getLocalName());
} else {
log.ignoredAttribute("total order executor", "9.0", attribute.getLocalName(), reader.getLocation().getLineNumber());
}
}
case REMOTE_COMMAND_EXECUTOR: {
globalBuilder.transport().remoteCommandThreadPool().read(
createThreadPoolConfiguration(value, REMOTE_COMMAND_EXECUTOR));
break;
}
case EVICTION_EXECUTOR:
break;
case EXPIRATION_EXECUTOR:
break;
case FAILURE_POLICY_CLASS:
break;
case FETCH_STATE:
break;
case FLUSH_LOCK_TIMEOUT:
break;
case GROUP_NAME:
break;
case ID:
break;
case INDEX:
break;
case INTERVAL:
break;
case INVALIDATION_CLEANUP_TASK_FREQUENCY:
break;
case ISOLATION:
break;
case JNDI_NAME:
break;
case JMX_DOMAIN:
break;
case KEEP_ALIVE_TIME:
break;
case KEY_EQUIVALENCE:
break;
case KEY_PARTITIONER:
break;
case L1_LIFESPAN:
break;
case LIFESPAN:
break;
case LISTENER_EXECUTOR:
break;
case LOCATION:
break;
case LOCK_TIMEOUT: {
globalBuilder.transport().distributedSyncTimeout(Long.valueOf(value));
break;
}
case NODE_NAME: {
globalBuilder.transport().nodeName(value);
for (DefaultThreadFactory threadFactory : threadFactories.values())
threadFactory.setNode(value);
break;
}
case LOCKING:
break;
case MACHINE_ID: {
globalBuilder.transport().machineId(value);
break;
}
case RACK_ID: {
globalBuilder.transport().rackId(value);
break;
}
case SITE: {
globalBuilder.transport().siteId(value);
globalBuilder.site().localSite(value);
break;
}
case INITIAL_CLUSTER_SIZE: {
if (reader.getSchema().since(8, 2)) {
globalBuilder.transport().initialClusterSize(Integer.valueOf(value));
} else {
throw ParseUtils.unexpectedAttribute(reader, i);
}
break;
}
case INITIAL_CLUSTER_TIMEOUT: {
if (reader.getSchema().since(8, 2)) {
globalBuilder.transport().initialClusterTimeout(Long.parseLong(value), TimeUnit.MILLISECONDS);
} else {
throw ParseUtils.unexpectedAttribute(reader, i);
}
break;
}
case MAPPER:
break;
case MARSHALLER_CLASS:
break;
case MAX_ENTRIES:
break;
case MAX_IDLE:
break;
case MAX_RETRIES:
break;
case MAX_THREADS:
break;
case MBEAN_SERVER_LOOKUP:
break;
case MODE:
break;
case MODIFICATION_QUEUE_SIZE:
break;
case MODULE:
break;
case NAME:
break;
case NAMES:
break;
case NOTIFICATIONS:
break;
case ON_REHASH:
break;
case OWNERS:
break;
case PATH:
break;
case PASSIVATION:
break;
case PERMISSIONS:
break;
case PERSISTENCE_EXECUTOR:
break;
case POSITION:
break;
case PRELOAD:
break;
case PRIORITY:
break;
case PURGE:
break;
case QUEUE_FLUSH_INTERVAL:
break;
case QUEUE_LENGTH:
break;
case QUEUE_SIZE:
break;
case READ_ONLY:
break;
case REAPER_WAKE_UP_INTERVAL:
break;
case RECOVERY_INFO_CACHE_NAME:
break;
case RELATIVE_TO:
break;
case REMOTE_CACHE:
break;
case REMOTE_SITE:
break;
case REMOTE_TIMEOUT:
break;
case REPLICATION_QUEUE_EXECUTOR:
break;
case ROLES:
break;
case SEGMENTS:
break;
case SHARED:
break;
case SHUTDOWN_HOOK:
break;
case SHUTDOWN_TIMEOUT:
break;
case SIMPLE_CACHE:
break;
case SINGLETON:
break;
case SIZE:
break;
case SPIN_DURATION:
break;
case STATISTICS:
break;
case STATISTICS_AVAILABLE:
break;
case START:
break;
case STATE_TRANSFER_EXECUTOR:
break;
case STORE_KEYS_AS_BINARY:
break;
case STORE_VALUES_AS_BINARY:
break;
case STRATEGY:
break;
case STRIPING:
break;
case STOP_TIMEOUT:
break;
case TAKE_BACKUP_OFFLINE_AFTER_FAILURES:
break;
case TAKE_BACKUP_OFFLINE_MIN_WAIT:
break;
case THREAD_FACTORY:
break;
case THREAD_NAME_PATTERN:
break;
case THREAD_POLICY:
break;
case THREAD_POOL_SIZE:
break;
case TIMEOUT:
break;
case TRANSACTION_MANAGER_LOOKUP_CLASS:
break;
case TRANSACTION_PROTOCOL:
break;
case TRANSPORT:
break;
case TYPE:
break;
case UNRELIABLE_RETURN_VALUES:
break;
case USE_TWO_PHASE_COMMIT:
break;
case VALUE:
break;
case VALUE_EQUIVALENCE:
break;
case VERSION:
break;
case VERSIONING_SCHEME:
break;
case WAIT_TIME:
break;
case WRITE_SKEW_CHECK:
break;
case FRAGMENTATION_FACTOR:
break;
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ParseUtils.requireNoContent(reader);
}
private void parseGlobalState(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
ParseUtils.requireNoAttributes(reader);
GlobalStateConfigurationBuilder builder = holder.getGlobalConfigurationBuilder().globalState().enable();
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case PERSISTENT_LOCATION: {
builder.persistentLocation(parseGlobalStatePath(reader));
break;
}
case TEMPORARY_LOCATION: {
builder.temporaryLocation(parseGlobalStatePath(reader));
break;
}
default: {
throw ParseUtils.unexpectedElement(reader);
}
}
}
}
private String parseGlobalStatePath(XMLExtendedStreamReader reader) throws XMLStreamException {
String path = replaceProperties(ParseUtils.requireAttributes(reader, Attribute.PATH.getLocalName())[0]);
for (int i = 0; i < reader.getAttributeCount(); i++) {
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case RELATIVE_TO: {
log.ignoreXmlAttribute(attribute);
break;
}
case PATH: {
// Handled above
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ParseUtils.requireNoContent(reader);
return path;
}
private ThreadPoolConfiguration createThreadPoolConfiguration(String threadPoolName, String componentName) {
ThreadPoolConfigurationBuilder threadPool = threadPools.get(threadPoolName);
if (threadPool == null)
throw log.undefinedThreadPoolName(threadPoolName);
ThreadPoolConfiguration threadPoolConfiguration = threadPool.create();
DefaultThreadFactory threadFactory = threadPoolConfiguration.threadFactory();
threadFactory.setComponent(shortened(componentName));
return threadPoolConfiguration;
}
private void parseLocalCache(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder, boolean template) throws XMLStreamException {
holder.pushScope(template ? ParserScope.CACHE_TEMPLATE : ParserScope.CACHE);
String name = reader.getAttributeValue(null, Attribute.NAME.getLocalName());
String configuration = reader.getAttributeValue(null, Attribute.CONFIGURATION.getLocalName());
ConfigurationBuilder builder = getConfigurationBuilder(holder, name, template, configuration);
builder.clustering().cacheMode(CacheMode.LOCAL);
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
this.parseCacheAttribute(reader, i, attribute, value, builder);
}
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
this.parseCacheElement(reader, element, holder);
}
holder.popScope();
}
private void parseCacheAttribute(XMLExtendedStreamReader reader,
int index, Attribute attribute, String value, ConfigurationBuilder builder) throws XMLStreamException {
switch (attribute) {
case NAME:
case CONFIGURATION:
// Handled by the caller
break;
case START:
case JNDI_NAME:
case MODULE: {
log.ignoreXmlAttribute(attribute);
break;
}
case SIMPLE_CACHE:
builder.simpleCache(Boolean.valueOf(value));
break;
case STATISTICS: {
builder.jmxStatistics().enabled(Boolean.valueOf(value));
break;
}
case STATISTICS_AVAILABLE: {
builder.jmxStatistics().available(Boolean.valueOf(value));
break;
}
case SPIN_DURATION: {
long spin = Long.parseLong(value);
if (spin > 0)
builder.deadlockDetection().enable().spinDuration(spin);
else
builder.deadlockDetection().disable();
break;
}
case UNRELIABLE_RETURN_VALUES: {
builder.unsafe().unreliableReturnValues(Boolean.valueOf(value));
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, index);
}
}
}
private void parseSharedStateCacheElement(XMLExtendedStreamReader reader, Element element, ConfigurationBuilderHolder holder) throws XMLStreamException {
ConfigurationBuilder builder = holder.getCurrentConfigurationBuilder();
switch (element) {
case STATE_TRANSFER: {
this.parseStateTransfer(reader, builder);
break;
}
default: {
this.parseCacheElement(reader, element, holder);
}
}
}
private void parseBackups(XMLExtendedStreamReader reader, ConfigurationBuilder builder) throws XMLStreamException {
// If backups is present then remove any existing backups as they were added by the default config.
builder.sites().backups().clear();
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case BACKUP: {
this.parseBackup(reader, builder);
break;
}
default: {
throw ParseUtils.unexpectedElement(reader);
}
}
}
}
private void parsePartitionHandling(XMLExtendedStreamReader reader, ConfigurationBuilder builder) throws XMLStreamException {
PartitionHandlingConfigurationBuilder ph = builder.clustering().partitionHandling();
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case ENABLED: {
ph.enabled(Boolean.valueOf(value));
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ParseUtils.requireNoContent(reader);
}
private void parseBackup(XMLExtendedStreamReader reader, ConfigurationBuilder builder) throws XMLStreamException {
BackupConfigurationBuilder backup = builder.sites().addBackup();
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case SITE: {
backup.site(value);
break;
}
case STRATEGY: {
backup.strategy(BackupConfiguration.BackupStrategy.valueOf(value));
break;
}
case BACKUP_FAILURE_POLICY: {
backup.backupFailurePolicy(BackupFailurePolicy.valueOf(value));
break;
}
case TIMEOUT: {
backup.replicationTimeout(Long.valueOf(value));
break;
}
case ENABLED: {
backup.enabled(Boolean.valueOf(value));
break;
}
case USE_TWO_PHASE_COMMIT: {
backup.useTwoPhaseCommit(Boolean.parseBoolean(value));
break;
}
case FAILURE_POLICY_CLASS: {
backup.failurePolicyClass(value);
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
if (backup.site() == null) {
throw ParseUtils.missingRequired(reader, Collections.singleton(Attribute.SITE));
}
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case TAKE_OFFLINE: {
this.parseTakeOffline(reader, backup);
break;
}
case STATE_TRANSFER: {
this.parseXSiteStateTransfer(reader, backup);
break;
}
default: {
throw ParseUtils.unexpectedElement(reader);
}
}
}
}
private void parseTakeOffline(XMLExtendedStreamReader reader, BackupConfigurationBuilder backup) throws XMLStreamException {
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case TAKE_BACKUP_OFFLINE_AFTER_FAILURES: {
backup.takeOffline().afterFailures(Integer.valueOf(value));
break;
}
case TAKE_BACKUP_OFFLINE_MIN_WAIT: {
backup.takeOffline().minTimeToWait(Long.valueOf(value));
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ParseUtils.requireNoContent(reader);
}
private void parseXSiteStateTransfer(XMLExtendedStreamReader reader, BackupConfigurationBuilder backup) throws XMLStreamException {
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case CHUNK_SIZE:
backup.stateTransfer().chunkSize(Integer.parseInt(value));
break;
case TIMEOUT:
backup.stateTransfer().timeout(Long.parseLong(value));
break;
case MAX_RETRIES:
backup.stateTransfer().maxRetries(Integer.parseInt(value));
break;
case WAIT_TIME:
backup.stateTransfer().waitTime(Long.parseLong(value));
break;
default:
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
ParseUtils.requireNoContent(reader);
}
private void parseBackupFor(XMLExtendedStreamReader reader, ConfigurationBuilder builder) throws XMLStreamException {
builder.sites().backupFor().reset();
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case REMOTE_CACHE: {
builder.sites().backupFor().remoteCache(value);
break;
}
case REMOTE_SITE: {
builder.sites().backupFor().remoteSite(value);
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ParseUtils.requireNoContent(reader);
}
private void parseCacheSecurity(XMLExtendedStreamReader reader, ConfigurationBuilder builder) throws XMLStreamException {
SecurityConfigurationBuilder securityBuilder = builder.security();
ParseUtils.requireNoAttributes(reader);
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case AUTHORIZATION: {
parseCacheAuthorization(reader, securityBuilder.authorization().enable());
break;
}
default: {
throw ParseUtils.unexpectedElement(reader);
}
}
}
}
private void parseCacheAuthorization(XMLExtendedStreamReader reader, AuthorizationConfigurationBuilder authzBuilder) throws XMLStreamException {
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case ENABLED: {
authzBuilder.enabled(Boolean.parseBoolean(value));
break;
}
case ROLES: {
for(String role : value.split("\\s+")) {
authzBuilder.role(role);
}
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ParseUtils.requireNoContent(reader);
}
protected void parseCacheElement(XMLExtendedStreamReader reader, Element element, ConfigurationBuilderHolder holder) throws XMLStreamException {
ConfigurationBuilder builder = holder.getCurrentConfigurationBuilder();
switch (element) {
case LOCKING: {
this.parseLocking(reader, builder);
break;
}
case TRANSACTION: {
this.parseTransaction(reader, builder, holder);
break;
}
case EVICTION: {
this.parseEviction(reader, builder);
break;
}
case EXPIRATION: {
this.parseExpiration(reader, builder);
break;
}
case PERSISTENCE: {
this.parsePersistence(reader, holder);
break;
}
case INDEXING: {
this.parseIndexing(reader, holder);
break;
}
case CUSTOM_INTERCEPTORS: {
this.parseCustomInterceptors(reader, holder);
break;
}
case VERSIONING: {
parseVersioning(reader, holder);
break;
}
case COMPATIBILITY: {
parseCompatibility(reader, holder);
break;
}
case STORE_AS_BINARY: {
parseStoreAsBinary(reader, holder);
break;
}
case MODULES: {
if (reader.getSchema().since(9, 0)) {
throw ParseUtils.unexpectedElement(reader);
} else {
parseModules(reader, holder);
}
break;
}
case DATA_CONTAINER: {
parseDataContainer(reader, holder);
break;
}
case MEMORY: {
parseMemory(reader, holder);
break;
}
case BACKUPS: {
this.parseBackups(reader, builder);
break;
}
case BACKUP_FOR: {
this.parseBackupFor(reader, builder);
break;
}
case PARTITION_HANDLING: {
this.parsePartitionHandling(reader, builder);
break;
}
case SECURITY: {
this.parseCacheSecurity(reader, builder);
break;
}
default: {
reader.handleAny(holder);
}
}
}
private void parseDataContainer(final XMLExtendedStreamReader reader, final ConfigurationBuilderHolder holder) throws XMLStreamException {
ConfigurationBuilder builder = holder.getCurrentConfigurationBuilder();
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case CLASS:
log.dataContainerConfigurationDeprecated();
builder.dataContainer().dataContainer(Util.getInstance(value, holder.getClassLoader()));
break;
case KEY_EQUIVALENCE:
builder.dataContainer().keyEquivalence(Util.getInstance(value, holder.getClassLoader()));
break;
case VALUE_EQUIVALENCE:
builder.dataContainer().valueEquivalence(Util.getInstance(value, holder.getClassLoader()));
break;
default:
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
Properties properties = new Properties();
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case PROPERTY: {
parseProperty(reader, properties);
break;
}
default: {
throw ParseUtils.unexpectedElement(reader);
}
}
}
builder.dataContainer().withProperties(properties);
}
private void parseMemory(final XMLExtendedStreamReader reader, final ConfigurationBuilderHolder holder) throws XMLStreamException {
MemoryConfigurationBuilder memoryBuilder = holder.getCurrentConfigurationBuilder().memory();
ParseUtils.requireNoAttributes(reader);
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case OFFHEAP:
memoryBuilder.storageType(StorageType.OFF_HEAP);
parseOffHeapMemoryAttributes(reader, holder);
break;
case OBJECT:
memoryBuilder.storageType(StorageType.OBJECT);
parseObjectMemoryAttributes(reader, holder);
break;
case BINARY:
memoryBuilder.storageType(StorageType.BINARY);
parseBinaryMemoryAttributes(reader, holder);
break;
default:
throw ParseUtils.unexpectedElement(reader);
}
}
}
private void parseOffHeapMemoryAttributes(final XMLExtendedStreamReader reader, final ConfigurationBuilderHolder holder) throws XMLStreamException {
MemoryConfigurationBuilder memoryBuilder = holder.getCurrentConfigurationBuilder().memory();
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case SIZE:
memoryBuilder.size(Long.parseLong(value));
break;
case EVICTION:
memoryBuilder.evictionType(EvictionType.valueOf(value));
break;
case ADDRESS_COUNT:
memoryBuilder.addressCount(Integer.parseInt(value));
break;
default:
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
ParseUtils.requireNoContent(reader);
}
private void parseObjectMemoryAttributes(final XMLExtendedStreamReader reader, final ConfigurationBuilderHolder holder) throws XMLStreamException {
MemoryConfigurationBuilder memoryBuilder = holder.getCurrentConfigurationBuilder().memory();
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case SIZE:
memoryBuilder.size(Long.parseLong(value));
break;
default:
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
ParseUtils.requireNoContent(reader);
}
private void parseBinaryMemoryAttributes(final XMLExtendedStreamReader reader, final ConfigurationBuilderHolder holder) throws XMLStreamException {
MemoryConfigurationBuilder memoryBuilder = holder.getCurrentConfigurationBuilder().memory();
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case SIZE:
memoryBuilder.size(Long.parseLong(value));
break;
case EVICTION:
memoryBuilder.evictionType(EvictionType.valueOf(value));
break;
default:
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
ParseUtils.requireNoContent(reader);
}
private void parseStoreAsBinary(final XMLExtendedStreamReader reader, final ConfigurationBuilderHolder holder) throws XMLStreamException {
ConfigurationBuilder builder = holder.getCurrentConfigurationBuilder();
Boolean binaryKeys = null;
Boolean binaryValues = null;
builder.storeAsBinary().enable();
builder.memory().storageType(StorageType.BINARY);
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case STORE_KEYS_AS_BINARY:
binaryKeys = Boolean.parseBoolean(value);
builder.storeAsBinary().storeKeysAsBinary(binaryKeys);
break;
case STORE_VALUES_AS_BINARY:
binaryValues = Boolean.parseBoolean(value);
builder.storeAsBinary().storeValuesAsBinary(binaryValues);
break;
default:
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
if (binaryKeys != null && !binaryKeys && binaryValues != null && !binaryValues)
builder.storeAsBinary().disable(); // explicitly disable
ParseUtils.requireNoContent(reader);
}
private void parseCompatibility(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
ConfigurationBuilder builder = holder.getCurrentConfigurationBuilder();
builder.compatibility().enable();
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case MARSHALLER_CLASS:
builder.compatibility().marshaller(Util.getInstance(value, holder.getClassLoader()));
break;
default:
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
ParseUtils.requireNoContent(reader);
}
private void parseVersioning(final XMLExtendedStreamReader reader, final ConfigurationBuilderHolder holder) throws XMLStreamException {
ConfigurationBuilder builder = holder.getCurrentConfigurationBuilder();
builder.versioning().enable();
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case VERSIONING_SCHEME:
builder.versioning().scheme(VersioningScheme.valueOf(value));
break;
default:
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
ParseUtils.requireNoContent(reader);
}
private void parseCustomInterceptors(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
ParseUtils.requireNoAttributes(reader);
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case INTERCEPTOR: {
parseInterceptor(reader, holder);
break;
}
default: {
throw ParseUtils.unexpectedElement(reader);
}
}
}
}
private void parseInterceptor(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
ConfigurationBuilder builder = holder.getCurrentConfigurationBuilder();
InterceptorConfigurationBuilder interceptorBuilder = builder.customInterceptors().addInterceptor();
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case AFTER:
interceptorBuilder.after(Util.loadClass(value, holder.getClassLoader()));
break;
case BEFORE:
interceptorBuilder.before(Util.loadClass(value, holder.getClassLoader()));
break;
case CLASS:
interceptorBuilder.interceptorClass(Util.loadClass(value, holder.getClassLoader()));
break;
case INDEX:
interceptorBuilder.index(Integer.parseInt(value));
break;
case POSITION:
interceptorBuilder.position(InterceptorConfiguration.Position.valueOf(value.toUpperCase()));
break;
default:
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
interceptorBuilder.withProperties(parseProperties(reader));
}
protected void parseLocking(XMLExtendedStreamReader reader, ConfigurationBuilder builder) throws XMLStreamException {
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case ISOLATION: {
builder.locking().isolationLevel(IsolationLevel.valueOf(value));
break;
}
case STRIPING: {
builder.locking().useLockStriping(Boolean.parseBoolean(value));
break;
}
case ACQUIRE_TIMEOUT: {
builder.locking().lockAcquisitionTimeout(Long.parseLong(value));
break;
}
case CONCURRENCY_LEVEL: {
builder.locking().concurrencyLevel(Integer.parseInt(value));
break;
}
case WRITE_SKEW_CHECK: {
builder.locking().writeSkewCheck(Boolean.valueOf(value));
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ParseUtils.requireNoContent(reader);
}
protected void parseTransaction(XMLExtendedStreamReader reader, ConfigurationBuilder builder, ConfigurationBuilderHolder holder) throws XMLStreamException {
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case STOP_TIMEOUT: {
builder.transaction().cacheStopTimeout(Long.parseLong(value));
break;
}
case MODE: {
TransactionMode txMode = TransactionMode.valueOf(value);
builder.transaction().transactionMode(txMode.getMode());
builder.transaction().useSynchronization(!txMode.isXAEnabled() && txMode.getMode().isTransactional());
builder.transaction().recovery().enabled(txMode.isRecoveryEnabled());
builder.invocationBatching().enable(txMode.isBatchingEnabled());
if (txMode.isRecoveryEnabled()) {
builder.transaction().syncCommitPhase(true).syncRollbackPhase(true);
}
break;
}
case LOCKING: {
builder.transaction().lockingMode(LockingMode.valueOf(value));
break;
}
case TRANSACTION_MANAGER_LOOKUP_CLASS: {
builder.transaction().transactionManagerLookup(Util.getInstance(value, holder.getClassLoader()));
break;
}
case REAPER_WAKE_UP_INTERVAL: {
builder.transaction().reaperWakeUpInterval(Long.parseLong(value));
break;
}
case COMPLETED_TX_TIMEOUT: {
builder.transaction().completedTxTimeout(Long.parseLong(value));
break;
}
case TRANSACTION_PROTOCOL: {
builder.transaction().transactionProtocol(TransactionProtocol.valueOf(value));
break;
}
case AUTO_COMMIT: {
builder.transaction().autoCommit(Boolean.parseBoolean(value));
break;
}
case RECOVERY_INFO_CACHE_NAME: {
builder.transaction().recovery().recoveryInfoCacheName(value);
break;
}
case NOTIFICATIONS: {
builder.transaction().notifications(Boolean.parseBoolean(value));
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ParseUtils.requireNoContent(reader);
}
protected void parseEviction(XMLExtendedStreamReader reader, ConfigurationBuilder builder) throws XMLStreamException {
log.evictionDeprecated();
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case STRATEGY: {
builder.eviction().strategy(EvictionStrategy.valueOf(value));
break;
}
case MAX_ENTRIES: {
log.evictionMaxEntriesDeprecated();
builder.eviction().maxEntries(Long.parseLong(value));
break;
}
case THREAD_POLICY: {
builder.eviction().threadPolicy(EvictionThreadPolicy.valueOf(value));
break;
}
case TYPE: {
builder.eviction().type(EvictionType.valueOf(value));
break;
}
case SIZE: {
builder.eviction().size(Long.parseLong(value));
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ParseUtils.requireNoContent(reader);
}
private void parseExpiration(XMLExtendedStreamReader reader, ConfigurationBuilder builder) throws XMLStreamException {
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case MAX_IDLE: {
builder.expiration().maxIdle(Long.parseLong(value));
break;
}
case LIFESPAN: {
builder.expiration().lifespan(Long.parseLong(value));
break;
}
case INTERVAL: {
builder.expiration().wakeUpInterval(Long.parseLong(value));
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ParseUtils.requireNoContent(reader);
}
private void parseInvalidationCache(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder, boolean template) throws XMLStreamException {
holder.pushScope(template ? ParserScope.CACHE_TEMPLATE : ParserScope.CACHE);
String name = reader.getAttributeValue(null, Attribute.NAME.getLocalName());
String configuration = reader.getAttributeValue(null, Attribute.CONFIGURATION.getLocalName());
ConfigurationBuilder builder = getConfigurationBuilder(holder, name, template, configuration);
CacheMode baseCacheMode = configuration == null ? CacheMode.INVALIDATION_SYNC : builder.clustering().cacheMode();
builder.clustering().cacheMode(baseCacheMode);
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case KEY_PARTITIONER: {
builder.clustering().hash().keyPartitioner(Util.getInstance(value, holder.getClassLoader()));
break;
}
default: {
this.parseClusteredCacheAttribute(reader, i, attribute, value, builder, baseCacheMode);
}
}
}
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
default: {
this.parseCacheElement(reader, element, holder);
}
}
}
holder.popScope();
}
private void parseClusteredCacheAttribute(XMLExtendedStreamReader reader,
int index, Attribute attribute, String value, ConfigurationBuilder builder, CacheMode baseCacheMode)
throws XMLStreamException {
switch (attribute) {
case ASYNC_MARSHALLING: {
if (reader.getSchema().since(9, 0)) {
throw ParseUtils.unexpectedAttribute(reader, attribute.getLocalName());
} else {
log.ignoredReplicationQueueAttribute(attribute.getLocalName(), reader.getLocation().getLineNumber());
}
break;
}
case MODE: {
Mode mode = Mode.valueOf(value);
builder.clustering().cacheMode(mode.apply(baseCacheMode));
break;
}
case QUEUE_SIZE: {
log.ignoredReplicationQueueAttribute(attribute.getLocalName(), reader.getLocation().getLineNumber());
break;
}
case QUEUE_FLUSH_INTERVAL: {
log.ignoredReplicationQueueAttribute(attribute.getLocalName(), reader.getLocation().getLineNumber());
break;
}
case REMOTE_TIMEOUT: {
builder.clustering().remoteTimeout(Long.parseLong(value));
break;
}
default: {
this.parseCacheAttribute(reader, index, attribute, value, builder);
}
}
}
private void parseReplicatedCache(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder, boolean template) throws XMLStreamException {
holder.pushScope(template ? ParserScope.CACHE_TEMPLATE : ParserScope.CACHE);
String name = reader.getAttributeValue(null, Attribute.NAME.getLocalName());
String configuration = reader.getAttributeValue(null, Attribute.CONFIGURATION.getLocalName());
ConfigurationBuilder builder = getConfigurationBuilder(holder, name, template, configuration);
CacheMode baseCacheMode = configuration == null ? CacheMode.REPL_SYNC : builder.clustering().cacheMode();
builder.clustering().cacheMode(baseCacheMode);
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case SEGMENTS: {
builder.clustering().hash().numSegments(Integer.parseInt(value));
break;
}
case CONSISTENT_HASH_FACTORY: {
builder.clustering().hash().consistentHashFactory(Util.getInstance(value, holder.getClassLoader()));
break;
}
case KEY_PARTITIONER: {
if (reader.getSchema().since(8, 2)) {
builder.clustering().hash().keyPartitioner(Util.getInstance(value, holder.getClassLoader()));
} else {
throw ParseUtils.unexpectedAttribute(reader, i);
}
break;
}
default: {
this.parseClusteredCacheAttribute(reader, i, attribute, value, builder, baseCacheMode);
}
}
}
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
default: {
this.parseSharedStateCacheElement(reader, element, holder);
}
}
}
holder.popScope();
}
private void parseStateTransfer(XMLExtendedStreamReader reader, ConfigurationBuilder builder) throws XMLStreamException {
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case AWAIT_INITIAL_TRANSFER: {
builder.clustering().stateTransfer().awaitInitialTransfer(Boolean.parseBoolean(value));
break;
}
case ENABLED: {
builder.clustering().stateTransfer().fetchInMemoryState(Boolean.parseBoolean(value));
break;
}
case TIMEOUT: {
builder.clustering().stateTransfer().timeout(Long.parseLong(value));
break;
}
case CHUNK_SIZE: {
builder.clustering().stateTransfer().chunkSize(Integer.parseInt(value));
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
ParseUtils.requireNoContent(reader);
}
private void parseDistributedCache(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder, boolean template) throws XMLStreamException {
holder.pushScope(template ? ParserScope.CACHE_TEMPLATE : ParserScope.CACHE);
String name = reader.getAttributeValue(null, Attribute.NAME.getLocalName());
String configuration = reader.getAttributeValue(null, Attribute.CONFIGURATION.getLocalName());
ConfigurationBuilder builder = getConfigurationBuilder(holder, name, template, configuration);
CacheMode baseCacheMode = configuration == null ? CacheMode.DIST_SYNC : builder.clustering().cacheMode();
builder.clustering().cacheMode(baseCacheMode);
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case OWNERS: {
builder.clustering().hash().numOwners(Integer.parseInt(value));
break;
}
case SEGMENTS: {
builder.clustering().hash().numSegments(Integer.parseInt(value));
break;
}
case L1_LIFESPAN: {
long lifespan = Long.parseLong(value);
if (lifespan > 0)
builder.clustering().l1().enable().lifespan(lifespan);
else
builder.clustering().l1().disable();
break;
}
case INVALIDATION_CLEANUP_TASK_FREQUENCY: {
builder.clustering().l1().cleanupTaskFrequency(Long.parseLong(value));
break;
}
case CAPACITY_FACTOR: {
builder.clustering().hash().capacityFactor(Float.parseFloat(value));
break;
}
case CONSISTENT_HASH_FACTORY: {
builder.clustering().hash().consistentHashFactory(
Util.getInstance(value, holder.getClassLoader()));
break;
}
case KEY_PARTITIONER: {
if (reader.getSchema().since(8, 2)) {
builder.clustering().hash().keyPartitioner(Util.getInstance(value, holder.getClassLoader()));
} else {
throw ParseUtils.unexpectedAttribute(reader, i);
}
break;
}
default: {
this.parseClusteredCacheAttribute(reader, i, attribute, value, builder, baseCacheMode);
}
}
}
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case GROUPS: {
parseGroups(reader, holder);
break;
}
default: {
this.parseSharedStateCacheElement(reader, element, holder);
}
}
}
holder.popScope();
}
private void parseGroups(final XMLExtendedStreamReader reader, final ConfigurationBuilderHolder holder) throws XMLStreamException {
ConfigurationBuilder builder = holder.getCurrentConfigurationBuilder();
ParseUtils.requireSingleAttribute(reader, "enabled");
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case ENABLED:
if (Boolean.parseBoolean(value)) {
builder.clustering().hash().groups().enabled();
} else {
builder.clustering().hash().groups().disabled();
}
break;
default:
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case GROUPER:
String value = ParseUtils.readStringAttributeElement(reader, "class");
builder.clustering().hash().groups().addGrouper(Util.>getInstance(value, holder.getClassLoader()));
break;
default:
throw ParseUtils.unexpectedElement(reader);
}
}
}
private ConfigurationBuilder getConfigurationBuilder(ConfigurationBuilderHolder holder, String name, boolean template, String baseConfigurationName) {
ConfigurationBuilder builder = holder.getNamedConfigurationBuilders().get(name);
if (builder == null) {
builder = holder.newConfigurationBuilder(name).template(template);
if (baseConfigurationName != null) {
ConfigurationBuilder baseConfigurationBuilder = holder.getNamedConfigurationBuilders().get(baseConfigurationName);
if (baseConfigurationBuilder == null) {
throw log.undeclaredConfiguration(baseConfigurationName, name);
}
Configuration baseConfiguration = baseConfigurationBuilder.build();
if (!baseConfiguration.isTemplate()) {
throw log.noConfiguration(baseConfigurationName);
}
builder.read(baseConfiguration);
}
}
return builder;
}
private void parsePersistence(final XMLExtendedStreamReader reader, final ConfigurationBuilderHolder holder) throws XMLStreamException {
ConfigurationBuilder builder = holder.getCurrentConfigurationBuilder();
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case PASSIVATION:
builder.persistence().passivation(Boolean.parseBoolean(value));
break;
default:
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
// clear in order to override any configuration defined in default cache
builder.persistence().clearStores();
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case CLUSTER_LOADER:
parseClusterLoader(reader, holder);
break;
case FILE_STORE:
parseFileStore(reader, holder);
break;
case STORE:
parseCustomStore(reader, holder);
break;
case LOADER:
log.ignoreXmlElement(element);
break;
default:
reader.handleAny(holder);
}
}
}
private void parseClusterLoader(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
ConfigurationBuilder builder = holder.getCurrentConfigurationBuilder();
ClusterLoaderConfigurationBuilder cclb = builder.persistence().addClusterLoader();
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
String attrName = reader.getAttributeLocalName(i);
Attribute attribute = Attribute.forName(attrName);
switch (attribute) {
case REMOTE_TIMEOUT:
cclb.remoteCallTimeout(Long.parseLong(value));
break;
default:
parseStoreAttribute(reader, i, cclb);
break;
}
}
parseStoreElements(reader, cclb);
}
protected void parseFileStore(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder) throws XMLStreamException {
SingleFileStoreConfigurationBuilder storeBuilder = holder.getCurrentConfigurationBuilder().persistence().addSingleFileStore();
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case RELATIVE_TO: {
log.ignoreXmlAttribute(attribute);
break;
}
case PATH: {
storeBuilder.location(value);
break;
}
case MAX_ENTRIES: {
storeBuilder.maxEntries(Integer.valueOf(value));
break;
}
case FRAGMENTATION_FACTOR: {
storeBuilder.fragmentationFactor(Float.parseFloat(value));
break;
}
default: {
parseStoreAttribute(reader, i, storeBuilder);
}
}
}
this.parseStoreElements(reader, storeBuilder);
}
/**
* This method is public static so that it can be reused by custom cache store/loader configuration parsers
*/
public static void parseStoreAttribute(XMLExtendedStreamReader reader, int index, AbstractStoreConfigurationBuilder, ?> storeBuilder) throws XMLStreamException {
String value = replaceProperties(reader.getAttributeValue(index));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(index));
switch (attribute) {
case SHARED: {
storeBuilder.shared(Boolean.parseBoolean(value));
break;
}
case READ_ONLY: {
storeBuilder.ignoreModifications(Boolean.valueOf(value));
break;
}
case PRELOAD: {
storeBuilder.preload(Boolean.parseBoolean(value));
break;
}
case FETCH_STATE: {
storeBuilder.fetchPersistentState(Boolean.parseBoolean(value));
break;
}
case PURGE: {
storeBuilder.purgeOnStartup(Boolean.parseBoolean(value));
break;
}
case SINGLETON: {
storeBuilder.singleton().enabled(Boolean.parseBoolean(value));
break;
}
case TRANSACTIONAL: {
storeBuilder.transactional(Boolean.parseBoolean(value));
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, index);
}
}
}
private void parseStoreElements(XMLExtendedStreamReader reader, StoreConfigurationBuilder, ?> storeBuilder) throws XMLStreamException {
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
parseStoreElement(reader, storeBuilder);
}
}
public static void parseStoreElement(XMLExtendedStreamReader reader, StoreConfigurationBuilder, ?> storeBuilder) throws XMLStreamException {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case WRITE_BEHIND: {
parseStoreWriteBehind(reader, storeBuilder.async().enable());
break;
}
case PROPERTY: {
parseStoreProperty(reader, storeBuilder);
break;
}
default: {
throw ParseUtils.unexpectedElement(reader);
}
}
}
public static void parseStoreWriteBehind(XMLExtendedStreamReader reader, AsyncStoreConfigurationBuilder> storeBuilder) throws XMLStreamException {
for (int i = 0; i < reader.getAttributeCount(); i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case FLUSH_LOCK_TIMEOUT: {
if (reader.getSchema().since(9, 0)) {
throw ParseUtils.unexpectedAttribute(reader, attribute.getLocalName());
} else {
storeBuilder.flushLockTimeout(Long.parseLong(value));
}
break;
}
case MODIFICATION_QUEUE_SIZE: {
storeBuilder.modificationQueueSize(Integer.parseInt(value));
break;
}
case SHUTDOWN_TIMEOUT: {
if (reader.getSchema().since(9, 0)) {
throw ParseUtils.unexpectedAttribute(reader, attribute.getLocalName());
} else {
storeBuilder.shutdownTimeout(Long.parseLong(value));
}
break;
}
case THREAD_POOL_SIZE: {
storeBuilder.threadPoolSize(Integer.parseInt(value));
break;
}
default:
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
ParseUtils.requireNoContent(reader);
}
public static void parseStoreProperty(XMLExtendedStreamReader reader, StoreConfigurationBuilder, ?> storeBuilder) throws XMLStreamException {
String property = ParseUtils.requireSingleAttribute(reader, Attribute.NAME.getLocalName());
String value = reader.getElementText();
storeBuilder.addProperty(property, value);
}
private void parseCustomStore(final XMLExtendedStreamReader reader, final ConfigurationBuilderHolder holder) throws XMLStreamException {
ConfigurationBuilder builder = holder.getCurrentConfigurationBuilder();
Boolean fetchPersistentState = null;
Boolean ignoreModifications = null;
Boolean purgeOnStartup = null;
Boolean preload = null;
Boolean shared = null;
Boolean singleton = null;
Boolean transactional = null;
CacheLoader store = null;
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case CLASS:
store = Util.getInstance(value, holder.getClassLoader());
break;
case FETCH_STATE:
fetchPersistentState = Boolean.valueOf(value);
break;
case READ_ONLY:
ignoreModifications = Boolean.valueOf(value);
break;
case PURGE:
purgeOnStartup = Boolean.valueOf(value);
break;
case PRELOAD:
preload = Boolean.parseBoolean(value);
break;
case SHARED:
shared = Boolean.parseBoolean(value);
break;
case SINGLETON:
singleton = Boolean.parseBoolean(value);
break;
case TRANSACTIONAL:
transactional = Boolean.parseBoolean(value);
break;
default:
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
if (store != null) {
if (store instanceof SingleFileStore) {
SingleFileStoreConfigurationBuilder sfs = builder.persistence().addSingleFileStore();
if (fetchPersistentState != null)
sfs.fetchPersistentState(fetchPersistentState);
if (ignoreModifications != null)
sfs.ignoreModifications(ignoreModifications);
if (purgeOnStartup != null)
sfs.purgeOnStartup(purgeOnStartup);
if (preload != null)
sfs.preload(preload);
if (shared != null)
sfs.shared(shared);
if (singleton != null)
sfs.singleton().enabled(singleton);
if (transactional != null)
sfs.transactional(transactional);
parseStoreElements(reader, sfs);
} else if (store instanceof ClusterLoader) {
ClusterLoaderConfigurationBuilder cscb = builder.persistence().addClusterLoader();
parseStoreElements(reader, cscb);
} else {
ConfiguredBy annotation = store.getClass().getAnnotation(ConfiguredBy.class);
Class extends StoreConfigurationBuilder> builderClass = null;
if (annotation != null) {
Class> configuredBy = annotation.value();
if (configuredBy != null) {
BuiltBy builtBy = configuredBy.getAnnotation(BuiltBy.class);
builderClass = builtBy.value().asSubclass(StoreConfigurationBuilder.class);
}
}
StoreConfigurationBuilder configBuilder;
// If they don't specify a builder just use the custom configuration builder and set the class
if (builderClass == null) {
configBuilder = builder.persistence().addStore(CustomStoreConfigurationBuilder.class).customStoreClass(
store.getClass());
} else {
configBuilder = builder.persistence().addStore(builderClass);
}
if (fetchPersistentState != null)
configBuilder.fetchPersistentState(fetchPersistentState);
if (ignoreModifications != null)
configBuilder.ignoreModifications(ignoreModifications);
if (purgeOnStartup != null)
configBuilder.purgeOnStartup(purgeOnStartup);
if (preload != null)
configBuilder.preload(preload);
if (shared != null)
configBuilder.shared(shared);
if (transactional != null)
configBuilder.transactional(transactional);
parseStoreElements(reader, configBuilder);
}
}
}
private void parseIndexing(final XMLExtendedStreamReader reader, final ConfigurationBuilderHolder holder) throws XMLStreamException {
ConfigurationBuilder builder = holder.getCurrentConfigurationBuilder();
for (int i = 0; i < reader.getAttributeCount(); i++) {
ParseUtils.requireNoNamespaceAttribute(reader, i);
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case INDEX:
Index index = Index.valueOf(value);
builder.indexing().index(index);
break;
case AUTO_CONFIG:
builder.indexing().autoConfig(Boolean.valueOf(value));
break;
default:
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
Properties indexingProperties = new Properties();
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case INDEXED_ENTITIES: {
parseIndexedEntities(reader, holder, builder);
break;
}
case PROPERTY: {
parseProperty(reader, indexingProperties);
break;
}
default: {
throw ParseUtils.unexpectedElement(reader);
}
}
}
builder.indexing().withProperties(indexingProperties);
}
private void parseIndexedEntities(XMLExtendedStreamReader reader, ConfigurationBuilderHolder holder, ConfigurationBuilder builder) throws XMLStreamException {
ParseUtils.requireNoAttributes(reader);
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case INDEXED_ENTITY: {
ParseUtils.requireNoAttributes(reader);
String className = reader.getElementText();
Class> indexedEntity = Util.loadClass(className, holder.getClassLoader());
builder.indexing().addIndexedEntity(indexedEntity);
break;
}
default: {
throw ParseUtils.unexpectedElement(reader);
}
}
}
}
private static void parseProperty(XMLExtendedStreamReader reader, Properties properties) throws XMLStreamException {
int attributes = reader.getAttributeCount();
ParseUtils.requireAttributes(reader, Attribute.NAME.getLocalName());
String key = null;
String propertyValue;
for (int i = 0; i < attributes; i++) {
String value = replaceProperties(reader.getAttributeValue(i));
Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case NAME: {
key = value;
break;
}
default: {
throw ParseUtils.unexpectedAttribute(reader, i);
}
}
}
propertyValue = replaceProperties(reader.getElementText());
properties.setProperty(key, propertyValue);
}
public static Properties parseProperties(final XMLExtendedStreamReader reader) throws XMLStreamException {
Properties properties = new Properties();
while (reader.hasNext() && (reader.nextTag() != XMLStreamConstants.END_ELEMENT)) {
Element element = Element.forName(reader.getLocalName());
switch (element) {
case PROPERTY: {
parseProperty(reader, properties);
break;
}
default: {
throw ParseUtils.unexpectedElement(reader);
}
}
}
return properties;
}
public enum TransactionMode {
NONE(org.infinispan.transaction.TransactionMode.NON_TRANSACTIONAL, false, false, false),
BATCH(org.infinispan.transaction.TransactionMode.TRANSACTIONAL, false, false, true),
NON_XA(org.infinispan.transaction.TransactionMode.TRANSACTIONAL, false, false, false),
NON_DURABLE_XA(org.infinispan.transaction.TransactionMode.TRANSACTIONAL, true, false, false),
FULL_XA(org.infinispan.transaction.TransactionMode.TRANSACTIONAL, true, true, false),
;
private final org.infinispan.transaction.TransactionMode mode;
private final boolean xaEnabled;
private final boolean recoveryEnabled;
private final boolean batchingEnabled;
private TransactionMode(org.infinispan.transaction.TransactionMode mode, boolean xaEnabled, boolean recoveryEnabled, boolean batchingEnabled) {
this.mode = mode;
this.xaEnabled = xaEnabled;
this.recoveryEnabled = recoveryEnabled;
this.batchingEnabled = batchingEnabled;
}
public static TransactionMode fromConfiguration(org.infinispan.transaction.TransactionMode mode, boolean xaEnabled, boolean recoveryEnabled, boolean batchingEnabled) {
if (mode==org.infinispan.transaction.TransactionMode.NON_TRANSACTIONAL) {
return NONE;
}
for(TransactionMode txMode : TransactionMode.values()) {
if (txMode.mode == mode && txMode.xaEnabled == xaEnabled && txMode.recoveryEnabled == recoveryEnabled && txMode.batchingEnabled == batchingEnabled)
return txMode;
}
throw log.unknownTransactionConfiguration(mode, xaEnabled, recoveryEnabled, batchingEnabled);
}
public org.infinispan.transaction.TransactionMode getMode() {
return this.mode;
}
public boolean isXAEnabled() {
return this.xaEnabled;
}
public boolean isRecoveryEnabled() {
return this.recoveryEnabled;
}
public boolean isBatchingEnabled() {
return batchingEnabled;
}
}
public enum Mode {
SYNC(true),
ASYNC(false),
;
private final boolean sync;
Mode(boolean sync) {
this.sync = sync;
}
public static Mode forCacheMode(CacheMode mode) {
return mode.isSynchronous() ? SYNC : ASYNC;
}
public CacheMode apply(CacheMode mode) {
return this.sync ? mode.toSync() : mode.toAsync();
}
public boolean isSynchronous() {
return this.sync;
}
}
@Override
public Namespace[] getNamespaces() {
return ParseUtils.getNamespaceAnnotations(getClass());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy