next 15.4.2-canary.36 → 15.4.2-canary.38

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.
Files changed (58) hide show
  1. package/dist/bin/next +1 -1
  2. package/dist/build/index.js +2 -2
  3. package/dist/build/swc/index.js +1 -1
  4. package/dist/build/webpack/config/blocks/css/loaders/next-font.js +1 -0
  5. package/dist/build/webpack/config/blocks/css/loaders/next-font.js.map +1 -1
  6. package/dist/build/webpack/config/index.d.ts +2 -1
  7. package/dist/build/webpack/config/index.js +2 -1
  8. package/dist/build/webpack/config/index.js.map +1 -1
  9. package/dist/build/webpack/config/utils.d.ts +1 -0
  10. package/dist/build/webpack/config/utils.js.map +1 -1
  11. package/dist/build/webpack/loaders/next-font-loader/index.js +2 -1
  12. package/dist/build/webpack/loaders/next-font-loader/index.js.map +1 -1
  13. package/dist/build/webpack-config.js +3 -2
  14. package/dist/build/webpack-config.js.map +1 -1
  15. package/dist/client/app-bootstrap.js +1 -1
  16. package/dist/client/index.js +1 -1
  17. package/dist/compiled/@next/font/dist/local/loader.js +6 -2
  18. package/dist/compiled/image-detector/detector.js +1 -0
  19. package/dist/compiled/next-server/pages-api-turbo.runtime.prod.js +1 -1
  20. package/dist/compiled/next-server/pages-api-turbo.runtime.prod.js.map +1 -1
  21. package/dist/compiled/next-server/pages-api.runtime.prod.js +1 -1
  22. package/dist/compiled/next-server/pages-api.runtime.prod.js.map +1 -1
  23. package/dist/compiled/next-server/pages-turbo.runtime.prod.js +1 -1
  24. package/dist/compiled/next-server/pages-turbo.runtime.prod.js.map +1 -1
  25. package/dist/compiled/next-server/pages.runtime.prod.js +1 -1
  26. package/dist/compiled/next-server/pages.runtime.prod.js.map +1 -1
  27. package/dist/esm/build/index.js +2 -2
  28. package/dist/esm/build/swc/index.js +1 -1
  29. package/dist/esm/build/webpack/config/blocks/css/loaders/next-font.js +1 -0
  30. package/dist/esm/build/webpack/config/blocks/css/loaders/next-font.js.map +1 -1
  31. package/dist/esm/build/webpack/config/index.js +2 -1
  32. package/dist/esm/build/webpack/config/index.js.map +1 -1
  33. package/dist/esm/build/webpack/config/utils.js.map +1 -1
  34. package/dist/esm/build/webpack/loaders/next-font-loader/index.js +2 -1
  35. package/dist/esm/build/webpack/loaders/next-font-loader/index.js.map +1 -1
  36. package/dist/esm/build/webpack-config.js +3 -2
  37. package/dist/esm/build/webpack-config.js.map +1 -1
  38. package/dist/esm/client/app-bootstrap.js +1 -1
  39. package/dist/esm/client/index.js +1 -1
  40. package/dist/esm/server/dev/hot-reloader-turbopack.js +1 -1
  41. package/dist/esm/server/dev/hot-reloader-webpack.js +1 -1
  42. package/dist/esm/server/image-optimizer.js +23 -3
  43. package/dist/esm/server/image-optimizer.js.map +1 -1
  44. package/dist/esm/server/lib/app-info-log.js +1 -1
  45. package/dist/esm/server/lib/start-server.js +1 -1
  46. package/dist/esm/shared/lib/canary-only.js +1 -1
  47. package/dist/server/dev/hot-reloader-turbopack.js +1 -1
  48. package/dist/server/dev/hot-reloader-webpack.js +1 -1
  49. package/dist/server/image-optimizer.js +23 -3
  50. package/dist/server/image-optimizer.js.map +1 -1
  51. package/dist/server/lib/app-info-log.js +1 -1
  52. package/dist/server/lib/start-server.js +1 -1
  53. package/dist/shared/lib/canary-only.js +1 -1
  54. package/dist/telemetry/anonymous-meta.js +1 -1
  55. package/dist/telemetry/events/session-stopped.js +2 -2
  56. package/dist/telemetry/events/version.js +2 -2
  57. package/font/index.d.ts +1 -0
  58. package/package.json +15 -15
@@ -4,7 +4,7 @@
4
4
  * - Polyfills
5
5
  * - next/script with `beforeInteractive` strategy
6
6
  */ import { setAttributesFromProps } from './set-attributes-from-props';
