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

org.redisson.spring.cache.CacheConfig Maven / Gradle / Ivy

/**
 * Copyright 2018 Nikita Koksharov
 *
 * 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.redisson.spring.cache;

import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.io.Reader;
import java.net.URL;
import java.util.Map;

/**
 * Cache config object used for Spring cache configuration.
 *
 * @author Nikita Koksharov
 *
 */
public class CacheConfig {

    private long ttl;

    private long maxIdleTime;
    
    private int maxSize;

    /**
     * Creates config object with
     * ttl = 0 and maxIdleTime = 0.
     *
     */
    public CacheConfig() {
    }

    /**
     * Creates config object.
     *
     * @param ttl - time to live for key\value entry in milliseconds.
     *              If 0 then time to live doesn't affect entry expiration.
     * @param maxIdleTime - max idle time for key\value entry in milliseconds.
     * 

* if maxIdleTime and ttl params are equal to 0 * then entry stores infinitely. */ public CacheConfig(long ttl, long maxIdleTime) { super(); this.ttl = ttl; this.maxIdleTime = maxIdleTime; } public long getTTL() { return ttl; } /** * Set time to live for key\value entry in milliseconds. * * @param ttl - time to live for key\value entry in milliseconds. * If 0 then time to live doesn't affect entry expiration. */ public void setTTL(long ttl) { this.ttl = ttl; } public int getMaxSize() { return maxSize; } /** * Set max size of map. Superfluous elements are evicted using LRU algorithm. * * @param maxSize - max size * If 0 the cache is unbounded (default). */ public void setMaxSize(int maxSize) { this.maxSize = maxSize; } public long getMaxIdleTime() { return maxIdleTime; } /** * Set max idle time for key\value entry in milliseconds. * * @param maxIdleTime - max idle time for key\value entry in milliseconds. * If 0 then max idle time doesn't affect entry expiration. */ public void setMaxIdleTime(long maxIdleTime) { this.maxIdleTime = maxIdleTime; } /** * Read config objects stored in JSON format from String * * @param content of config * @return config * @throws IOException error */ public static Map fromJSON(String content) throws IOException { return new CacheConfigSupport().fromJSON(content); } /** * Read config objects stored in JSON format from InputStream * * @param inputStream of config * @return config * @throws IOException error */ public static Map fromJSON(InputStream inputStream) throws IOException { return new CacheConfigSupport().fromJSON(inputStream); } /** * Read config objects stored in JSON format from File * * @param file of config * @return config * @throws IOException error */ public static Map fromJSON(File file) throws IOException { return new CacheConfigSupport().fromJSON(file); } /** * Read config objects stored in JSON format from URL * * @param url of config * @return config * @throws IOException error */ public static Map fromJSON(URL url) throws IOException { return new CacheConfigSupport().fromJSON(url); } /** * Read config objects stored in JSON format from Reader * * @param reader of config * @return config * @throws IOException error */ public static Map fromJSON(Reader reader) throws IOException { return new CacheConfigSupport().fromJSON(reader); } /** * Convert current configuration to JSON format * * @param config object * @return json string * @throws IOException error */ public static String toJSON(Map config) throws IOException { return new CacheConfigSupport().toJSON(config); } /** * Read config objects stored in YAML format from String * * @param content of config * @return config * @throws IOException error */ public static Map fromYAML(String content) throws IOException { return new CacheConfigSupport().fromYAML(content); } /** * Read config objects stored in YAML format from InputStream * * @param inputStream of config * @return config * @throws IOException error */ public static Map fromYAML(InputStream inputStream) throws IOException { return new CacheConfigSupport().fromYAML(inputStream); } /** * Read config objects stored in YAML format from File * * @param file of config * @return config * @throws IOException error */ public static Map fromYAML(File file) throws IOException { return new CacheConfigSupport().fromYAML(file); } /** * Read config objects stored in YAML format from URL * * @param url of config * @return config * @throws IOException error */ public static Map fromYAML(URL url) throws IOException { return new CacheConfigSupport().fromYAML(url); } /** * Read config objects stored in YAML format from Reader * * @param reader of config * @return config * @throws IOException error */ public static Map fromYAML(Reader reader) throws IOException { return new CacheConfigSupport().fromYAML(reader); } /** * Convert current configuration to YAML format * * @param config map * @return yaml string * @throws IOException error */ public static String toYAML(Map config) throws IOException { return new CacheConfigSupport().toYAML(config); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy