@netlify/plugin-nextjs 5.9.3-background-debug-logs.0 → 5.9.3

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.
@@ -103,22 +103,13 @@ init_internal();
103
103
  // src/run/handlers/request-context.cts
104
104
  function createRequestContext(request, context) {
105
105
  const backgroundWorkPromises = [];
106
- let backgroundWorkCounter = 0;
107
106
  return {
108
107
  captureServerTiming: request?.headers.has("x-next-debug-logging") ?? false,
109
- trackBackgroundWork: (promise, description) => {
110
- backgroundWorkCounter += 1;
111
- const counter = backgroundWorkCounter;
112
- const label = `background #${counter} - ${description ?? "unknown"} - ${context?.requestId}`;
113
- const start = Date.now();
114
- console.log(`Start ${label}`);
115
- const trackedPromise = promise.finally(() => {
116
- console.log(`End ${label} - ${(Date.now() - start) / 1e3}s`);
117
- });
108
+ trackBackgroundWork: (promise) => {
118
109
  if (context?.waitUntil) {
119
- context.waitUntil(trackedPromise);
110
+ context.waitUntil(promise);
120
111
  } else {
121
- backgroundWorkPromises.push(trackedPromise);
112
+ backgroundWorkPromises.push(promise);
122
113
  }
123
114
  },
124
115
  get backgroundWorkPromise() {
@@ -6,7 +6,7 @@
6
6
 
7
7
  import {
8
8
  getRequestContext
9
- } from "./chunk-FB56KFLR.js";
9
+ } from "./chunk-LVXJQ2G2.js";
10
10
  import {
11
11
  wrapTracer
12
12
  } from "./chunk-5QSXBV7L.js";
@@ -19,7 +19,7 @@ var nextResponseProxy = (res, requestContext) => {
19
19
  requestContext.didPagesRouterOnDemandRevalidate = true;
20
20
  const result = originalValue.apply(target, args);
21
21
  if (result && isPromise(result)) {
22
- requestContext.trackBackgroundWork(result, "res.revalidate");
22
+ requestContext.trackBackgroundWork(result);
23
23
  }
24
24
  return result;
25
25
  };
@@ -6,10 +6,10 @@
6
6
 
7
7
  import {
8
8
  getTracer
9
- } from "./chunk-PG4KVN6X.js";
9
+ } from "./chunk-NEZW7TGG.js";
10
10
  import {
11
11
  getRequestContext
12
- } from "./chunk-FB56KFLR.js";
12
+ } from "./chunk-LVXJQ2G2.js";
13
13
  import {
14
14
  getRegionalBlobStore
15
15
  } from "./chunk-K4RDUZYO.js";
@@ -490,10 +490,7 @@ ResponseCache.prototype.get = function get(...getArgs) {
490
490
  const workPromise = fn(...workFnArgs);
491
491
  const requestContext = getRequestContext();
492
492
  if (requestContext && workPromise instanceof Promise) {
493
- requestContext.trackBackgroundWork(
494
- workPromise,
495
- `responseCache batcher ${JSON.stringify(key)}`
496
- );
493
+ requestContext.trackBackgroundWork(workPromise);
497
494
  }
498
495
  return await workPromise;
499
496
  };
@@ -508,10 +505,7 @@ ResponseCache.prototype.get = function get(...getArgs) {
508
505
  const workPromise = new Promise((_resolve) => {
509
506
  backgroundWork.set(key, _resolve);
510
507
  });
511
- requestContext.trackBackgroundWork(
512
- workPromise,
513
- `responseCache pendingResponses ${JSON.stringify(key)}`
514
- );
508
+ requestContext.trackBackgroundWork(workPromise);
515
509
  }
516
510
  return originalPendingResponsesSet.call(this.pendingResponses, key, value);
517
511
  };
@@ -8,7 +8,7 @@ import "./chunk-OEQOKJGE.js";
8
8
 
9
9
  // package.json
10
10
  var name = "@netlify/plugin-nextjs";
11
- var version = "5.9.3-background-debug-logs.0";
11
+ var version = "5.9.3";
12
12
  var description = "Run Next.js seamlessly on Netlify";
13
13
  var main = "./dist/index.js";
14
14
  var type = "module";
package/dist/index.js CHANGED
@@ -4,9 +4,18 @@
4
4
  return createRequire(import.meta.url);
