import { LibsqlCacheAdapter } from "@daiso-tech/core/cache/adapters";
import { Serde } from "@daiso-tech/core/serde";
import { SuperJsonSerdeAdapter } from "@daiso-tech/core/serde/adapters";
import { createClient } from "@libsql/client";
const database = createClient({ url: "file:local.db" });
const serde = new Serde(new SuperJsonSerdeAdapter());
const cacheAdapter = new LibsqlCacheAdapter({
database,
serde,
});
// You need initialize the adapter once before using it.
await cacheAdapter.init();
The find
method returns the the key
data which includs ICacheData.value
and ICacheData.expiration
.
The incrementUnexpired
should always throw an error if the existing item is not a number type.
The insert
method inserts the given cache data
.
The removeExpiredMany
method updates a expired key
.
The removeExpiredMany
method updates a unexpired key
.
The upsert
method inserts a key and if the key already exists then key will be updated with new data.value
and data.expiration
.
The method always returns the old cache data if it exists otherwise null will be returned.
To utilize the
LibsqlCacheAdapter
, you must install the"@libsql/client"
package and supply aISerde<string>
, with an adapter likeSuperJsonSerdeAdapter
.IMPORT_PATH:
"@daiso-tech/core/cache/adapters"