next
Version:
The React Framework
99 lines (98 loc) • 3.89 kB
TypeScript
import type { AsyncLocalStorage } from 'async_hooks';
import type { IncrementalCache } from '../lib/incremental-cache';
import type { FetchMetrics } from '../base-http';
import type { DeepReadonly } from '../../shared/lib/deep-readonly';
import type { AppSegmentConfig } from '../../build/segment-config/app/app-segment-config';
import type { AfterContext } from '../after/after-context';
import type { CacheLife } from '../use-cache/cache-life';
import { workAsyncStorageInstance } from './work-async-storage-instance';
import type { LazyResult } from '../lib/lazy-result';
export interface WorkStore {
readonly isStaticGeneration: boolean;
/**
* The page that is being rendered. This relates to the path to the page file.
*/
readonly page: string;
/**
* The route that is being rendered. This is the page property without the
* trailing `/page` or `/route` suffix.
*/
readonly route: string;
readonly incrementalCache?: IncrementalCache;
readonly cacheLifeProfiles?: {
[profile: string]: CacheLife;
};
readonly isOnDemandRevalidate?: boolean;
readonly isBuildTimePrerendering?: boolean;
/**
* This is true when:
* - source maps are generated
* - source maps are applied
* - minification is disabled
*/
readonly hasReadableErrorStacks?: boolean;
forceDynamic?: boolean;
fetchCache?: AppSegmentConfig['fetchCache'];
forceStatic?: boolean;
dynamicShouldError?: boolean;
pendingRevalidates?: Record<string, Promise<any>>;
pendingRevalidateWrites?: Array<Promise<void>>;
readonly afterContext: AfterContext;
dynamicUsageDescription?: string;
dynamicUsageStack?: string;
/**
* Invalid dynamic usage errors might be caught in userland. We attach them to
* the work store to ensure we can still fail the build, or show en error in
* dev mode.
*/
invalidDynamicUsageError?: Error;
nextFetchId?: number;
pathWasRevalidated?: boolean;
/**
* Tags that were revalidated during the current request. They need to be sent
* to cache handlers to propagate their revalidation.
*/
pendingRevalidatedTags?: Array<{
tag: string;
profile?: string | {
stale?: number;
revalidate?: number;
expire?: number;
};
}>;
/**
* Tags that were previously revalidated (e.g. by a redirecting server action)
* and have already been sent to cache handlers. Retrieved cache entries that
* include any of these tags must be discarded.
*/
readonly previouslyRevalidatedTags: readonly string[];
/**
* This map contains lazy results so that we can evaluate them when the first
* cache entry is read. It allows us to skip refreshing tags if no caches are
* read at all.
*/
readonly refreshTagsByCacheKind: Map<string, LazyResult<void>>;
fetchMetrics?: FetchMetrics;
shouldTrackFetchMetrics: boolean;
isDraftMode?: boolean;
isUnstableNoStore?: boolean;
isPrefetchRequest?: boolean;
buildId: string;
readonly reactLoadableManifest?: DeepReadonly<Record<string, {
files: string[];
}>>;
readonly assetPrefix?: string;
readonly nonce?: string;
cacheComponentsEnabled: boolean;
dev: boolean;
/**
* Run the given function inside a clean AsyncLocalStorage snapshot. This is
* useful when generating cache entries, to ensure that the cache generation
* cannot read anything from the context we're currently executing in, which
* might include request-specific things like `cookies()` inside a
* `React.cache()`.
*/
runInCleanSnapshot: <R, TArgs extends any[]>(fn: (...args: TArgs) => R, ...args: TArgs) => R;
}
export type WorkAsyncStorage = AsyncLocalStorage<WorkStore>;
export { workAsyncStorageInstance as workAsyncStorage };