5
5
  })();
6
6
 
7
+ import {
8
+ clearStaleEdgeHandlers,
9
+ createEdgeHandlers
10
+ } from "./esm-chunks/chunk-HGXG447M.js";
11
+ import {
12
+ clearStaleServerHandlers,
13
+ createServerHandler
14
+ } from "./esm-chunks/chunk-DLVROEVU.js";
7
15
  import {
8
16
  copyPrerenderedContent
9
17
  } from "./esm-chunks/chunk-J4D25YDX.js";
18
+ import "./esm-chunks/chunk-IJZEDP6B.js";
10
19
  import {
11
20
  copyStaticAssets,
12
21
  copyStaticContent,
@@ -14,15 +23,6 @@ import {
14
23
  publishStaticDir,
15
24
  unpublishStaticDir
16
25
  } from "./esm-chunks/chunk-NTLBFRPA.js";
17
- import {
18
- clearStaleEdgeHandlers,
19
- createEdgeHandlers
20
- } from "./esm-chunks/chunk-HGXG447M.js";
21
- import {
22
- clearStaleServerHandlers,
23
- createServerHandler
24
- } from "./esm-chunks/chunk-DLVROEVU.js";
25
- import "./esm-chunks/chunk-IJZEDP6B.js";
26
26
  import {
27
27
  wrapTracer
28
28
  } from "./esm-chunks/chunk-5QSXBV7L.js";
@@ -203,7 +203,7 @@ var import_constants = require("next/dist/lib/constants.js");
203
203
 
204
204
  // package.json
205
205
  var name = "@netlify/plugin-nextjs";
206
- var version = "5.9.3-background-debug-logs.0";
206
+ var version = "5.9.3";
207
207
 
208
208
  // src/shared/cache-types.cts
209
209
  var isCachedPageValue = (value) => value.kind === "PAGE" || value.kind === "PAGES";
@@ -2022,8 +2022,7 @@ var NetlifyCacheHandler = class {
2022
2022
  requestContext.trackBackgroundWork(
2023
2023
  purgeCache({ tags, userAgent: purgeCacheUserAgent }).catch((error) => {
2024
2024
  getLogger().withError(error).error(`[NetlifyCacheHandler]: Purging the cache for tag ${tag} failed`);
2025
- }),
2026
- `cdn purge after page router .revalidate ${tag}`
2025
+ })
2027
2026
  );
2028
2027
  }
2029
2028
  }
@@ -2034,10 +2033,7 @@ var NetlifyCacheHandler = class {
2034
2033
  const revalidateTagPromise = this.doRevalidateTag(tagOrTags, ...args);
2035
2034
  const requestContext = getRequestContext();
2036
2035
  if (requestContext) {
2037
- requestContext.trackBackgroundWork(
2038
- revalidateTagPromise,
2039
- `revalidateTag ${JSON.stringify(tagOrTags)}`
2040
- );
2036
+ requestContext.trackBackgroundWork(revalidateTagPromise);
2041
2037
  }
2042
2038
  return revalidateTagPromise;
2043
2039
  }
@@ -123,22 +123,13 @@ init_internal();
123
123
  // src/run/handlers/request-context.cts
