Simple Time-To-Live Cache for Android
Simple Time-To-Live Cache [Android]
Very simple in-memory key-value cache with time-to-live (TTL) support.
The library uses kotlin.time.Duration
API it provides a nice DSL to manipulate time durations.
Each object in the cache has its own time to live (TTL).
Objects with an expired TTL are stored in the cache, but will then be deleted the first time they are accessed.
The cache is manually cleared of obsolete objects or when the maximum size is reached when new objects arrive.
A simple capacity limit — objects over the specified capacity are not cached. In this case, the cache will try to delete objects with an expired TTL and place a new object in the cache.
The default is no cache size limit.
Gradle
Add library to your project dependencies:
allprojects {
repositories {
maven { url 'https://jitpack.io' }
}
}
dependencies {
implementation "com.github.tim4dev:ttl_cache:VERSION"
}
Usage
val cache = TtlCache.Builder()
.maxCacheSize(100) // The default is no cache size limit
.build()
Data class, for example
data class SomeData(
val id: Int,
val name: String
)
Data layer
import kotlin.time.Duration
class Repository(
private val cache: TtlCache
) {
private enum class CacheType(
val mapKey: String,
val ttl: Duration
) {
SOME_DATA("loadSomeData", 1.minutes + 30.seconds);
}
suspend fun loadSomeData(): List<SomeData>? {
/**
* If the object is not obtained from the cache,
* then "loader" will be run to obtain the object from the external source.
* The resulting object will be cached.
*/
return cache.getOrLoad(
key = CacheType.SOME_DATA.mapKey,
timeToLive = CacheType.SOME_DATA.ttl // TTL for caching the object loaded
) {
// loader
loadRemoteData()
}
}
suspend fun loadRemoteData(): List<SomeData>? { ... }
}
Simple Usage
val cache = TtlCache.Builder().build()
cache.put(
key = "SomeData_key",
value = SomeData(...),
timeToLive = 5.minutes
)
val data = cache.get<SomeData>("SomeData_key")
License
Copyright (c) 2023 Yuriy Timofeev. Distributed under the Apache License 2.