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

io.micronaut.cache.DefaultCacheManager Maven / Gradle / Ivy

/*
 * Copyright 2017-2019 original 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 io.micronaut.cache;

import io.micronaut.context.annotation.Primary;
import io.micronaut.context.exceptions.ConfigurationException;
import io.micronaut.core.util.CollectionUtils;

import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import javax.inject.Inject;
import javax.inject.Provider;
import javax.inject.Singleton;
import java.util.*;

/**
 * Default implementation of the {@link CacheManager} interface.
 *
 * @param  The native cache implementation
 *
 * @author Graeme Rocher
 * @since 1.0
 */
@Singleton
@Primary
public class DefaultCacheManager implements CacheManager {

    private final Map> cacheMap;
    /**
     * Prevents early initialization of the dynamic cache manager until it is
     * actually needed. Caches requested that already exist can proceed
     * without the bean being initialized.
     */
    private final Provider> dynamicCacheManager;

    /**
     * Create default cache manager for the given caches.
     *
     * @param caches List of synchronous cache implementations
     * @deprecated Use {@link #DefaultCacheManager(List, Provider)} instead.
     */
    @Deprecated
    public DefaultCacheManager(List> caches) {
        this(caches, null);
    }

    /**
     * Create default cache manager for the given caches.
     *
     * @param caches List of synchronous cache implementations
     * @param dynamicCacheManager The dynamic cache manager
     */
    @Inject public DefaultCacheManager(List> caches, @Nullable Provider> dynamicCacheManager) {
        this.dynamicCacheManager = dynamicCacheManager;
        if (CollectionUtils.isEmpty(caches)) {
            this.cacheMap = new LinkedHashMap<>();
        } else {
            this.cacheMap = new LinkedHashMap<>(caches.size());
            for (SyncCache cache : caches) {
                final String cacheName = cache.getName();
                if (cacheMap.containsKey(cacheName)) {
                    throw new ConfigurationException("Cannot registry duplicate cache [" + cache + "] with cache manager. Ensure configured cache names are unique. Cache already configured for name [" + cacheName + "]: " + cacheMap.get(cacheName));
                } else {
                    this.cacheMap.put(cacheName, cache);
                }
            }
        }
    }

    /**
     * Create default cache manager for the given caches.
     *
     * @param caches List of synchronous cache implementations
     */
    public DefaultCacheManager(SyncCache... caches) {
        this(Arrays.asList(caches));
    }

    @Override
    @Nonnull
    public Set getCacheNames() {
        return cacheMap.keySet();
    }

    @Override
    @Nonnull
    public SyncCache getCache(String name) {
        SyncCache cache = cacheMap.get(name);
        if (cache == null) {
            if (dynamicCacheManager != null) {
                cache = dynamicCacheManager.get().getCache(name);
                Objects.requireNonNull(cache);
                cacheMap.put(name, cache);
            } else {
                throw new ConfigurationException("No cache configured for name: " + name);
            }
        }
        return cache;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy