Store ephemeral values in memory and shared preferences

android-ephemeral

A super lightweight library to help you store/retrieve ephemeral values which can be either persisted (in shared preferences) or put in memory.

Dependency

In your build.gradle file add the following in dependencies

implementation 'io.github.ashwinbhaskar:ephemeral-android:1.0.0'

Usage

In Memory

import java.time.*
import arrow.core.*
import com.ephemeral.*

data class SomeClass(str: String, i: Int, b: Boolean)
val sc = SomeClass("quixx", 1, true)

//Put a value in memory which gets deleted after 5 seconds
ImMemory.put(key = "foo-key", value = sc, expireAfter = Duration.ofSeconds(5))

// Gets the value from memory
val maybeValueOrError: Either<CastError, Option<SomeClass>> = ImMemory.get("foo-key", SomeClass::class)

//Use unsafe() method if you are confident that SomeClass is the right type
val maybeValue: Option<SomeClass> = InMemory.get("foo-key", SomeClass::class).unsafe()

when(maybeValue) {
 is None -> // The value has either expired or was never there
 is Some -> // do something with maybeValue.value
}

//Update an existing value by providing an update function
val didUpdate: Boolean = InMemory.updateValueIfPresent(key = "foo-key", updateFun = {sc -> sc.copy(str = "quixx100")}, SomeClass::class)

//Update the expiry time as you access the value
val maybeValue: Option<SomeClass> = InMemory.getAndUpdateExpiryIfPresent("foo-key", Duration.ofSeconds(5), SomeClass::class).unsafe()

//Remove a key-value
val isRemoved: Boolean = InMemory.remove("foo-key")

In Shared Preferences

This is a wrapper around android shared preference methods with an extra field – expireAfter.

import java.time.*
import com.ephemeral.*
import com.ephemeral.Extensions.*

//Put a value in shared preferences which gets deleted after 5 seconds
Persisted.putString("some-key", "this is a the value", Duration.ofSeconds(5), applicationContext)

//If you do not want to pass applicationContext everytime can you use the extension functions on Context that are imported above
context.putEphemeralString("some-key", "this is a the value", Duration.ofSeconds(5))

val defaultValue = ""

val value = context.getEphemeralString("some-key", defaultValue)
when(value) {
    defaultValue -> //The value has either expired or was never there
    else -> // do something with the value
}

//Similarly you can use methods for Boolean, Int, Long, Float, Set<String>

GitHub

View Github