UNPKG

next

Version:

The React Framework

99 lines (98 loc) 3.89 kB
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 };