124
124
  function createRequestContext(request, context) {
125
125
  const backgroundWorkPromises = [];
126
- let backgroundWorkCounter = 0;
127
126
  return {
128
127
  captureServerTiming: request?.headers.has("x-next-debug-logging") ?? false,
129
- trackBackgroundWork: (promise, description) => {
130
- backgroundWorkCounter += 1;
131
- const counter = backgroundWorkCounter;
132
- const label = `background #${counter} - ${description ?? "unknown"} - ${context?.requestId}`;
133
- const start = Date.now();
134
- console.log(`Start ${label}`);
135
- const trackedPromise = promise.finally(() => {
136
- console.log(`End ${label} - ${(Date.now() - start) / 1e3}s`);
137
- });
128
+ trackBackgroundWork: (promise) => {
138
129
  if (context?.waitUntil) {
139
- context.waitUntil(trackedPromise);
130
+ context.waitUntil(promise);
140
131
  } else {
141
- backgroundWorkPromises.push(trackedPromise);
132
+ backgroundWorkPromises.push(promise);
142
133
  }
143
134
  },
144
135
  get backgroundWorkPromise() {
@@ -6,12 +6,12 @@
6
6
 
7
7
  import {
8
8
  getTracer
9
- } from "../../esm-chunks/chunk-PG4KVN6X.js";
9
+ } from "../../esm-chunks/chunk-NEZW7TGG.js";
10
10
  import {
11
11
  createRequestContext,
12
12
  getLogger,
13
13
  getRequestContext
14
- } from "../../esm-chunks/chunk-FB56KFLR.js";
14
+ } from "../../esm-chunks/chunk-LVXJQ2G2.js";
15
15
  import {
16
16
  adjustDateHeader,
17
17
  setCacheControlHeaders,
@@ -22,7 +22,7 @@ import {
22
22
  import "../../esm-chunks/chunk-K4RDUZYO.js";
23
23
  import {
24
24
  nextResponseProxy
25
- } from "../../esm-chunks/chunk-5N54G5SN.js";
25
+ } from "../../esm-chunks/chunk-XS27YRA5.js";
26
26
  import "../../esm-chunks/chunk-5QSXBV7L.js";
27
27
  import "../../esm-chunks/chunk-GNGHTHMQ.js";
28
28
  import "../../esm-chunks/chunk-TYCYFZ22.js";
@@ -3118,16 +3118,13 @@ function setupWaitUntil() {
3118
3118
  ;
3119
3119
  globalThis[NEXT_REQUEST_CONTEXT_SYMBOL] = {
3120
3120
  get() {
3121
- const trackBackgroundWork = getRequestContext()?.trackBackgroundWork;
3122
- return {
3123
- waitUntil: trackBackgroundWork ? (promise) => trackBackgroundWork(promise, "after()") : void 0
3124
- };
3121
+ return { waitUntil: getRequestContext()?.trackBackgroundWork };
3125
3122
  }
3126
3123
  };
3127
3124
  }
3128
3125
 
3129
3126
  // src/run/handlers/server.ts
3130
- var nextImportPromise = import("../../esm-chunks/next-FWMVEHSM.js");
3127
+ var nextImportPromise = import("../../esm-chunks/next-H2VMRX5P.js");
3131
3128
  setupWaitUntil();
3132
3129
  var nextHandler;
3133
3130
  var nextConfig;
@@ -3144,10 +3141,7 @@ var disableFaultyTransferEncodingHandling = (res) => {
3144
3141
  return originalStoreHeader.call(this, firstLine, headers);
3145
3142
  };
3146
3143
  };
3147
- var server_default = async (request, context) => {
3148
- const label = `response - ${request.url} - ${context.requestId}`;
3149
- const start = Date.now();
3150
- console.log(`Start ${label}`);
3144
+ var server_default = async (request) => {
3151
3145
  const tracer = getTracer();
3152
3146
  if (!nextHandler) {
3153
3147
  await tracer.withActiveSpan("initialize next server", async () => {
@@ -3202,7 +3196,6 @@ var server_default = async (request, context) => {
3202
3196
  const keepOpenUntilNextFullyRendered = new TransformStream({
3203
3197
  async flush() {
3204
3198
  await nextHandlerPromise;
3205
- console.log(`End ${label} - ${(Date.now() - start) / 1e3}s`);
3206
3199
  res.emit("close");
3207
3200
  await requestContext.backgroundWorkPromise;
3208
3201
  }
@@ -6,7 +6,7 @@
6
6
 
7
7
  import {
8
8
  getLogger
9
- } from "../../esm-chunks/chunk-FB56KFLR.js";
9
+ } from "../../esm-chunks/chunk-LVXJQ2G2.js";
10
10
  import {
11
11
  esm_exports,
12
12
  init_esm
@@ -68868,7 +68868,7 @@ var import_sdk_trace_node = __toESM(require_src20(), 1);
68868
68868
  var import_semantic_conventions = __toESM(require_src(), 1);
68869
68869
  var {
68870
68870
  default: { version, name }
68871
- } = await import("../../esm-chunks/package-W4QAAZFL.js");
68871
+ } = await import("../../esm-chunks/package-MI2MBCHL.js");
68872
68872
  var sdk = new import_sdk_node.NodeSDK({
68873
68873
  resource: new import_resources.Resource({
68874
68874
  [import_semantic_conventions.SEMRESATTRS_SERVICE_NAME]: name,
@@ -143,10 +143,7 @@ function setupWaitUntil() {
143
143
  ;
144
144
  globalThis[NEXT_REQUEST_CONTEXT_SYMBOL] = {
145
145
  get() {
146
- const trackBackgroundWork = getRequestContext()?.trackBackgroundWork;
147
- return {
148
- waitUntil: trackBackgroundWork ? (promise) => trackBackgroundWork(promise, "after()") : void 0
149
- };
146
+ return { waitUntil: getRequestContext()?.trackBackgroundWork };
150
147
  }
151
148
  };
152
149
  }
package/dist/run/next.cjs CHANGED
@@ -2119,10 +2119,7 @@ ResponseCache.prototype.get = function get(...getArgs) {
2119
2119
  const workPromise = fn(...workFnArgs);
2120
2120
  const requestContext = getRequestContext();
2121
2121
  if (requestContext && workPromise instanceof Promise) {
2122
- requestContext.trackBackgroundWork(
2123
- workPromise,
2124
- `responseCache batcher ${JSON.stringify(key)}`
2125
- );
2122
+ requestContext.trackBackgroundWork(workPromise);
2126
2123
  }
2127
2124
  return await workPromise;
2128
2125
  };
@@ -2137,10 +2134,7 @@ ResponseCache.prototype.get = function get(...getArgs) {
2137
2134
  const workPromise = new Promise((_resolve) => {
2138
2135
  backgroundWork.set(key, _resolve);
2139
2136
  });
2140
- requestContext.trackBackgroundWork(
2141
- workPromise,
2142
- `responseCache pendingResponses ${JSON.stringify(key)}`
2143
- );
2137
+ requestContext.trackBackgroundWork(workPromise);
2144
2138
  }
2145
2139
  return originalPendingResponsesSet.call(this.pendingResponses, key, value);
2146
2140
  };
@@ -6,7 +6,7 @@
6
6
 
7
7
  import {
8
8
  nextResponseProxy
9
- } from "../esm-chunks/chunk-5N54G5SN.js";
9
+ } from "../esm-chunks/chunk-XS27YRA5.js";
10
10
  import "../esm-chunks/chunk-OEQOKJGE.js";
11
11
  export {
12
12
  nextResponseProxy
@@ -14,6 +14,8 @@ import {
14
14
  normalizeLocalePath,
15
15
  normalizeTrailingSlash,
16
16
  relativizeURL,
17
+ removeBasePath,
18
+ rewriteDataPath,
17
19
  } from './util.ts'
18
20
 
19
21
  export interface FetchEventResult {
@@ -180,14 +182,16 @@ export const buildResponse = async ({
180
182
  }
181
183
 
182
184
  if (isDataReq) {
183
- // The rewrite target is a data request, but a middleware rewrite target is always for the page route,
184
- // so we need to tell the server this is a data request. Setting the `x-nextjs-data` header is not enough. 🤷
185
- rewriteUrl.searchParams.set('__nextDataReq', '1')
185
+ rewriteUrl.pathname = rewriteDataPath({
186
+ dataUrl: new URL(request.url).pathname,
187
+ newRoute: removeBasePath(rewriteUrl.pathname, nextConfig?.basePath),
188
+ basePath: nextConfig?.basePath,
189
+ })
190
+ } else {
191
+ // respect trailing slash rules to prevent 308s
192
+ rewriteUrl.pathname = normalizeTrailingSlash(rewriteUrl.pathname, nextConfig?.trailingSlash)
186
193
  }
187
194
 
188
- // respect trailing slash rules to prevent 308s
189
- rewriteUrl.pathname = normalizeTrailingSlash(rewriteUrl.pathname, nextConfig?.trailingSlash)
190
-
191
195
  const target = normalizeLocalizedTarget({ target: rewriteUrl.toString(), request, nextConfig })
192
196
  if (target === request.url) {
193
197
  logger.withFields({ rewrite_url: rewrite }).debug('Rewrite url is same as original url')
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@netlify/plugin-nextjs",
3
- "version": "5.9.3-background-debug-logs.0",
3
+ "version": "5.9.3",
4
4
  "description": "Run Next.js seamlessly on Netlify",
5
5
  "main": "./dist/index.js",
6
6
  "type": "module",