Commit d0fd6145 authored by Phillip Webb's avatar Phillip Webb

Fix CacheType outer class tangle

Fixes gh-3168
parent 5312be4a
...@@ -131,7 +131,7 @@ public class CacheAutoConfiguration { ...@@ -131,7 +131,7 @@ public class CacheAutoConfiguration {
CacheType[] types = CacheType.values(); CacheType[] types = CacheType.values();
String[] imports = new String[types.length]; String[] imports = new String[types.length];
for (int i = 0; i < types.length; i++) { for (int i = 0; i < types.length; i++) {
imports[i] = types[i].getConfigurationClass().getName(); imports[i] = CacheConfigurations.getConfigurationClass(types[i]);
} }
return imports; return imports;
} }
......
...@@ -40,8 +40,8 @@ class CacheCondition extends SpringBootCondition { ...@@ -40,8 +40,8 @@ class CacheCondition extends SpringBootCondition {
if (!resolver.containsProperty("type")) { if (!resolver.containsProperty("type")) {
return ConditionOutcome.match("Automatic cache type"); return ConditionOutcome.match("Automatic cache type");
} }
CacheType cacheType = CacheType CacheType cacheType = CacheConfigurations.getType(((AnnotationMetadata) metadata)
.forConfigurationClass(((AnnotationMetadata) metadata).getClassName()); .getClassName());
String value = resolver.getProperty("type").replace("-", "_").toUpperCase(); String value = resolver.getProperty("type").replace("-", "_").toUpperCase();
if (value.equals(cacheType.name())) { if (value.equals(cacheType.name())) {
return ConditionOutcome.match("Cache type " + cacheType); return ConditionOutcome.match("Cache type " + cacheType);
......
/*
* Copyright 2012-2015 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.springframework.boot.autoconfigure.cache;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import org.springframework.util.Assert;
/**
* Mappings between {@link CacheType} and {@code @Configuration}.
*
* @author Phillip Webb
*/
class CacheConfigurations {
private static final Map<CacheType, Class<?>> MAPPINGS;
static {
Map<CacheType, Class<?>> mappings = new HashMap<CacheType, Class<?>>();
mappings.put(CacheType.GENERIC, GenericCacheConfiguration.class);
mappings.put(CacheType.EHCACHE, EhCacheCacheConfiguration.class);
mappings.put(CacheType.HAZELCAST, HazelcastCacheConfiguration.class);
mappings.put(CacheType.INFINISPAN, InfinispanCacheConfiguration.class);
mappings.put(CacheType.JCACHE, JCacheCacheConfiguration.class);
mappings.put(CacheType.REDIS, RedisCacheConfiguration.class);
mappings.put(CacheType.GUAVA, GuavaCacheConfiguration.class);
mappings.put(CacheType.SIMPLE, SimpleCacheConfiguration.class);
mappings.put(CacheType.NONE, NoOpCacheConfiguration.class);
MAPPINGS = Collections.unmodifiableMap(mappings);
}
public static String getConfigurationClass(CacheType cacheType) {
Class<?> configurationClass = MAPPINGS.get(cacheType);
Assert.state(configurationClass != null, "Unknown cache type " + cacheType);
return configurationClass.getName();
}
public static CacheType getType(String configurationClassName) {
for (Map.Entry<CacheType, Class<?>> entry : MAPPINGS.entrySet()) {
if (entry.getValue().getName().equals(configurationClassName)) {
return entry.getKey();
}
}
throw new IllegalStateException("Unknown configuration class "
+ configurationClassName);
}
}
...@@ -29,65 +29,46 @@ public enum CacheType { ...@@ -29,65 +29,46 @@ public enum CacheType {
/** /**
* Generic caching using 'Cache' beans from the context. * Generic caching using 'Cache' beans from the context.
*/ */
GENERIC(GenericCacheConfiguration.class), GENERIC,
/** /**
* EhCache backed caching. * EhCache backed caching.
*/ */
EHCACHE(EhCacheCacheConfiguration.class), EHCACHE,
/** /**
* Hazelcast backed caching * Hazelcast backed caching
*/ */
HAZELCAST(HazelcastCacheConfiguration.class), HAZELCAST,
/** /**
* Infinispan backed caching. * Infinispan backed caching.
*/ */
INFINISPAN(InfinispanCacheConfiguration.class), INFINISPAN,
/** /**
* JCache (JSR-107) backed caching. * JCache (JSR-107) backed caching.
*/ */
JCACHE(JCacheCacheConfiguration.class), JCACHE,
/** /**
* Redis backed caching. * Redis backed caching.
*/ */
REDIS(RedisCacheConfiguration.class), REDIS,
/** /**
* Guava backed caching. * Guava backed caching.
*/ */
GUAVA(GuavaCacheConfiguration.class), GUAVA,
/** /**
* Simple in-memory caching. * Simple in-memory caching.
*/ */
SIMPLE(SimpleCacheConfiguration.class), SIMPLE,
/** /**
* No caching. * No caching.
*/ */
NONE(NoOpCacheConfiguration.class); NONE;
private final Class<?> configurationClass;
CacheType(Class<?> configurationClass) {
this.configurationClass = configurationClass;
}
Class<?> getConfigurationClass() {
return this.configurationClass;
}
static CacheType forConfigurationClass(String configurationClass) {
for (CacheType type : values()) {
if (type.getConfigurationClass().getName().equals(configurationClass)) {
return type;
}
}
throw new IllegalArgumentException("Unsupported class " + configurationClass);
}
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment