next 15.3.0-canary.2 → 15.3.0-canary.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/bin/next +1 -1
- package/dist/build/index.js +10 -2
- package/dist/build/index.js.map +1 -1
- package/dist/build/swc/index.js +1 -1
- package/dist/build/webpack-config.js +2 -2
- package/dist/client/app-bootstrap.js +1 -1
- package/dist/client/components/react-dev-overlay/app/hot-reloader-client.js +10 -33
- package/dist/client/components/react-dev-overlay/app/hot-reloader-client.js.map +1 -1
- package/dist/client/components/react-dev-overlay/pages/hot-reloader-client.d.ts +1 -2
- package/dist/client/components/react-dev-overlay/pages/hot-reloader-client.js +13 -39
- package/dist/client/components/react-dev-overlay/pages/hot-reloader-client.js.map +1 -1
- package/dist/client/components/react-dev-overlay/shared.d.ts +3 -0
- package/dist/client/components/react-dev-overlay/shared.js +12 -0
- package/dist/client/components/react-dev-overlay/shared.js.map +1 -1
- package/dist/client/components/react-dev-overlay/utils/report-hmr-latency.d.ts +6 -0
- package/dist/client/components/react-dev-overlay/utils/report-hmr-latency.js +36 -0
- package/dist/client/components/react-dev-overlay/utils/report-hmr-latency.js.map +1 -0
- package/dist/client/dev/amp-dev.js +2 -2
- package/dist/client/dev/amp-dev.js.map +1 -1
- package/dist/client/dev/hot-middleware-client.d.ts +1 -1
- package/dist/client/dev/hot-middleware-client.js +2 -2
- package/dist/client/dev/hot-middleware-client.js.map +1 -1
- package/dist/client/index.js +1 -1
- package/dist/client/next-dev-turbopack.js +1 -1
- package/dist/client/next-dev-turbopack.js.map +1 -1
- package/dist/client/next-dev.js +1 -1
- package/dist/client/next-dev.js.map +1 -1
- package/dist/compiled/next-server/app-page-experimental.runtime.dev.js +3 -3
- package/dist/compiled/next-server/app-page-experimental.runtime.dev.js.map +1 -1
- package/dist/compiled/next-server/app-page.runtime.dev.js +3 -3
- package/dist/compiled/next-server/app-page.runtime.dev.js.map +1 -1
- package/dist/esm/build/index.js +10 -2
- package/dist/esm/build/index.js.map +1 -1
- package/dist/esm/build/swc/index.js +1 -1
- package/dist/esm/build/webpack-config.js +2 -2
- package/dist/esm/client/app-bootstrap.js +1 -1
- package/dist/esm/client/components/react-dev-overlay/app/hot-reloader-client.js +10 -33
- package/dist/esm/client/components/react-dev-overlay/app/hot-reloader-client.js.map +1 -1
- package/dist/esm/client/components/react-dev-overlay/pages/hot-reloader-client.js +14 -40
- package/dist/esm/client/components/react-dev-overlay/pages/hot-reloader-client.js.map +1 -1
- package/dist/esm/client/components/react-dev-overlay/shared.js +4 -0
- package/dist/esm/client/components/react-dev-overlay/shared.js.map +1 -1
- package/dist/esm/client/components/react-dev-overlay/utils/report-hmr-latency.js +20 -0
- package/dist/esm/client/components/react-dev-overlay/utils/report-hmr-latency.js.map +1 -0
- package/dist/esm/client/dev/amp-dev.js +2 -2
- package/dist/esm/client/dev/amp-dev.js.map +1 -1
- package/dist/esm/client/dev/hot-middleware-client.js +2 -2
- package/dist/esm/client/dev/hot-middleware-client.js.map +1 -1
- package/dist/esm/client/index.js +1 -1
- package/dist/esm/client/next-dev-turbopack.js +1 -1
- package/dist/esm/client/next-dev-turbopack.js.map +1 -1
- package/dist/esm/client/next-dev.js +1 -1
- package/dist/esm/client/next-dev.js.map +1 -1
- package/dist/esm/server/config-schema.js +2 -1
- package/dist/esm/server/config-schema.js.map +1 -1
- package/dist/esm/server/config-shared.js +2 -1
- package/dist/esm/server/config-shared.js.map +1 -1
- package/dist/esm/server/dev/hot-reloader-turbopack.js +1 -1
- package/dist/esm/server/dev/hot-reloader-webpack.js +1 -1
- package/dist/esm/server/lib/app-info-log.js +1 -1
- package/dist/esm/server/lib/router-server.js +1 -1
- package/dist/esm/server/lib/router-server.js.map +1 -1
- package/dist/esm/server/lib/router-utils/block-cross-site.js +5 -1
- package/dist/esm/server/lib/router-utils/block-cross-site.js.map +1 -1
- package/dist/esm/server/lib/start-server.js +1 -1
- package/dist/esm/shared/lib/canary-only.js +1 -1
- package/dist/server/config-schema.js +2 -1
- package/dist/server/config-schema.js.map +1 -1
- package/dist/server/config-shared.d.ts +2 -1
- package/dist/server/config-shared.js +2 -1
- package/dist/server/config-shared.js.map +1 -1
- package/dist/server/dev/hot-reloader-turbopack.js +1 -1
- package/dist/server/dev/hot-reloader-webpack.js +1 -1
- package/dist/server/lib/app-info-log.js +1 -1
- package/dist/server/lib/router-server.js +1 -1
- package/dist/server/lib/router-server.js.map +1 -1
- package/dist/server/lib/router-utils/block-cross-site.js +5 -1
- package/dist/server/lib/router-utils/block-cross-site.js.map +1 -1
- package/dist/server/lib/start-server.js +1 -1
- package/dist/shared/lib/canary-only.js +1 -1
- package/dist/telemetry/anonymous-meta.js +1 -1
- package/dist/telemetry/events/session-stopped.js +2 -2
- package/dist/telemetry/events/version.js +2 -2
- package/package.json +15 -15
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../../src/server/lib/router-server.ts"],"sourcesContent":["// this must come first as it includes require hooks\nimport type { WorkerRequestHandler, WorkerUpgradeHandler } from './types'\nimport type { DevBundler, ServerFields } from './router-utils/setup-dev-bundler'\nimport type { NextUrlWithParsedQuery, RequestMeta } from '../request-meta'\n\n// This is required before other imports to ensure the require hook is setup.\nimport '../node-environment'\nimport '../require-hook'\n\nimport url from 'url'\nimport path from 'path'\nimport loadConfig from '../config'\nimport { serveStatic } from '../serve-static'\nimport setupDebug from 'next/dist/compiled/debug'\nimport * as Log from '../../build/output/log'\nimport { DecodeError } from '../../shared/lib/utils'\nimport { findPagesDir } from '../../lib/find-pages-dir'\nimport { setupFsCheck } from './router-utils/filesystem'\nimport { proxyRequest } from './router-utils/proxy-request'\nimport { isAbortError, pipeToNodeResponse } from '../pipe-readable'\nimport { getResolveRoutes } from './router-utils/resolve-routes'\nimport { addRequestMeta, getRequestMeta } from '../request-meta'\nimport { pathHasPrefix } from '../../shared/lib/router/utils/path-has-prefix'\nimport { removePathPrefix } from '../../shared/lib/router/utils/remove-path-prefix'\nimport setupCompression from 'next/dist/compiled/compression'\nimport { NoFallbackError } from '../base-server'\nimport { signalFromNodeResponse } from '../web/spec-extension/adapters/next-request'\nimport { isPostpone } from './router-utils/is-postpone'\nimport { parseUrl as parseUrlUtil } from '../../shared/lib/router/utils/parse-url'\n\nimport {\n PHASE_PRODUCTION_SERVER,\n PHASE_DEVELOPMENT_SERVER,\n UNDERSCORE_NOT_FOUND_ROUTE,\n} from '../../shared/lib/constants'\nimport { RedirectStatusCode } from '../../client/components/redirect-status-code'\nimport { DevBundlerService } from './dev-bundler-service'\nimport { type Span, trace } from '../../trace'\nimport { ensureLeadingSlash } from '../../shared/lib/page-path/ensure-leading-slash'\nimport { getNextPathnameInfo } from '../../shared/lib/router/utils/get-next-pathname-info'\nimport { getHostname } from '../../shared/lib/get-hostname'\nimport { detectDomainLocale } from '../../shared/lib/i18n/detect-domain-locale'\nimport { MockedResponse } from './mock-request'\nimport {\n HMR_ACTIONS_SENT_TO_BROWSER,\n type AppIsrManifestAction,\n} from '../dev/hot-reloader-types'\nimport { normalizedAssetPrefix } from '../../shared/lib/normalized-asset-prefix'\nimport { NEXT_PATCH_SYMBOL } from './patch-fetch'\nimport type { ServerInitResult } from './render-server'\nimport { filterInternalHeaders } from './server-ipc/utils'\nimport { blockCrossSite } from './router-utils/block-cross-site'\n\nconst debug = setupDebug('next:router-server:main')\nconst isNextFont = (pathname: string | null) =>\n pathname && /\\/media\\/[^/]+\\.(woff|woff2|eot|ttf|otf)$/.test(pathname)\n\nexport type RenderServer = Pick<\n typeof import('./render-server'),\n | 'initialize'\n | 'clearModuleContext'\n | 'propagateServerField'\n | 'getServerField'\n>\n\nexport interface LazyRenderServerInstance {\n instance?: RenderServer\n}\n\nconst requestHandlers: Record<string, WorkerRequestHandler> = {}\n\nexport async function initialize(opts: {\n dir: string\n port: number\n dev: boolean\n onDevServerCleanup: ((listener: () => Promise<void>) => void) | undefined\n server?: import('http').Server\n minimalMode?: boolean\n hostname?: string\n keepAliveTimeout?: number\n customServer?: boolean\n experimentalHttpsServer?: boolean\n startServerSpan?: Span\n quiet?: boolean\n}): Promise<ServerInitResult> {\n if (!process.env.NODE_ENV) {\n // @ts-ignore not readonly\n process.env.NODE_ENV = opts.dev ? 'development' : 'production'\n }\n\n const config = await loadConfig(\n opts.dev ? PHASE_DEVELOPMENT_SERVER : PHASE_PRODUCTION_SERVER,\n opts.dir,\n { silent: false }\n )\n\n let compress: ReturnType<typeof setupCompression> | undefined\n\n if (config?.compress !== false) {\n compress = setupCompression()\n }\n\n const fsChecker = await setupFsCheck({\n dev: opts.dev,\n dir: opts.dir,\n config,\n minimalMode: opts.minimalMode,\n })\n\n const renderServer: LazyRenderServerInstance = {}\n\n let developmentBundler: DevBundler | undefined\n\n let devBundlerService: DevBundlerService | undefined\n\n let originalFetch = globalThis.fetch\n\n if (opts.dev) {\n const { Telemetry } =\n require('../../telemetry/storage') as typeof import('../../telemetry/storage')\n\n const telemetry = new Telemetry({\n distDir: path.join(opts.dir, config.distDir),\n })\n const { pagesDir, appDir } = findPagesDir(opts.dir)\n\n const { setupDevBundler } =\n require('./router-utils/setup-dev-bundler') as typeof import('./router-utils/setup-dev-bundler')\n\n const resetFetch = () => {\n globalThis.fetch = originalFetch\n ;(globalThis as Record<symbol, unknown>)[NEXT_PATCH_SYMBOL] = false\n }\n\n const setupDevBundlerSpan = opts.startServerSpan\n ? opts.startServerSpan.traceChild('setup-dev-bundler')\n : trace('setup-dev-bundler')\n developmentBundler = await setupDevBundlerSpan.traceAsyncFn(() =>\n setupDevBundler({\n // Passed here but the initialization of this object happens below, doing the initialization before the setupDev call breaks.\n renderServer,\n appDir,\n pagesDir,\n telemetry,\n fsChecker,\n dir: opts.dir,\n nextConfig: config,\n isCustomServer: opts.customServer,\n turbo: !!process.env.TURBOPACK,\n port: opts.port,\n onDevServerCleanup: opts.onDevServerCleanup,\n resetFetch,\n })\n )\n\n devBundlerService = new DevBundlerService(\n developmentBundler,\n // The request handler is assigned below, this allows us to create a lazy\n // reference to it.\n (req, res) => {\n return requestHandlers[opts.dir](req, res)\n }\n )\n }\n\n renderServer.instance =\n require('./render-server') as typeof import('./render-server')\n\n const allowedOrigins = [\n 'localhost',\n ...(config.experimental.allowedDevOrigins || []),\n ]\n if (opts.hostname) {\n allowedOrigins.push(opts.hostname)\n }\n\n const requestHandlerImpl: WorkerRequestHandler = async (req, res) => {\n // internal headers should not be honored by the request handler\n if (!process.env.NEXT_PRIVATE_TEST_HEADERS) {\n filterInternalHeaders(req.headers)\n }\n\n if (\n !opts.minimalMode &&\n config.i18n &&\n config.i18n.localeDetection !== false\n ) {\n const urlParts = (req.url || '').split('?', 1)\n let urlNoQuery = urlParts[0] || ''\n\n if (config.basePath) {\n urlNoQuery = removePathPrefix(urlNoQuery, config.basePath)\n }\n\n const pathnameInfo = getNextPathnameInfo(urlNoQuery, {\n nextConfig: config,\n })\n\n const domainLocale = detectDomainLocale(\n config.i18n.domains,\n getHostname({ hostname: urlNoQuery }, req.headers)\n )\n\n const defaultLocale =\n domainLocale?.defaultLocale || config.i18n.defaultLocale\n\n const { getLocaleRedirect } =\n require('../../shared/lib/i18n/get-locale-redirect') as typeof import('../../shared/lib/i18n/get-locale-redirect')\n\n const parsedUrl = parseUrlUtil((req.url || '')?.replace(/^\\/+/, '/'))\n\n const redirect = getLocaleRedirect({\n defaultLocale,\n domainLocale,\n headers: req.headers,\n nextConfig: config,\n pathLocale: pathnameInfo.locale,\n urlParsed: {\n ...parsedUrl,\n pathname: pathnameInfo.locale\n ? `/${pathnameInfo.locale}${urlNoQuery}`\n : urlNoQuery,\n },\n })\n\n if (redirect) {\n res.setHeader('Location', redirect)\n res.statusCode = RedirectStatusCode.TemporaryRedirect\n res.end(redirect)\n return\n }\n }\n\n if (compress) {\n // @ts-expect-error not express req/res\n compress(req, res, () => {})\n }\n req.on('error', (_err) => {\n // TODO: log socket errors?\n })\n res.on('error', (_err) => {\n // TODO: log socket errors?\n })\n\n const invokedOutputs = new Set<string>()\n\n async function invokeRender(\n parsedUrl: NextUrlWithParsedQuery,\n invokePath: string,\n handleIndex: number,\n additionalRequestMeta?: RequestMeta\n ) {\n // invokeRender expects /api routes to not be locale prefixed\n // so normalize here before continuing\n if (\n config.i18n &&\n removePathPrefix(invokePath, config.basePath).startsWith(\n `/${getRequestMeta(req, 'locale')}/api`\n )\n ) {\n invokePath = fsChecker.handleLocale(\n removePathPrefix(invokePath, config.basePath)\n ).pathname\n }\n\n if (\n req.headers['x-nextjs-data'] &&\n fsChecker.getMiddlewareMatchers()?.length &&\n removePathPrefix(invokePath, config.basePath) === '/404'\n ) {\n res.setHeader('x-nextjs-matched-path', parsedUrl.pathname || '')\n res.statusCode = 404\n res.setHeader('content-type', 'application/json')\n res.end('{}')\n return null\n }\n\n if (!handlers) {\n throw new Error('Failed to initialize render server')\n }\n\n addRequestMeta(req, 'invokePath', invokePath)\n addRequestMeta(req, 'invokeQuery', parsedUrl.query)\n addRequestMeta(req, 'middlewareInvoke', false)\n\n for (const key in additionalRequestMeta || {}) {\n addRequestMeta(\n req,\n key as keyof RequestMeta,\n additionalRequestMeta![key as keyof RequestMeta]\n )\n }\n\n debug('invokeRender', req.url, req.headers)\n\n try {\n const initResult =\n await renderServer?.instance?.initialize(renderServerOpts)\n try {\n await initResult?.requestHandler(req, res)\n } catch (err) {\n if (err instanceof NoFallbackError) {\n // eslint-disable-next-line\n await handleRequest(handleIndex + 1)\n return\n }\n throw err\n }\n return\n } catch (e) {\n // If the client aborts before we can receive a response object (when\n // the headers are flushed), then we can early exit without further\n // processing.\n if (isAbortError(e)) {\n return\n }\n throw e\n }\n }\n\n const handleRequest = async (handleIndex: number) => {\n if (handleIndex > 5) {\n throw new Error(`Attempted to handle request too many times ${req.url}`)\n }\n\n // handle hot-reloader first\n if (developmentBundler) {\n if (blockCrossSite(req, res, allowedOrigins, `${opts.port}`)) {\n return\n }\n const origUrl = req.url || '/'\n\n if (config.basePath && pathHasPrefix(origUrl, config.basePath)) {\n req.url = removePathPrefix(origUrl, config.basePath)\n }\n const parsedUrl = url.parse(req.url || '/')\n\n const hotReloaderResult = await developmentBundler.hotReloader.run(\n req,\n res,\n parsedUrl\n )\n\n if (hotReloaderResult.finished) {\n return hotReloaderResult\n }\n req.url = origUrl\n }\n\n const {\n finished,\n parsedUrl,\n statusCode,\n resHeaders,\n bodyStream,\n matchedOutput,\n } = await resolveRoutes({\n req,\n res,\n isUpgradeReq: false,\n signal: signalFromNodeResponse(res),\n invokedOutputs,\n })\n\n if (res.closed || res.finished) {\n return\n }\n\n if (developmentBundler && matchedOutput?.type === 'devVirtualFsItem') {\n const origUrl = req.url || '/'\n\n if (config.basePath && pathHasPrefix(origUrl, config.basePath)) {\n req.url = removePathPrefix(origUrl, config.basePath)\n }\n\n if (resHeaders) {\n for (const key of Object.keys(resHeaders)) {\n res.setHeader(key, resHeaders[key])\n }\n }\n const result = await developmentBundler.requestHandler(req, res)\n\n if (result.finished) {\n return\n }\n // TODO: throw invariant if we resolved to this but it wasn't handled?\n req.url = origUrl\n }\n\n debug('requestHandler!', req.url, {\n matchedOutput,\n statusCode,\n resHeaders,\n bodyStream: !!bodyStream,\n parsedUrl: {\n pathname: parsedUrl.pathname,\n query: parsedUrl.query,\n },\n finished,\n })\n\n // apply any response headers from routing\n for (const key of Object.keys(resHeaders || {})) {\n res.setHeader(key, resHeaders[key])\n }\n\n // handle redirect\n if (!bodyStream && statusCode && statusCode > 300 && statusCode < 400) {\n const destination = url.format(parsedUrl)\n res.statusCode = statusCode\n res.setHeader('location', destination)\n\n if (statusCode === RedirectStatusCode.PermanentRedirect) {\n res.setHeader('Refresh', `0;url=${destination}`)\n }\n return res.end(destination)\n }\n\n // handle middleware body response\n if (bodyStream) {\n res.statusCode = statusCode || 200\n return await pipeToNodeResponse(bodyStream, res)\n }\n\n if (finished && parsedUrl.protocol) {\n return await proxyRequest(\n req,\n res,\n parsedUrl,\n undefined,\n getRequestMeta(req, 'clonableBody')?.cloneBodyStream(),\n config.experimental.proxyTimeout\n )\n }\n\n if (matchedOutput?.fsPath && matchedOutput.itemPath) {\n if (\n opts.dev &&\n (fsChecker.appFiles.has(matchedOutput.itemPath) ||\n fsChecker.pageFiles.has(matchedOutput.itemPath))\n ) {\n res.statusCode = 500\n const message = `A conflicting public file and page file was found for path ${matchedOutput.itemPath} https://nextjs.org/docs/messages/conflicting-public-file-page`\n await invokeRender(parsedUrl, '/_error', handleIndex, {\n invokeStatus: 500,\n invokeError: new Error(message),\n })\n Log.error(message)\n return\n }\n\n if (\n !res.getHeader('cache-control') &&\n matchedOutput.type === 'nextStaticFolder'\n ) {\n if (opts.dev && !isNextFont(parsedUrl.pathname)) {\n res.setHeader('Cache-Control', 'no-store, must-revalidate')\n } else {\n res.setHeader(\n 'Cache-Control',\n 'public, max-age=31536000, immutable'\n )\n }\n }\n if (!(req.method === 'GET' || req.method === 'HEAD')) {\n res.setHeader('Allow', ['GET', 'HEAD'])\n res.statusCode = 405\n return await invokeRender(\n url.parse('/405', true),\n '/405',\n handleIndex,\n {\n invokeStatus: 405,\n }\n )\n }\n\n try {\n return await serveStatic(req, res, matchedOutput.itemPath, {\n root: matchedOutput.itemsRoot,\n // Ensures that etags are not generated for static files when disabled.\n etag: config.generateEtags,\n })\n } catch (err: any) {\n /**\n * Hardcoded every possible error status code that could be thrown by \"serveStatic\" method\n * This is done by searching \"this.error\" inside \"send\" module's source code:\n * https://github.com/pillarjs/send/blob/master/index.js\n * https://github.com/pillarjs/send/blob/develop/index.js\n */\n const POSSIBLE_ERROR_CODE_FROM_SERVE_STATIC = new Set([\n // send module will throw 500 when header is already sent or fs.stat error happens\n // https://github.com/pillarjs/send/blob/53f0ab476145670a9bdd3dc722ab2fdc8d358fc6/index.js#L392\n // Note: we will use Next.js built-in 500 page to handle 500 errors\n // 500,\n\n // send module will throw 404 when file is missing\n // https://github.com/pillarjs/send/blob/53f0ab476145670a9bdd3dc722ab2fdc8d358fc6/index.js#L421\n // Note: we will use Next.js built-in 404 page to handle 404 errors\n // 404,\n\n // send module will throw 403 when redirecting to a directory without enabling directory listing\n // https://github.com/pillarjs/send/blob/53f0ab476145670a9bdd3dc722ab2fdc8d358fc6/index.js#L484\n // Note: Next.js throws a different error (without status code) for directory listing\n // 403,\n\n // send module will throw 400 when fails to normalize the path\n // https://github.com/pillarjs/send/blob/53f0ab476145670a9bdd3dc722ab2fdc8d358fc6/index.js#L520\n 400,\n\n // send module will throw 412 with conditional GET request\n // https://github.com/pillarjs/send/blob/53f0ab476145670a9bdd3dc722ab2fdc8d358fc6/index.js#L632\n 412,\n\n // send module will throw 416 when range is not satisfiable\n // https://github.com/pillarjs/send/blob/53f0ab476145670a9bdd3dc722ab2fdc8d358fc6/index.js#L669\n 416,\n ])\n\n let validErrorStatus = POSSIBLE_ERROR_CODE_FROM_SERVE_STATIC.has(\n err.statusCode\n )\n\n // normalize non-allowed status codes\n if (!validErrorStatus) {\n ;(err as any).statusCode = 400\n }\n\n if (typeof err.statusCode === 'number') {\n const invokePath = `/${err.statusCode}`\n const invokeStatus = err.statusCode\n res.statusCode = err.statusCode\n return await invokeRender(\n url.parse(invokePath, true),\n invokePath,\n handleIndex,\n {\n invokeStatus,\n }\n )\n }\n throw err\n }\n }\n\n if (matchedOutput) {\n invokedOutputs.add(matchedOutput.itemPath)\n\n return await invokeRender(\n parsedUrl,\n parsedUrl.pathname || '/',\n handleIndex,\n {\n invokeOutput: matchedOutput.itemPath,\n }\n )\n }\n\n // 404 case\n res.setHeader(\n 'Cache-Control',\n 'private, no-cache, no-store, max-age=0, must-revalidate'\n )\n\n // Short-circuit favicon.ico serving so that the 404 page doesn't get built as favicon is requested by the browser when loading any route.\n if (opts.dev && !matchedOutput && parsedUrl.pathname === '/favicon.ico') {\n res.statusCode = 404\n res.end('')\n return null\n }\n\n const appNotFound = opts.dev\n ? developmentBundler?.serverFields.hasAppNotFound\n : await fsChecker.getItem(UNDERSCORE_NOT_FOUND_ROUTE)\n\n res.statusCode = 404\n\n if (appNotFound) {\n return await invokeRender(\n parsedUrl,\n UNDERSCORE_NOT_FOUND_ROUTE,\n handleIndex,\n {\n invokeStatus: 404,\n }\n )\n }\n\n await invokeRender(parsedUrl, '/404', handleIndex, {\n invokeStatus: 404,\n })\n }\n\n try {\n await handleRequest(0)\n } catch (err) {\n try {\n let invokePath = '/500'\n let invokeStatus = '500'\n\n if (err instanceof DecodeError) {\n invokePath = '/400'\n invokeStatus = '400'\n } else {\n console.error(err)\n }\n res.statusCode = Number(invokeStatus)\n return await invokeRender(url.parse(invokePath, true), invokePath, 0, {\n invokeStatus: res.statusCode,\n })\n } catch (err2) {\n console.error(err2)\n }\n res.statusCode = 500\n res.end('Internal Server Error')\n }\n }\n\n let requestHandler: WorkerRequestHandler = requestHandlerImpl\n if (config.experimental.testProxy) {\n // Intercept fetch and other testmode apis.\n const { wrapRequestHandlerWorker, interceptTestApis } =\n require('next/dist/experimental/testmode/server') as typeof import('next/src/experimental/testmode/server')\n requestHandler = wrapRequestHandlerWorker(requestHandler)\n interceptTestApis()\n // We treat the intercepted fetch as \"original\" fetch that should be reset to during HMR.\n originalFetch = globalThis.fetch\n }\n requestHandlers[opts.dir] = requestHandler\n\n const renderServerOpts: Parameters<RenderServer['initialize']>[0] = {\n port: opts.port,\n dir: opts.dir,\n hostname: opts.hostname,\n minimalMode: opts.minimalMode,\n dev: !!opts.dev,\n server: opts.server,\n serverFields: {\n ...(developmentBundler?.serverFields || {}),\n setIsrStatus: devBundlerService?.setIsrStatus.bind(devBundlerService),\n } satisfies ServerFields,\n experimentalTestProxy: !!config.experimental.testProxy,\n experimentalHttpsServer: !!opts.experimentalHttpsServer,\n bundlerService: devBundlerService,\n startServerSpan: opts.startServerSpan,\n quiet: opts.quiet,\n onDevServerCleanup: opts.onDevServerCleanup,\n }\n renderServerOpts.serverFields.routerServerHandler = requestHandlerImpl\n\n // pre-initialize workers\n const handlers = await renderServer.instance.initialize(renderServerOpts)\n\n const logError = async (\n type: 'uncaughtException' | 'unhandledRejection',\n err: Error | undefined\n ) => {\n if (isPostpone(err)) {\n // React postpones that are unhandled might end up logged here but they're\n // not really errors. They're just part of rendering.\n return\n }\n if (type === 'unhandledRejection') {\n Log.error('unhandledRejection: ', err)\n } else if (type === 'uncaughtException') {\n Log.error('uncaughtException: ', err)\n }\n }\n\n process.on('uncaughtException', logError.bind(null, 'uncaughtException'))\n process.on('unhandledRejection', logError.bind(null, 'unhandledRejection'))\n\n const resolveRoutes = getResolveRoutes(\n fsChecker,\n config,\n opts,\n renderServer.instance,\n renderServerOpts,\n developmentBundler?.ensureMiddleware\n )\n\n const upgradeHandler: WorkerUpgradeHandler = async (req, socket, head) => {\n try {\n req.on('error', (_err) => {\n // TODO: log socket errors?\n // console.error(_err);\n })\n socket.on('error', (_err) => {\n // TODO: log socket errors?\n // console.error(_err);\n })\n\n if (opts.dev && developmentBundler && req.url) {\n if (blockCrossSite(req, socket, allowedOrigins, `${opts.port}`)) {\n return\n }\n const { basePath, assetPrefix } = config\n\n let hmrPrefix = basePath\n\n // assetPrefix overrides basePath for HMR path\n if (assetPrefix) {\n hmrPrefix = normalizedAssetPrefix(assetPrefix)\n\n if (URL.canParse(hmrPrefix)) {\n // remove trailing slash from pathname\n // return empty string if pathname is '/'\n // to avoid conflicts with '/_next' below\n hmrPrefix = new URL(hmrPrefix).pathname.replace(/\\/$/, '')\n }\n }\n\n const isHMRRequest = req.url.startsWith(\n ensureLeadingSlash(`${hmrPrefix}/_next/webpack-hmr`)\n )\n\n // only handle HMR requests if the basePath in the request\n // matches the basePath for the handler responding to the request\n if (isHMRRequest) {\n return developmentBundler.hotReloader.onHMR(\n req,\n socket,\n head,\n (client) => {\n client.send(\n JSON.stringify({\n action: HMR_ACTIONS_SENT_TO_BROWSER.ISR_MANIFEST,\n data: devBundlerService?.appIsrManifest || {},\n } satisfies AppIsrManifestAction)\n )\n }\n )\n }\n }\n\n const res = new MockedResponse({\n resWriter: () => {\n throw new Error(\n 'Invariant: did not expect response writer to be written to for upgrade request'\n )\n },\n })\n const { matchedOutput, parsedUrl } = await resolveRoutes({\n req,\n res,\n isUpgradeReq: true,\n signal: signalFromNodeResponse(socket),\n })\n\n // TODO: allow upgrade requests to pages/app paths?\n // this was not previously supported\n if (matchedOutput) {\n return socket.end()\n }\n\n if (parsedUrl.protocol) {\n return await proxyRequest(req, socket, parsedUrl, head)\n }\n\n // If there's no matched output, we don't handle the request as user's\n // custom WS server may be listening on the same path.\n } catch (err) {\n console.error('Error handling upgrade request', err)\n socket.end()\n }\n }\n\n return {\n requestHandler,\n upgradeHandler,\n server: handlers.server,\n closeUpgraded() {\n developmentBundler?.hotReloader?.close()\n },\n }\n}\n"],"names":["initialize","debug","setupDebug","isNextFont","pathname","test","requestHandlers","opts","process","env","NODE_ENV","dev","config","loadConfig","PHASE_DEVELOPMENT_SERVER","PHASE_PRODUCTION_SERVER","dir","silent","compress","setupCompression","fsChecker","setupFsCheck","minimalMode","renderServer","developmentBundler","devBundlerService","originalFetch","globalThis","fetch","Telemetry","require","telemetry","distDir","path","join","pagesDir","appDir","findPagesDir","setupDevBundler","resetFetch","NEXT_PATCH_SYMBOL","setupDevBundlerSpan","startServerSpan","traceChild","trace","traceAsyncFn","nextConfig","isCustomServer","customServer","turbo","TURBOPACK","port","onDevServerCleanup","DevBundlerService","req","res","instance","allowedOrigins","experimental","allowedDevOrigins","hostname","push","requestHandlerImpl","NEXT_PRIVATE_TEST_HEADERS","filterInternalHeaders","headers","i18n","localeDetection","urlParts","url","split","urlNoQuery","basePath","removePathPrefix","pathnameInfo","getNextPathnameInfo","domainLocale","detectDomainLocale","domains","getHostname","defaultLocale","getLocaleRedirect","parsedUrl","parseUrlUtil","replace","redirect","pathLocale","locale","urlParsed","setHeader","statusCode","RedirectStatusCode","TemporaryRedirect","end","on","_err","invokedOutputs","Set","invokeRender","invokePath","handleIndex","additionalRequestMeta","startsWith","getRequestMeta","handleLocale","getMiddlewareMatchers","length","handlers","Error","addRequestMeta","query","key","initResult","renderServerOpts","requestHandler","err","NoFallbackError","handleRequest","e","isAbortError","blockCrossSite","origUrl","pathHasPrefix","parse","hotReloaderResult","hotReloader","run","finished","resHeaders","bodyStream","matchedOutput","resolveRoutes","isUpgradeReq","signal","signalFromNodeResponse","closed","type","Object","keys","result","destination","format","PermanentRedirect","pipeToNodeResponse","protocol","proxyRequest","undefined","cloneBodyStream","proxyTimeout","fsPath","itemPath","appFiles","has","pageFiles","message","invokeStatus","invokeError","Log","error","getHeader","method","serveStatic","root","itemsRoot","etag","generateEtags","POSSIBLE_ERROR_CODE_FROM_SERVE_STATIC","validErrorStatus","add","invokeOutput","appNotFound","serverFields","hasAppNotFound","getItem","UNDERSCORE_NOT_FOUND_ROUTE","DecodeError","console","Number","err2","testProxy","wrapRequestHandlerWorker","interceptTestApis","server","setIsrStatus","bind","experimentalTestProxy","experimentalHttpsServer","bundlerService","quiet","routerServerHandler","logError","isPostpone","getResolveRoutes","ensureMiddleware","upgradeHandler","socket","head","assetPrefix","hmrPrefix","normalizedAssetPrefix","URL","canParse","isHMRRequest","ensureLeadingSlash","onHMR","client","send","JSON","stringify","action","HMR_ACTIONS_SENT_TO_BROWSER","ISR_MANIFEST","data","appIsrManifest","MockedResponse","resWriter","closeUpgraded","close"],"mappings":"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"}
|
1
|
+
{"version":3,"sources":["../../../src/server/lib/router-server.ts"],"sourcesContent":["// this must come first as it includes require hooks\nimport type { WorkerRequestHandler, WorkerUpgradeHandler } from './types'\nimport type { DevBundler, ServerFields } from './router-utils/setup-dev-bundler'\nimport type { NextUrlWithParsedQuery, RequestMeta } from '../request-meta'\n\n// This is required before other imports to ensure the require hook is setup.\nimport '../node-environment'\nimport '../require-hook'\n\nimport url from 'url'\nimport path from 'path'\nimport loadConfig from '../config'\nimport { serveStatic } from '../serve-static'\nimport setupDebug from 'next/dist/compiled/debug'\nimport * as Log from '../../build/output/log'\nimport { DecodeError } from '../../shared/lib/utils'\nimport { findPagesDir } from '../../lib/find-pages-dir'\nimport { setupFsCheck } from './router-utils/filesystem'\nimport { proxyRequest } from './router-utils/proxy-request'\nimport { isAbortError, pipeToNodeResponse } from '../pipe-readable'\nimport { getResolveRoutes } from './router-utils/resolve-routes'\nimport { addRequestMeta, getRequestMeta } from '../request-meta'\nimport { pathHasPrefix } from '../../shared/lib/router/utils/path-has-prefix'\nimport { removePathPrefix } from '../../shared/lib/router/utils/remove-path-prefix'\nimport setupCompression from 'next/dist/compiled/compression'\nimport { NoFallbackError } from '../base-server'\nimport { signalFromNodeResponse } from '../web/spec-extension/adapters/next-request'\nimport { isPostpone } from './router-utils/is-postpone'\nimport { parseUrl as parseUrlUtil } from '../../shared/lib/router/utils/parse-url'\n\nimport {\n PHASE_PRODUCTION_SERVER,\n PHASE_DEVELOPMENT_SERVER,\n UNDERSCORE_NOT_FOUND_ROUTE,\n} from '../../shared/lib/constants'\nimport { RedirectStatusCode } from '../../client/components/redirect-status-code'\nimport { DevBundlerService } from './dev-bundler-service'\nimport { type Span, trace } from '../../trace'\nimport { ensureLeadingSlash } from '../../shared/lib/page-path/ensure-leading-slash'\nimport { getNextPathnameInfo } from '../../shared/lib/router/utils/get-next-pathname-info'\nimport { getHostname } from '../../shared/lib/get-hostname'\nimport { detectDomainLocale } from '../../shared/lib/i18n/detect-domain-locale'\nimport { MockedResponse } from './mock-request'\nimport {\n HMR_ACTIONS_SENT_TO_BROWSER,\n type AppIsrManifestAction,\n} from '../dev/hot-reloader-types'\nimport { normalizedAssetPrefix } from '../../shared/lib/normalized-asset-prefix'\nimport { NEXT_PATCH_SYMBOL } from './patch-fetch'\nimport type { ServerInitResult } from './render-server'\nimport { filterInternalHeaders } from './server-ipc/utils'\nimport { blockCrossSite } from './router-utils/block-cross-site'\n\nconst debug = setupDebug('next:router-server:main')\nconst isNextFont = (pathname: string | null) =>\n pathname && /\\/media\\/[^/]+\\.(woff|woff2|eot|ttf|otf)$/.test(pathname)\n\nexport type RenderServer = Pick<\n typeof import('./render-server'),\n | 'initialize'\n | 'clearModuleContext'\n | 'propagateServerField'\n | 'getServerField'\n>\n\nexport interface LazyRenderServerInstance {\n instance?: RenderServer\n}\n\nconst requestHandlers: Record<string, WorkerRequestHandler> = {}\n\nexport async function initialize(opts: {\n dir: string\n port: number\n dev: boolean\n onDevServerCleanup: ((listener: () => Promise<void>) => void) | undefined\n server?: import('http').Server\n minimalMode?: boolean\n hostname?: string\n keepAliveTimeout?: number\n customServer?: boolean\n experimentalHttpsServer?: boolean\n startServerSpan?: Span\n quiet?: boolean\n}): Promise<ServerInitResult> {\n if (!process.env.NODE_ENV) {\n // @ts-ignore not readonly\n process.env.NODE_ENV = opts.dev ? 'development' : 'production'\n }\n\n const config = await loadConfig(\n opts.dev ? PHASE_DEVELOPMENT_SERVER : PHASE_PRODUCTION_SERVER,\n opts.dir,\n { silent: false }\n )\n\n let compress: ReturnType<typeof setupCompression> | undefined\n\n if (config?.compress !== false) {\n compress = setupCompression()\n }\n\n const fsChecker = await setupFsCheck({\n dev: opts.dev,\n dir: opts.dir,\n config,\n minimalMode: opts.minimalMode,\n })\n\n const renderServer: LazyRenderServerInstance = {}\n\n let developmentBundler: DevBundler | undefined\n\n let devBundlerService: DevBundlerService | undefined\n\n let originalFetch = globalThis.fetch\n\n if (opts.dev) {\n const { Telemetry } =\n require('../../telemetry/storage') as typeof import('../../telemetry/storage')\n\n const telemetry = new Telemetry({\n distDir: path.join(opts.dir, config.distDir),\n })\n const { pagesDir, appDir } = findPagesDir(opts.dir)\n\n const { setupDevBundler } =\n require('./router-utils/setup-dev-bundler') as typeof import('./router-utils/setup-dev-bundler')\n\n const resetFetch = () => {\n globalThis.fetch = originalFetch\n ;(globalThis as Record<symbol, unknown>)[NEXT_PATCH_SYMBOL] = false\n }\n\n const setupDevBundlerSpan = opts.startServerSpan\n ? opts.startServerSpan.traceChild('setup-dev-bundler')\n : trace('setup-dev-bundler')\n developmentBundler = await setupDevBundlerSpan.traceAsyncFn(() =>\n setupDevBundler({\n // Passed here but the initialization of this object happens below, doing the initialization before the setupDev call breaks.\n renderServer,\n appDir,\n pagesDir,\n telemetry,\n fsChecker,\n dir: opts.dir,\n nextConfig: config,\n isCustomServer: opts.customServer,\n turbo: !!process.env.TURBOPACK,\n port: opts.port,\n onDevServerCleanup: opts.onDevServerCleanup,\n resetFetch,\n })\n )\n\n devBundlerService = new DevBundlerService(\n developmentBundler,\n // The request handler is assigned below, this allows us to create a lazy\n // reference to it.\n (req, res) => {\n return requestHandlers[opts.dir](req, res)\n }\n )\n }\n\n renderServer.instance =\n require('./render-server') as typeof import('./render-server')\n\n const allowedOrigins = ['localhost', ...(config.allowedDevOrigins || [])]\n if (opts.hostname) {\n allowedOrigins.push(opts.hostname)\n }\n\n const requestHandlerImpl: WorkerRequestHandler = async (req, res) => {\n // internal headers should not be honored by the request handler\n if (!process.env.NEXT_PRIVATE_TEST_HEADERS) {\n filterInternalHeaders(req.headers)\n }\n\n if (\n !opts.minimalMode &&\n config.i18n &&\n config.i18n.localeDetection !== false\n ) {\n const urlParts = (req.url || '').split('?', 1)\n let urlNoQuery = urlParts[0] || ''\n\n if (config.basePath) {\n urlNoQuery = removePathPrefix(urlNoQuery, config.basePath)\n }\n\n const pathnameInfo = getNextPathnameInfo(urlNoQuery, {\n nextConfig: config,\n })\n\n const domainLocale = detectDomainLocale(\n config.i18n.domains,\n getHostname({ hostname: urlNoQuery }, req.headers)\n )\n\n const defaultLocale =\n domainLocale?.defaultLocale || config.i18n.defaultLocale\n\n const { getLocaleRedirect } =\n require('../../shared/lib/i18n/get-locale-redirect') as typeof import('../../shared/lib/i18n/get-locale-redirect')\n\n const parsedUrl = parseUrlUtil((req.url || '')?.replace(/^\\/+/, '/'))\n\n const redirect = getLocaleRedirect({\n defaultLocale,\n domainLocale,\n headers: req.headers,\n nextConfig: config,\n pathLocale: pathnameInfo.locale,\n urlParsed: {\n ...parsedUrl,\n pathname: pathnameInfo.locale\n ? `/${pathnameInfo.locale}${urlNoQuery}`\n : urlNoQuery,\n },\n })\n\n if (redirect) {\n res.setHeader('Location', redirect)\n res.statusCode = RedirectStatusCode.TemporaryRedirect\n res.end(redirect)\n return\n }\n }\n\n if (compress) {\n // @ts-expect-error not express req/res\n compress(req, res, () => {})\n }\n req.on('error', (_err) => {\n // TODO: log socket errors?\n })\n res.on('error', (_err) => {\n // TODO: log socket errors?\n })\n\n const invokedOutputs = new Set<string>()\n\n async function invokeRender(\n parsedUrl: NextUrlWithParsedQuery,\n invokePath: string,\n handleIndex: number,\n additionalRequestMeta?: RequestMeta\n ) {\n // invokeRender expects /api routes to not be locale prefixed\n // so normalize here before continuing\n if (\n config.i18n &&\n removePathPrefix(invokePath, config.basePath).startsWith(\n `/${getRequestMeta(req, 'locale')}/api`\n )\n ) {\n invokePath = fsChecker.handleLocale(\n removePathPrefix(invokePath, config.basePath)\n ).pathname\n }\n\n if (\n req.headers['x-nextjs-data'] &&\n fsChecker.getMiddlewareMatchers()?.length &&\n removePathPrefix(invokePath, config.basePath) === '/404'\n ) {\n res.setHeader('x-nextjs-matched-path', parsedUrl.pathname || '')\n res.statusCode = 404\n res.setHeader('content-type', 'application/json')\n res.end('{}')\n return null\n }\n\n if (!handlers) {\n throw new Error('Failed to initialize render server')\n }\n\n addRequestMeta(req, 'invokePath', invokePath)\n addRequestMeta(req, 'invokeQuery', parsedUrl.query)\n addRequestMeta(req, 'middlewareInvoke', false)\n\n for (const key in additionalRequestMeta || {}) {\n addRequestMeta(\n req,\n key as keyof RequestMeta,\n additionalRequestMeta![key as keyof RequestMeta]\n )\n }\n\n debug('invokeRender', req.url, req.headers)\n\n try {\n const initResult =\n await renderServer?.instance?.initialize(renderServerOpts)\n try {\n await initResult?.requestHandler(req, res)\n } catch (err) {\n if (err instanceof NoFallbackError) {\n // eslint-disable-next-line\n await handleRequest(handleIndex + 1)\n return\n }\n throw err\n }\n return\n } catch (e) {\n // If the client aborts before we can receive a response object (when\n // the headers are flushed), then we can early exit without further\n // processing.\n if (isAbortError(e)) {\n return\n }\n throw e\n }\n }\n\n const handleRequest = async (handleIndex: number) => {\n if (handleIndex > 5) {\n throw new Error(`Attempted to handle request too many times ${req.url}`)\n }\n\n // handle hot-reloader first\n if (developmentBundler) {\n if (blockCrossSite(req, res, allowedOrigins, `${opts.port}`)) {\n return\n }\n const origUrl = req.url || '/'\n\n if (config.basePath && pathHasPrefix(origUrl, config.basePath)) {\n req.url = removePathPrefix(origUrl, config.basePath)\n }\n const parsedUrl = url.parse(req.url || '/')\n\n const hotReloaderResult = await developmentBundler.hotReloader.run(\n req,\n res,\n parsedUrl\n )\n\n if (hotReloaderResult.finished) {\n return hotReloaderResult\n }\n req.url = origUrl\n }\n\n const {\n finished,\n parsedUrl,\n statusCode,\n resHeaders,\n bodyStream,\n matchedOutput,\n } = await resolveRoutes({\n req,\n res,\n isUpgradeReq: false,\n signal: signalFromNodeResponse(res),\n invokedOutputs,\n })\n\n if (res.closed || res.finished) {\n return\n }\n\n if (developmentBundler && matchedOutput?.type === 'devVirtualFsItem') {\n const origUrl = req.url || '/'\n\n if (config.basePath && pathHasPrefix(origUrl, config.basePath)) {\n req.url = removePathPrefix(origUrl, config.basePath)\n }\n\n if (resHeaders) {\n for (const key of Object.keys(resHeaders)) {\n res.setHeader(key, resHeaders[key])\n }\n }\n const result = await developmentBundler.requestHandler(req, res)\n\n if (result.finished) {\n return\n }\n // TODO: throw invariant if we resolved to this but it wasn't handled?\n req.url = origUrl\n }\n\n debug('requestHandler!', req.url, {\n matchedOutput,\n statusCode,\n resHeaders,\n bodyStream: !!bodyStream,\n parsedUrl: {\n pathname: parsedUrl.pathname,\n query: parsedUrl.query,\n },\n finished,\n })\n\n // apply any response headers from routing\n for (const key of Object.keys(resHeaders || {})) {\n res.setHeader(key, resHeaders[key])\n }\n\n // handle redirect\n if (!bodyStream && statusCode && statusCode > 300 && statusCode < 400) {\n const destination = url.format(parsedUrl)\n res.statusCode = statusCode\n res.setHeader('location', destination)\n\n if (statusCode === RedirectStatusCode.PermanentRedirect) {\n res.setHeader('Refresh', `0;url=${destination}`)\n }\n return res.end(destination)\n }\n\n // handle middleware body response\n if (bodyStream) {\n res.statusCode = statusCode || 200\n return await pipeToNodeResponse(bodyStream, res)\n }\n\n if (finished && parsedUrl.protocol) {\n return await proxyRequest(\n req,\n res,\n parsedUrl,\n undefined,\n getRequestMeta(req, 'clonableBody')?.cloneBodyStream(),\n config.experimental.proxyTimeout\n )\n }\n\n if (matchedOutput?.fsPath && matchedOutput.itemPath) {\n if (\n opts.dev &&\n (fsChecker.appFiles.has(matchedOutput.itemPath) ||\n fsChecker.pageFiles.has(matchedOutput.itemPath))\n ) {\n res.statusCode = 500\n const message = `A conflicting public file and page file was found for path ${matchedOutput.itemPath} https://nextjs.org/docs/messages/conflicting-public-file-page`\n await invokeRender(parsedUrl, '/_error', handleIndex, {\n invokeStatus: 500,\n invokeError: new Error(message),\n })\n Log.error(message)\n return\n }\n\n if (\n !res.getHeader('cache-control') &&\n matchedOutput.type === 'nextStaticFolder'\n ) {\n if (opts.dev && !isNextFont(parsedUrl.pathname)) {\n res.setHeader('Cache-Control', 'no-store, must-revalidate')\n } else {\n res.setHeader(\n 'Cache-Control',\n 'public, max-age=31536000, immutable'\n )\n }\n }\n if (!(req.method === 'GET' || req.method === 'HEAD')) {\n res.setHeader('Allow', ['GET', 'HEAD'])\n res.statusCode = 405\n return await invokeRender(\n url.parse('/405', true),\n '/405',\n handleIndex,\n {\n invokeStatus: 405,\n }\n )\n }\n\n try {\n return await serveStatic(req, res, matchedOutput.itemPath, {\n root: matchedOutput.itemsRoot,\n // Ensures that etags are not generated for static files when disabled.\n etag: config.generateEtags,\n })\n } catch (err: any) {\n /**\n * Hardcoded every possible error status code that could be thrown by \"serveStatic\" method\n * This is done by searching \"this.error\" inside \"send\" module's source code:\n * https://github.com/pillarjs/send/blob/master/index.js\n * https://github.com/pillarjs/send/blob/develop/index.js\n */\n const POSSIBLE_ERROR_CODE_FROM_SERVE_STATIC = new Set([\n // send module will throw 500 when header is already sent or fs.stat error happens\n // https://github.com/pillarjs/send/blob/53f0ab476145670a9bdd3dc722ab2fdc8d358fc6/index.js#L392\n // Note: we will use Next.js built-in 500 page to handle 500 errors\n // 500,\n\n // send module will throw 404 when file is missing\n // https://github.com/pillarjs/send/blob/53f0ab476145670a9bdd3dc722ab2fdc8d358fc6/index.js#L421\n // Note: we will use Next.js built-in 404 page to handle 404 errors\n // 404,\n\n // send module will throw 403 when redirecting to a directory without enabling directory listing\n // https://github.com/pillarjs/send/blob/53f0ab476145670a9bdd3dc722ab2fdc8d358fc6/index.js#L484\n // Note: Next.js throws a different error (without status code) for directory listing\n // 403,\n\n // send module will throw 400 when fails to normalize the path\n // https://github.com/pillarjs/send/blob/53f0ab476145670a9bdd3dc722ab2fdc8d358fc6/index.js#L520\n 400,\n\n // send module will throw 412 with conditional GET request\n // https://github.com/pillarjs/send/blob/53f0ab476145670a9bdd3dc722ab2fdc8d358fc6/index.js#L632\n 412,\n\n // send module will throw 416 when range is not satisfiable\n // https://github.com/pillarjs/send/blob/53f0ab476145670a9bdd3dc722ab2fdc8d358fc6/index.js#L669\n 416,\n ])\n\n let validErrorStatus = POSSIBLE_ERROR_CODE_FROM_SERVE_STATIC.has(\n err.statusCode\n )\n\n // normalize non-allowed status codes\n if (!validErrorStatus) {\n ;(err as any).statusCode = 400\n }\n\n if (typeof err.statusCode === 'number') {\n const invokePath = `/${err.statusCode}`\n const invokeStatus = err.statusCode\n res.statusCode = err.statusCode\n return await invokeRender(\n url.parse(invokePath, true),\n invokePath,\n handleIndex,\n {\n invokeStatus,\n }\n )\n }\n throw err\n }\n }\n\n if (matchedOutput) {\n invokedOutputs.add(matchedOutput.itemPath)\n\n return await invokeRender(\n parsedUrl,\n parsedUrl.pathname || '/',\n handleIndex,\n {\n invokeOutput: matchedOutput.itemPath,\n }\n )\n }\n\n // 404 case\n res.setHeader(\n 'Cache-Control',\n 'private, no-cache, no-store, max-age=0, must-revalidate'\n )\n\n // Short-circuit favicon.ico serving so that the 404 page doesn't get built as favicon is requested by the browser when loading any route.\n if (opts.dev && !matchedOutput && parsedUrl.pathname === '/favicon.ico') {\n res.statusCode = 404\n res.end('')\n return null\n }\n\n const appNotFound = opts.dev\n ? developmentBundler?.serverFields.hasAppNotFound\n : await fsChecker.getItem(UNDERSCORE_NOT_FOUND_ROUTE)\n\n res.statusCode = 404\n\n if (appNotFound) {\n return await invokeRender(\n parsedUrl,\n UNDERSCORE_NOT_FOUND_ROUTE,\n handleIndex,\n {\n invokeStatus: 404,\n }\n )\n }\n\n await invokeRender(parsedUrl, '/404', handleIndex, {\n invokeStatus: 404,\n })\n }\n\n try {\n await handleRequest(0)\n } catch (err) {\n try {\n let invokePath = '/500'\n let invokeStatus = '500'\n\n if (err instanceof DecodeError) {\n invokePath = '/400'\n invokeStatus = '400'\n } else {\n console.error(err)\n }\n res.statusCode = Number(invokeStatus)\n return await invokeRender(url.parse(invokePath, true), invokePath, 0, {\n invokeStatus: res.statusCode,\n })\n } catch (err2) {\n console.error(err2)\n }\n res.statusCode = 500\n res.end('Internal Server Error')\n }\n }\n\n let requestHandler: WorkerRequestHandler = requestHandlerImpl\n if (config.experimental.testProxy) {\n // Intercept fetch and other testmode apis.\n const { wrapRequestHandlerWorker, interceptTestApis } =\n require('next/dist/experimental/testmode/server') as typeof import('next/src/experimental/testmode/server')\n requestHandler = wrapRequestHandlerWorker(requestHandler)\n interceptTestApis()\n // We treat the intercepted fetch as \"original\" fetch that should be reset to during HMR.\n originalFetch = globalThis.fetch\n }\n requestHandlers[opts.dir] = requestHandler\n\n const renderServerOpts: Parameters<RenderServer['initialize']>[0] = {\n port: opts.port,\n dir: opts.dir,\n hostname: opts.hostname,\n minimalMode: opts.minimalMode,\n dev: !!opts.dev,\n server: opts.server,\n serverFields: {\n ...(developmentBundler?.serverFields || {}),\n setIsrStatus: devBundlerService?.setIsrStatus.bind(devBundlerService),\n } satisfies ServerFields,\n experimentalTestProxy: !!config.experimental.testProxy,\n experimentalHttpsServer: !!opts.experimentalHttpsServer,\n bundlerService: devBundlerService,\n startServerSpan: opts.startServerSpan,\n quiet: opts.quiet,\n onDevServerCleanup: opts.onDevServerCleanup,\n }\n renderServerOpts.serverFields.routerServerHandler = requestHandlerImpl\n\n // pre-initialize workers\n const handlers = await renderServer.instance.initialize(renderServerOpts)\n\n const logError = async (\n type: 'uncaughtException' | 'unhandledRejection',\n err: Error | undefined\n ) => {\n if (isPostpone(err)) {\n // React postpones that are unhandled might end up logged here but they're\n // not really errors. They're just part of rendering.\n return\n }\n if (type === 'unhandledRejection') {\n Log.error('unhandledRejection: ', err)\n } else if (type === 'uncaughtException') {\n Log.error('uncaughtException: ', err)\n }\n }\n\n process.on('uncaughtException', logError.bind(null, 'uncaughtException'))\n process.on('unhandledRejection', logError.bind(null, 'unhandledRejection'))\n\n const resolveRoutes = getResolveRoutes(\n fsChecker,\n config,\n opts,\n renderServer.instance,\n renderServerOpts,\n developmentBundler?.ensureMiddleware\n )\n\n const upgradeHandler: WorkerUpgradeHandler = async (req, socket, head) => {\n try {\n req.on('error', (_err) => {\n // TODO: log socket errors?\n // console.error(_err);\n })\n socket.on('error', (_err) => {\n // TODO: log socket errors?\n // console.error(_err);\n })\n\n if (opts.dev && developmentBundler && req.url) {\n if (blockCrossSite(req, socket, allowedOrigins, `${opts.port}`)) {\n return\n }\n const { basePath, assetPrefix } = config\n\n let hmrPrefix = basePath\n\n // assetPrefix overrides basePath for HMR path\n if (assetPrefix) {\n hmrPrefix = normalizedAssetPrefix(assetPrefix)\n\n if (URL.canParse(hmrPrefix)) {\n // remove trailing slash from pathname\n // return empty string if pathname is '/'\n // to avoid conflicts with '/_next' below\n hmrPrefix = new URL(hmrPrefix).pathname.replace(/\\/$/, '')\n }\n }\n\n const isHMRRequest = req.url.startsWith(\n ensureLeadingSlash(`${hmrPrefix}/_next/webpack-hmr`)\n )\n\n // only handle HMR requests if the basePath in the request\n // matches the basePath for the handler responding to the request\n if (isHMRRequest) {\n return developmentBundler.hotReloader.onHMR(\n req,\n socket,\n head,\n (client) => {\n client.send(\n JSON.stringify({\n action: HMR_ACTIONS_SENT_TO_BROWSER.ISR_MANIFEST,\n data: devBundlerService?.appIsrManifest || {},\n } satisfies AppIsrManifestAction)\n )\n }\n )\n }\n }\n\n const res = new MockedResponse({\n resWriter: () => {\n throw new Error(\n 'Invariant: did not expect response writer to be written to for upgrade request'\n )\n },\n })\n const { matchedOutput, parsedUrl } = await resolveRoutes({\n req,\n res,\n isUpgradeReq: true,\n signal: signalFromNodeResponse(socket),\n })\n\n // TODO: allow upgrade requests to pages/app paths?\n // this was not previously supported\n if (matchedOutput) {\n return socket.end()\n }\n\n if (parsedUrl.protocol) {\n return await proxyRequest(req, socket, parsedUrl, head)\n }\n\n // If there's no matched output, we don't handle the request as user's\n // custom WS server may be listening on the same path.\n } catch (err) {\n console.error('Error handling upgrade request', err)\n socket.end()\n }\n }\n\n return {\n requestHandler,\n upgradeHandler,\n server: handlers.server,\n closeUpgraded() {\n developmentBundler?.hotReloader?.close()\n },\n }\n}\n"],"names":["initialize","debug","setupDebug","isNextFont","pathname","test","requestHandlers","opts","process","env","NODE_ENV","dev","config","loadConfig","PHASE_DEVELOPMENT_SERVER","PHASE_PRODUCTION_SERVER","dir","silent","compress","setupCompression","fsChecker","setupFsCheck","minimalMode","renderServer","developmentBundler","devBundlerService","originalFetch","globalThis","fetch","Telemetry","require","telemetry","distDir","path","join","pagesDir","appDir","findPagesDir","setupDevBundler","resetFetch","NEXT_PATCH_SYMBOL","setupDevBundlerSpan","startServerSpan","traceChild","trace","traceAsyncFn","nextConfig","isCustomServer","customServer","turbo","TURBOPACK","port","onDevServerCleanup","DevBundlerService","req","res","instance","allowedOrigins","allowedDevOrigins","hostname","push","requestHandlerImpl","NEXT_PRIVATE_TEST_HEADERS","filterInternalHeaders","headers","i18n","localeDetection","urlParts","url","split","urlNoQuery","basePath","removePathPrefix","pathnameInfo","getNextPathnameInfo","domainLocale","detectDomainLocale","domains","getHostname","defaultLocale","getLocaleRedirect","parsedUrl","parseUrlUtil","replace","redirect","pathLocale","locale","urlParsed","setHeader","statusCode","RedirectStatusCode","TemporaryRedirect","end","on","_err","invokedOutputs","Set","invokeRender","invokePath","handleIndex","additionalRequestMeta","startsWith","getRequestMeta","handleLocale","getMiddlewareMatchers","length","handlers","Error","addRequestMeta","query","key","initResult","renderServerOpts","requestHandler","err","NoFallbackError","handleRequest","e","isAbortError","blockCrossSite","origUrl","pathHasPrefix","parse","hotReloaderResult","hotReloader","run","finished","resHeaders","bodyStream","matchedOutput","resolveRoutes","isUpgradeReq","signal","signalFromNodeResponse","closed","type","Object","keys","result","destination","format","PermanentRedirect","pipeToNodeResponse","protocol","proxyRequest","undefined","cloneBodyStream","experimental","proxyTimeout","fsPath","itemPath","appFiles","has","pageFiles","message","invokeStatus","invokeError","Log","error","getHeader","method","serveStatic","root","itemsRoot","etag","generateEtags","POSSIBLE_ERROR_CODE_FROM_SERVE_STATIC","validErrorStatus","add","invokeOutput","appNotFound","serverFields","hasAppNotFound","getItem","UNDERSCORE_NOT_FOUND_ROUTE","DecodeError","console","Number","err2","testProxy","wrapRequestHandlerWorker","interceptTestApis","server","setIsrStatus","bind","experimentalTestProxy","experimentalHttpsServer","bundlerService","quiet","routerServerHandler","logError","isPostpone","getResolveRoutes","ensureMiddleware","upgradeHandler","socket","head","assetPrefix","hmrPrefix","normalizedAssetPrefix","URL","canParse","isHMRRequest","ensureLeadingSlash","onHMR","client","send","JSON","stringify","action","HMR_ACTIONS_SENT_TO_BROWSER","ISR_MANIFEST","data","appIsrManifest","MockedResponse","resWriter","closeUpgraded","close"],"mappings":"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"}
|
@@ -10,6 +10,8 @@ Object.defineProperty(exports, "blockCrossSite", {
|
|
10
10
|
});
|
11
11
|
const _url = require("../../../lib/url");
|
12
12
|
const _net = /*#__PURE__*/ _interop_require_default(require("net"));
|
13
|
+
const _log = require("../../../build/output/log");
|
14
|
+
const _csrfprotection = require("../../app-render/csrf-protection");
|
13
15
|
function _interop_require_default(obj) {
|
14
16
|
return obj && obj.__esModule ? obj : {
|
15
17
|
default: obj
|
@@ -28,6 +30,7 @@ const blockCrossSite = (req, res, allowedOrigins, activePort)=>{
|
|
28
30
|
res.statusCode = 403;
|
29
31
|
}
|
30
32
|
res.end('Unauthorized');
|
33
|
+
(0, _log.warnOnce)(`Blocked cross-origin request to /_next/*. Cross-site requests are blocked in "no-cors" mode.`);
|
31
34
|
return true;
|
32
35
|
}
|
33
36
|
// ensure websocket requests from allowed origin
|
@@ -40,11 +43,12 @@ const blockCrossSite = (req, res, allowedOrigins, activePort)=>{
|
|
40
43
|
const isIpRequest = _net.default.isIPv4(originLowerCase) || _net.default.isIPv6(originLowerCase);
|
41
44
|
if (// allow requests if direct IP and matching port and
|
42
45
|
// allow if any of the allowed origins match
|
43
|
-
!(isIpRequest && isMatchingPort) && !
|
46
|
+
!(isIpRequest && isMatchingPort) && !(0, _csrfprotection.isCsrfOriginAllowed)(originLowerCase, allowedOrigins)) {
|
44
47
|
if ('statusCode' in res) {
|
45
48
|
res.statusCode = 403;
|
46
49
|
}
|
47
50
|
res.end('Unauthorized');
|
51
|
+
(0, _log.warnOnce)(`Blocked cross-origin request from ${originLowerCase}. To allow this, configure "allowedDevOrigins" in next.config\nRead more: https://nextjs.org/docs/app/api-reference/config/next-config-js/allowedDevOrigins`);
|
48
52
|
return true;
|
49
53
|
}
|
50
54
|
}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../../../src/server/lib/router-utils/block-cross-site.ts"],"sourcesContent":["import type { Duplex } from 'stream'\nimport type { IncomingMessage, ServerResponse } from 'webpack-dev-server'\nimport { parseUrl } from '../../../lib/url'\nimport net from 'net'\n\nexport const blockCrossSite = (\n req: IncomingMessage,\n res: ServerResponse | Duplex,\n allowedOrigins: string[],\n activePort: string\n): boolean => {\n // only process _next URLs\n if (!req.url?.includes('/_next')) {\n return false\n }\n // block non-cors request from cross-site e.g. script tag on\n // different host\n if (\n req.headers['sec-fetch-mode'] === 'no-cors' &&\n req.headers['sec-fetch-site'] === 'cross-site'\n ) {\n if ('statusCode' in res) {\n res.statusCode = 403\n }\n res.end('Unauthorized')\n return true\n }\n\n // ensure websocket requests from allowed origin\n const rawOrigin = req.headers['origin']\n\n if (rawOrigin) {\n const parsedOrigin = parseUrl(rawOrigin)\n\n if (parsedOrigin) {\n const originLowerCase = parsedOrigin.hostname.toLowerCase()\n const isMatchingPort = parsedOrigin.port === activePort\n const isIpRequest =\n net.isIPv4(originLowerCase) || net.isIPv6(originLowerCase)\n\n if (\n // allow requests if direct IP and matching port and\n // allow if any of the allowed origins match\n !(isIpRequest && isMatchingPort) &&\n !
|
1
|
+
{"version":3,"sources":["../../../../src/server/lib/router-utils/block-cross-site.ts"],"sourcesContent":["import type { Duplex } from 'stream'\nimport type { IncomingMessage, ServerResponse } from 'webpack-dev-server'\nimport { parseUrl } from '../../../lib/url'\nimport net from 'net'\nimport { warnOnce } from '../../../build/output/log'\nimport { isCsrfOriginAllowed } from '../../app-render/csrf-protection'\n\nexport const blockCrossSite = (\n req: IncomingMessage,\n res: ServerResponse | Duplex,\n allowedOrigins: string[],\n activePort: string\n): boolean => {\n // only process _next URLs\n if (!req.url?.includes('/_next')) {\n return false\n }\n // block non-cors request from cross-site e.g. script tag on\n // different host\n if (\n req.headers['sec-fetch-mode'] === 'no-cors' &&\n req.headers['sec-fetch-site'] === 'cross-site'\n ) {\n if ('statusCode' in res) {\n res.statusCode = 403\n }\n res.end('Unauthorized')\n warnOnce(\n `Blocked cross-origin request to /_next/*. Cross-site requests are blocked in \"no-cors\" mode.`\n )\n return true\n }\n\n // ensure websocket requests from allowed origin\n const rawOrigin = req.headers['origin']\n\n if (rawOrigin) {\n const parsedOrigin = parseUrl(rawOrigin)\n\n if (parsedOrigin) {\n const originLowerCase = parsedOrigin.hostname.toLowerCase()\n const isMatchingPort = parsedOrigin.port === activePort\n const isIpRequest =\n net.isIPv4(originLowerCase) || net.isIPv6(originLowerCase)\n\n if (\n // allow requests if direct IP and matching port and\n // allow if any of the allowed origins match\n !(isIpRequest && isMatchingPort) &&\n !isCsrfOriginAllowed(originLowerCase, allowedOrigins)\n ) {\n if ('statusCode' in res) {\n res.statusCode = 403\n }\n res.end('Unauthorized')\n warnOnce(\n `Blocked cross-origin request from ${originLowerCase}. To allow this, configure \"allowedDevOrigins\" in next.config\\nRead more: https://nextjs.org/docs/app/api-reference/config/next-config-js/allowedDevOrigins`\n )\n return true\n }\n }\n }\n\n return false\n}\n"],"names":["blockCrossSite","req","res","allowedOrigins","activePort","url","includes","headers","statusCode","end","warnOnce","rawOrigin","parsedOrigin","parseUrl","originLowerCase","hostname","toLowerCase","isMatchingPort","port","isIpRequest","net","isIPv4","isIPv6","isCsrfOriginAllowed"],"mappings":";;;;+BAOaA;;;eAAAA;;;qBALY;4DACT;qBACS;gCACW;;;;;;AAE7B,MAAMA,iBAAiB,CAC5BC,KACAC,KACAC,gBACAC;QAGKH;IADL,0BAA0B;IAC1B,IAAI,GAACA,WAAAA,IAAII,GAAG,qBAAPJ,SAASK,QAAQ,CAAC,YAAW;QAChC,OAAO;IACT;IACA,4DAA4D;IAC5D,iBAAiB;IACjB,IACEL,IAAIM,OAAO,CAAC,iBAAiB,KAAK,aAClCN,IAAIM,OAAO,CAAC,iBAAiB,KAAK,cAClC;QACA,IAAI,gBAAgBL,KAAK;YACvBA,IAAIM,UAAU,GAAG;QACnB;QACAN,IAAIO,GAAG,CAAC;QACRC,IAAAA,aAAQ,EACN,CAAC,4FAA4F,CAAC;QAEhG,OAAO;IACT;IAEA,gDAAgD;IAChD,MAAMC,YAAYV,IAAIM,OAAO,CAAC,SAAS;IAEvC,IAAII,WAAW;QACb,MAAMC,eAAeC,IAAAA,aAAQ,EAACF;QAE9B,IAAIC,cAAc;YAChB,MAAME,kBAAkBF,aAAaG,QAAQ,CAACC,WAAW;YACzD,MAAMC,iBAAiBL,aAAaM,IAAI,KAAKd;YAC7C,MAAMe,cACJC,YAAG,CAACC,MAAM,CAACP,oBAAoBM,YAAG,CAACE,MAAM,CAACR;YAE5C,IACE,oDAAoD;YACpD,4CAA4C;YAC5C,CAAEK,CAAAA,eAAeF,cAAa,KAC9B,CAACM,IAAAA,mCAAmB,EAACT,iBAAiBX,iBACtC;gBACA,IAAI,gBAAgBD,KAAK;oBACvBA,IAAIM,UAAU,GAAG;gBACnB;gBACAN,IAAIO,GAAG,CAAC;gBACRC,IAAAA,aAAQ,EACN,CAAC,kCAAkC,EAAEI,gBAAgB,2JAA2J,CAAC;gBAEnN,OAAO;YACT;QACF;IACF;IAEA,OAAO;AACT"}
|
@@ -111,7 +111,7 @@ async function getRequestHandlers({ dir, port, isDev, onDevServerCleanup, server
|
|
111
111
|
async function startServer(serverOptions) {
|
112
112
|
const { dir, isDev, hostname, minimalMode, allowRetry, keepAliveTimeout, selfSignedCertificate } = serverOptions;
|
113
113
|
let { port } = serverOptions;
|
114
|
-
process.title = `next-server (v${"15.3.0-canary.
|
114
|
+
process.title = `next-server (v${"15.3.0-canary.4"})`;
|
115
115
|
let handlersReady = ()=>{};
|
116
116
|
let handlersError = ()=>{};
|
117
117
|
let handlersPromise = new Promise((resolve, reject)=>{
|
@@ -22,7 +22,7 @@ _export(exports, {
|
|
22
22
|
});
|
23
23
|
function isStableBuild() {
|
24
24
|
var _process_env___NEXT_VERSION;
|
25
|
-
return !((_process_env___NEXT_VERSION = "15.3.0-canary.
|
25
|
+
return !((_process_env___NEXT_VERSION = "15.3.0-canary.4") == null ? void 0 : _process_env___NEXT_VERSION.includes('canary')) && !process.env.__NEXT_TEST_MODE && !process.env.NEXT_PRIVATE_LOCAL_DEV;
|
26
26
|
}
|
27
27
|
class CanaryOnlyError extends Error {
|
28
28
|
constructor(arg){
|
@@ -11,11 +11,11 @@ Object.defineProperty(exports, "eventCliSessionStopped", {
|
|
11
11
|
const EVENT_VERSION = 'NEXT_CLI_SESSION_STOPPED';
|
12
12
|
function eventCliSessionStopped(event) {
|
13
13
|
// This should be an invariant, if it fails our build tooling is broken.
|
14
|
-
if (typeof "15.3.0-canary.
|
14
|
+
if (typeof "15.3.0-canary.4" !== 'string') {
|
15
15
|
return [];
|
16
16
|
}
|
17
17
|
const payload = {
|
18
|
-
nextVersion: "15.3.0-canary.
|
18
|
+
nextVersion: "15.3.0-canary.4",
|
19
19
|
nodeVersion: process.version,
|
20
20
|
cliCommand: event.cliCommand,
|
21
21
|
durationMilliseconds: event.durationMilliseconds,
|
@@ -36,12 +36,12 @@ function hasBabelConfig(dir) {
|
|
36
36
|
function eventCliSession(dir, nextConfig, event) {
|
37
37
|
var _nextConfig_experimental_staleTimes, _nextConfig_experimental_staleTimes1, _nextConfig_experimental_reactCompiler, _nextConfig_experimental_reactCompiler1;
|
38
38
|
// This should be an invariant, if it fails our build tooling is broken.
|
39
|
-
if (typeof "15.3.0-canary.
|
39
|
+
if (typeof "15.3.0-canary.4" !== 'string') {
|
40
40
|
return [];
|
41
41
|
}
|
42
42
|
const { images, i18n } = nextConfig || {};
|
43
43
|
const payload = {
|
44
|
-
nextVersion: "15.3.0-canary.
|
44
|
+
nextVersion: "15.3.0-canary.4",
|
45
45
|
nodeVersion: process.version,
|
46
46
|
cliCommand: event.cliCommand,
|
47
47
|
isSrcDir: event.isSrcDir,
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "next",
|
3
|
-
"version": "15.3.0-canary.
|
3
|
+
"version": "15.3.0-canary.4",
|
4
4
|
"description": "The React Framework",
|
5
5
|
"main": "./dist/server/next.js",
|
6
6
|
"license": "MIT",
|
@@ -100,7 +100,7 @@
|
|
100
100
|
]
|
101
101
|
},
|
102
102
|
"dependencies": {
|
103
|
-
"@next/env": "15.3.0-canary.
|
103
|
+
"@next/env": "15.3.0-canary.4",
|
104
104
|
"@swc/counter": "0.1.3",
|
105
105
|
"@swc/helpers": "0.5.15",
|
106
106
|
"busboy": "1.6.0",
|
@@ -132,14 +132,14 @@
|
|
132
132
|
},
|
133
133
|
"optionalDependencies": {
|
134
134
|
"sharp": "^0.33.5",
|
135
|
-
"@next/swc-darwin-arm64": "15.3.0-canary.
|
136
|
-
"@next/swc-darwin-x64": "15.3.0-canary.
|
137
|
-
"@next/swc-linux-arm64-gnu": "15.3.0-canary.
|
138
|
-
"@next/swc-linux-arm64-musl": "15.3.0-canary.
|
139
|
-
"@next/swc-linux-x64-gnu": "15.3.0-canary.
|
140
|
-
"@next/swc-linux-x64-musl": "15.3.0-canary.
|
141
|
-
"@next/swc-win32-arm64-msvc": "15.3.0-canary.
|
142
|
-
"@next/swc-win32-x64-msvc": "15.3.0-canary.
|
135
|
+
"@next/swc-darwin-arm64": "15.3.0-canary.4",
|
136
|
+
"@next/swc-darwin-x64": "15.3.0-canary.4",
|
137
|
+
"@next/swc-linux-arm64-gnu": "15.3.0-canary.4",
|
138
|
+
"@next/swc-linux-arm64-musl": "15.3.0-canary.4",
|
139
|
+
"@next/swc-linux-x64-gnu": "15.3.0-canary.4",
|
140
|
+
"@next/swc-linux-x64-musl": "15.3.0-canary.4",
|
141
|
+
"@next/swc-win32-arm64-msvc": "15.3.0-canary.4",
|
142
|
+
"@next/swc-win32-x64-msvc": "15.3.0-canary.4"
|
143
143
|
},
|
144
144
|
"devDependencies": {
|
145
145
|
"@ampproject/toolbox-optimizer": "2.8.3",
|
@@ -172,11 +172,11 @@
|
|
172
172
|
"@jest/types": "29.5.0",
|
173
173
|
"@mswjs/interceptors": "0.23.0",
|
174
174
|
"@napi-rs/triples": "1.2.0",
|
175
|
-
"@next/font": "15.3.0-canary.
|
176
|
-
"@next/polyfill-module": "15.3.0-canary.
|
177
|
-
"@next/polyfill-nomodule": "15.3.0-canary.
|
178
|
-
"@next/react-refresh-utils": "15.3.0-canary.
|
179
|
-
"@next/swc": "15.3.0-canary.
|
175
|
+
"@next/font": "15.3.0-canary.4",
|
176
|
+
"@next/polyfill-module": "15.3.0-canary.4",
|
177
|
+
"@next/polyfill-nomodule": "15.3.0-canary.4",
|
178
|
+
"@next/react-refresh-utils": "15.3.0-canary.4",
|
179
|
+
"@next/swc": "15.3.0-canary.4",
|
180
180
|
"@opentelemetry/api": "1.6.0",
|
181
181
|
"@playwright/test": "1.41.2",
|
182
182
|
"@storybook/addon-a11y": "8.6.0",
|