@unkey/cache
TypeScript icon, indicating that this package has built-in type declarations

0.0.3 • Public • Published

@unkey/cache

Cache all the things

Battle-tested, strongly typed caching with metrics and tracing out of the box.

Features

  • Tiered caching
  • Memory Cache
  • Cloudflare Cache
  • Cloudflare KV (todo)
  • Cloudflare R2 (todo)
  • Metrics (axiom)
  • Tracing (todo)

Quickstart

npm install @unkey/cache
import {
  createCache,
  MemoryStore,
  CloudflareStore,
  DefaultStatefulContext,
} from "@unkey/cache";

// Only required in stateful environments.
// Cloudflare workers or Vercel provide an executionContext for you.
const ctx = new DefaultStatefulContext();

type User = {
  id: string;
  email: string;
};

type Post = {
  slug: string;
  title: string;
  content: string;
  publishedAt: Date;
};

const fresh = 60_000;
const stale = 900_000;

const ctx = new DefaultStatefulContext();

const memory = new MemoryStore({
  persistentMap: new Map(),
});

const cloudflare = new CloudflareStore({
  cloudflareApiKey: "CLOUDFLARE_API_KEY",
  zoneId: "CLOUDFLARE_ZONE_ID",
  domain: "my-domain-on-cloudflare",
});
const cache = createCache({
  account: new Namespace<Account>(ctx, {
    stores: [memory],
    fresh,
    stale,
  }),
  user: new Namespace<User>(ctx, {
    stores: [memory, cloudflare],
    fresh,
    stale,
  }),
});

await cache.user.set("chronark", { id: "chronark", email: "iykyk" });

// This is fully typesafe and will check the stores in the above defined order.
const user = await cache.user.get("chronark");

Stale while revalidate with origin refresh

Add your database query and the cache will return the stale data while revalidating the data in the background.

const user = await cache.user.swr("chronark", async (id) => {
  return await db.query.users.findFirst({
    where: (table, { eq }) => eq(table.id, id),
  });
});

Instrumentation

TODO: document metrics and tracing

Package Sidebar

Install

npm i @unkey/cache

Weekly Downloads

254

Version

0.0.3

License

AGPL-3.0

Unpacked Size

142 kB

Total Files

10

Last publish

Collaborators

  • domeccleston
  • perkinsjr
  • chronark