UNPKG

next-boost

Version:

Add a cache layer for next.js SSR pages. Use stale-while-revalidate to boost the performance.

32 lines (31 loc) 1.11 kB
/// <reference types="node" /> import { IncomingMessage, RequestListener } from 'http'; import { InitArgs } from './renderer'; import { ParamFilter } from './utils'; interface URLCacheRule { regex: string; ttl: number; } export declare type CacheKeyBuilder = (req: IncomingMessage) => string; export declare type CacheStatus = 'hit' | 'stale' | 'miss'; export declare type CacheAdapter = { set(key: string, value: Buffer, ttl?: number): Promise<void>; get(key: string, defaultValue?: Buffer): Promise<Buffer | undefined>; has(key: string): Promise<CacheStatus>; del(key: string): Promise<void>; }; export declare type URLCacheRuleResolver = (req: IncomingMessage) => number; export interface HandlerConfig { filename?: string; quiet?: boolean; rules?: Array<URLCacheRule> | URLCacheRuleResolver; cacheAdapter?: CacheAdapter; paramFilter?: ParamFilter; cacheKey?: CacheKeyBuilder; } export default function CachedHandler(args: InitArgs, options?: HandlerConfig): Promise<{ handler: RequestListener; cache: CacheAdapter; close: () => void; }>; export {};