Duffer Derek
{"version":3,"sources":["../../../src/server/next-server.ts"],"sourcesContent":["import './node-environment'\nimport './require-hook'\nimport './node-polyfill-crypto'\n\nimport type { CacheFs } from '../shared/lib/utils'\nimport {\n DecodeError,\n PageNotFoundError,\n MiddlewareNotFoundError,\n} from '../shared/lib/utils'\nimport type { MiddlewareManifest } from '../build/webpack/plugins/middleware-plugin'\nimport type RenderResult from './render-result'\nimport type { FetchEventResult } from './web/types'\nimport type { PrerenderManifest, RoutesManifest } from '../build'\nimport type { PagesManifest } from '../build/webpack/plugins/pages-manifest-plugin'\nimport type {\n NextParsedUrlQuery,\n NextUrlWithParsedQuery,\n RequestMeta,\n} from './request-meta'\nimport type { Params } from './request/params'\nimport type { MiddlewareRouteMatch } from '../shared/lib/router/utils/middleware-route-matcher'\nimport type { RouteMatch } from './route-matches/route-match'\nimport type { IncomingMessage, ServerResponse } from 'http'\nimport type { ParsedUrlQuery } from 'querystring'\nimport type { ParsedUrl } from '../shared/lib/router/utils/parse-url'\nimport type { CacheControl } from './lib/cache-control'\nimport type { WaitUntil } from './after/builtin-request-context'\nimport type { AppPageModule } from './route-modules/app-page/module'\nimport type { AppRouteModule } from './route-modules/app-route/module.compiled'\nimport type { ErrorModule } from './load-default-error-components'\nimport type { PagesModule } from './route-modules/pages/module.compiled'\n\nimport fs from 'fs'\nimport { join, relative } from 'path'\nimport { getRouteMatcher } from '../shared/lib/router/utils/route-matcher'\nimport { addRequestMeta, getRequestMeta, setRequestMeta } from './request-meta'\nimport {\n PAGES_MANIFEST,\n BUILD_ID_FILE,\n MIDDLEWARE_MANIFEST,\n PREFETCH_HINTS,\n PRERENDER_MANIFEST,\n ROUTES_MANIFEST,\n CLIENT_PUBLIC_FILES_PATH,\n APP_PATHS_MANIFEST,\n SERVER_DIRECTORY,\n NEXT_FONT_MANIFEST,\n UNDERSCORE_NOT_FOUND_ROUTE_ENTRY,\n FUNCTIONS_CONFIG_MANIFEST,\n} from '../shared/lib/constants'\nimport { findDir } from '../lib/find-pages-dir'\nimport { NodeNextRequest, NodeNextResponse } from './base-http/node'\nimport { sendRenderResult } from './send-payload'\nimport { parseUrl } from '../shared/lib/router/utils/parse-url'\nimport * as Log from '../build/output/log'\n\nimport type {\n Options,\n FindComponentsResult,\n MiddlewareRoutingItem,\n RequestContext,\n NormalizedRouteManifest,\n LoadedRenderOpts,\n RouteHandler,\n NextEnabledDirectories,\n BaseRequestHandler,\n} from './base-server'\nimport BaseServer from './base-server'\nimport { getMaybePagePath, getPagePath } from './require'\nimport { denormalizePagePath } from '../shared/lib/page-path/denormalize-page-path'\nimport { normalizePagePath } from '../shared/lib/page-path/normalize-page-path'\nimport { loadComponents } from './load-components'\nimport type { LoadComponentsReturnType } from './load-components'\nimport isError, { getProperError } from '../lib/is-error'\nimport { splitCookiesString, toNodeOutgoingHttpHeaders } from './web/utils'\nimport { getMiddlewareRouteMatcher } from '../shared/lib/router/utils/middleware-route-matcher'\nimport { loadEnvConfig } from '@next/env'\nimport { urlQueryToSearchParams } from '../shared/lib/router/utils/querystring'\nimport { removeTrailingSlash } from '../shared/lib/router/utils/remove-trailing-slash'\nimport { getNextPathnameInfo } from '../shared/lib/router/utils/get-next-pathname-info'\nimport { getCloneableBody } from './body-streams'\nimport { checkIsOnDemandRevalidate } from './api-utils'\nimport ResponseCache, {\n CachedRouteKind,\n type IncrementalResponseCacheEntry,\n} from './response-cache'\nimport {\n IncrementalCache,\n type CacheHandler as ICacheHandler,\n} from './lib/incremental-cache'\nimport { normalizeAppPath } from '../shared/lib/router/utils/app-paths'\n\nimport { setHttpClientAndAgentOptions } from './setup-http-agent-env'\n\nimport { isPagesAPIRouteMatch } from './route-matches/pages-api-route-match'\nimport type { PagesAPIRouteMatch } from './route-matches/pages-api-route-match'\nimport type { MatchOptions } from './route-matcher-managers/route-matcher-manager'\nimport { BubbledError, getTracer } from './lib/trace/tracer'\nimport { NextNodeServerSpan } from './lib/trace/constants'\nimport { nodeFs } from './lib/node-fs-methods'\nimport { getRouteRegex } from '../shared/lib/router/utils/route-regex'\nimport { pipeToNodeResponse } from './pipe-readable'\nimport { createRequestResponseMocks } from './lib/mock-request'\nimport { NEXT_RSC_UNION_QUERY } from '../client/components/app-router-headers'\nimport { signalFromNodeResponse } from './web/spec-extension/adapters/next-request'\nimport { loadManifest } from './load-manifest.external'\nimport { lazyRenderAppPage } from './route-modules/app-page/module.render'\nimport { lazyRenderPagesPage } from './route-modules/pages/module.render'\nimport { interopDefault } from '../lib/interop-default'\nimport { formatDynamicImportPath } from '../lib/format-dynamic-import-path'\nimport type { NextFontManifest } from '../build/webpack/plugins/next-font-manifest-plugin'\nimport { isInterceptionRouteRewrite } from '../lib/is-interception-route-rewrite'\nimport type { ServerOnInstrumentationRequestError } from './app-render/types'\nimport type { PrefetchHints } from '../shared/lib/app-router-types'\nimport { RouteKind } from './route-kind'\nimport { InvariantError } from '../shared/lib/invariant-error'\nimport { AwaiterOnce } from './after/awaiter'\nimport { AsyncCallbackSet } from './lib/async-callback-set'\nimport { initializeCacheHandlers, setCacheHandler } from './use-cache/handlers'\nimport type { UnwrapPromise } from '../lib/coalesced-function'\nimport { populateStaticEnv } from '../lib/static-env'\nimport { NodeModuleLoader } from './lib/module-loader/node-module-loader'\nimport { NoFallbackError } from '../shared/lib/no-fallback-error.external'\nimport {\n ensureInstrumentationRegistered,\n getInstrumentationModule,\n} from './lib/router-utils/instrumentation-globals.external'\nimport {\n RouterServerContextSymbol,\n routerServerGlobal,\n} from './lib/router-utils/router-server-context'\nimport { installGlobalBehaviors } from './node-environment-extensions/global-behaviors'\nimport { installProcessErrorHandlers } from './node-environment-extensions/process-error-handlers'\n\nexport * from './base-server'\n\n// For module that can be both CJS or ESM\nconst dynamicImportEsmDefault = process.env.NEXT_MINIMAL\n ? (id: string) =>\n import(/* webpackIgnore: true */ id).then((mod) => mod.default || mod)\n : (id: string) => import(id).then((mod) => mod.default || mod)\n\nexport type NodeRequestHandler = BaseRequestHandler<\n IncomingMessage | NodeNextRequest,\n ServerResponse | NodeNextResponse\n>\n\ntype NodeRouteHandler = RouteHandler<NodeNextRequest, NodeNextResponse>\n\nconst MiddlewareMatcherCache = new WeakMap<\n MiddlewareManifest['middleware'][string],\n MiddlewareRouteMatch\n>()\n\nfunction getMiddlewareMatcher(\n info: MiddlewareManifest['middleware'][string]\n): MiddlewareRouteMatch {\n const stored = MiddlewareMatcherCache.get(info)\n if (stored) {\n return stored\n }\n\n if (!Array.isArray(info.matchers)) {\n throw new Error(\n `Invariant: invalid matchers for middleware ${JSON.stringify(info)}`\n )\n }\n\n const matcher = getMiddlewareRouteMatcher(info.matchers)\n MiddlewareMatcherCache.set(info, matcher)\n return matcher\n}\n\nexport default class NextNodeServer extends BaseServer<\n Options,\n NodeNextRequest,\n NodeNextResponse\n> {\n protected middlewareManifestPath: string\n private _serverDistDir: string | undefined\n private imageResponseCache?: ResponseCache\n private imageCacheHandler?: ICacheHandler\n protected renderWorkersPromises?: Promise<void>\n protected dynamicRoutes?: {\n match: import('../shared/lib/router/utils/route-matcher').RouteMatchFn\n page: string\n re: RegExp\n }[]\n private routerServerHandler?: (\n req: IncomingMessage,\n res: ServerResponse\n ) => void\n\n protected cleanupListeners = new AsyncCallbackSet()\n protected internalWaitUntil: WaitUntil | undefined\n private isDev: boolean\n private sriEnabled: boolean\n\n constructor(options: Options) {\n // Initialize super class\n super(options)\n\n installGlobalBehaviors(this.nextConfig)\n\n // Load prefetch hints from the build output. This must happen before\n // any render to ensure segment inlining decisions are available.\n this.renderOpts.prefetchHints = this.getPrefetchHints()\n\n const isDev = options.dev ?? false\n this.isDev = isDev\n this.sriEnabled = Boolean(options.conf.experimental?.sri?.algorithm)\n\n /**\n * This sets environment variable to be used at the time of SSR by head.tsx.\n * Using this from process.env allows targeting SSR by calling\n * `process.env.__NEXT_OPTIMIZE_CSS`.\n */\n if (this.renderOpts.optimizeCss) {\n process.env.__NEXT_OPTIMIZE_CSS = JSON.stringify(true)\n }\n if (this.renderOpts.nextScriptWorkers) {\n process.env.__NEXT_SCRIPT_WORKERS = JSON.stringify(true)\n }\n\n if (!this.minimalMode) {\n this.imageResponseCache = new ResponseCache(this.minimalMode)\n }\n\n if (\n !options.dev &&\n !this.minimalMode &&\n this.nextConfig.experimental.preloadEntriesOnStart\n ) {\n this.unstable_preloadEntries()\n }\n\n if (!options.dev) {\n const { dynamicRoutes = [] } = this.getRoutesManifest() ?? {}\n this.dynamicRoutes = dynamicRoutes.map((r) => {\n // TODO: can we just re-use the regex from the manifest?\n const regex = getRouteRegex(r.page)\n const match = getRouteMatcher(regex)\n\n return {\n match,\n page: r.page,\n re: regex.re,\n }\n })\n }\n\n // ensure options are set when loadConfig isn't called\n setHttpClientAndAgentOptions(this.nextConfig)\n\n // Intercept fetch and other testmode apis.\n if (this.serverOptions.experimentalTestProxy) {\n process.env.NEXT_PRIVATE_TEST_PROXY = 'true'\n const { interceptTestApis } =\n // eslint-disable-next-line @next/internal/typechecked-require -- experimental/testmode is not built ins next/dist/esm\n require('next/dist/experimental/testmode/server') as typeof import('../experimental/testmode/server')\n interceptTestApis()\n }\n\n this.middlewareManifestPath = join(\n /* turbopackIgnore: true */ this.serverDistDir,\n MIDDLEWARE_MANIFEST\n )\n\n // This is just optimization to fire prepare as soon as possible. It will be\n // properly awaited later. We add the catch here to ensure that it does not\n // cause a unhandled promise rejection. The promise rejection will be\n // handled later on via the `await` when the request handler is called.\n if (!options.dev) {\n this.prepare().catch((err) => {\n console.error('Failed to prepare server', err)\n })\n }\n\n // when using compile mode static env isn't inlined so we\n // need to populate in normal runtime env\n if (this.renderOpts.isExperimentalCompile) {\n // immutableAssetToken only works with Turbopack, and `isExperimentalCompile` isn't supported\n // with that anyway, so we can assign immutableAssetToken to deploymentId here\n populateStaticEnv(this.nextConfig, this.deploymentId || '')\n }\n\n const shouldRemoveUncaughtErrorAndRejectionListeners = Boolean(\n options.conf.experimental?.removeUncaughtErrorAndRejectionListeners\n )\n installProcessErrorHandlers(shouldRemoveUncaughtErrorAndRejectionListeners)\n }\n\n public async unstable_preloadEntries(): Promise<void> {\n // Ensure prepare process will be finished before preloading entries.\n await this.prepare()\n\n const appPathsManifest = this.getAppPathsManifest()\n const pagesManifest = this.getPagesManifest()\n\n await this.loadCustomCacheHandlers()\n\n for (const page of Object.keys(pagesManifest || {})) {\n try {\n await loadComponents({\n distDir: this.distDir,\n page,\n isAppPath: false,\n isDev: this.isDev,\n sriEnabled: this.sriEnabled,\n needsManifestsForLegacyReasons: false,\n })\n } catch (_err) {\n // Intentionally ignored because this is a preload step.\n }\n }\n\n for (const page of Object.keys(appPathsManifest || {})) {\n try {\n const { ComponentMod } = await loadComponents<\n AppPageModule | AppRouteModule\n >({\n distDir: this.distDir,\n page,\n isAppPath: true,\n isDev: this.isDev,\n sriEnabled: this.sriEnabled,\n needsManifestsForLegacyReasons: false,\n })\n // we need to ensure fetch is patched before we require the page,\n // otherwise if the fetch is patched by user code, we will be patching it\n // too late and there won't be any caching behaviors\n ComponentMod.patchFetch()\n } catch (_err) {\n // Intentionally ignored because this is a preload step.\n }\n }\n }\n\n protected async handleUpgrade(): Promise<void> {\n // The web server does not support web sockets, it's only used for HMR in\n // development.\n }\n\n protected async loadInstrumentationModule() {\n if (!this.serverOptions.dev) {\n try {\n this.instrumentation = await getInstrumentationModule(\n this.dir,\n this.nextConfig.distDir\n )\n } catch (err: any) {\n if (err.code !== 'MODULE_NOT_FOUND') {\n throw new Error(\n 'An error occurred while loading the instrumentation hook',\n { cause: err }\n )\n }\n }\n }\n return this.instrumentation\n }\n\n protected async prepareImpl() {\n await super.prepareImpl()\n await this.runInstrumentationHookIfAvailable()\n }\n\n protected async runInstrumentationHookIfAvailable() {\n await ensureInstrumentationRegistered(this.dir, this.nextConfig.distDir)\n }\n\n protected loadEnvConfig({\n dev,\n forceReload,\n }: {\n dev: boolean\n forceReload: boolean\n }) {\n loadEnvConfig(\n this.dir,\n dev,\n Log,\n forceReload,\n forceReload\n ? (envFilePath) => {\n Log.info(`Reload env: ${envFilePath}`)\n }\n : undefined\n )\n }\n\n private async loadCustomCacheHandlers() {\n const { cacheMaxMemorySize, cacheHandlers } = this.nextConfig\n if (!cacheHandlers) return\n\n // If we've already initialized the cache handlers interface, don't do it\n // again.\n if (!initializeCacheHandlers(cacheMaxMemorySize)) return\n\n for (const [kind, handler] of Object.entries(cacheHandlers)) {\n if (!handler) continue\n\n setCacheHandler(\n kind,\n interopDefault(\n await dynamicImportEsmDefault(\n formatDynamicImportPath(this.distDir, handler)\n )\n )\n )\n }\n }\n\n protected async getIncrementalCache({\n requestHeaders,\n }: {\n requestHeaders: IncrementalCache['requestHeaders']\n }) {\n const dev = !!this.dev\n let CacheHandler: any\n const { cacheHandler } = this.nextConfig\n\n if (cacheHandler) {\n CacheHandler = interopDefault(\n await dynamicImportEsmDefault(\n formatDynamicImportPath(this.distDir, cacheHandler)\n )\n )\n }\n\n await this.loadCustomCacheHandlers()\n\n // incremental-cache is request specific\n // although can have shared caches in module scope\n // per-cache handler\n return new IncrementalCache({\n fs: this.getCacheFilesystem(),\n dev,\n requestHeaders,\n allowedRevalidateHeaderKeys:\n this.nextConfig.experimental.allowedRevalidateHeaderKeys,\n minimalMode: this.minimalMode,\n serverDistDir: this.serverDistDir,\n fetchCacheKeyPrefix: this.nextConfig.experimental.fetchCacheKeyPrefix,\n maxMemoryCacheSize: this.nextConfig.cacheMaxMemorySize,\n flushToDisk:\n !this.minimalMode && this.nextConfig.experimental.isrFlushToDisk,\n getPrerenderManifest: () => this.getPrerenderManifest(),\n CurCacheHandler: CacheHandler,\n })\n }\n\n protected getPublicDir(): string {\n return join(/* turbopackIgnore: true */ this.dir, CLIENT_PUBLIC_FILES_PATH)\n }\n\n protected getHasStaticDir(): boolean {\n return fs.existsSync(\n /* turbopackIgnore: true */ join(\n /* turbopackIgnore: true */ this.dir,\n 'static'\n )\n )\n }\n\n protected getPagesManifest(): PagesManifest | undefined {\n return loadManifest(\n join(/* turbopackIgnore: true */ this.serverDistDir, PAGES_MANIFEST)\n ) as PagesManifest\n }\n\n protected getAppPathsManifest(): PagesManifest | undefined {\n if (!this.enabledDirectories.app) return undefined\n\n return loadManifest(\n join(/* turbopackIgnore: true */ this.serverDistDir, APP_PATHS_MANIFEST)\n ) as PagesManifest\n }\n\n protected getinterceptionRoutePatterns(): RegExp[] {\n if (!this.enabledDirectories.app) return []\n\n const routesManifest = this.getRoutesManifest()\n return (\n routesManifest?.rewrites.beforeFiles\n .filter(isInterceptionRouteRewrite)\n .map((rewrite) => new RegExp(rewrite.regex)) ?? []\n )\n }\n\n protected async hasPage(pathname: string): Promise<boolean> {\n return !!getMaybePagePath(\n pathname,\n this.distDir,\n this.nextConfig.i18n?.locales,\n this.enabledDirectories.app\n )\n }\n\n protected getBuildId(): string {\n const buildIdFile = join(\n /* turbopackIgnore: true */ this.distDir,\n BUILD_ID_FILE\n )\n try {\n return fs\n .readFileSync(/* turbopackIgnore: true */ buildIdFile, 'utf8')\n .trim()\n } catch (err: any) {\n if (err.code === 'ENOENT') {\n throw new Error(\n `Could not find a production build in the '${this.distDir}' directory. Try building your app with 'next build' before starting the production server. https://nextjs.org/docs/messages/production-start-no-build-id`\n )\n }\n\n throw err\n }\n }\n\n protected getEnabledDirectories(dev: boolean): NextEnabledDirectories {\n const dir = dev ? this.dir : this.serverDistDir\n\n return {\n app: findDir(dir, 'app') ? true : false,\n pages: findDir(dir, 'pages') ? true : false,\n }\n }\n\n protected sendRenderResult(\n req: NodeNextRequest,\n res: NodeNextResponse,\n options: {\n result: RenderResult\n generateEtags: boolean\n poweredByHeader: boolean\n cacheControl: CacheControl | undefined\n }\n ): Promise<void> {\n return sendRenderResult({\n req: req.originalRequest,\n res: res.originalResponse,\n result: options.result,\n generateEtags: options.generateEtags,\n poweredByHeader: options.poweredByHeader,\n cacheControl: options.cacheControl,\n })\n }\n\n protected async runApi(\n req: NodeNextRequest,\n res: NodeNextResponse,\n query: ParsedUrlQuery,\n match: PagesAPIRouteMatch\n ): Promise<boolean> {\n const edgeFunctionsPages = this.getEdgeFunctionsPages()\n\n for (const edgeFunctionsPage of edgeFunctionsPages) {\n if (edgeFunctionsPage === match.definition.pathname) {\n const handledAsEdgeFunction = await this.runEdgeFunction({\n req,\n res,\n query,\n params: match.params,\n page: match.definition.pathname,\n appPaths: null,\n })\n\n if (handledAsEdgeFunction) {\n return true\n }\n }\n }\n // The module supports minimal mode, load the minimal module.\n // Restore original URL as the handler handles it's own parsing\n const parsedInitUrl = parseUrl(getRequestMeta(req, 'initURL') || req.url)\n req.url = `${parsedInitUrl.pathname}${parsedInitUrl.search || ''}`\n\n const loader = new NodeModuleLoader()\n const module = (await loader.load(match.definition.filename)) as {\n handler: (\n req: IncomingMessage,\n res: ServerResponse,\n ctx: {\n waitUntil: ReturnType<BaseServer['getWaitUntil']>\n }\n ) => Promise<void>\n }\n addRequestMeta(\n req.originalRequest,\n 'relativeProjectDir',\n relative(process.cwd(), this.dir)\n )\n addRequestMeta(req.originalRequest, 'distDir', this.distDir)\n await module.handler(req.originalRequest, res.originalResponse, {\n waitUntil: this.getWaitUntil(),\n })\n return true\n }\n\n protected async renderHTML(\n req: NodeNextRequest,\n res: NodeNextResponse,\n pathname: string,\n query: NextParsedUrlQuery,\n renderOpts: LoadedRenderOpts\n ): Promise<RenderResult> {\n return getTracer().trace(NextNodeServerSpan.renderHTML, async () =>\n this.renderHTMLImpl(req, res, pathname, query, renderOpts)\n )\n }\n\n private async renderHTMLImpl(\n req: NodeNextRequest,\n res: NodeNextResponse,\n pathname: string,\n query: NextParsedUrlQuery,\n renderOpts: LoadedRenderOpts\n ): Promise<RenderResult> {\n if (process.env.NEXT_MINIMAL) {\n throw new Error(\n 'Invariant: renderHTML should not be called in minimal mode'\n )\n // the `else` branch is needed for tree-shaking\n } else {\n // Due to the way we pass data by mutating `renderOpts`, we can't extend the\n // object here but only updating its `nextFontManifest` field.\n // https://github.com/vercel/next.js/blob/df7cbd904c3bd85f399d1ce90680c0ecf92d2752/packages/next/server/render.tsx#L947-L952\n renderOpts.nextFontManifest = this.nextFontManifest\n\n if (this.enabledDirectories.app && renderOpts.isAppPath) {\n return lazyRenderAppPage(\n req,\n res,\n pathname,\n query,\n // This code path does not service revalidations for unknown param\n // shells. As a result, we don't need to pass in the unknown params.\n null,\n renderOpts as LoadedRenderOpts<AppPageModule>,\n this.getServerComponentsHmrCache(),\n {\n buildId: this.buildId,\n deploymentId: this.deploymentId,\n clientAssetToken:\n this.nextConfig.experimental.immutableAssetToken ??\n this.deploymentId,\n }\n )\n } else {\n // TODO: re-enable this once we've refactored to use implicit matches\n // throw new Error('Invariant: render should have used routeModule')\n\n return lazyRenderPagesPage(\n req.originalRequest,\n res.originalResponse,\n pathname,\n query,\n renderOpts as LoadedRenderOpts<PagesModule>,\n {\n buildId: this.buildId,\n deploymentId: this.deploymentId,\n clientAssetToken:\n this.nextConfig.experimental.immutableAssetToken ??\n this.deploymentId,\n customServer: this.serverOptions.customServer || undefined,\n },\n {\n isFallback: false,\n isDraftMode: renderOpts.isDraftMode,\n developmentNotFoundSourcePage: getRequestMeta(\n req,\n 'developmentNotFoundSourcePage'\n ),\n }\n )\n }\n }\n }\n\n protected async imageOptimizer(\n req: NodeNextRequest,\n res: NodeNextResponse,\n paramsResult: import('./image-optimizer').ImageParamsResult,\n previousCacheEntry?: IncrementalResponseCacheEntry | null\n ): Promise<{\n buffer: Buffer\n contentType: string\n maxAge: number\n upstreamEtag: string\n etag: string\n }> {\n if (process.env.NEXT_MINIMAL) {\n throw new Error(\n 'invariant: imageOptimizer should not be called in minimal mode'\n )\n } else {\n const { imageOptimizer, fetchExternalImage, fetchInternalImage } =\n require('./image-optimizer') as typeof import('./image-optimizer')\n\n const handleInternalReq = async (\n newReq: IncomingMessage,\n newRes: ServerResponse\n ) => {\n if (newReq.url === req.url) {\n throw new Error(`Invariant attempted to optimize _next/image itself`)\n }\n\n if (!this.routerServerHandler) {\n throw new Error(`Invariant missing routerServerHandler`)\n }\n\n await this.routerServerHandler(newReq, newRes)\n return\n }\n\n let { href } = paramsResult\n\n if (\n process.env.__NEXT_TEST_MODE &&\n process.env.IS_TURBOPACK_TEST &&\n !paramsResult.isAbsolute\n ) {\n // Forward the dpl query param from the original /_next/image request to the\n // internal static file request so that the static file validation in\n // resolve-routes.ts can verify it.\n const dpl =\n typeof req.url === 'string'\n ? new URL(req.url, 'http://n').searchParams.get('dpl')\n : undefined\n if (dpl) {\n href += `${href.includes('?') ? '&' : '?'}dpl=${dpl}`\n }\n }\n\n const imageUpstream = paramsResult.isAbsolute\n ? await fetchExternalImage(\n href,\n this.nextConfig.images.dangerouslyAllowLocalIP,\n this.nextConfig.images.maximumResponseBody,\n this.nextConfig.images.maximumRedirects\n )\n : await fetchInternalImage(\n href,\n req.originalRequest,\n res.originalResponse,\n handleInternalReq\n )\n\n return imageOptimizer(imageUpstream, paramsResult, this.nextConfig, {\n isDev: this.dev,\n previousCacheEntry,\n })\n }\n }\n\n protected getPagePath(pathname: string, locales?: string[]): string {\n return getPagePath(\n pathname,\n this.distDir,\n locales,\n this.enabledDirectories.app\n )\n }\n\n protected async renderPageComponent(\n ctx: RequestContext<NodeNextRequest, NodeNextResponse>,\n bubbleNoFallback: boolean\n ) {\n const edgeFunctionsPages = this.getEdgeFunctionsPages() || []\n if (edgeFunctionsPages.length) {\n const appPaths = this.getOriginalAppPaths(ctx.pathname)\n const isAppPath = Array.isArray(appPaths)\n\n let page = ctx.pathname\n if (isAppPath) {\n // When it's an array, we need to pass all parallel routes to the loader.\n page = appPaths[0]\n }\n\n for (const edgeFunctionsPage of edgeFunctionsPages) {\n if (edgeFunctionsPage === page) {\n await this.runEdgeFunction({\n req: ctx.req,\n res: ctx.res,\n query: ctx.query,\n params: ctx.renderOpts.params,\n page,\n appPaths,\n })\n return null\n }\n }\n }\n\n return super.renderPageComponent(ctx, bubbleNoFallback)\n }\n\n protected async findPageComponents({\n locale,\n page,\n query,\n params,\n isAppPath,\n url,\n }: {\n locale: string | undefined\n page: string\n query: NextParsedUrlQuery\n params: Params\n isAppPath: boolean\n // The following parameters are used in the development server's\n // implementation.\n sriEnabled?: boolean\n appPaths?: ReadonlyArray<string> | null\n shouldEnsure: boolean\n url?: string\n }): Promise<FindComponentsResult | null> {\n return getTracer().trace(\n NextNodeServerSpan.findPageComponents,\n {\n spanName: 'resolve page components',\n attributes: {\n 'next.route': isAppPath ? normalizeAppPath(page) : page,\n },\n },\n () =>\n this.findPageComponentsImpl({\n locale,\n page,\n query,\n params,\n isAppPath,\n url,\n })\n )\n }\n\n private async findPageComponentsImpl({\n locale,\n page,\n query,\n params,\n isAppPath,\n url: _url,\n }: {\n locale: string | undefined\n page: string\n query: NextParsedUrlQuery\n params: Params\n isAppPath: boolean\n url?: string\n }): Promise<FindComponentsResult | null> {\n const pagePaths: string[] = [page]\n\n if (locale) {\n pagePaths.unshift(\n ...pagePaths.map((path) => `/${locale}${path === '/' ? '' : path}`)\n )\n }\n\n for (const pagePath of pagePaths) {\n try {\n const components = await loadComponents({\n distDir: this.distDir,\n page: pagePath,\n isAppPath,\n isDev: this.isDev,\n sriEnabled: this.sriEnabled,\n needsManifestsForLegacyReasons: false,\n })\n\n if (\n locale &&\n typeof components.Component === 'string' &&\n !pagePath.startsWith(`/${locale}/`) &&\n pagePath !== `/${locale}`\n ) {\n // if loading an static HTML file the locale is required\n // to be present since all HTML files are output under their locale\n continue\n }\n\n return {\n components,\n query: {\n ...(!this.renderOpts.isExperimentalCompile &&\n components.getStaticProps\n ? {}\n : query),\n // For appDir params is excluded.\n ...((isAppPath ? {} : params) || {}),\n },\n }\n } catch (err) {\n // we should only not throw if we failed to find the page\n // in the pages-manifest\n if (!(err instanceof PageNotFoundError)) {\n throw err\n }\n }\n }\n return null\n }\n\n protected getNextFontManifest(): NextFontManifest | undefined {\n return loadManifest(\n join(\n /* turbopackIgnore: true */ this.distDir,\n 'server',\n NEXT_FONT_MANIFEST + '.json'\n )\n ) as NextFontManifest\n }\n\n protected handleNextImageRequest: NodeRouteHandler = async (\n req,\n res,\n parsedUrl\n ) => {\n if (!parsedUrl.pathname || !parsedUrl.pathname.startsWith('/_next/image')) {\n return false\n }\n // Ignore if its a middleware request\n if (getRequestMeta(req, 'middlewareInvoke')) {\n return false\n }\n\n if (\n this.minimalMode ||\n this.nextConfig.output === 'export' ||\n process.env.NEXT_MINIMAL\n ) {\n res.statusCode = 400\n res.body('Bad Request').send()\n return true\n // the `else` branch is needed for tree-shaking\n } else {\n const { ImageOptimizerCache } =\n require('./image-optimizer') as typeof import('./image-optimizer')\n\n // Load custom cache handler if configured and opt-in via images.customCacheHandler\n // Cache the handler instance to preserve state across requests\n if (\n !this.imageCacheHandler &&\n this.nextConfig.images.customCacheHandler\n ) {\n const { cacheHandler } = this.nextConfig\n if (cacheHandler) {\n const CacheHandler = interopDefault(\n await dynamicImportEsmDefault(\n formatDynamicImportPath(this.distDir, cacheHandler)\n )\n )\n this.imageCacheHandler = new CacheHandler({\n dev: !!this.dev,\n flushToDisk: this.nextConfig.experimental.isrFlushToDisk,\n serverDistDir: this.serverDistDir,\n maxMemoryCacheSize: this.nextConfig.cacheMaxMemorySize,\n revalidatedTags: [],\n _requestHeaders: {},\n })\n }\n }\n\n const imageOptimizerCache = new ImageOptimizerCache({\n distDir: this.distDir,\n nextConfig: this.nextConfig,\n cacheHandler: this.imageCacheHandler,\n })\n\n const { sendResponse, ImageError } =\n require('./image-optimizer') as typeof import('./image-optimizer')\n\n if (!this.imageResponseCache) {\n throw new Error('invariant image optimizer cache was not initialized')\n }\n const imagesConfig = this.nextConfig.images\n\n if (imagesConfig.loader !== 'default' || imagesConfig.unoptimized) {\n await this.render404(req, res)\n return true\n }\n\n const paramsResult = ImageOptimizerCache.validateParams(\n req.originalRequest,\n parsedUrl.query,\n this.nextConfig,\n !!this.dev\n )\n\n if ('errorMessage' in paramsResult) {\n res.statusCode = 400\n res.body(paramsResult.errorMessage).send()\n return true\n }\n\n const cacheKey = ImageOptimizerCache.getCacheKey(paramsResult)\n\n try {\n const { getExtension } =\n require('./serve-static') as typeof import('./serve-static')\n const cacheEntry = await this.imageResponseCache.get(\n cacheKey,\n async ({ previousCacheEntry }) => {\n const { buffer, contentType, maxAge, upstreamEtag, etag } =\n await this.imageOptimizer(\n req,\n res,\n paramsResult,\n previousCacheEntry\n )\n\n return {\n value: {\n kind: CachedRouteKind.IMAGE,\n buffer,\n etag,\n extension: getExtension(contentType) as string,\n upstreamEtag,\n },\n cacheControl: { revalidate: maxAge, expire: undefined },\n }\n },\n {\n routeKind: RouteKind.IMAGE,\n incrementalCache: imageOptimizerCache,\n isFallback: false,\n }\n )\n\n if (cacheEntry?.value?.kind !== CachedRouteKind.IMAGE) {\n throw new Error(\n 'invariant did not get entry from image response cache'\n )\n }\n\n sendResponse(\n req.originalRequest,\n res.originalResponse,\n paramsResult.href,\n cacheEntry.value.extension,\n cacheEntry.value.buffer,\n cacheEntry.value.etag,\n paramsResult.isStatic,\n cacheEntry.isMiss ? 'MISS' : cacheEntry.isStale ? 'STALE' : 'HIT',\n imagesConfig,\n cacheEntry.cacheControl?.revalidate || 0,\n Boolean(this.dev)\n )\n return true\n } catch (err) {\n if (err instanceof ImageError) {\n res.statusCode = err.statusCode\n res.body(err.message).send()\n return true\n }\n throw err\n }\n }\n }\n\n protected handleCatchallRenderRequest: NodeRouteHandler = async (\n req,\n res,\n parsedUrl\n ) => {\n let { pathname, query } = parsedUrl\n if (!pathname) {\n throw new Error('Invariant: pathname is undefined')\n }\n\n // When in minimal mode we do not bubble the fallback as the\n // router-server is not present to handle the error\n addRequestMeta(req, 'bubbleNoFallback', this.minimalMode ? undefined : true)\n\n // This is needed to expose render404 and nextConfig\n // for environments without router-server\n if (!routerServerGlobal[RouterServerContextSymbol]) {\n routerServerGlobal[RouterServerContextSymbol] = {}\n }\n const relativeProjectDir = relative(process.cwd(), this.dir)\n const existingServerContext =\n routerServerGlobal[RouterServerContextSymbol][relativeProjectDir]\n\n if (!existingServerContext) {\n routerServerGlobal[RouterServerContextSymbol][relativeProjectDir] = {\n render404: this.render404.bind(this),\n }\n }\n routerServerGlobal[RouterServerContextSymbol][\n relativeProjectDir\n ].nextConfig = this.nextConfig\n routerServerGlobal[RouterServerContextSymbol][\n relativeProjectDir\n ].isWrappedByNextServer = true\n\n try {\n // next.js core assumes page path without trailing slash\n pathname = removeTrailingSlash(pathname)\n\n const options: MatchOptions = {\n i18n: this.i18nProvider?.fromRequest(req, pathname),\n }\n const match = await this.matchers.match(pathname, options)\n\n // If we don't have a match, try to render it anyways.\n if (!match) {\n await this.render(req, res, pathname, query, parsedUrl, true)\n\n return true\n }\n\n // Add the match to the request so we don't have to re-run the matcher\n // for the same request.\n addRequestMeta(req, 'match', match)\n\n // TODO-APP: move this to a route handler\n const edgeFunctionsPages = this.getEdgeFunctionsPages()\n for (const edgeFunctionsPage of edgeFunctionsPages) {\n // If the page doesn't match the edge function page, skip it.\n if (edgeFunctionsPage !== match.definition.page) continue\n\n if (this.nextConfig.output === 'export') {\n await this.render404(req, res, parsedUrl)\n return true\n }\n delete query[NEXT_RSC_UNION_QUERY]\n\n // If we handled the request, we can return early.\n // For api routes edge runtime\n try {\n const handled = await this.runEdgeFunction({\n req,\n res,\n query,\n params: match.params,\n page: match.definition.page,\n match,\n appPaths: null,\n })\n if (handled) return true\n } catch (apiError) {\n const silenceLog = false\n await this.instrumentationOnRequestError(\n apiError,\n req,\n {\n routePath: match.definition.page,\n routerKind: 'Pages Router',\n routeType: 'route',\n // Edge runtime does not support ISR\n revalidateReason: undefined,\n },\n silenceLog\n )\n throw apiError\n }\n }\n\n // If the route was detected as being a Pages API route, then handle\n // it.\n // TODO: move this behavior into a route handler.\n if (isPagesAPIRouteMatch(match)) {\n if (this.nextConfig.output === 'export') {\n await this.render404(req, res, parsedUrl)\n return true\n }\n\n const handled = await this.handleApiRequest(req, res, query, match)\n if (handled) return true\n }\n\n await this.render(req, res, pathname, query, parsedUrl, true)\n\n return true\n } catch (err: any) {\n if (err instanceof NoFallbackError) {\n throw err\n }\n\n try {\n if (this.dev) {\n const { formatServerError } =\n require('../lib/format-server-error') as typeof import('../lib/format-server-error')\n formatServerError(err)\n this.logErrorWithOriginalStack(err)\n } else {\n this.logError(err)\n }\n res.statusCode = 500\n await this.renderError(err, req, res, pathname, query)\n return true\n } catch {}\n\n throw err\n }\n }\n\n // Used in development only, overloaded in next-dev-server\n protected logErrorWithOriginalStack(\n _err?: unknown,\n _type?: 'unhandledRejection' | 'uncaughtException' | 'warning' | 'app-dir'\n ): void {\n throw new Error(\n 'Invariant: logErrorWithOriginalStack can only be called on the development server'\n )\n }\n\n // Used in development only, overloaded in next-dev-server\n protected async ensurePage(_opts: {\n page: string\n clientOnly: boolean\n appPaths?: ReadonlyArray<string> | null\n match?: RouteMatch\n url?: string\n }): Promise<void> {\n throw new Error(\n 'Invariant: ensurePage can only be called on the development server'\n )\n }\n\n /**\n * Resolves `API` request, in development builds on demand\n * @param req http request\n * @param res http response\n * @param pathname path of request\n */\n protected async handleApiRequest(\n req: NodeNextRequest,\n res: NodeNextResponse,\n query: ParsedUrlQuery,\n match: PagesAPIRouteMatch\n ): Promise<boolean> {\n return this.runApi(req, res, query, match)\n }\n\n protected getCacheFilesystem(): CacheFs {\n return nodeFs\n }\n\n protected normalizeReq(\n req: NodeNextRequest | IncomingMessage\n ): NodeNextRequest {\n return !(req instanceof NodeNextRequest) ? new NodeNextRequest(req) : req\n }\n\n protected normalizeRes(\n res: NodeNextResponse | ServerResponse\n ): NodeNextResponse {\n return !(res instanceof NodeNextResponse) ? new NodeNextResponse(res) : res\n }\n\n public getRequestHandler(): NodeRequestHandler {\n const handler = this.makeRequestHandler()\n if (this.serverOptions.experimentalTestProxy) {\n const { wrapRequestHandlerNode } =\n // eslint-disable-next-line @next/internal/typechecked-require -- experimental/testmode is not built ins next/dist/esm\n require('next/dist/experimental/testmode/server') as typeof import('../experimental/testmode/server')\n return wrapRequestHandlerNode(handler)\n }\n return handler\n }\n\n /**\n * @internal - this method is internal to Next.js and should not be used directly by end-users\n */\n public getRequestHandlerWithMetadata(meta: RequestMeta): NodeRequestHandler {\n const handler = this.makeRequestHandler()\n return (req, res, parsedUrl) => {\n setRequestMeta(req, meta)\n return handler(req, res, parsedUrl)\n }\n }\n\n private makeRequestHandler(): NodeRequestHandler {\n // This is just optimization to fire prepare as soon as possible. It will be\n // properly awaited later. We add the catch here to ensure that it does not\n // cause an unhandled promise rejection. The promise rejection will be\n // handled later on via the `await` when the request handler is called.\n this.prepare().catch((err) => {\n console.error('Failed to prepare server', err)\n })\n\n const handler = super.getRequestHandler()\n\n return (req, res, parsedUrl) =>\n handler(this.normalizeReq(req), this.normalizeRes(res), parsedUrl)\n }\n\n public async revalidate({\n urlPath,\n headers,\n opts,\n }: {\n urlPath: string\n headers: { [key: string]: string | string[] }\n opts: { unstable_onlyGenerated?: boolean }\n }) {\n const mocked = createRequestResponseMocks({\n url: urlPath,\n headers,\n })\n\n const handler = this.getRequestHandler()\n await handler(\n new NodeNextRequest(mocked.req),\n new NodeNextResponse(mocked.res)\n )\n await mocked.res.hasStreamed\n\n if (\n mocked.res.getHeader('x-nextjs-cache') !== 'REVALIDATED' &&\n mocked.res.statusCode !== 200 &&\n !(mocked.res.statusCode === 404 && opts.unstable_onlyGenerated)\n ) {\n throw new Error(`Invalid response ${mocked.res.statusCode}`)\n }\n }\n\n public async render(\n req: NodeNextRequest | IncomingMessage,\n res: NodeNextResponse | ServerResponse,\n pathname: string,\n query?: NextParsedUrlQuery,\n parsedUrl?: NextUrlWithParsedQuery,\n internal = false\n ): Promise<void> {\n return super.render(\n this.normalizeReq(req),\n this.normalizeRes(res),\n pathname,\n query,\n parsedUrl,\n internal\n )\n }\n\n public async renderToHTML(\n req: NodeNextRequest | IncomingMessage,\n res: NodeNextResponse | ServerResponse,\n pathname: string,\n query?: ParsedUrlQuery\n ): Promise<string | null> {\n return super.renderToHTML(\n this.normalizeReq(req),\n this.normalizeRes(res),\n pathname,\n query\n )\n }\n\n protected async renderErrorToResponseImpl(\n ctx: RequestContext<NodeNextRequest, NodeNextResponse>,\n err: Error | null\n ) {\n const { req, res, query } = ctx\n const is404 = res.statusCode === 404\n\n if (is404 && this.enabledDirectories.app) {\n if (this.dev) {\n await this.ensurePage({\n page: UNDERSCORE_NOT_FOUND_ROUTE_ENTRY,\n clientOnly: false,\n url: req.url,\n }).catch(() => {})\n }\n\n if (\n this.getEdgeFunctionsPages().includes(UNDERSCORE_NOT_FOUND_ROUTE_ENTRY)\n ) {\n await this.runEdgeFunction({\n req,\n res,\n query: query || {},\n params: {},\n page: UNDERSCORE_NOT_FOUND_ROUTE_ENTRY,\n appPaths: null,\n })\n return null\n }\n }\n return super.renderErrorToResponseImpl(ctx, err)\n }\n\n public async renderError(\n err: Error | null,\n req: NodeNextRequest | IncomingMessage,\n res: NodeNextResponse | ServerResponse,\n pathname: string,\n query?: NextParsedUrlQuery,\n setHeaders?: boolean\n ): Promise<void> {\n return super.renderError(\n err,\n this.normalizeReq(req),\n this.normalizeRes(res),\n pathname,\n query,\n setHeaders\n )\n }\n\n public async renderErrorToHTML(\n err: Error | null,\n req: NodeNextRequest | IncomingMessage,\n res: NodeNextResponse | ServerResponse,\n pathname: string,\n query?: ParsedUrlQuery\n ): Promise<string | null> {\n return super.renderErrorToHTML(\n err,\n this.normalizeReq(req),\n this.normalizeRes(res),\n pathname,\n query\n )\n }\n\n public async render404(\n req: NodeNextRequest | IncomingMessage,\n res: NodeNextResponse | ServerResponse,\n parsedUrl?: NextUrlWithParsedQuery,\n setHeaders?: boolean\n ): Promise<void> {\n return super.render404(\n this.normalizeReq(req),\n this.normalizeRes(res),\n parsedUrl,\n setHeaders\n )\n }\n\n protected getMiddlewareManifest(): MiddlewareManifest | null {\n if (this.minimalMode) {\n return null\n } else {\n const manifest: MiddlewareManifest = require(this.middlewareManifestPath)\n return manifest\n }\n }\n\n /** Returns the middleware routing item if there is one. */\n protected async getMiddleware(): Promise<MiddlewareRoutingItem | undefined> {\n const manifest = this.getMiddlewareManifest()\n const middleware = manifest?.middleware?.['/']\n if (!middleware) {\n const middlewareModule = await this.loadNodeMiddleware()\n\n if (middlewareModule) {\n return {\n match: getMiddlewareRouteMatcher(\n middlewareModule.config?.matchers || [\n { regexp: '.*', originalSource: '/:path*' },\n ]\n ),\n page: '/',\n }\n }\n\n return\n }\n\n return {\n match: getMiddlewareMatcher(middleware),\n page: '/',\n }\n }\n\n protected getEdgeFunctionsPages(): string[] {\n const manifest = this.getMiddlewareManifest()\n if (!manifest) {\n return []\n }\n\n return Object.keys(manifest.functions)\n }\n\n /**\n * Get information for the edge function located in the provided page\n * folder. If the edge function info can't be found it will throw\n * an error.\n */\n protected getEdgeFunctionInfo(params: {\n page: string\n /** Whether we should look for a middleware or not */\n middleware: boolean\n }): {\n name: string\n paths: string[]\n wasm: { filePath: string; name: string }[]\n env: { [key: string]: string }\n assets?: { filePath: string; name: string }[]\n } | null {\n const manifest = this.getMiddlewareManifest()\n if (!manifest) {\n return null\n }\n\n let foundPage: string\n\n try {\n foundPage = denormalizePagePath(normalizePagePath(params.page))\n } catch (err) {\n return null\n }\n\n let pageInfo = params.middleware\n ? manifest.middleware[foundPage]\n : manifest.functions[foundPage]\n\n if (!pageInfo) {\n if (!params.middleware) {\n throw new PageNotFoundError(foundPage)\n }\n return null\n }\n\n return {\n name: pageInfo.name,\n paths: pageInfo.files.map((file) =>\n join(/* turbopackIgnore: true */ this.distDir, file)\n ),\n wasm: (pageInfo.wasm ?? []).map((binding) => ({\n ...binding,\n filePath: join(\n /* turbopackIgnore: true */ this.distDir,\n binding.filePath\n ),\n })),\n assets:\n pageInfo.assets &&\n pageInfo.assets.map((binding) => {\n return {\n ...binding,\n filePath: join(\n /* turbopackIgnore: true */ this.distDir,\n binding.filePath\n ),\n }\n }),\n env: pageInfo.env,\n }\n }\n\n private async loadNodeMiddleware() {\n if (!process.env.NEXT_MINIMAL) {\n try {\n const functionsConfig = this.dev\n ? {}\n : require(\n join(\n /* turbopackIgnore: true */ this.distDir,\n 'server',\n FUNCTIONS_CONFIG_MANIFEST\n )\n )\n\n if (this.dev || functionsConfig?.functions?.['/_middleware']) {\n // if used with top level await, this will be a promise\n return require(\n join(\n /* turbopackIgnore: true */ this.distDir,\n 'server',\n 'middleware.js'\n )\n )\n }\n } catch (err) {\n if (\n isError(err) &&\n err.code !== 'ENOENT' &&\n err.code !== 'MODULE_NOT_FOUND'\n ) {\n throw err\n }\n }\n }\n }\n\n /**\n * Checks if a middleware exists. This method is useful for the development\n * server where we need to check the filesystem. Here we just check the\n * middleware manifest.\n */\n protected async hasMiddleware(pathname: string): Promise<boolean> {\n const info = this.getEdgeFunctionInfo({ page: pathname, middleware: true })\n const nodeMiddleware = await this.loadNodeMiddleware()\n\n if (!info && nodeMiddleware) {\n return true\n }\n return Boolean(info && info.paths.length > 0)\n }\n\n /**\n * A placeholder for a function to be defined in the development server.\n * It will make sure that the root middleware or an edge function has been compiled\n * so that we can run it.\n */\n protected async ensureMiddleware(_url?: string) {}\n protected async ensureEdgeFunction(_params: {\n page: string\n appPaths: string[] | null\n url?: string\n }) {}\n\n /**\n * This method gets all middleware matchers and execute them when the request\n * matches. It will make sure that each middleware exists and is compiled and\n * ready to be invoked. The development server will decorate it to add warns\n * and errors with rich traces.\n */\n protected async runMiddleware(params: {\n request: NodeNextRequest\n response: NodeNextResponse\n parsedUrl: ParsedUrl\n parsed: NextUrlWithParsedQuery\n onWarning?: (warning: Error) => void\n }) {\n if (process.env.NEXT_MINIMAL) {\n throw new Error(\n 'invariant: runMiddleware should not be called in minimal mode'\n )\n }\n\n // Middleware is skipped for on-demand revalidate requests\n if (\n checkIsOnDemandRevalidate(params.request, this.renderOpts.previewProps)\n .isOnDemandRevalidate\n ) {\n return {\n response: new Response(null, { headers: { 'x-middleware-next': '1' } }),\n } as FetchEventResult\n }\n\n let url: string\n\n if (this.nextConfig.skipProxyUrlNormalize) {\n url = getRequestMeta(params.request, 'initURL')!\n } else {\n // For middleware to \"fetch\" we must always provide an absolute URL\n const query = urlQueryToSearchParams(params.parsed.query).toString()\n const locale = getRequestMeta(params.request, 'locale')\n\n url = `${getRequestMeta(params.request, 'initProtocol')}://${\n this.fetchHostname || 'localhost'\n }:${this.port}${locale ? `/${locale}` : ''}${params.parsed.pathname}${\n query ? `?${query}` : ''\n }`\n }\n\n if (!url.startsWith('http')) {\n throw new Error(\n 'To use middleware you must provide a `hostname` and `port` to the Next.js Server'\n )\n }\n\n const page: {\n name?: string\n params?: { [key: string]: string | string[] }\n } = {}\n\n const middleware = await this.getMiddleware()\n if (!middleware) {\n return { finished: false }\n }\n if (!(await this.hasMiddleware(middleware.page))) {\n return { finished: false }\n }\n\n await this.ensureMiddleware(params.request.url)\n const middlewareInfo = this.getEdgeFunctionInfo({\n page: middleware.page,\n middleware: true,\n })\n\n const method = (params.request.method || 'GET').toUpperCase()\n const requestData = {\n headers: params.request.headers,\n method,\n nextConfig: {\n basePath: this.nextConfig.basePath,\n i18n: this.nextConfig.i18n,\n trailingSlash: this.nextConfig.trailingSlash,\n experimental: this.nextConfig.experimental,\n },\n url: url,\n page,\n body:\n method !== 'GET' && method !== 'HEAD'\n ? (getRequestMeta(params.request, 'clonableBody') as any)\n : undefined,\n\n signal: signalFromNodeResponse(params.response.originalResponse),\n waitUntil: this.getWaitUntil(),\n }\n let result:\n | UnwrapPromise<ReturnType<typeof import('./web/sandbox').run>>\n | undefined\n\n // if no middleware info check for Node.js middleware\n // this is not in the middleware-manifest as that historically\n // has only included edge-functions, we need to do a breaking\n // version bump for that manifest to write this info there if\n // we decide we want to\n if (!middlewareInfo) {\n let middlewareModule\n middlewareModule = await this.loadNodeMiddleware()\n\n if (!middlewareModule) {\n throw new MiddlewareNotFoundError()\n }\n const adapterFn: typeof import('./web/adapter').adapter =\n middlewareModule.default || middlewareModule\n\n const hasRequestBody =\n !['HEAD', 'GET'].includes(params.request.method) &&\n Boolean(requestData.body)\n\n try {\n result = await adapterFn({\n handler:\n middlewareModule.proxy ||\n middlewareModule.middleware ||\n middlewareModule,\n request: {\n ...requestData,\n body: hasRequestBody\n ? requestData.body.cloneBodyStream()\n : undefined,\n },\n page: 'middleware',\n })\n } finally {\n if (hasRequestBody) {\n await requestData.body.finalize()\n }\n }\n } else {\n const { run } = require('./web/sandbox') as typeof import('./web/sandbox')\n\n result = await run({\n distDir: this.distDir,\n name: middlewareInfo.name,\n paths: middlewareInfo.paths,\n edgeFunctionEntry: middlewareInfo,\n request: requestData,\n useCache: true,\n onWarning: params.onWarning,\n clientAssetToken:\n this.nextConfig.experimental.immutableAssetToken || this.deploymentId,\n })\n }\n\n if (!this.dev) {\n result.waitUntil.catch((error) => {\n console.error(`Uncaught: middleware waitUntil errored`, error)\n })\n }\n\n if (!result) {\n this.render404(params.request, params.response, params.parsed)\n return { finished: true }\n }\n\n // Split compound (comma-separated) set-cookie headers\n if (result.response.headers.has('set-cookie')) {\n const cookies = result.response.headers\n .getSetCookie()\n .flatMap((maybeCompoundCookie) =>\n splitCookiesString(maybeCompoundCookie)\n )\n\n // Clear existing header(s)\n result.response.headers.delete('set-cookie')\n\n // Append each cookie individually.\n for (const cookie of cookies) {\n result.response.headers.append('set-cookie', cookie)\n }\n\n // Add cookies to request meta.\n addRequestMeta(params.request, 'middlewareCookie', cookies)\n }\n\n return result\n }\n\n protected handleCatchallMiddlewareRequest: NodeRouteHandler = async (\n req,\n res,\n parsed\n ) => {\n const isMiddlewareInvoke = getRequestMeta(req, 'middlewareInvoke')\n\n if (!isMiddlewareInvoke) {\n return false\n }\n\n const handleFinished = () => {\n addRequestMeta(req, 'middlewareInvoke', true)\n res.body('').send()\n return true\n }\n\n const middleware = await this.getMiddleware()\n if (!middleware) {\n return handleFinished()\n }\n\n const initUrl = getRequestMeta(req, 'initURL')!\n const parsedUrl = parseUrl(initUrl)\n const pathnameInfo = getNextPathnameInfo(parsedUrl.pathname, {\n nextConfig: this.nextConfig,\n i18nProvider: this.i18nProvider,\n })\n\n parsedUrl.pathname = pathnameInfo.pathname\n const normalizedPathname = removeTrailingSlash(parsed.pathname || '')\n let maybeDecodedPathname = normalizedPathname\n\n try {\n maybeDecodedPathname = decodeURIComponent(normalizedPathname)\n } catch {\n /* non-fatal we can't decode so can't match it */\n }\n\n if (\n !(\n middleware.match(normalizedPathname, req, parsedUrl.query) ||\n middleware.match(maybeDecodedPathname, req, parsedUrl.query)\n )\n ) {\n return handleFinished()\n }\n\n let result: Awaited<\n ReturnType<typeof NextNodeServer.prototype.runMiddleware>\n >\n let bubblingResult = false\n\n try {\n await this.ensureMiddleware(req.url)\n\n result = await this.runMiddleware({\n request: req,\n response: res,\n parsedUrl: parsedUrl,\n parsed: parsed,\n })\n\n if ('response' in result) {\n if (isMiddlewareInvoke) {\n bubblingResult = true\n throw new BubbledError(true, result)\n }\n\n for (const [key, value] of Object.entries(\n toNodeOutgoingHttpHeaders(result.response.headers)\n )) {\n if (key !== 'content-encoding' && value !== undefined) {\n res.setHeader(key, value as string | string[])\n }\n }\n res.statusCode = result.response.status\n\n const { originalResponse } = res\n if (result.response.body) {\n await pipeToNodeResponse(result.response.body, originalResponse)\n } else {\n originalResponse.end()\n }\n return true\n }\n } catch (err: unknown) {\n if (bubblingResult) {\n throw err\n }\n\n if (isError(err) && err.code === 'ENOENT') {\n await this.render404(req, res, parsed)\n return true\n }\n\n if (err instanceof DecodeError) {\n res.statusCode = 400\n await this.renderError(err, req, res, parsed.pathname || '')\n return true\n }\n\n const error = getProperError(err)\n console.error(error)\n res.statusCode = 500\n await this.renderError(error, req, res, parsed.pathname || '')\n return true\n }\n\n return result.finished\n }\n\n private _cachedPreviewManifest: PrerenderManifest | undefined\n protected getPrerenderManifest(): PrerenderManifest {\n if (this._cachedPreviewManifest) {\n return this._cachedPreviewManifest\n }\n\n this._cachedPreviewManifest = loadManifest(\n join(/* turbopackIgnore: true */ this.distDir, PRERENDER_MANIFEST)\n ) as PrerenderManifest\n\n return this._cachedPreviewManifest\n }\n\n private _cachedPrefetchHints: Record<string, PrefetchHints> | undefined\n protected getPrefetchHints(): Record<string, PrefetchHints> {\n if (this._cachedPrefetchHints) {\n return this._cachedPrefetchHints\n }\n\n this._cachedPrefetchHints =\n (loadManifest(\n join(\n /* turbopackIgnore: true */ this.distDir,\n SERVER_DIRECTORY,\n PREFETCH_HINTS\n ),\n true,\n undefined,\n false,\n true // handleMissing: don't crash if the file doesn't exist\n ) as Record<string, PrefetchHints>) ?? {}\n\n return this._cachedPrefetchHints\n }\n\n protected getRoutesManifest(): NormalizedRouteManifest | undefined {\n return getTracer().trace(\n NextNodeServerSpan.getRoutesManifest,\n () =>\n loadManifest(\n join(/* turbopackIgnore: true */ this.distDir, ROUTES_MANIFEST)\n ) as RoutesManifest\n )\n }\n\n protected attachRequestMeta(\n req: NodeNextRequest,\n parsedUrl: NextUrlWithParsedQuery,\n isUpgradeReq?: boolean\n ) {\n // Injected in base-server.ts\n const protocol = req.headers['x-forwarded-proto']?.includes('https')\n ? 'https'\n : 'http'\n\n // When there are hostname and port we build an absolute URL\n const initUrl =\n this.fetchHostname && this.port\n ? `${protocol}://${this.fetchHostname}:${this.port}${req.url}`\n : this.nextConfig.experimental.trustHostHeader\n ? `https://${req.headers.host || 'localhost'}${req.url}`\n : req.url\n\n addRequestMeta(req, 'initURL', initUrl)\n addRequestMeta(req, 'initQuery', { ...parsedUrl.query })\n addRequestMeta(req, 'initProtocol', protocol)\n\n if (!isUpgradeReq) {\n const bodySizeLimit = this.nextConfig.experimental\n ?.proxyClientMaxBodySize as number | undefined\n addRequestMeta(\n req,\n 'clonableBody',\n getCloneableBody(req.originalRequest, bodySizeLimit)\n )\n }\n }\n\n protected async runEdgeFunction(params: {\n req: NodeNextRequest\n res: NodeNextResponse\n query: ParsedUrlQuery\n params: Params | undefined\n page: string\n appPaths: string[] | null\n match?: RouteMatch\n onError?: (err: unknown) => void\n onWarning?: (warning: Error) => void\n }): Promise<FetchEventResult | null> {\n if (process.env.NEXT_MINIMAL) {\n throw new Error(\n 'Middleware is not supported in minimal mode. Please remove the `NEXT_MINIMAL` environment variable.'\n )\n }\n let edgeInfo: ReturnType<typeof this.getEdgeFunctionInfo> | undefined\n\n const { query, page, match } = params\n\n if (!match)\n await this.ensureEdgeFunction({\n page,\n appPaths: params.appPaths,\n url: params.req.url,\n })\n edgeInfo = this.getEdgeFunctionInfo({\n page,\n middleware: false,\n })\n\n if (!edgeInfo) {\n return null\n }\n\n // For edge to \"fetch\" we must always provide an absolute URL\n const isNextDataRequest = getRequestMeta(params.req, 'isNextDataReq')\n const initialUrl = new URL(\n getRequestMeta(params.req, 'initURL') || '/',\n 'http://n'\n )\n const queryString = urlQueryToSearchParams({\n ...Object.fromEntries(initialUrl.searchParams),\n ...query,\n ...params.params,\n }).toString()\n\n if (isNextDataRequest) {\n params.req.headers['x-nextjs-data'] = '1'\n }\n initialUrl.search = queryString\n const url = initialUrl.toString()\n\n if (!url.startsWith('http')) {\n throw new Error(\n 'To use middleware you must provide a `hostname` and `port` to the Next.js Server'\n )\n }\n\n const { run } = require('./web/sandbox') as typeof import('./web/sandbox')\n const result = await run({\n distDir: this.distDir,\n name: edgeInfo.name,\n paths: edgeInfo.paths,\n edgeFunctionEntry: edgeInfo,\n request: {\n headers: params.req.headers,\n method: params.req.method,\n nextConfig: {\n basePath: this.nextConfig.basePath,\n i18n: this.nextConfig.i18n,\n trailingSlash: this.nextConfig.trailingSlash,\n },\n url,\n page: {\n name: params.page,\n ...(params.params && { params: params.params }),\n },\n body: getRequestMeta(params.req, 'clonableBody'),\n signal: signalFromNodeResponse(params.res.originalResponse),\n waitUntil: this.getWaitUntil(),\n },\n useCache: true,\n onError: params.onError,\n onWarning: params.onWarning,\n incrementalCache:\n (globalThis as any).__incrementalCache ||\n getRequestMeta(params.req, 'incrementalCache'),\n serverComponentsHmrCache: getRequestMeta(\n params.req,\n 'serverComponentsHmrCache'\n ),\n clientAssetToken:\n this.nextConfig.experimental.immutableAssetToken || this.deploymentId,\n })\n\n if (result.fetchMetrics) {\n params.req.fetchMetrics = result.fetchMetrics\n }\n\n if (!params.res.statusCode || params.res.statusCode < 400) {\n params.res.statusCode = result.response.status\n params.res.statusMessage = result.response.statusText\n }\n\n // TODO: (wyattjoh) investigate improving this\n\n result.response.headers.forEach((value, key) => {\n // The append handling is special cased for `set-cookie`.\n if (key.toLowerCase() === 'set-cookie') {\n // TODO: (wyattjoh) replace with native response iteration when we can upgrade undici\n for (const cookie of splitCookiesString(value)) {\n params.res.appendHeader(key, cookie)\n }\n } else {\n params.res.appendHeader(key, value)\n }\n })\n\n const { originalResponse } = params.res\n if (result.response.body) {\n await pipeToNodeResponse(result.response.body, originalResponse)\n } else {\n originalResponse.end()\n }\n\n return result\n }\n\n protected get serverDistDir(): string {\n if (this._serverDistDir) {\n return this._serverDistDir\n }\n const serverDistDir = join(\n /* turbopackIgnore: true */ this.distDir,\n SERVER_DIRECTORY\n )\n this._serverDistDir = serverDistDir\n return serverDistDir\n }\n\n protected async getFallbackErrorComponents(\n _url?: string\n ): Promise<LoadComponentsReturnType<ErrorModule> | null> {\n // Not implemented for production use cases, this is implemented on the\n // development server.\n return null\n }\n\n protected async instrumentationOnRequestError(\n ...args: Parameters<ServerOnInstrumentationRequestError>\n ) {\n await super.instrumentationOnRequestError(...args)\n\n // For Node.js runtime production logs, in dev it will be overridden by next-dev-server\n if (!this.dev) {\n const [err, , , silenceLog] = args\n if (!silenceLog) {\n this.logError(err)\n }\n }\n }\n\n protected onServerClose(listener: () => Promise<void>) {\n this.cleanupListeners.add(listener)\n }\n\n async close(): Promise<void> {\n await this.cleanupListeners.runAll()\n }\n\n protected getInternalWaitUntil(): WaitUntil {\n this.internalWaitUntil ??= this.createInternalWaitUntil()\n return this.internalWaitUntil\n }\n\n private createInternalWaitUntil() {\n if (this.minimalMode) {\n throw new InvariantError(\n 'createInternalWaitUntil should never be called in minimal mode'\n )\n }\n\n const awaiter = new AwaiterOnce({ onError: console.error })\n\n // TODO(after): warn if the process exits before these are awaited\n this.onServerClose(() => awaiter.awaiting())\n\n return awaiter.waitUntil\n }\n}\n"],"names":["DecodeError","PageNotFoundError","MiddlewareNotFoundError","fs","join","relative","getRouteMatcher","addRequestMeta","getRequestMeta","setRequestMeta","PAGES_MANIFEST","BUILD_ID_FILE","MIDDLEWARE_MANIFEST","PREFETCH_HINTS","PRERENDER_MANIFEST","ROUTES_MANIFEST","CLIENT_PUBLIC_FILES_PATH","APP_PATHS_MANIFEST","SERVER_DIRECTORY","NEXT_FONT_MANIFEST","UNDERSCORE_NOT_FOUND_ROUTE_ENTRY","FUNCTIONS_CONFIG_MANIFEST","findDir","NodeNextRequest","NodeNextResponse","sendRenderResult","parseUrl","Log","BaseServer","getMaybePagePath","getPagePath","denormalizePagePath","normalizePagePath","loadComponents","isError","getProperError","splitCookiesString","toNodeOutgoingHttpHeaders","getMiddlewareRouteMatcher","loadEnvConfig","urlQueryToSearchParams","removeTrailingSlash","getNextPathnameInfo","getCloneableBody","checkIsOnDemandRevalidate","ResponseCache","CachedRouteKind","IncrementalCache","normalizeAppPath","setHttpClientAndAgentOptions","isPagesAPIRouteMatch","BubbledError","getTracer","NextNodeServerSpan","nodeFs","getRouteRegex","pipeToNodeResponse","createRequestResponseMocks","NEXT_RSC_UNION_QUERY","signalFromNodeResponse","loadManifest","lazyRenderAppPage","lazyRenderPagesPage","interopDefault","formatDynamicImportPath","isInterceptionRouteRewrite","RouteKind","InvariantError","AwaiterOnce","AsyncCallbackSet","initializeCacheHandlers","setCacheHandler","populateStaticEnv","NodeModuleLoader","NoFallbackError","ensureInstrumentationRegistered","getInstrumentationModule","RouterServerContextSymbol","routerServerGlobal","installGlobalBehaviors","installProcessErrorHandlers","dynamicImportEsmDefault","process","env","NEXT_MINIMAL","id","then","mod","default","MiddlewareMatcherCache","WeakMap","getMiddlewareMatcher","info","stored","get","Array","isArray","matchers","Error","JSON","stringify","matcher","set","NextNodeServer","constructor","options","cleanupListeners","handleNextImageRequest","req","res","parsedUrl","pathname","startsWith","minimalMode","nextConfig","output","statusCode","body","send","ImageOptimizerCache","require","imageCacheHandler","images","customCacheHandler","cacheHandler","CacheHandler","distDir","dev","flushToDisk","experimental","isrFlushToDisk","serverDistDir","maxMemoryCacheSize","cacheMaxMemorySize","revalidatedTags","_requestHeaders","imageOptimizerCache","sendResponse","ImageError","imageResponseCache","imagesConfig","loader","unoptimized","render404","paramsResult","validateParams","originalRequest","query","errorMessage","cacheKey","getCacheKey","cacheEntry","getExtension","previousCacheEntry","buffer","contentType","maxAge","upstreamEtag","etag","imageOptimizer","value","kind","IMAGE","extension","cacheControl","revalidate","expire","undefined","routeKind","incrementalCache","isFallback","originalResponse","href","isStatic","isMiss","isStale","Boolean","err","message","handleCatchallRenderRequest","relativeProjectDir","cwd","dir","existingServerContext","bind","isWrappedByNextServer","i18n","i18nProvider","fromRequest","match","render","edgeFunctionsPages","getEdgeFunctionsPages","edgeFunctionsPage","definition","page","handled","runEdgeFunction","params","appPaths","apiError","silenceLog","instrumentationOnRequestError","routePath","routerKind","routeType","revalidateReason","handleApiRequest","formatServerError","logErrorWithOriginalStack","logError","renderError","handleCatchallMiddlewareRequest","parsed","isMiddlewareInvoke","handleFinished","middleware","getMiddleware","initUrl","pathnameInfo","normalizedPathname","maybeDecodedPathname","decodeURIComponent","result","bubblingResult","ensureMiddleware","url","runMiddleware","request","response","key","Object","entries","headers","setHeader","status","end","code","error","console","finished","renderOpts","prefetchHints","getPrefetchHints","isDev","sriEnabled","conf","sri","algorithm","optimizeCss","__NEXT_OPTIMIZE_CSS","nextScriptWorkers","__NEXT_SCRIPT_WORKERS","preloadEntriesOnStart","unstable_preloadEntries","dynamicRoutes","getRoutesManifest","map","r","regex","re","serverOptions","experimentalTestProxy","NEXT_PRIVATE_TEST_PROXY","interceptTestApis","middlewareManifestPath","prepare","catch","isExperimentalCompile","deploymentId","shouldRemoveUncaughtErrorAndRejectionListeners","removeUncaughtErrorAndRejectionListeners","appPathsManifest","getAppPathsManifest","pagesManifest","getPagesManifest","loadCustomCacheHandlers","keys","isAppPath","needsManifestsForLegacyReasons","_err","ComponentMod","patchFetch","handleUpgrade","loadInstrumentationModule","instrumentation","cause","prepareImpl","runInstrumentationHookIfAvailable","forceReload","envFilePath","cacheHandlers","handler","getIncrementalCache","requestHeaders","getCacheFilesystem","allowedRevalidateHeaderKeys","fetchCacheKeyPrefix","getPrerenderManifest","CurCacheHandler","getPublicDir","getHasStaticDir","existsSync","enabledDirectories","app","getinterceptionRoutePatterns","routesManifest","rewrites","beforeFiles","filter","rewrite","RegExp","hasPage","locales","getBuildId","buildIdFile","readFileSync","trim","getEnabledDirectories","pages","generateEtags","poweredByHeader","runApi","handledAsEdgeFunction","parsedInitUrl","search","module","load","filename","waitUntil","getWaitUntil","renderHTML","trace","renderHTMLImpl","nextFontManifest","getServerComponentsHmrCache","buildId","clientAssetToken","immutableAssetToken","customServer","isDraftMode","developmentNotFoundSourcePage","fetchExternalImage","fetchInternalImage","handleInternalReq","newReq","newRes","routerServerHandler","__NEXT_TEST_MODE","IS_TURBOPACK_TEST","isAbsolute","dpl","URL","searchParams","includes","imageUpstream","dangerouslyAllowLocalIP","maximumResponseBody","maximumRedirects","renderPageComponent","ctx","bubbleNoFallback","length","getOriginalAppPaths","findPageComponents","locale","spanName","attributes","findPageComponentsImpl","_url","pagePaths","unshift","path","pagePath","components","Component","getStaticProps","getNextFontManifest","_type","ensurePage","_opts","normalizeReq","normalizeRes","getRequestHandler","makeRequestHandler","wrapRequestHandlerNode","getRequestHandlerWithMetadata","meta","urlPath","opts","mocked","hasStreamed","getHeader","unstable_onlyGenerated","internal","renderToHTML","renderErrorToResponseImpl","is404","clientOnly","setHeaders","renderErrorToHTML","getMiddlewareManifest","manifest","middlewareModule","loadNodeMiddleware","config","regexp","originalSource","functions","getEdgeFunctionInfo","foundPage","pageInfo","name","paths","files","file","wasm","binding","filePath","assets","functionsConfig","hasMiddleware","nodeMiddleware","ensureEdgeFunction","_params","previewProps","isOnDemandRevalidate","Response","skipProxyUrlNormalize","toString","fetchHostname","port","middlewareInfo","method","toUpperCase","requestData","basePath","trailingSlash","signal","adapterFn","hasRequestBody","proxy","cloneBodyStream","finalize","run","edgeFunctionEntry","useCache","onWarning","has","cookies","getSetCookie","flatMap","maybeCompoundCookie","delete","cookie","append","_cachedPreviewManifest","_cachedPrefetchHints","attachRequestMeta","isUpgradeReq","protocol","trustHostHeader","host","bodySizeLimit","proxyClientMaxBodySize","edgeInfo","isNextDataRequest","initialUrl","queryString","fromEntries","onError","globalThis","__incrementalCache","serverComponentsHmrCache","fetchMetrics","statusMessage","statusText","forEach","toLowerCase","appendHeader","_serverDistDir","getFallbackErrorComponents","args","onServerClose","listener","add","close","runAll","getInternalWaitUntil","internalWaitUntil","createInternalWaitUntil","awaiter","awaiting"],"mappings":"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","ignoreList":[0]}
Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists