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

org.infinispan.spring.remote.AbstractRemoteCacheManagerFactory Maven / Gradle / Ivy

There is a newer version: 14.0.33.Final
Show newest version
package org.infinispan.spring.remote;

import java.io.IOException;
import java.io.InputStream;
import java.lang.invoke.MethodHandles;
import java.net.InetSocketAddress;
import java.util.Collection;
import java.util.Collections;
import java.util.LinkedHashSet;
import java.util.Properties;
import java.util.Set;

import org.infinispan.client.hotrod.RemoteCacheManager;
import org.infinispan.client.hotrod.impl.ConfigurationProperties;
import org.infinispan.commons.logging.Log;
import org.infinispan.commons.logging.LogFactory;
import org.infinispan.commons.marshall.JavaSerializationMarshaller;
import org.infinispan.commons.util.Util;
import org.springframework.core.io.Resource;

/**
 * 

* An abstract base class for factories creating cache manager that are backed by an Infinispan * RemoteCacheManager. *

* * @author Olaf Bergner * * @see RemoteCacheManager */ public abstract class AbstractRemoteCacheManagerFactory { protected static final Log logger = LogFactory.getLog(MethodHandles.lookup().lookupClass()); public static final String SPRING_JAVA_SERIAL_ALLOWLIST = "java.util.HashMap,java.time.*,org.springframework.*,org.infinispan.spring.remote.*"; protected boolean startAutomatically = true; private Properties configurationProperties; private Resource configurationPropertiesFileLocation; private final ConfigurationPropertiesOverrides configurationPropertiesOverrides = new ConfigurationPropertiesOverrides(); protected void assertCorrectlyConfigured() throws IllegalStateException { if ((this.configurationProperties != null) && (this.configurationPropertiesFileLocation != null)) { throw new IllegalStateException( "You may only use either \"configurationProperties\" or \"configurationPropertiesFileLocation\" " + "to configure the RemoteCacheManager, not both."); } else if ((this.configurationProperties != null) && !this.configurationPropertiesOverrides.isEmpty()) { throw new IllegalStateException( "You may only use either \"configurationProperties\" or setters on this FactoryBean " + "to configure the RemoteCacheManager, not both."); } } protected Properties configurationProperties() throws IOException { final Properties answer; if (this.configurationProperties != null) { answer = this.configurationPropertiesOverrides.override(this.configurationProperties); logger.debug("Using user-defined properties [" + this.configurationProperties + "] for configuring RemoteCacheManager"); } else if (this.configurationPropertiesFileLocation != null) { answer = loadPropertiesFromFile(this.configurationPropertiesFileLocation); logger.debug("Loading properties from file [" + this.configurationProperties + "] for configuring RemoteCacheManager"); } else if (!this.configurationPropertiesOverrides.isEmpty()) { answer = this.configurationPropertiesOverrides.override(new Properties()); logger.debug("Using explicitly set configuration settings [" + answer + "] for configuring RemoteCacheManager"); } else { logger.debug("No configuration properties. RemoteCacheManager will use default configuration."); RemoteCacheManager remoteCacheManager = new RemoteCacheManager(false); try { answer = remoteCacheManager.getConfiguration().properties(); } finally { remoteCacheManager.stop(); } } initializeMarshallingProperties(answer); return answer; } private void initializeMarshallingProperties(Properties properties) { // If the property has already been overridden, we don't apply any default behaviour if (!configurationPropertiesOverrides.containsProperty(ConfigurationProperties.MARSHALLER)) { String marshaller = JavaSerializationMarshaller.class.getName(); String configuredMarshaller = properties.getProperty(ConfigurationProperties.MARSHALLER); if (configuredMarshaller != null && configuredMarshaller.equals(Util.GENERIC_JBOSS_MARSHALLING_CLASS)) { // If the marshaller is equal to the legacy jboss-marshaller, and infinispan-jboss-marshalling is on the cp, allow if (Util.getJBossMarshaller(Thread.currentThread().getContextClassLoader(), null) != null) marshaller = configuredMarshaller; } properties.setProperty(ConfigurationProperties.MARSHALLER, marshaller); } if (!configurationPropertiesOverrides.containsProperty(ConfigurationProperties.JAVA_SERIAL_WHITELIST) && !configurationPropertiesOverrides.containsProperty(ConfigurationProperties.JAVA_SERIAL_ALLOWLIST)) { Set userRegexSet = new LinkedHashSet<>(); Collections.addAll(userRegexSet, SPRING_JAVA_SERIAL_ALLOWLIST.split(",")); String userAllowList = properties.getProperty(ConfigurationProperties.JAVA_SERIAL_ALLOWLIST); if (userAllowList != null && !userAllowList.isEmpty()) { Collections.addAll(userRegexSet, userAllowList.split(",")); } String userWhiteList = properties.getProperty(ConfigurationProperties.JAVA_SERIAL_WHITELIST); if (userWhiteList != null && !userWhiteList.isEmpty()) { Collections.addAll(userRegexSet, userWhiteList.split(",")); } String allowList = String.join(",", userRegexSet); properties.setProperty(ConfigurationProperties.JAVA_SERIAL_ALLOWLIST, allowList); } } private Properties loadPropertiesFromFile(final Resource propertiesFileLocation) throws IOException { InputStream propsStream = null; try { propsStream = propertiesFileLocation.getInputStream(); final Properties answer = new Properties(); answer.load(propsStream); return answer; } finally { if (propsStream != null) { try { propsStream.close(); } catch (final IOException e) { logger.warn( "Failed to close InputStream used to load configuration properties: " + e.getMessage(), e); } } } } // ------------------------------------------------------------------------ // Setters for configuring RemoteCacheManager // ------------------------------------------------------------------------ /** * @param configurationProperties * the configurationProperties to set */ public void setConfigurationProperties(final Properties configurationProperties) { this.configurationProperties = configurationProperties; } /** * @param configurationPropertiesFileLocation * the configurationPropertiesFileLocation to set */ public void setConfigurationPropertiesFileLocation( final Resource configurationPropertiesFileLocation) { this.configurationPropertiesFileLocation = configurationPropertiesFileLocation; } /** * @param startAutomatically * the startAutomatically to set */ public void setStartAutomatically(final boolean startAutomatically) { this.startAutomatically = startAutomatically; } /** * @param transportFactory * @see ConfigurationPropertiesOverrides#setTransportFactory(String) */ @Deprecated(forRemoval = true) public void setTransportFactory(final String transportFactory) { } /** * @param serverList * @see ConfigurationPropertiesOverrides#setServerList(Collection) */ public void setServerList(final Collection serverList) { this.configurationPropertiesOverrides.setServerList(serverList); } /** * @param marshaller * @see ConfigurationPropertiesOverrides#setMarshaller(String) */ public void setMarshaller(final String marshaller) { this.configurationPropertiesOverrides.setMarshaller(marshaller); } /** * @param allowListRegex * @see ConfigurationPropertiesOverrides#setClassAllowList(String) */ public void setClassAllowList(final String allowListRegex) { this.configurationPropertiesOverrides.setClassAllowList(allowListRegex); } /** * @param allowListRegex * @see ConfigurationPropertiesOverrides#setClassAllowList(String) * @deprecated Use {@link #setClassAllowList(String)} instead. Will be removed in 14.0. */ @Deprecated(forRemoval = true) public void setClassWhiteList(final String allowListRegex) { setClassAllowList(allowListRegex); } /** * @param asyncExecutorFactory * @see ConfigurationPropertiesOverrides#setAsyncExecutorFactory(String) */ public void setAsyncExecutorFactory(final String asyncExecutorFactory) { this.configurationPropertiesOverrides.setAsyncExecutorFactory(asyncExecutorFactory); } /** * @param tcpNoDelay * @see ConfigurationPropertiesOverrides#setTcpNoDelay(boolean) */ public void setTcpNoDelay(final boolean tcpNoDelay) { this.configurationPropertiesOverrides.setTcpNoDelay(tcpNoDelay); } /** * @see ConfigurationPropertiesOverrides#setTcpNoDelay(boolean) */ public void setTcpKeepAlive(final boolean tcpKeepAlive) { this.configurationPropertiesOverrides.setTcpKeepAlive(tcpKeepAlive); } /** * @param requestBalancingStrategy * @see ConfigurationPropertiesOverrides#setRequestBalancingStrategy(String) */ public void setRequestBalancingStrategy(final String requestBalancingStrategy) { this.configurationPropertiesOverrides.setRequestBalancingStrategy(requestBalancingStrategy); } /** * @deprecated Since 12.0, does nothing and will be removed in 15.0 */ @Deprecated(forRemoval = true) public void setKeySizeEstimate(final int keySizeEstimate) { this.configurationPropertiesOverrides.setKeySizeEstimate(keySizeEstimate); } /** * @deprecated Since 12.0, does nothing and will be removed in 15.0 */ @Deprecated(forRemoval = true) public void setValueSizeEstimate(final int valueSizeEstimate) { this.configurationPropertiesOverrides.setValueSizeEstimate(valueSizeEstimate); } /** * @param forceReturnValues * @see ConfigurationPropertiesOverrides#setForceReturnValues(boolean) */ public void setForceReturnValues(final boolean forceReturnValues) { this.configurationPropertiesOverrides.setForceReturnValues(forceReturnValues); } /** * @param readTimeout * @see ConfigurationPropertiesOverrides#setReadTimeout(long) */ public void setReadTimeout(final long readTimeout) { this.configurationPropertiesOverrides.setReadTimeout(readTimeout); } /** * @param writeTimeout * @see ConfigurationPropertiesOverrides#setWriteTimeout(long) */ public void setWriteTimeout(final long writeTimeout) { this.configurationPropertiesOverrides.setWriteTimeout(writeTimeout); } /** * @param mode * @see ConfigurationPropertiesOverrides#setNearCacheMode(String) */ public void setNearCacheMode(String mode) { this.configurationPropertiesOverrides.setNearCacheMode(mode); } /** * @param maxEntries * @see ConfigurationPropertiesOverrides#setNearCacheMaxEntries(int) */ public void setNearCacheMaxEntries(int maxEntries) { this.configurationPropertiesOverrides.setNearCacheMaxEntries(maxEntries); } /** * @param pattern * @see ConfigurationPropertiesOverrides#setNearCacheNamePattern(String) */ public void setNearCacheNamePattern(String pattern) { this.configurationPropertiesOverrides.setNearCacheNamePattern(pattern); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy