/*
 * Copyright Terracotta, Inc.
 *
 * 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.ehcache.expiry;

import java.time.Duration;
import java.util.function.Supplier;

A policy object that governs expiration for mappings in a Cache.

Previous values are not accessible directly but are rather available through a value Supplier to indicate that access can require computation (such as deserialization).

Negative durations are not supported, expiry policy implementation returning such a duration will result in immediate expiry, as if the duration was zero.

NOTE: Some cache configurations (eg. caches with eventual consistency) may use local (ie. non-consistent) state to decide whether to call getExpiryForUpdate(Object, Supplier, Object) vs. getExpiryForCreation(Object, Object). For these cache configurations it is advised to return the same value for both of these methods

Type parameters:
  • <K> – the key type for the cache
  • <V> – the value type for the cache
/** * A policy object that governs expiration for mappings in a {@link org.ehcache.Cache Cache}. * <p> * Previous values are not accessible directly but are rather available through a value {@code Supplier} * to indicate that access can require computation (such as deserialization). * <p> * {@link java.time.Duration#isNegative() Negative durations} are not supported, expiry policy implementation returning such a * duration will result in immediate expiry, as if the duration was {@link java.time.Duration#ZERO zero}. * <p> * NOTE: Some cache configurations (eg. caches with eventual consistency) may use local (ie. non-consistent) state * to decide whether to call {@link #getExpiryForUpdate(Object, Supplier, Object)} vs. * {@link #getExpiryForCreation(Object, Object)}. For these cache configurations it is advised to return the same * value for both of these methods * * @param <K> the key type for the cache * @param <V> the value type for the cache * */
public interface ExpiryPolicy<K, V> {
A duration that represents an infinite time.
/** * A {@link Duration duration} that represents an infinite time. */
Duration INFINITE = Duration.ofNanos(Long.MAX_VALUE);
An ExpiryPolicy that represents a no expiration policy
/** * An {@code ExpiryPolicy} that represents a no expiration policy */
ExpiryPolicy<Object, Object> NO_EXPIRY = new ExpiryPolicy<Object, Object>() { @Override public Duration getExpiryForCreation(Object key, Object value) { return INFINITE; } @Override public Duration getExpiryForAccess(Object key, Supplier<?> value) { return null; } @Override public Duration getExpiryForUpdate(Object key, Supplier<?> oldValue, Object newValue) { return null; } };
Returns the lifetime of an entry when it is initially added to a Cache.

This method must not return null.

Exceptions thrown from this method will be swallowed and result in the expiry duration being ZERO.

Params:
  • key – the key of the newly added entry
  • value – the value of the newly added entry
Returns:a non-null Duration
/** * Returns the lifetime of an entry when it is initially added to a {@link org.ehcache.Cache Cache}. * <p> * This method must not return {@code null}. * <p> * Exceptions thrown from this method will be swallowed and result in the expiry duration being * {@link Duration#ZERO ZERO}. * * @param key the key of the newly added entry * @param value the value of the newly added entry * @return a non-null {@code Duration} */
Duration getExpiryForCreation(K key, V value);
Returns the expiration duration (relative to the current time) when an existing entry is accessed from a Cache.

Returning null indicates that the expiration time remains unchanged.

Exceptions thrown from this method will be swallowed and result in the expiry duration being ZERO.

Params:
  • key – the key of the accessed entry
  • value – a value supplier for the accessed entry
Returns:an expiration Duration, null means unchanged
/** * Returns the expiration {@link Duration duration} (relative to the current time) when an existing entry * is accessed from a {@link org.ehcache.Cache Cache}. * <p> * Returning {@code null} indicates that the expiration time remains unchanged. * <p> * Exceptions thrown from this method will be swallowed and result in the expiry duration being * {@link Duration#ZERO ZERO}. * * @param key the key of the accessed entry * @param value a value supplier for the accessed entry * @return an expiration {@code Duration}, {@code null} means unchanged */
Duration getExpiryForAccess(K key, Supplier<? extends V> value);
Returns the expiration duration (relative to the current time) when an existing entry is updated in a Cache.

Returning null indicates that the expiration time remains unchanged.

Exceptions thrown from this method will be swallowed and result in the expiry duration being ZERO.

Params:
  • key – the key of the updated entry
  • oldValue – a value supplier for the previous value of the entry
  • newValue – the new value of the entry
Returns:an expiration Duration, null means unchanged
/** * Returns the expiration {@link Duration duration} (relative to the current time) when an existing entry * is updated in a {@link org.ehcache.Cache Cache}. * <p> * Returning {@code null} indicates that the expiration time remains unchanged. * <p> * Exceptions thrown from this method will be swallowed and result in the expiry duration being * {@link Duration#ZERO ZERO}. * * @param key the key of the updated entry * @param oldValue a value supplier for the previous value of the entry * @param newValue the new value of the entry * @return an expiration {@code Duration}, {@code null} means unchanged */
Duration getExpiryForUpdate(K key, Supplier<? extends V> oldValue, V newValue); }