result-cache
v1.4.0
Published
Tiny library that caches the result of any function that returns a promise. API heavily inspired by [@tanstack/query](https://tanstack.com/query/latest).
Downloads
156
Readme
Cache Promise Results
Tiny library that caches the result of any function that returns a promise. API heavily inspired by @tanstack/query.
Fully typed; zero dependencies (Redis optional)
npm install result-cacheimport { createCache } from 'result-cache';
const { cache } = createCache({ ttl: 30 });
// If there's a previous value in the cache matching the key 'results', fetch and return it.
// Otherwise, execute the fetch call and cache the result.
const result = await cache(() => fetch('api.example.com').then(response => response.json()), 'results');
Use with Redis
By default, records will be cached in memory (just a simple Map). This is only really advisable for development or testing. In production, configure the Redis driver:
npm install @redis/clientimport { createCache } from 'result-cache';
import { RedisDriver } from 'result-cache/redis';
import { createClient } from '@redis/client';
const driver = new RedisDriver(createClient());
const { cache } = createCache({ driver });Caveats
Serialisation
Objects will be serialised before being written to the cache. Therefore any unsupported attributes (functions, symbols) will be stripped when the cache is hit.
Validation
This library does not validate anything retrieved from the cache. This responsibility should lie outside the library. As such, it is strongly recommended to consider any data returned as unstructured.
import { z } from 'zod';
const personSchema = z.object({ name: z.string() });
const result = await cache(fetchPerson, 'person');
const person = personSchema.parse(result);