UNPKG

next

Version:

The React Framework

100 lines (99 loc) 4.75 kB
import type { FlightRouterState, InitialRSCPayload, NavigationFlightResponse } from '../../../shared/lib/app-router-types'; import { type NEXT_ROUTER_PREFETCH_HEADER, type NEXT_ROUTER_SEGMENT_PREFETCH_HEADER, type NEXT_INSTANT_PREFETCH_HEADER, NEXT_ROUTER_STATE_TREE_HEADER, NEXT_URL, RSC_HEADER, NEXT_HMR_REFRESH_HEADER, NEXT_HTML_REQUEST_ID_HEADER, NEXT_REQUEST_ID_HEADER } from '../app-router-headers'; import { type NormalizedFlightData } from '../../flight-data-helpers'; import type { NormalizedSearch } from '../segment-cache/cache-key'; export interface FetchServerResponseOptions { readonly flightRouterState: FlightRouterState; readonly nextUrl: string | null; readonly isHmrRefresh?: boolean; } export type StaticStageData<T extends NavigationFlightResponse | InitialRSCPayload = NavigationFlightResponse> = { readonly response: T; readonly isResponsePartial: boolean; }; type SpaFetchServerResponseResult = { flightData: NormalizedFlightData[]; canonicalUrl: URL; renderedSearch: NormalizedSearch; couldBeIntercepted: boolean; supportsPerSegmentPrefetching: boolean; postponed: boolean; dynamicStaleTime: number; staticStageData: StaticStageData | null; runtimePrefetchStream: ReadableStream<Uint8Array> | null; responseHeaders: Headers; debugInfo: Array<any> | null; }; type MpaFetchServerResponseResult = string; export type FetchServerResponseResult = MpaFetchServerResponseResult | SpaFetchServerResponseResult; export type RequestHeaders = { [RSC_HEADER]?: '1'; [NEXT_ROUTER_STATE_TREE_HEADER]?: string; [NEXT_URL]?: string; [NEXT_ROUTER_PREFETCH_HEADER]?: '1' | '2'; [NEXT_ROUTER_SEGMENT_PREFETCH_HEADER]?: string; 'x-deployment-id'?: string; [NEXT_HMR_REFRESH_HEADER]?: '1'; 'Next-Test-Fetch-Priority'?: RequestInit['priority']; [NEXT_HTML_REQUEST_ID_HEADER]?: string; [NEXT_REQUEST_ID_HEADER]?: string; [NEXT_INSTANT_PREFETCH_HEADER]?: '1'; }; /** * Fetch the flight data for the provided url. Takes in the current router state * to decide what to render server-side. */ export declare function fetchServerResponse(url: URL, options: FetchServerResponseOptions): Promise<FetchServerResponseResult>; export type RSCResponse<T> = { ok: boolean; redirected: boolean; headers: Headers; body: ReadableStream<Uint8Array> | null; status: number; url: string; flightResponsePromise: (Promise<T> & { _debugInfo?: Array<any>; }) | null; cacheData: Promise<FetchResponseCacheData | null>; }; type FetchResponseCacheData = { isResponsePartial: boolean; responseBodyClone?: ReadableStream<Uint8Array>; }; /** * Strips the leading isPartial byte from an RSC navigation response and * clones the body for segment cache extraction. * * When cache components is enabled, the server prepends a single byte: * '~' (0x7e) for partial, '#' (0x23) for complete. This must be stripped * before Flight decoding because it's not valid RSC data. The body is * cloned before Flight can consume it so the clone is available for later use. * * When cache components is disabled, returns the original response with * cacheData: null. */ export declare function processFetch(response: Response): Promise<{ response: Response; cacheData: FetchResponseCacheData | null; }>; /** * Resolves the static stage response from the raw `processFetch` outputs and * the decoded flight response, for writing into the segment cache. * * - Fully static: use the decoded flight response as-is, no truncation needed. * - Not fully static + `l` field: truncate the body clone at the static stage * byte boundary and decode. * - Otherwise: no cache-worthy data. */ export declare function resolveStaticStageData<T extends NavigationFlightResponse | InitialRSCPayload>(cacheData: FetchResponseCacheData, flightResponse: T, headers: RequestHeaders | undefined): Promise<StaticStageData<T> | null>; /** * Truncates a Flight stream clone at the given byte boundary and decodes the * static stage prefix. Used by both the navigation path and the initial HTML * hydration path. */ export declare function decodeStaticStage<T>(responseBodyClone: ReadableStream<Uint8Array>, staticStageByteLengthPromise: Promise<number>, headers: RequestHeaders | undefined): Promise<T>; export declare function createFetch<T>(url: URL, headers: RequestHeaders, fetchPriority: 'auto' | 'high' | 'low' | null, shouldImmediatelyDecode: boolean, signal?: AbortSignal): Promise<RSCResponse<T>>; export declare function createFromNextReadableStream<T>(flightStream: ReadableStream<Uint8Array>, requestHeaders: RequestHeaders | undefined, options?: { allowPartialStream?: boolean; }): Promise<T>; export {};