7
- const version = "15.4.2-canary.36";
7
+ const version = "15.4.2-canary.38";
8
8
  window.next = {
9
9
  version,
10
10
  appDir: true
@@ -26,7 +26,7 @@ import { SearchParamsContext, PathParamsContext } from '../shared/lib/hooks-clie
26
26
  import { onRecoverableError } from './react-client-callbacks/on-recoverable-error';
27
27
  import tracer from './tracing/tracer';
28
28
  import { isNextRouterError } from './components/is-next-router-error';
29
- export const version = "15.4.2-canary.36";
29
+ export const version = "15.4.2-canary.38";
30
30
  export let router;
31
31
  export const emitter = mitt();
32
32
  const looseToArray = (input)=>[].slice.call(input);
@@ -89,7 +89,7 @@ export async function createHotReloaderTurbopack(opts, serverFields, distDir, re
89
89
  }
90
90
  const hasRewrites = opts.fsChecker.rewrites.afterFiles.length > 0 || opts.fsChecker.rewrites.beforeFiles.length > 0 || opts.fsChecker.rewrites.fallback.length > 0;
91
91
  const hotReloaderSpan = trace('hot-reloader', undefined, {
92
- version: "15.4.2-canary.36"
92
+ version: "15.4.2-canary.38"
93
93
  });
94
94
  // Ensure the hotReloaderSpan is flushed immediately as it's the parentSpan for all processing
95
95
  // of the current `next dev` invocation.
@@ -186,7 +186,7 @@ export default class HotReloaderWebpack {
186
186
  this.previewProps = previewProps;
187
187
  this.rewrites = rewrites;
188
188
  this.hotReloaderSpan = trace('hot-reloader', undefined, {
189
- version: "15.4.2-canary.36"
189
+ version: "15.4.2-canary.38"
190
190
  });
191
191
  // Ensure the hotReloaderSpan is flushed immediately as it's the parentSpan for all processing
192
192
  // of the current `next dev` invocation.
@@ -3,6 +3,7 @@ import { promises } from 'fs';
3
3
  import { mediaType } from 'next/dist/compiled/@hapi/accept';
4
4
  import contentDisposition from 'next/dist/compiled/content-disposition';
5
5
  import imageSizeOf from 'next/dist/compiled/image-size';
6
+ import { detector } from 'next/dist/compiled/image-detector/detector.js';
6
7
  import isAnimated from 'next/dist/compiled/is-animated';
7
8
  import { join } from 'path';
8
9
  import nodeUrl from 'url';
@@ -288,9 +289,14 @@ async function writeToCacheDir(dir, extension, maxAge, expireAt, buffer, etag, u
288
289
  ].every((b, i)=>buffer[i] === b)) {
289
290
  return JP2;
290
291
  }
291
- const sharp = getSharp(null);
292
- const meta = await sharp(buffer).metadata().catch((_)=>null);
293
- switch(meta == null ? void 0 : meta.format){
292
+ let format;
293
+ format = detector(buffer);
294
+ if (!format) {
295
+ const sharp = getSharp(null);
296
+ const meta = await sharp(buffer).metadata().catch((_)=>null);
297
+ format = meta == null ? void 0 : meta.format;
298
+ }
299
+ switch(format){
294
300
  case 'avif':
295
301
  return AVIF;
296
302
  case 'webp':
@@ -305,6 +311,7 @@ async function writeToCacheDir(dir, extension, maxAge, expireAt, buffer, etag, u
305
311
  case 'svg':
306
312
  return SVG;
307
313
  case 'jxl':
314
+ case 'jxl-stream':
308
315
  return JXL;
309
316
  case 'jp2':
310
317
  return JP2;
@@ -313,6 +320,12 @@ async function writeToCacheDir(dir, extension, maxAge, expireAt, buffer, etag, u
313
320
  return TIFF;
314
321
  case 'pdf':
315
322
  return PDF;
323
+ case 'bmp':
324
+ return BMP;
325
+ case 'ico':
326
+ return ICO;
327
+ case 'icns':
328
+ return ICNS;
316
329
  case 'dcraw':
317
330
  case 'dz':
318
331
  case 'exr':
@@ -325,6 +338,13 @@ async function writeToCacheDir(dir, extension, maxAge, expireAt, buffer, etag, u
325
338
  case 'rad':
326
339
  case 'raw':
327
340
  case 'v':
341
+ case 'cur':
342
+ case 'dds':
343
+ case 'j2c':
344
+ case 'ktx':
345
+ case 'pnm':
346
+ case 'psd':
347
+ case 'tga':
328
348
  case undefined:
329
349
  default:
330
350
  return null;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/server/image-optimizer.ts"],"sourcesContent":["import { createHash } from 'crypto'\nimport { promises } from 'fs'\nimport type { IncomingMessage, ServerResponse } from 'http'\nimport { mediaType } from 'next/dist/compiled/@hapi/accept'\nimport contentDisposition from 'next/dist/compiled/content-disposition'\nimport imageSizeOf from 'next/dist/compiled/image-size'\nimport isAnimated from 'next/dist/compiled/is-animated'\nimport { join } from 'path'\nimport nodeUrl, { type UrlWithParsedQuery } from 'url'\n\nimport { getImageBlurSvg } from '../shared/lib/image-blur-svg'\nimport type { ImageConfigComplete } from '../shared/lib/image-config'\nimport { hasLocalMatch } from '../shared/lib/match-local-pattern'\nimport { hasRemoteMatch } from '../shared/lib/match-remote-pattern'\nimport type { NextConfigComplete } from './config-shared'\nimport { createRequestResponseMocks } from './lib/mock-request'\nimport type { NextUrlWithParsedQuery } from './request-meta'\nimport {\n CachedRouteKind,\n type CachedImageValue,\n type IncrementalCacheEntry,\n type IncrementalCacheValue,\n type IncrementalResponseCacheEntry,\n} from './response-cache'\nimport { sendEtagResponse } from './send-payload'\nimport { getContentType, getExtension } from './serve-static'\nimport * as Log from '../build/output/log'\nimport isError from '../lib/is-error'\nimport { parseUrl } from '../lib/url'\nimport type { CacheControl } from './lib/cache-control'\nimport { InvariantError } from '../shared/lib/invariant-error'\n\ntype XCacheHeader = 'MISS' | 'HIT' | 'STALE'\n\nconst AVIF = 'image/avif'\nconst WEBP = 'image/webp'\nconst PNG = 'image/png'\nconst JPEG = 'image/jpeg'\nconst JXL = 'image/jxl'\nconst JP2 = 'image/jp2'\nconst HEIC = 'image/heic'\nconst GIF = 'image/gif'\nconst SVG = 'image/svg+xml'\nconst ICO = 'image/x-icon'\nconst ICNS = 'image/x-icns'\nconst TIFF = 'image/tiff'\nconst BMP = 'image/bmp'\nconst PDF = 'application/pdf'\nconst CACHE_VERSION = 4\nconst ANIMATABLE_TYPES = [WEBP, PNG, GIF]\nconst BYPASS_TYPES = [SVG, ICO, ICNS, BMP, JXL, HEIC]\nconst BLUR_IMG_SIZE = 8 // should match `next-image-loader`\nconst BLUR_QUALITY = 70 // should match `next-image-loader`\n\nlet _sharp: typeof import('sharp')\n\nexport function getSharp(concurrency: number | null | undefined) {\n if (_sharp) {\n return _sharp\n }\n try {\n _sharp = require('sharp') as typeof import('sharp')\n if (_sharp && _sharp.concurrency() > 1) {\n // Reducing concurrency should reduce the memory usage too.\n // We more aggressively reduce in dev but also reduce in prod.\n // https://sharp.pixelplumbing.com/api-utility#concurrency\n const divisor = process.env.NODE_ENV === 'development' ? 4 : 2\n _sharp.concurrency(\n concurrency ?? Math.floor(Math.max(_sharp.concurrency() / divisor, 1))\n )\n }\n } catch (e: unknown) {\n if (isError(e) && e.code === 'MODULE_NOT_FOUND') {\n throw new Error(\n 'Module `sharp` not found. Please run `npm install --cpu=wasm32 sharp` to install it.'\n )\n }\n throw e\n }\n return _sharp\n}\n\nexport interface ImageParamsResult {\n href: string\n isAbsolute: boolean\n isStatic: boolean\n width: number\n quality: number\n mimeType: string\n sizes: number[]\n minimumCacheTTL: number\n}\n\ninterface ImageUpstream {\n buffer: Buffer\n contentType: string | null | undefined\n cacheControl: string | null | undefined\n etag: string\n}\n\nfunction getSupportedMimeType(options: string[], accept = ''): string {\n const mimeType = mediaType(accept, options)\n return accept.includes(mimeType) ? mimeType : ''\n}\n\nexport function getHash(items: (string | number | Buffer)[]) {\n const hash = createHash('sha256')\n for (let item of items) {\n if (typeof item === 'number') hash.update(String(item))\n else {\n hash.update(item)\n }\n }\n // See https://en.wikipedia.org/wiki/Base64#URL_applications\n return hash.digest('base64url')\n}\n\nexport function extractEtag(\n etag: string | null | undefined,\n imageBuffer: Buffer\n) {\n if (etag) {\n // upstream etag needs to be base64url encoded due to weak etag signature\n // as we store this in the cache-entry file name.\n return Buffer.from(etag).toString('base64url')\n }\n return getImageEtag(imageBuffer)\n}\n\nexport function getImageEtag(image: Buffer) {\n return getHash([image])\n}\n\nasync function writeToCacheDir(\n dir: string,\n extension: string,\n maxAge: number,\n expireAt: number,\n buffer: Buffer,\n etag: string,\n upstreamEtag: string\n) {\n const filename = join(\n dir,\n `${maxAge}.${expireAt}.${etag}.${upstreamEtag}.${extension}`\n )\n\n await promises.rm(dir, { recursive: true, force: true }).catch(() => {})\n\n await promises.mkdir(dir, { recursive: true })\n await promises.writeFile(filename, buffer)\n}\n\n/**\n * Inspects the first few bytes of a buffer to determine if\n * it matches the \"magic number\" of known file signatures.\n * https://en.wikipedia.org/wiki/List_of_file_signatures\n */\nexport async function detectContentType(\n buffer: Buffer\n): Promise<string | null> {\n if ([0xff, 0xd8, 0xff].every((b, i) => buffer[i] === b)) {\n return JPEG\n }\n if (\n [0x89, 0x50, 0x4e, 0x47, 0x0d, 0x0a, 0x1a, 0x0a].every(\n (b, i) => buffer[i] === b\n )\n ) {\n return PNG\n }\n if ([0x47, 0x49, 0x46, 0x38].every((b, i) => buffer[i] === b)) {\n return GIF\n }\n if (\n [0x52, 0x49, 0x46, 0x46, 0, 0, 0, 0, 0x57, 0x45, 0x42, 0x50].every(\n (b, i) => !b || buffer[i] === b\n )\n ) {\n return WEBP\n }\n if ([0x3c, 0x3f, 0x78, 0x6d, 0x6c].every((b, i) => buffer[i] === b)) {\n return SVG\n }\n if ([0x3c, 0x73, 0x76, 0x67].every((b, i) => buffer[i] === b)) {\n return SVG\n }\n if (\n [0, 0, 0, 0, 0x66, 0x74, 0x79, 0x70, 0x61, 0x76, 0x69, 0x66].every(\n (b, i) => !b || buffer[i] === b\n )\n ) {\n return AVIF\n }\n if ([0x00, 0x00, 0x01, 0x00].every((b, i) => buffer[i] === b)) {\n return ICO\n }\n if ([0x69, 0x63, 0x6e, 0x73].every((b, i) => buffer[i] === b)) {\n return ICNS\n }\n if ([0x49, 0x49, 0x2a, 0x00].every((b, i) => buffer[i] === b)) {\n return TIFF\n }\n if ([0x42, 0x4d].every((b, i) => buffer[i] === b)) {\n return BMP\n }\n if ([0xff, 0x0a].every((b, i) => buffer[i] === b)) {\n return JXL\n }\n if (\n [\n 0x00, 0x00, 0x00, 0x0c, 0x4a, 0x58, 0x4c, 0x20, 0x0d, 0x0a, 0x87, 0x0a,\n ].every((b, i) => buffer[i] === b)\n ) {\n return JXL\n }\n if (\n [0, 0, 0, 0, 0x66, 0x74, 0x79, 0x70, 0x68, 0x65, 0x69, 0x63].every(\n (b, i) => !b || buffer[i] === b\n )\n ) {\n return HEIC\n }\n if ([0x25, 0x50, 0x44, 0x46, 0x2d].every((b, i) => buffer[i] === b)) {\n return PDF\n }\n if (\n [\n 0x00, 0x00, 0x00, 0x0c, 0x6a, 0x50, 0x20, 0x20, 0x0d, 0x0a, 0x87, 0x0a,\n ].every((b, i) => buffer[i] === b)\n ) {\n return JP2\n }\n\n const sharp = getSharp(null)\n const meta = await sharp(buffer)\n .metadata()\n .catch((_) => null)\n switch (meta?.format) {\n case 'avif':\n return AVIF\n case 'webp':\n return WEBP\n case 'png':\n return PNG\n case 'jpeg':\n case 'jpg':\n return JPEG\n case 'gif':\n return GIF\n case 'svg':\n return SVG\n case 'jxl':\n return JXL\n case 'jp2':\n return JP2\n case 'tiff':\n case 'tif':\n return TIFF\n case 'pdf':\n return PDF\n case 'dcraw':\n case 'dz':\n case 'exr':\n case 'fits':\n case 'heif':\n case 'input':\n case 'magick':\n case 'openslide':\n case 'ppm':\n case 'rad':\n case 'raw':\n case 'v':\n case undefined:\n default:\n return null\n }\n}\n\nexport class ImageOptimizerCache {\n private cacheDir: string\n private nextConfig: NextConfigComplete\n\n static validateParams(\n req: IncomingMessage,\n query: UrlWithParsedQuery['query'],\n nextConfig: NextConfigComplete,\n isDev: boolean\n ): ImageParamsResult | { errorMessage: string } {\n const imageData = nextConfig.images\n const {\n deviceSizes = [],\n imageSizes = [],\n domains = [],\n minimumCacheTTL = 60,\n formats = ['image/webp'],\n } = imageData\n const remotePatterns = nextConfig.images?.remotePatterns || []\n const localPatterns = nextConfig.images?.localPatterns\n const qualities = nextConfig.images?.qualities\n const { url, w, q } = query\n let href: string\n\n if (domains.length > 0) {\n Log.warnOnce(\n 'The \"images.domains\" configuration is deprecated. Please use \"images.remotePatterns\" configuration instead.'\n )\n }\n\n if (!url) {\n return { errorMessage: '\"url\" parameter is required' }\n } else if (Array.isArray(url)) {\n return { errorMessage: '\"url\" parameter cannot be an array' }\n }\n\n if (url.length > 3072) {\n return { errorMessage: '\"url\" parameter is too long' }\n }\n\n if (url.startsWith('//')) {\n return {\n errorMessage: '\"url\" parameter cannot be a protocol-relative URL (//)',\n }\n }\n\n let isAbsolute: boolean\n\n if (url.startsWith('/')) {\n href = url\n isAbsolute = false\n if (\n /\\/_next\\/image($|\\/)/.test(\n decodeURIComponent(parseUrl(url)?.pathname ?? '')\n )\n ) {\n return {\n errorMessage: '\"url\" parameter cannot be recursive',\n }\n }\n if (!hasLocalMatch(localPatterns, url)) {\n return { errorMessage: '\"url\" parameter is not allowed' }\n }\n } else {\n let hrefParsed: URL\n\n try {\n hrefParsed = new URL(url)\n href = hrefParsed.toString()\n isAbsolute = true\n } catch (_error) {\n return { errorMessage: '\"url\" parameter is invalid' }\n }\n\n if (!['http:', 'https:'].includes(hrefParsed.protocol)) {\n return { errorMessage: '\"url\" parameter is invalid' }\n }\n\n if (!hasRemoteMatch(domains, remotePatterns, hrefParsed)) {\n return { errorMessage: '\"url\" parameter is not allowed' }\n }\n }\n\n if (!w) {\n return { errorMessage: '\"w\" parameter (width) is required' }\n } else if (Array.isArray(w)) {\n return { errorMessage: '\"w\" parameter (width) cannot be an array' }\n } else if (!/^[0-9]+$/.test(w)) {\n return {\n errorMessage: '\"w\" parameter (width) must be an integer greater than 0',\n }\n }\n\n if (!q) {\n return { errorMessage: '\"q\" parameter (quality) is required' }\n } else if (Array.isArray(q)) {\n return { errorMessage: '\"q\" parameter (quality) cannot be an array' }\n } else if (!/^[0-9]+$/.test(q)) {\n return {\n errorMessage:\n '\"q\" parameter (quality) must be an integer between 1 and 100',\n }\n }\n\n const width = parseInt(w, 10)\n\n if (width <= 0 || isNaN(width)) {\n return {\n errorMessage: '\"w\" parameter (width) must be an integer greater than 0',\n }\n }\n\n const sizes = [...(deviceSizes || []), ...(imageSizes || [])]\n\n if (isDev) {\n sizes.push(BLUR_IMG_SIZE)\n }\n\n const isValidSize =\n sizes.includes(width) || (isDev && width <= BLUR_IMG_SIZE)\n\n if (!isValidSize) {\n return {\n errorMessage: `\"w\" parameter (width) of ${width} is not allowed`,\n }\n }\n\n const quality = parseInt(q, 10)\n\n if (isNaN(quality) || quality < 1 || quality > 100) {\n return {\n errorMessage:\n '\"q\" parameter (quality) must be an integer between 1 and 100',\n }\n }\n\n if (qualities) {\n if (isDev) {\n qualities.push(BLUR_QUALITY)\n }\n\n if (!qualities.includes(quality)) {\n return {\n errorMessage: `\"q\" parameter (quality) of ${q} is not allowed`,\n }\n }\n }\n\n const mimeType = getSupportedMimeType(formats || [], req.headers['accept'])\n\n const isStatic = url.startsWith(\n `${nextConfig.basePath || ''}/_next/static/media`\n )\n\n return {\n href,\n sizes,\n isAbsolute,\n isStatic,\n width,\n quality,\n mimeType,\n minimumCacheTTL,\n }\n }\n\n static getCacheKey({\n href,\n width,\n quality,\n mimeType,\n }: {\n href: string\n width: number\n quality: number\n mimeType: string\n }): string {\n return getHash([CACHE_VERSION, href, width, quality, mimeType])\n }\n\n constructor({\n distDir,\n nextConfig,\n }: {\n distDir: string\n nextConfig: NextConfigComplete\n }) {\n this.cacheDir = join(distDir, 'cache', 'images')\n this.nextConfig = nextConfig\n }\n\n async get(cacheKey: string): Promise<IncrementalResponseCacheEntry | null> {\n try {\n const cacheDir = join(this.cacheDir, cacheKey)\n const files = await promises.readdir(cacheDir)\n const now = Date.now()\n\n for (const file of files) {\n const [maxAgeSt, expireAtSt, etag, upstreamEtag, extension] =\n file.split('.', 5)\n const buffer = await promises.readFile(join(cacheDir, file))\n const expireAt = Number(expireAtSt)\n const maxAge = Number(maxAgeSt)\n\n return {\n value: {\n kind: CachedRouteKind.IMAGE,\n etag,\n buffer,\n extension,\n upstreamEtag,\n },\n revalidateAfter:\n Math.max(maxAge, this.nextConfig.images.minimumCacheTTL) * 1000 +\n Date.now(),\n cacheControl: { revalidate: maxAge, expire: undefined },\n isStale: now > expireAt,\n }\n }\n } catch (_) {\n // failed to read from cache dir, treat as cache miss\n }\n return null\n }\n async set(\n cacheKey: string,\n value: IncrementalCacheValue | null,\n {\n cacheControl,\n }: {\n cacheControl?: CacheControl\n }\n ) {\n if (!this.nextConfig.experimental.isrFlushToDisk) {\n return\n }\n\n if (value?.kind !== CachedRouteKind.IMAGE) {\n throw new Error('invariant attempted to set non-image to image-cache')\n }\n\n const revalidate = cacheControl?.revalidate\n\n if (typeof revalidate !== 'number') {\n throw new InvariantError('revalidate must be a number for image-cache')\n }\n\n const expireAt =\n Math.max(revalidate, this.nextConfig.images.minimumCacheTTL) * 1000 +\n Date.now()\n\n try {\n await writeToCacheDir(\n join(this.cacheDir, cacheKey),\n value.extension,\n revalidate,\n expireAt,\n value.buffer,\n value.etag,\n value.upstreamEtag\n )\n } catch (err) {\n Log.error(`Failed to write image to cache ${cacheKey}`, err)\n }\n }\n}\nexport class ImageError extends Error {\n statusCode: number\n\n constructor(statusCode: number, message: string) {\n super(message)\n\n // ensure an error status is used > 400\n if (statusCode >= 400) {\n this.statusCode = statusCode\n } else {\n this.statusCode = 500\n }\n }\n}\n\nfunction parseCacheControl(\n str: string | null | undefined\n): Map<string, string> {\n const map = new Map<string, string>()\n if (!str) {\n return map\n }\n for (let directive of str.split(',')) {\n let [key, value] = directive.trim().split('=', 2)\n key = key.toLowerCase()\n if (value) {\n value = value.toLowerCase()\n }\n map.set(key, value)\n }\n return map\n}\n\nexport function getMaxAge(str: string | null | undefined): number {\n const map = parseCacheControl(str)\n if (map) {\n let age = map.get('s-maxage') || map.get('max-age') || ''\n if (age.startsWith('\"') && age.endsWith('\"')) {\n age = age.slice(1, -1)\n }\n const n = parseInt(age, 10)\n if (!isNaN(n)) {\n return n\n }\n }\n return 0\n}\nexport function getPreviouslyCachedImageOrNull(\n upstreamImage: ImageUpstream,\n previousCacheEntry: IncrementalCacheEntry | null | undefined\n): CachedImageValue | null {\n if (\n previousCacheEntry?.value?.kind === 'IMAGE' &&\n // Images that are SVGs, animated or failed the optimization previously end up using upstreamEtag as their etag as well,\n // in these cases we want to trigger a new \"optimization\" attempt.\n previousCacheEntry.value.upstreamEtag !== previousCacheEntry.value.etag &&\n // and the upstream etag is the same as the previous cache entry's\n upstreamImage.etag === previousCacheEntry.value.upstreamEtag\n ) {\n return previousCacheEntry.value\n }\n return null\n}\n\nexport async function optimizeImage({\n buffer,\n contentType,\n quality,\n width,\n height,\n concurrency,\n limitInputPixels,\n sequentialRead,\n timeoutInSeconds,\n}: {\n buffer: Buffer\n contentType: string\n quality: number\n width: number\n height?: number\n concurrency?: number | null\n limitInputPixels?: number\n sequentialRead?: boolean | null\n timeoutInSeconds?: number\n}): Promise<Buffer> {\n const sharp = getSharp(concurrency)\n const transformer = sharp(buffer, {\n limitInputPixels,\n sequentialRead: sequentialRead ?? undefined,\n })\n .timeout({\n seconds: timeoutInSeconds ?? 7,\n })\n .rotate()\n\n if (height) {\n transformer.resize(width, height)\n } else {\n transformer.resize(width, undefined, {\n withoutEnlargement: true,\n })\n }\n\n if (contentType === AVIF) {\n transformer.avif({\n quality: Math.max(quality - 20, 1),\n effort: 3,\n })\n } else if (contentType === WEBP) {\n transformer.webp({ quality })\n } else if (contentType === PNG) {\n transformer.png({ quality })\n } else if (contentType === JPEG) {\n transformer.jpeg({ quality, mozjpeg: true })\n }\n\n const optimizedBuffer = await transformer.toBuffer()\n\n return optimizedBuffer\n}\n\nexport async function fetchExternalImage(href: string): Promise<ImageUpstream> {\n const res = await fetch(href, {\n signal: AbortSignal.timeout(7_000),\n }).catch((err) => err as Error)\n\n if (res instanceof Error) {\n const err = res as Error\n if (err.name === 'TimeoutError') {\n Log.error('upstream image response timed out for', href)\n throw new ImageError(\n 504,\n '\"url\" parameter is valid but upstream response timed out'\n )\n }\n throw err\n }\n\n if (!res.ok) {\n Log.error('upstream image response failed for', href, res.status)\n throw new ImageError(\n res.status,\n '\"url\" parameter is valid but upstream response is invalid'\n )\n }\n\n const buffer = Buffer.from(await res.arrayBuffer())\n const contentType = res.headers.get('Content-Type')\n const cacheControl = res.headers.get('Cache-Control')\n const etag = extractEtag(res.headers.get('ETag'), buffer)\n return { buffer, contentType, cacheControl, etag }\n}\n\nexport async function fetchInternalImage(\n href: string,\n _req: IncomingMessage,\n _res: ServerResponse,\n handleRequest: (\n newReq: IncomingMessage,\n newRes: ServerResponse,\n newParsedUrl?: NextUrlWithParsedQuery\n ) => Promise<void>\n): Promise<ImageUpstream> {\n try {\n const mocked = createRequestResponseMocks({\n url: href,\n method: _req.method || 'GET',\n socket: _req.socket,\n })\n\n await handleRequest(mocked.req, mocked.res, nodeUrl.parse(href, true))\n await mocked.res.hasStreamed\n\n if (!mocked.res.statusCode) {\n Log.error('image response failed for', href, mocked.res.statusCode)\n throw new ImageError(\n mocked.res.statusCode,\n '\"url\" parameter is valid but internal response is invalid'\n )\n }\n\n const buffer = Buffer.concat(mocked.res.buffers)\n const contentType = mocked.res.getHeader('Content-Type')\n const cacheControl = mocked.res.getHeader('Cache-Control')\n const etag = extractEtag(mocked.res.getHeader('ETag'), buffer)\n\n return { buffer, contentType, cacheControl, etag }\n } catch (err) {\n Log.error('upstream image response failed for', href, err)\n throw new ImageError(\n 500,\n '\"url\" parameter is valid but upstream response is invalid'\n )\n }\n}\n\nexport async function imageOptimizer(\n imageUpstream: ImageUpstream,\n paramsResult: Pick<\n ImageParamsResult,\n 'href' | 'width' | 'quality' | 'mimeType'\n >,\n nextConfig: {\n experimental: Pick<\n NextConfigComplete['experimental'],\n | 'imgOptConcurrency'\n | 'imgOptMaxInputPixels'\n | 'imgOptSequentialRead'\n | 'imgOptTimeoutInSeconds'\n >\n images: Pick<\n NextConfigComplete['images'],\n 'dangerouslyAllowSVG' | 'minimumCacheTTL'\n >\n },\n opts: {\n isDev?: boolean\n silent?: boolean\n previousCacheEntry?: IncrementalResponseCacheEntry | null\n }\n): Promise<{\n buffer: Buffer\n contentType: string\n maxAge: number\n etag: string\n upstreamEtag: string\n error?: unknown\n}> {\n const { href, quality, width, mimeType } = paramsResult\n const { buffer: upstreamBuffer, etag: upstreamEtag } = imageUpstream\n const maxAge = Math.max(\n nextConfig.images.minimumCacheTTL,\n getMaxAge(imageUpstream.cacheControl)\n )\n\n const upstreamType = await detectContentType(upstreamBuffer)\n\n if (\n !upstreamType ||\n !upstreamType.startsWith('image/') ||\n upstreamType.includes(',')\n ) {\n if (!opts.silent) {\n Log.error(\n \"The requested resource isn't a valid image for\",\n href,\n 'received',\n upstreamType\n )\n }\n throw new ImageError(400, \"The requested resource isn't a valid image.\")\n }\n if (\n upstreamType.startsWith('image/svg') &&\n !nextConfig.images.dangerouslyAllowSVG\n ) {\n if (!opts.silent) {\n Log.error(\n `The requested resource \"${href}\" has type \"${upstreamType}\" but dangerouslyAllowSVG is disabled. Consider adding the \"unoptimized\" property to the <Image>.`\n )\n }\n throw new ImageError(\n 400,\n '\"url\" parameter is valid but image type is not allowed'\n )\n }\n if (ANIMATABLE_TYPES.includes(upstreamType) && isAnimated(upstreamBuffer)) {\n if (!opts.silent) {\n Log.warnOnce(\n `The requested resource \"${href}\" is an animated image so it will not be optimized. Consider adding the \"unoptimized\" property to the <Image>.`\n )\n }\n return {\n buffer: upstreamBuffer,\n contentType: upstreamType,\n maxAge,\n etag: upstreamEtag,\n upstreamEtag,\n }\n }\n if (BYPASS_TYPES.includes(upstreamType)) {\n return {\n buffer: upstreamBuffer,\n contentType: upstreamType,\n maxAge,\n etag: upstreamEtag,\n upstreamEtag,\n }\n }\n\n let contentType: string\n\n if (mimeType) {\n contentType = mimeType\n } else if (\n getExtension(upstreamType) &&\n upstreamType !== WEBP &&\n upstreamType !== AVIF\n ) {\n contentType = upstreamType\n } else {\n contentType = JPEG\n }\n const previouslyCachedImage = getPreviouslyCachedImageOrNull(\n imageUpstream,\n opts.previousCacheEntry\n )\n if (previouslyCachedImage) {\n return {\n buffer: previouslyCachedImage.buffer,\n contentType,\n maxAge: opts?.previousCacheEntry?.cacheControl?.revalidate || maxAge,\n etag: previouslyCachedImage.etag,\n upstreamEtag: previouslyCachedImage.upstreamEtag,\n }\n }\n\n try {\n let optimizedBuffer = await optimizeImage({\n buffer: upstreamBuffer,\n contentType,\n quality,\n width,\n concurrency: nextConfig.experimental.imgOptConcurrency,\n limitInputPixels: nextConfig.experimental.imgOptMaxInputPixels,\n sequentialRead: nextConfig.experimental.imgOptSequentialRead,\n timeoutInSeconds: nextConfig.experimental.imgOptTimeoutInSeconds,\n })\n if (opts.isDev && width <= BLUR_IMG_SIZE && quality === BLUR_QUALITY) {\n // During `next dev`, we don't want to generate blur placeholders with webpack\n // because it can delay starting the dev server. Instead, `next-image-loader.js`\n // will inline a special url to lazily generate the blur placeholder at request time.\n const meta = await getImageSize(optimizedBuffer)\n const blurOpts = {\n blurWidth: meta.width,\n blurHeight: meta.height,\n blurDataURL: `data:${contentType};base64,${optimizedBuffer.toString(\n 'base64'\n )}`,\n }\n optimizedBuffer = Buffer.from(unescape(getImageBlurSvg(blurOpts)))\n contentType = 'image/svg+xml'\n }\n return {\n buffer: optimizedBuffer,\n contentType,\n maxAge,\n etag: getImageEtag(optimizedBuffer),\n upstreamEtag,\n }\n } catch (error) {\n if (upstreamType) {\n // If we fail to optimize, fallback to the original image\n return {\n buffer: upstreamBuffer,\n contentType: upstreamType,\n maxAge: nextConfig.images.minimumCacheTTL,\n etag: upstreamEtag,\n upstreamEtag,\n error,\n }\n } else {\n throw new ImageError(\n 400,\n 'Unable to optimize image and unable to fallback to upstream image'\n )\n }\n }\n}\n\nfunction getFileNameWithExtension(\n url: string,\n contentType: string | null\n): string {\n const [urlWithoutQueryParams] = url.split('?', 1)\n const fileNameWithExtension = urlWithoutQueryParams.split('/').pop()\n if (!contentType || !fileNameWithExtension) {\n return 'image.bin'\n }\n\n const [fileName] = fileNameWithExtension.split('.', 1)\n const extension = getExtension(contentType)\n return `${fileName}.${extension}`\n}\n\nfunction setResponseHeaders(\n req: IncomingMessage,\n res: ServerResponse,\n url: string,\n etag: string,\n contentType: string | null,\n isStatic: boolean,\n xCache: XCacheHeader,\n imagesConfig: ImageConfigComplete,\n maxAge: number,\n isDev: boolean\n) {\n res.setHeader('Vary', 'Accept')\n res.setHeader(\n 'Cache-Control',\n isStatic\n ? 'public, max-age=315360000, immutable'\n : `public, max-age=${isDev ? 0 : maxAge}, must-revalidate`\n )\n if (sendEtagResponse(req, res, etag)) {\n // already called res.end() so we're finished\n return { finished: true }\n }\n if (contentType) {\n res.setHeader('Content-Type', contentType)\n }\n\n const fileName = getFileNameWithExtension(url, contentType)\n res.setHeader(\n 'Content-Disposition',\n contentDisposition(fileName, { type: imagesConfig.contentDispositionType })\n )\n\n res.setHeader('Content-Security-Policy', imagesConfig.contentSecurityPolicy)\n res.setHeader('X-Nextjs-Cache', xCache)\n\n return { finished: false }\n}\n\nexport function sendResponse(\n req: IncomingMessage,\n res: ServerResponse,\n url: string,\n extension: string,\n buffer: Buffer,\n etag: string,\n isStatic: boolean,\n xCache: XCacheHeader,\n imagesConfig: ImageConfigComplete,\n maxAge: number,\n isDev: boolean\n) {\n const contentType = getContentType(extension)\n const result = setResponseHeaders(\n req,\n res,\n url,\n etag,\n contentType,\n isStatic,\n xCache,\n imagesConfig,\n maxAge,\n isDev\n )\n if (!result.finished) {\n res.setHeader('Content-Length', Buffer.byteLength(buffer))\n res.end(buffer)\n }\n}\n\nexport async function getImageSize(buffer: Buffer): Promise<{\n width?: number\n height?: number\n}> {\n const { width, height } = imageSizeOf(buffer)\n return { width, height }\n}\n"],"names":["createHash","promises","mediaType","contentDisposition","imageSizeOf","isAnimated","join","nodeUrl","getImageBlurSvg","hasLocalMatch","hasRemoteMatch","createRequestResponseMocks","CachedRouteKind","sendEtagResponse","getContentType","getExtension","Log","isError","parseUrl","InvariantError","AVIF","WEBP","PNG","JPEG","JXL","JP2","HEIC","GIF","SVG","ICO","ICNS","TIFF","BMP","PDF","CACHE_VERSION","ANIMATABLE_TYPES","BYPASS_TYPES","BLUR_IMG_SIZE","BLUR_QUALITY","_sharp","getSharp","concurrency","require","divisor","process","env","NODE_ENV","Math","floor","max","e","code","Error","getSupportedMimeType","options","accept","mimeType","includes","getHash","items","hash","item","update","String","digest","extractEtag","etag","imageBuffer","Buffer","from","toString","getImageEtag","image","writeToCacheDir","dir","extension","maxAge","expireAt","buffer","upstreamEtag","filename","rm","recursive","force","catch","mkdir","writeFile","detectContentType","every","b","i","sharp","meta","metadata","_","format","undefined","ImageOptimizerCache","validateParams","req","query","nextConfig","isDev","imageData","images","deviceSizes","imageSizes","domains","minimumCacheTTL","formats","remotePatterns","localPatterns","qualities","url","w","q","href","length","warnOnce","errorMessage","Array","isArray","startsWith","isAbsolute","test","decodeURIComponent","pathname","hrefParsed","URL","_error","protocol","width","parseInt","isNaN","sizes","push","isValidSize","quality","headers","isStatic","basePath","getCacheKey","constructor","distDir","cacheDir","get","cacheKey","files","readdir","now","Date","file","maxAgeSt","expireAtSt","split","readFile","Number","value","kind","IMAGE","revalidateAfter","cacheControl","revalidate","expire","isStale","set","experimental","isrFlushToDisk","err","error","ImageError","statusCode","message","parseCacheControl","str","map","Map","directive","key","trim","toLowerCase","getMaxAge","age","endsWith","slice","n","getPreviouslyCachedImageOrNull","upstreamImage","previousCacheEntry","optimizeImage","contentType","height","limitInputPixels","sequentialRead","timeoutInSeconds","transformer","timeout","seconds","rotate","resize","withoutEnlargement","avif","effort","webp","png","jpeg","mozjpeg","optimizedBuffer","toBuffer","fetchExternalImage","res","fetch","signal","AbortSignal","name","ok","status","arrayBuffer","fetchInternalImage","_req","_res","handleRequest","mocked","method","socket","parse","hasStreamed","concat","buffers","getHeader","imageOptimizer","imageUpstream","paramsResult","opts","upstreamBuffer","upstreamType","silent","dangerouslyAllowSVG","previouslyCachedImage","imgOptConcurrency","imgOptMaxInputPixels","imgOptSequentialRead","imgOptTimeoutInSeconds","getImageSize","blurOpts","blurWidth","blurHeight","blurDataURL","unescape","getFileNameWithExtension","urlWithoutQueryParams","fileNameWithExtension","pop","fileName","setResponseHeaders","xCache","imagesConfig","setHeader","finished","type","contentDispositionType","contentSecurityPolicy","sendResponse","result","byteLength","end"],"mappings":"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","ignoreList":[0]}
1
+ {"version":3,"sources":["../../src/server/image-optimizer.ts"],"sourcesContent":["import { createHash } from 'crypto'\nimport { promises } from 'fs'\nimport type { IncomingMessage, ServerResponse } from 'http'\nimport { mediaType } from 'next/dist/compiled/@hapi/accept'\nimport contentDisposition from 'next/dist/compiled/content-disposition'\nimport imageSizeOf from 'next/dist/compiled/image-size'\nimport { detector } from 'next/dist/compiled/image-detector/detector.js'\nimport isAnimated from 'next/dist/compiled/is-animated'\nimport { join } from 'path'\nimport nodeUrl, { type UrlWithParsedQuery } from 'url'\n\nimport { getImageBlurSvg } from '../shared/lib/image-blur-svg'\nimport type { ImageConfigComplete } from '../shared/lib/image-config'\nimport { hasLocalMatch } from '../shared/lib/match-local-pattern'\nimport { hasRemoteMatch } from '../shared/lib/match-remote-pattern'\nimport type { NextConfigComplete } from './config-shared'\nimport { createRequestResponseMocks } from './lib/mock-request'\nimport type { NextUrlWithParsedQuery } from './request-meta'\nimport {\n CachedRouteKind,\n type CachedImageValue,\n type IncrementalCacheEntry,\n type IncrementalCacheValue,\n type IncrementalResponseCacheEntry,\n} from './response-cache'\nimport { sendEtagResponse } from './send-payload'\nimport { getContentType, getExtension } from './serve-static'\nimport * as Log from '../build/output/log'\nimport isError from '../lib/is-error'\nimport { parseUrl } from '../lib/url'\nimport type { CacheControl } from './lib/cache-control'\nimport { InvariantError } from '../shared/lib/invariant-error'\n\ntype XCacheHeader = 'MISS' | 'HIT' | 'STALE'\n\nconst AVIF = 'image/avif'\nconst WEBP = 'image/webp'\nconst PNG = 'image/png'\nconst JPEG = 'image/jpeg'\nconst JXL = 'image/jxl'\nconst JP2 = 'image/jp2'\nconst HEIC = 'image/heic'\nconst GIF = 'image/gif'\nconst SVG = 'image/svg+xml'\nconst ICO = 'image/x-icon'\nconst ICNS = 'image/x-icns'\nconst TIFF = 'image/tiff'\nconst BMP = 'image/bmp'\nconst PDF = 'application/pdf'\nconst CACHE_VERSION = 4\nconst ANIMATABLE_TYPES = [WEBP, PNG, GIF]\nconst BYPASS_TYPES = [SVG, ICO, ICNS, BMP, JXL, HEIC]\nconst BLUR_IMG_SIZE = 8 // should match `next-image-loader`\nconst BLUR_QUALITY = 70 // should match `next-image-loader`\n\nlet _sharp: typeof import('sharp')\n\nexport function getSharp(concurrency: number | null | undefined) {\n if (_sharp) {\n return _sharp\n }\n try {\n _sharp = require('sharp') as typeof import('sharp')\n if (_sharp && _sharp.concurrency() > 1) {\n // Reducing concurrency should reduce the memory usage too.\n // We more aggressively reduce in dev but also reduce in prod.\n // https://sharp.pixelplumbing.com/api-utility#concurrency\n const divisor = process.env.NODE_ENV === 'development' ? 4 : 2\n _sharp.concurrency(\n concurrency ?? Math.floor(Math.max(_sharp.concurrency() / divisor, 1))\n )\n }\n } catch (e: unknown) {\n if (isError(e) && e.code === 'MODULE_NOT_FOUND') {\n throw new Error(\n 'Module `sharp` not found. Please run `npm install --cpu=wasm32 sharp` to install it.'\n )\n }\n throw e\n }\n return _sharp\n}\n\nexport interface ImageParamsResult {\n href: string\n isAbsolute: boolean\n isStatic: boolean\n width: number\n quality: number\n mimeType: string\n sizes: number[]\n minimumCacheTTL: number\n}\n\ninterface ImageUpstream {\n buffer: Buffer\n contentType: string | null | undefined\n cacheControl: string | null | undefined\n etag: string\n}\n\nfunction getSupportedMimeType(options: string[], accept = ''): string {\n const mimeType = mediaType(accept, options)\n return accept.includes(mimeType) ? mimeType : ''\n}\n\nexport function getHash(items: (string | number | Buffer)[]) {\n const hash = createHash('sha256')\n for (let item of items) {\n if (typeof item === 'number') hash.update(String(item))\n else {\n hash.update(item)\n }\n }\n // See https://en.wikipedia.org/wiki/Base64#URL_applications\n return hash.digest('base64url')\n}\n\nexport function extractEtag(\n etag: string | null | undefined,\n imageBuffer: Buffer\n) {\n if (etag) {\n // upstream etag needs to be base64url encoded due to weak etag signature\n // as we store this in the cache-entry file name.\n return Buffer.from(etag).toString('base64url')\n }\n return getImageEtag(imageBuffer)\n}\n\nexport function getImageEtag(image: Buffer) {\n return getHash([image])\n}\n\nasync function writeToCacheDir(\n dir: string,\n extension: string,\n maxAge: number,\n expireAt: number,\n buffer: Buffer,\n etag: string,\n upstreamEtag: string\n) {\n const filename = join(\n dir,\n `${maxAge}.${expireAt}.${etag}.${upstreamEtag}.${extension}`\n )\n\n await promises.rm(dir, { recursive: true, force: true }).catch(() => {})\n\n await promises.mkdir(dir, { recursive: true })\n await promises.writeFile(filename, buffer)\n}\n\n/**\n * Inspects the first few bytes of a buffer to determine if\n * it matches the \"magic number\" of known file signatures.\n * https://en.wikipedia.org/wiki/List_of_file_signatures\n */\nexport async function detectContentType(\n buffer: Buffer\n): Promise<string | null> {\n if ([0xff, 0xd8, 0xff].every((b, i) => buffer[i] === b)) {\n return JPEG\n }\n if (\n [0x89, 0x50, 0x4e, 0x47, 0x0d, 0x0a, 0x1a, 0x0a].every(\n (b, i) => buffer[i] === b\n )\n ) {\n return PNG\n }\n if ([0x47, 0x49, 0x46, 0x38].every((b, i) => buffer[i] === b)) {\n return GIF\n }\n if (\n [0x52, 0x49, 0x46, 0x46, 0, 0, 0, 0, 0x57, 0x45, 0x42, 0x50].every(\n (b, i) => !b || buffer[i] === b\n )\n ) {\n return WEBP\n }\n if ([0x3c, 0x3f, 0x78, 0x6d, 0x6c].every((b, i) => buffer[i] === b)) {\n return SVG\n }\n if ([0x3c, 0x73, 0x76, 0x67].every((b, i) => buffer[i] === b)) {\n return SVG\n }\n if (\n [0, 0, 0, 0, 0x66, 0x74, 0x79, 0x70, 0x61, 0x76, 0x69, 0x66].every(\n (b, i) => !b || buffer[i] === b\n )\n ) {\n return AVIF\n }\n if ([0x00, 0x00, 0x01, 0x00].every((b, i) => buffer[i] === b)) {\n return ICO\n }\n if ([0x69, 0x63, 0x6e, 0x73].every((b, i) => buffer[i] === b)) {\n return ICNS\n }\n if ([0x49, 0x49, 0x2a, 0x00].every((b, i) => buffer[i] === b)) {\n return TIFF\n }\n if ([0x42, 0x4d].every((b, i) => buffer[i] === b)) {\n return BMP\n }\n if ([0xff, 0x0a].every((b, i) => buffer[i] === b)) {\n return JXL\n }\n if (\n [\n 0x00, 0x00, 0x00, 0x0c, 0x4a, 0x58, 0x4c, 0x20, 0x0d, 0x0a, 0x87, 0x0a,\n ].every((b, i) => buffer[i] === b)\n ) {\n return JXL\n }\n if (\n [0, 0, 0, 0, 0x66, 0x74, 0x79, 0x70, 0x68, 0x65, 0x69, 0x63].every(\n (b, i) => !b || buffer[i] === b\n )\n ) {\n return HEIC\n }\n if ([0x25, 0x50, 0x44, 0x46, 0x2d].every((b, i) => buffer[i] === b)) {\n return PDF\n }\n if (\n [\n 0x00, 0x00, 0x00, 0x0c, 0x6a, 0x50, 0x20, 0x20, 0x0d, 0x0a, 0x87, 0x0a,\n ].every((b, i) => buffer[i] === b)\n ) {\n return JP2\n }\n\n let format:\n | import('sharp').Metadata['format']\n | ReturnType<typeof detector>\n | undefined\n format = detector(buffer)\n\n if (!format) {\n const sharp = getSharp(null)\n const meta = await sharp(buffer)\n .metadata()\n .catch((_) => null)\n format = meta?.format\n }\n\n switch (format) {\n case 'avif':\n return AVIF\n case 'webp':\n return WEBP\n case 'png':\n return PNG\n case 'jpeg':\n case 'jpg':\n return JPEG\n case 'gif':\n return GIF\n case 'svg':\n return SVG\n case 'jxl':\n case 'jxl-stream':\n return JXL\n case 'jp2':\n return JP2\n case 'tiff':\n case 'tif':\n return TIFF\n case 'pdf':\n return PDF\n case 'bmp':\n return BMP\n case 'ico':\n return ICO\n case 'icns':\n return ICNS\n case 'dcraw':\n case 'dz':\n case 'exr':\n case 'fits':\n case 'heif':\n case 'input':\n case 'magick':\n case 'openslide':\n case 'ppm':\n case 'rad':\n case 'raw':\n case 'v':\n case 'cur':\n case 'dds':\n case 'j2c':\n case 'ktx':\n case 'pnm':\n case 'psd':\n case 'tga':\n case undefined:\n default:\n return null\n }\n}\n\nexport class ImageOptimizerCache {\n private cacheDir: string\n private nextConfig: NextConfigComplete\n\n static validateParams(\n req: IncomingMessage,\n query: UrlWithParsedQuery['query'],\n nextConfig: NextConfigComplete,\n isDev: boolean\n ): ImageParamsResult | { errorMessage: string } {\n const imageData = nextConfig.images\n const {\n deviceSizes = [],\n imageSizes = [],\n domains = [],\n minimumCacheTTL = 60,\n formats = ['image/webp'],\n } = imageData\n const remotePatterns = nextConfig.images?.remotePatterns || []\n const localPatterns = nextConfig.images?.localPatterns\n const qualities = nextConfig.images?.qualities\n const { url, w, q } = query\n let href: string\n\n if (domains.length > 0) {\n Log.warnOnce(\n 'The \"images.domains\" configuration is deprecated. Please use \"images.remotePatterns\" configuration instead.'\n )\n }\n\n if (!url) {\n return { errorMessage: '\"url\" parameter is required' }\n } else if (Array.isArray(url)) {\n return { errorMessage: '\"url\" parameter cannot be an array' }\n }\n\n if (url.length > 3072) {\n return { errorMessage: '\"url\" parameter is too long' }\n }\n\n if (url.startsWith('//')) {\n return {\n errorMessage: '\"url\" parameter cannot be a protocol-relative URL (//)',\n }\n }\n\n let isAbsolute: boolean\n\n if (url.startsWith('/')) {\n href = url\n isAbsolute = false\n if (\n /\\/_next\\/image($|\\/)/.test(\n decodeURIComponent(parseUrl(url)?.pathname ?? '')\n )\n ) {\n return {\n errorMessage: '\"url\" parameter cannot be recursive',\n }\n }\n if (!hasLocalMatch(localPatterns, url)) {\n return { errorMessage: '\"url\" parameter is not allowed' }\n }\n } else {\n let hrefParsed: URL\n\n try {\n hrefParsed = new URL(url)\n href = hrefParsed.toString()\n isAbsolute = true\n } catch (_error) {\n return { errorMessage: '\"url\" parameter is invalid' }\n }\n\n if (!['http:', 'https:'].includes(hrefParsed.protocol)) {\n return { errorMessage: '\"url\" parameter is invalid' }\n }\n\n if (!hasRemoteMatch(domains, remotePatterns, hrefParsed)) {\n return { errorMessage: '\"url\" parameter is not allowed' }\n }\n }\n\n if (!w) {\n return { errorMessage: '\"w\" parameter (width) is required' }\n } else if (Array.isArray(w)) {\n return { errorMessage: '\"w\" parameter (width) cannot be an array' }\n } else if (!/^[0-9]+$/.test(w)) {\n return {\n errorMessage: '\"w\" parameter (width) must be an integer greater than 0',\n }\n }\n\n if (!q) {\n return { errorMessage: '\"q\" parameter (quality) is required' }\n } else if (Array.isArray(q)) {\n return { errorMessage: '\"q\" parameter (quality) cannot be an array' }\n } else if (!/^[0-9]+$/.test(q)) {\n return {\n errorMessage:\n '\"q\" parameter (quality) must be an integer between 1 and 100',\n }\n }\n\n const width = parseInt(w, 10)\n\n if (width <= 0 || isNaN(width)) {\n return {\n errorMessage: '\"w\" parameter (width) must be an integer greater than 0',\n }\n }\n\n const sizes = [...(deviceSizes || []), ...(imageSizes || [])]\n\n if (isDev) {\n sizes.push(BLUR_IMG_SIZE)\n }\n\n const isValidSize =\n sizes.includes(width) || (isDev && width <= BLUR_IMG_SIZE)\n\n if (!isValidSize) {\n return {\n errorMessage: `\"w\" parameter (width) of ${width} is not allowed`,\n }\n }\n\n const quality = parseInt(q, 10)\n\n if (isNaN(quality) || quality < 1 || quality > 100) {\n return {\n errorMessage:\n '\"q\" parameter (quality) must be an integer between 1 and 100',\n }\n }\n\n if (qualities) {\n if (isDev) {\n qualities.push(BLUR_QUALITY)\n }\n\n if (!qualities.includes(quality)) {\n return {\n errorMessage: `\"q\" parameter (quality) of ${q} is not allowed`,\n }\n }\n }\n\n const mimeType = getSupportedMimeType(formats || [], req.headers['accept'])\n\n const isStatic = url.startsWith(\n `${nextConfig.basePath || ''}/_next/static/media`\n )\n\n return {\n href,\n sizes,\n isAbsolute,\n isStatic,\n width,\n quality,\n mimeType,\n minimumCacheTTL,\n }\n }\n\n static getCacheKey({\n href,\n width,\n quality,\n mimeType,\n }: {\n href: string\n width: number\n quality: number\n mimeType: string\n }): string {\n return getHash([CACHE_VERSION, href, width, quality, mimeType])\n }\n\n constructor({\n distDir,\n nextConfig,\n }: {\n distDir: string\n nextConfig: NextConfigComplete\n }) {\n this.cacheDir = join(distDir, 'cache', 'images')\n this.nextConfig = nextConfig\n }\n\n async get(cacheKey: string): Promise<IncrementalResponseCacheEntry | null> {\n try {\n const cacheDir = join(this.cacheDir, cacheKey)\n const files = await promises.readdir(cacheDir)\n const now = Date.now()\n\n for (const file of files) {\n const [maxAgeSt, expireAtSt, etag, upstreamEtag, extension] =\n file.split('.', 5)\n const buffer = await promises.readFile(join(cacheDir, file))\n const expireAt = Number(expireAtSt)\n const maxAge = Number(maxAgeSt)\n\n return {\n value: {\n kind: CachedRouteKind.IMAGE,\n etag,\n buffer,\n extension,\n upstreamEtag,\n },\n revalidateAfter:\n Math.max(maxAge, this.nextConfig.images.minimumCacheTTL) * 1000 +\n Date.now(),\n cacheControl: { revalidate: maxAge, expire: undefined },\n isStale: now > expireAt,\n }\n }\n } catch (_) {\n // failed to read from cache dir, treat as cache miss\n }\n return null\n }\n async set(\n cacheKey: string,\n value: IncrementalCacheValue | null,\n {\n cacheControl,\n }: {\n cacheControl?: CacheControl\n }\n ) {\n if (!this.nextConfig.experimental.isrFlushToDisk) {\n return\n }\n\n if (value?.kind !== CachedRouteKind.IMAGE) {\n throw new Error('invariant attempted to set non-image to image-cache')\n }\n\n const revalidate = cacheControl?.revalidate\n\n if (typeof revalidate !== 'number') {\n throw new InvariantError('revalidate must be a number for image-cache')\n }\n\n const expireAt =\n Math.max(revalidate, this.nextConfig.images.minimumCacheTTL) * 1000 +\n Date.now()\n\n try {\n await writeToCacheDir(\n join(this.cacheDir, cacheKey),\n value.extension,\n revalidate,\n expireAt,\n value.buffer,\n value.etag,\n value.upstreamEtag\n )\n } catch (err) {\n Log.error(`Failed to write image to cache ${cacheKey}`, err)\n }\n }\n}\nexport class ImageError extends Error {\n statusCode: number\n\n constructor(statusCode: number, message: string) {\n super(message)\n\n // ensure an error status is used > 400\n if (statusCode >= 400) {\n this.statusCode = statusCode\n } else {\n this.statusCode = 500\n }\n }\n}\n\nfunction parseCacheControl(\n str: string | null | undefined\n): Map<string, string> {\n const map = new Map<string, string>()\n if (!str) {\n return map\n }\n for (let directive of str.split(',')) {\n let [key, value] = directive.trim().split('=', 2)\n key = key.toLowerCase()\n if (value) {\n value = value.toLowerCase()\n }\n map.set(key, value)\n }\n return map\n}\n\nexport function getMaxAge(str: string | null | undefined): number {\n const map = parseCacheControl(str)\n if (map) {\n let age = map.get('s-maxage') || map.get('max-age') || ''\n if (age.startsWith('\"') && age.endsWith('\"')) {\n age = age.slice(1, -1)\n }\n const n = parseInt(age, 10)\n if (!isNaN(n)) {\n return n\n }\n }\n return 0\n}\nexport function getPreviouslyCachedImageOrNull(\n upstreamImage: ImageUpstream,\n previousCacheEntry: IncrementalCacheEntry | null | undefined\n): CachedImageValue | null {\n if (\n previousCacheEntry?.value?.kind === 'IMAGE' &&\n // Images that are SVGs, animated or failed the optimization previously end up using upstreamEtag as their etag as well,\n // in these cases we want to trigger a new \"optimization\" attempt.\n previousCacheEntry.value.upstreamEtag !== previousCacheEntry.value.etag &&\n // and the upstream etag is the same as the previous cache entry's\n upstreamImage.etag === previousCacheEntry.value.upstreamEtag\n ) {\n return previousCacheEntry.value\n }\n return null\n}\n\nexport async function optimizeImage({\n buffer,\n contentType,\n quality,\n width,\n height,\n concurrency,\n limitInputPixels,\n sequentialRead,\n timeoutInSeconds,\n}: {\n buffer: Buffer\n contentType: string\n quality: number\n width: number\n height?: number\n concurrency?: number | null\n limitInputPixels?: number\n sequentialRead?: boolean | null\n timeoutInSeconds?: number\n}): Promise<Buffer> {\n const sharp = getSharp(concurrency)\n const transformer = sharp(buffer, {\n limitInputPixels,\n sequentialRead: sequentialRead ?? undefined,\n })\n .timeout({\n seconds: timeoutInSeconds ?? 7,\n })\n .rotate()\n\n if (height) {\n transformer.resize(width, height)\n } else {\n transformer.resize(width, undefined, {\n withoutEnlargement: true,\n })\n }\n\n if (contentType === AVIF) {\n transformer.avif({\n quality: Math.max(quality - 20, 1),\n effort: 3,\n })\n } else if (contentType === WEBP) {\n transformer.webp({ quality })\n } else if (contentType === PNG) {\n transformer.png({ quality })\n } else if (contentType === JPEG) {\n transformer.jpeg({ quality, mozjpeg: true })\n }\n\n const optimizedBuffer = await transformer.toBuffer()\n\n return optimizedBuffer\n}\n\nexport async function fetchExternalImage(href: string): Promise<ImageUpstream> {\n const res = await fetch(href, {\n signal: AbortSignal.timeout(7_000),\n }).catch((err) => err as Error)\n\n if (res instanceof Error) {\n const err = res as Error\n if (err.name === 'TimeoutError') {\n Log.error('upstream image response timed out for', href)\n throw new ImageError(\n 504,\n '\"url\" parameter is valid but upstream response timed out'\n )\n }\n throw err\n }\n\n if (!res.ok) {\n Log.error('upstream image response failed for', href, res.status)\n throw new ImageError(\n res.status,\n '\"url\" parameter is valid but upstream response is invalid'\n )\n }\n\n const buffer = Buffer.from(await res.arrayBuffer())\n const contentType = res.headers.get('Content-Type')\n const cacheControl = res.headers.get('Cache-Control')\n const etag = extractEtag(res.headers.get('ETag'), buffer)\n return { buffer, contentType, cacheControl, etag }\n}\n\nexport async function fetchInternalImage(\n href: string,\n _req: IncomingMessage,\n _res: ServerResponse,\n handleRequest: (\n newReq: IncomingMessage,\n newRes: ServerResponse,\n newParsedUrl?: NextUrlWithParsedQuery\n ) => Promise<void>\n): Promise<ImageUpstream> {\n try {\n const mocked = createRequestResponseMocks({\n url: href,\n method: _req.method || 'GET',\n socket: _req.socket,\n })\n\n await handleRequest(mocked.req, mocked.res, nodeUrl.parse(href, true))\n await mocked.res.hasStreamed\n\n if (!mocked.res.statusCode) {\n Log.error('image response failed for', href, mocked.res.statusCode)\n throw new ImageError(\n mocked.res.statusCode,\n '\"url\" parameter is valid but internal response is invalid'\n )\n }\n\n const buffer = Buffer.concat(mocked.res.buffers)\n const contentType = mocked.res.getHeader('Content-Type')\n const cacheControl = mocked.res.getHeader('Cache-Control')\n const etag = extractEtag(mocked.res.getHeader('ETag'), buffer)\n\n return { buffer, contentType, cacheControl, etag }\n } catch (err) {\n Log.error('upstream image response failed for', href, err)\n throw new ImageError(\n 500,\n '\"url\" parameter is valid but upstream response is invalid'\n )\n }\n}\n\nexport async function imageOptimizer(\n imageUpstream: ImageUpstream,\n paramsResult: Pick<\n ImageParamsResult,\n 'href' | 'width' | 'quality' | 'mimeType'\n >,\n nextConfig: {\n experimental: Pick<\n NextConfigComplete['experimental'],\n | 'imgOptConcurrency'\n | 'imgOptMaxInputPixels'\n | 'imgOptSequentialRead'\n | 'imgOptTimeoutInSeconds'\n >\n images: Pick<\n NextConfigComplete['images'],\n 'dangerouslyAllowSVG' | 'minimumCacheTTL'\n >\n },\n opts: {\n isDev?: boolean\n silent?: boolean\n previousCacheEntry?: IncrementalResponseCacheEntry | null\n }\n): Promise<{\n buffer: Buffer\n contentType: string\n maxAge: number\n etag: string\n upstreamEtag: string\n error?: unknown\n}> {\n const { href, quality, width, mimeType } = paramsResult\n const { buffer: upstreamBuffer, etag: upstreamEtag } = imageUpstream\n const maxAge = Math.max(\n nextConfig.images.minimumCacheTTL,\n getMaxAge(imageUpstream.cacheControl)\n )\n\n const upstreamType = await detectContentType(upstreamBuffer)\n\n if (\n !upstreamType ||\n !upstreamType.startsWith('image/') ||\n upstreamType.includes(',')\n ) {\n if (!opts.silent) {\n Log.error(\n \"The requested resource isn't a valid image for\",\n href,\n 'received',\n upstreamType\n )\n }\n throw new ImageError(400, \"The requested resource isn't a valid image.\")\n }\n if (\n upstreamType.startsWith('image/svg') &&\n !nextConfig.images.dangerouslyAllowSVG\n ) {\n if (!opts.silent) {\n Log.error(\n `The requested resource \"${href}\" has type \"${upstreamType}\" but dangerouslyAllowSVG is disabled. Consider adding the \"unoptimized\" property to the <Image>.`\n )\n }\n throw new ImageError(\n 400,\n '\"url\" parameter is valid but image type is not allowed'\n )\n }\n if (ANIMATABLE_TYPES.includes(upstreamType) && isAnimated(upstreamBuffer)) {\n if (!opts.silent) {\n Log.warnOnce(\n `The requested resource \"${href}\" is an animated image so it will not be optimized. Consider adding the \"unoptimized\" property to the <Image>.`\n )\n }\n return {\n buffer: upstreamBuffer,\n contentType: upstreamType,\n maxAge,\n etag: upstreamEtag,\n upstreamEtag,\n }\n }\n if (BYPASS_TYPES.includes(upstreamType)) {\n return {\n buffer: upstreamBuffer,\n contentType: upstreamType,\n maxAge,\n etag: upstreamEtag,\n upstreamEtag,\n }\n }\n\n let contentType: string\n\n if (mimeType) {\n contentType = mimeType\n } else if (\n getExtension(upstreamType) &&\n upstreamType !== WEBP &&\n upstreamType !== AVIF\n ) {\n contentType = upstreamType\n } else {\n contentType = JPEG\n }\n const previouslyCachedImage = getPreviouslyCachedImageOrNull(\n imageUpstream,\n opts.previousCacheEntry\n )\n if (previouslyCachedImage) {\n return {\n buffer: previouslyCachedImage.buffer,\n contentType,\n maxAge: opts?.previousCacheEntry?.cacheControl?.revalidate || maxAge,\n etag: previouslyCachedImage.etag,\n upstreamEtag: previouslyCachedImage.upstreamEtag,\n }\n }\n\n try {\n let optimizedBuffer = await optimizeImage({\n buffer: upstreamBuffer,\n contentType,\n quality,\n width,\n concurrency: nextConfig.experimental.imgOptConcurrency,\n limitInputPixels: nextConfig.experimental.imgOptMaxInputPixels,\n sequentialRead: nextConfig.experimental.imgOptSequentialRead,\n timeoutInSeconds: nextConfig.experimental.imgOptTimeoutInSeconds,\n })\n if (opts.isDev && width <= BLUR_IMG_SIZE && quality === BLUR_QUALITY) {\n // During `next dev`, we don't want to generate blur placeholders with webpack\n // because it can delay starting the dev server. Instead, `next-image-loader.js`\n // will inline a special url to lazily generate the blur placeholder at request time.\n const meta = await getImageSize(optimizedBuffer)\n const blurOpts = {\n blurWidth: meta.width,\n blurHeight: meta.height,\n blurDataURL: `data:${contentType};base64,${optimizedBuffer.toString(\n 'base64'\n )}`,\n }\n optimizedBuffer = Buffer.from(unescape(getImageBlurSvg(blurOpts)))\n contentType = 'image/svg+xml'\n }\n return {\n buffer: optimizedBuffer,\n contentType,\n maxAge,\n etag: getImageEtag(optimizedBuffer),\n upstreamEtag,\n }\n } catch (error) {\n if (upstreamType) {\n // If we fail to optimize, fallback to the original image\n return {\n buffer: upstreamBuffer,\n contentType: upstreamType,\n maxAge: nextConfig.images.minimumCacheTTL,\n etag: upstreamEtag,\n upstreamEtag,\n error,\n }\n } else {\n throw new ImageError(\n 400,\n 'Unable to optimize image and unable to fallback to upstream image'\n )\n }\n }\n}\n\nfunction getFileNameWithExtension(\n url: string,\n contentType: string | null\n): string {\n const [urlWithoutQueryParams] = url.split('?', 1)\n const fileNameWithExtension = urlWithoutQueryParams.split('/').pop()\n if (!contentType || !fileNameWithExtension) {\n return 'image.bin'\n }\n\n const [fileName] = fileNameWithExtension.split('.', 1)\n const extension = getExtension(contentType)\n return `${fileName}.${extension}`\n}\n\nfunction setResponseHeaders(\n req: IncomingMessage,\n res: ServerResponse,\n url: string,\n etag: string,\n contentType: string | null,\n isStatic: boolean,\n xCache: XCacheHeader,\n imagesConfig: ImageConfigComplete,\n maxAge: number,\n isDev: boolean\n) {\n res.setHeader('Vary', 'Accept')\n res.setHeader(\n 'Cache-Control',\n isStatic\n ? 'public, max-age=315360000, immutable'\n : `public, max-age=${isDev ? 0 : maxAge}, must-revalidate`\n )\n if (sendEtagResponse(req, res, etag)) {\n // already called res.end() so we're finished\n return { finished: true }\n }\n if (contentType) {\n res.setHeader('Content-Type', contentType)\n }\n\n const fileName = getFileNameWithExtension(url, contentType)\n res.setHeader(\n 'Content-Disposition',\n contentDisposition(fileName, { type: imagesConfig.contentDispositionType })\n )\n\n res.setHeader('Content-Security-Policy', imagesConfig.contentSecurityPolicy)\n res.setHeader('X-Nextjs-Cache', xCache)\n\n return { finished: false }\n}\n\nexport function sendResponse(\n req: IncomingMessage,\n res: ServerResponse,\n url: string,\n extension: string,\n buffer: Buffer,\n etag: string,\n isStatic: boolean,\n xCache: XCacheHeader,\n imagesConfig: ImageConfigComplete,\n maxAge: number,\n isDev: boolean\n) {\n const contentType = getContentType(extension)\n const result = setResponseHeaders(\n req,\n res,\n url,\n etag,\n contentType,\n isStatic,\n xCache,\n imagesConfig,\n maxAge,\n isDev\n )\n if (!result.finished) {\n res.setHeader('Content-Length', Buffer.byteLength(buffer))\n res.end(buffer)\n }\n}\n\nexport async function getImageSize(buffer: Buffer): Promise<{\n width?: number\n height?: number\n}> {\n const { width, height } = imageSizeOf(buffer)\n return { width, height }\n}\n"],"names":["createHash","promises","mediaType","contentDisposition","imageSizeOf","detector","isAnimated","join","nodeUrl","getImageBlurSvg","hasLocalMatch","hasRemoteMatch","createRequestResponseMocks","CachedRouteKind","sendEtagResponse","getContentType","getExtension","Log","isError","parseUrl","InvariantError","AVIF","WEBP","PNG","JPEG","JXL","JP2","HEIC","GIF","SVG","ICO","ICNS","TIFF","BMP","PDF","CACHE_VERSION","ANIMATABLE_TYPES","BYPASS_TYPES","BLUR_IMG_SIZE","BLUR_QUALITY","_sharp","getSharp","concurrency","require","divisor","process","env","NODE_ENV","Math","floor","max","e","code","Error","getSupportedMimeType","options","accept","mimeType","includes","getHash","items","hash","item","update","String","digest","extractEtag","etag","imageBuffer","Buffer","from","toString","getImageEtag","image","writeToCacheDir","dir","extension","maxAge","expireAt","buffer","upstreamEtag","filename","rm","recursive","force","catch","mkdir","writeFile","detectContentType","every","b","i","format","sharp","meta","metadata","_","undefined","ImageOptimizerCache","validateParams","req","query","nextConfig","isDev","imageData","images","deviceSizes","imageSizes","domains","minimumCacheTTL","formats","remotePatterns","localPatterns","qualities","url","w","q","href","length","warnOnce","errorMessage","Array","isArray","startsWith","isAbsolute","test","decodeURIComponent","pathname","hrefParsed","URL","_error","protocol","width","parseInt","isNaN","sizes","push","isValidSize","quality","headers","isStatic","basePath","getCacheKey","constructor","distDir","cacheDir","get","cacheKey","files","readdir","now","Date","file","maxAgeSt","expireAtSt","split","readFile","Number","value","kind","IMAGE","revalidateAfter","cacheControl","revalidate","expire","isStale","set","experimental","isrFlushToDisk","err","error","ImageError","statusCode","message","parseCacheControl","str","map","Map","directive","key","trim","toLowerCase","getMaxAge","age","endsWith","slice","n","getPreviouslyCachedImageOrNull","upstreamImage","previousCacheEntry","optimizeImage","contentType","height","limitInputPixels","sequentialRead","timeoutInSeconds","transformer","timeout","seconds","rotate","resize","withoutEnlargement","avif","effort","webp","png","jpeg","mozjpeg","optimizedBuffer","toBuffer","fetchExternalImage","res","fetch","signal","AbortSignal","name","ok","status","arrayBuffer","fetchInternalImage","_req","_res","handleRequest","mocked","method","socket","parse","hasStreamed","concat","buffers","getHeader","imageOptimizer","imageUpstream","paramsResult","opts","upstreamBuffer","upstreamType","silent","dangerouslyAllowSVG","previouslyCachedImage","imgOptConcurrency","imgOptMaxInputPixels","imgOptSequentialRead","imgOptTimeoutInSeconds","getImageSize","blurOpts","blurWidth","blurHeight","blurDataURL","unescape","getFileNameWithExtension","urlWithoutQueryParams","fileNameWithExtension","pop","fileName","setResponseHeaders","xCache","imagesConfig","setHeader","finished","type","contentDispositionType","contentSecurityPolicy","sendResponse","result","byteLength","end"],"mappings":"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","ignoreList":[0]}
@@ -12,7 +12,7 @@ export function logStartInfo({ networkUrl, appUrl, envInfo, experimentalFeatures
12
12
  } else {
13
13
  bundlerSuffix = '';
14
14
  }
15
- Log.bootstrap(`${bold(purple(`${Log.prefixes.ready} Next.js ${"15.4.2-canary.36"}`))}${bundlerSuffix}`);
15
+ Log.bootstrap(`${bold(purple(`${Log.prefixes.ready} Next.js ${"15.4.2-canary.38"}`))}${bundlerSuffix}`);
16
16
  if (appUrl) {
17
17
  Log.bootstrap(`- Local: ${appUrl}`);
18
18
  }
@@ -111,7 +111,7 @@ export async function getRequestHandlers({ dir, port, isDev, onDevServerCleanup,
111
111
  export 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.4.2-canary.36"})`;
114
+ process.title = `next-server (v${"15.4.2-canary.38"})`;
115
115
  let handlersReady = ()=>{};
116
116
  let handlersError = ()=>{};
117
117
  let handlersPromise = new Promise((resolve, reject)=>{
@@ -1,6 +1,6 @@
1
1
  export function isStableBuild() {
2
2
  var _process_env___NEXT_VERSION;
3
- return !((_process_env___NEXT_VERSION = "15.4.2-canary.36") == null ? void 0 : _process_env___NEXT_VERSION.includes('canary')) && !process.env.__NEXT_TEST_MODE && !process.env.NEXT_PRIVATE_LOCAL_DEV;
3
+ return !((_process_env___NEXT_VERSION = "15.4.2-canary.38") == null ? void 0 : _process_env___NEXT_VERSION.includes('canary')) && !process.env.__NEXT_TEST_MODE && !process.env.NEXT_PRIVATE_LOCAL_DEV;
4
4
  }
5
5
  export class CanaryOnlyError extends Error {
6
6
  constructor(arg){
@@ -145,7 +145,7 @@ async function createHotReloaderTurbopack(opts, serverFields, distDir, resetFetc
145
145
  }
146
146
  const hasRewrites = opts.fsChecker.rewrites.afterFiles.length > 0 || opts.fsChecker.rewrites.beforeFiles.length > 0 || opts.fsChecker.rewrites.fallback.length > 0;
147
147
  const hotReloaderSpan = (0, _trace.trace)('hot-reloader', undefined, {
148
- version: "15.4.2-canary.36"
148
+ version: "15.4.2-canary.38"
149
149
  });
150
150
  // Ensure the hotReloaderSpan is flushed immediately as it's the parentSpan for all processing
151
151
  // of the current `next dev` invocation.
@@ -262,7 +262,7 @@ class HotReloaderWebpack {
262
262
  this.previewProps = previewProps;
263
263
  this.rewrites = rewrites;
264
264
  this.hotReloaderSpan = (0, _trace.trace)('hot-reloader', undefined, {
265
- version: "15.4.2-canary.36"
265
+ version: "15.4.2-canary.38"
266
266
  });
267
267
  // Ensure the hotReloaderSpan is flushed immediately as it's the parentSpan for all processing
268
268
  // of the current `next dev` invocation.
@@ -77,6 +77,7 @@ const _fs = require("fs");
77
77
  const _accept = require("next/dist/compiled/@hapi/accept");
78
78
  const _contentdisposition = /*#__PURE__*/ _interop_require_default(require("next/dist/compiled/content-disposition"));
79
79
  const _imagesize = /*#__PURE__*/ _interop_require_default(require("next/dist/compiled/image-size"));
80
+ const _detector = require("next/dist/compiled/image-detector/detector.js");
80
81
  const _isanimated = /*#__PURE__*/ _interop_require_default(require("next/dist/compiled/is-animated"));
81
82
  const _path = require("path");
82
83
  const _url = /*#__PURE__*/ _interop_require_default(require("url"));
@@ -404,9 +405,14 @@ async function detectContentType(buffer) {
404
405
  ].every((b, i)=>buffer[i] === b)) {
405
406
  return JP2;
406
407
  }
407
- const sharp = getSharp(null);
408
- const meta = await sharp(buffer).metadata().catch((_)=>null);
409
- switch(meta == null ? void 0 : meta.format){
408
+ let format;
409
+ format = (0, _detector.detector)(buffer);
410
+ if (!format) {
411
+ const sharp = getSharp(null);
412
+ const meta = await sharp(buffer).metadata().catch((_)=>null);
413
+ format = meta == null ? void 0 : meta.format;
414
+ }
415
+ switch(format){
410
416
  case 'avif':
411
417
  return AVIF;
412
418
  case 'webp':
@@ -421,6 +427,7 @@ async function detectContentType(buffer) {
421
427
  case 'svg':
422
428
  return SVG;
423
429
  case 'jxl':
430
+ case 'jxl-stream':
424
431
  return JXL;
425
432
  case 'jp2':
426
433
  return JP2;
@@ -429,6 +436,12 @@ async function detectContentType(buffer) {
429
436
  return TIFF;
430
437
  case 'pdf':
431
438
  return PDF;
439
+ case 'bmp':
440
+ return BMP;
441
+ case 'ico':
442
+ return ICO;
443
+ case 'icns':
444
+ return ICNS;
432
445
  case 'dcraw':
433
446
  case 'dz':
434
447
  case 'exr':
@@ -441,6 +454,13 @@ async function detectContentType(buffer) {
441
454
  case 'rad':
442
455
  case 'raw':
443
456
  case 'v':
457
+ case 'cur':
458
+ case 'dds':
459
+ case 'j2c':
460
+ case 'ktx':
461
+ case 'pnm':
462
+ case 'psd':
463
+ case 'tga':
444
464
  case undefined:
445
465
  default:
446
466
  return null;