@moontra/moonui-pro 2.37.4 → 2.37.6
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/cdn/index.global.js +1 -1
- package/dist/cdn/index.global.js.map +1 -1
- package/dist/index.mjs +31 -13
- package/dist/server.d.ts +1 -0
- package/dist/server.mjs +4 -4
- package/dist/styles/nprogress.mjs +0 -2
- package/package.json +2 -4
- package/dist/index.mjs.map +0 -1
- package/dist/server.mjs.map +0 -1
- package/dist/styles/nprogress.mjs.map +0 -1
- package/templates/api-route.template.ts +0 -157
- package/templates/validate-pro-route.ts +0 -475
package/dist/server.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../node_modules/next/dist/compiled/@edge-runtime/cookies/index.js","../../../node_modules/next/src/server/web/spec-extension/cookies.ts","../../../node_modules/next/src/server/web/spec-extension/adapters/reflect.ts","../../../node_modules/next/src/server/app-render/async-local-storage.ts","../../../node_modules/next/src/server/app-render/work-async-storage-instance.ts","../../../node_modules/next/src/server/app-render/work-async-storage.external.ts","../../../node_modules/next/src/server/app-render/work-unit-async-storage-instance.ts","../../../node_modules/next/src/client/components/app-router-headers.ts","../../../node_modules/next/src/server/app-render/work-unit-async-storage.external.ts","../../../node_modules/next/src/server/web/spec-extension/adapters/request-cookies.ts","../../../node_modules/next/src/client/components/hooks-server-context.ts","../../../node_modules/next/src/client/components/static-generation-bailout.ts","../../../node_modules/next/src/server/dynamic-rendering-utils.ts","../../../node_modules/next/src/lib/metadata/metadata-constants.tsx","../../../node_modules/next/src/lib/scheduler.ts","../../../node_modules/next/src/server/app-render/dynamic-rendering.ts","../../../node_modules/next/src/server/create-deduped-by-callsite-server-error-logger.ts","../../../node_modules/next/src/server/app-render/after-task-async-storage-instance.ts","../../../node_modules/next/src/server/app-render/after-task-async-storage.external.ts","../../../node_modules/next/src/server/request/utils.ts","../../../node_modules/next/src/server/request/cookies.ts","../../../node_modules/next/src/server/web/spec-extension/adapters/headers.ts","../../../node_modules/next/src/server/request/headers.ts","../../../node_modules/next/src/server/request/draft-mode.ts","../../../node_modules/next/headers.js","../src/lib/server-auth.ts","../src/lib/auth-config.ts","../src/server.ts"],"names":["__defProp","__getOwnPropDesc","__getOwnPropNames","__hasOwnProp","__copyProps","headers","RequestCookies","ResponseCookies","stringifyCookie","ReflectAdapter","get","target","prop","receiver","value","Reflect","bind","set","has","deleteProperty","bindSnapshot","createAsyncLocalStorage","createSnapshot","sharedAsyncLocalStorageNotAvailableError","Error","FakeAsyncLocalStorage","disable","getStore","undefined","run","exit","enterWith","fn","maybeGlobalAsyncLocalStorage","globalThis","AsyncLocalStorage","snapshot","args","workAsyncStorageInstance","workAsyncStorage","workUnitAsyncStorageInstance","ACTION_HEADER","FLIGHT_HEADERS","NEXT_DID_POSTPONE_HEADER","NEXT_HMR_REFRESH_HASH_COOKIE","NEXT_HMR_REFRESH_HEADER","NEXT_IS_PRERENDER_HEADER","NEXT_REWRITTEN_PATH_HEADER","NEXT_REWRITTEN_QUERY_HEADER","NEXT_ROUTER_PREFETCH_HEADER","NEXT_ROUTER_SEGMENT_PREFETCH_HEADER","NEXT_ROUTER_STALE_TIME_HEADER","NEXT_ROUTER_STATE_TREE_HEADER","NEXT_RSC_UNION_QUERY","NEXT_URL","RSC_CONTENT_TYPE_HEADER","RSC_HEADER","getDraftModeProviderForCacheScope","getExpectedRequestStore","getHmrRefreshHash","getPrerenderResumeDataCache","getRenderResumeDataCache","throwForMissingRequestStore","workUnitAsyncStorage","callingExpression","workUnitStore","type","_exhaustiveCheck","prerenderResumeDataCache","renderResumeDataCache","workStore","dev","hmrRefreshHash","cookies","isDraftMode","draftMode","MutableRequestCookiesAdapter","ReadonlyRequestCookiesError","RequestCookiesAdapter","appendMutableCookies","areCookiesMutableInCurrentPhase","getModifiedCookieValues","responseCookiesToRequestCookies","wrapWithMutableAccessCheck","constructor","callable","seal","Proxy","SYMBOL_MODIFY_COOKIE_VALUES","Symbol","for","modified","Array","isArray","length","mutableCookies","modifiedCookieValues","resCookies","returnedCookies","getAll","cookie","wrap","onUpdateCookies","responseCookies","Headers","modifiedValues","modifiedCookies","Set","updateResponseCookies","pathWasRevalidated","allCookies","filter","c","name","serializedCookies","tempCookies","push","toString","wrappedCookies","add","delete","ensureCookiesAreStillMutable","requestStore","phase","requestCookies","DynamicServerError","isDynamicServerError","DYNAMIC_ERROR_CODE","description","digest","err","StaticGenBailoutError","isStaticGenBailoutError","NEXT_STATIC_GEN_BAILOUT","code","error","isHangingPromiseRejectionError","makeHangingPromise","HANGING_PROMISE_REJECTION","HangingPromiseRejectionError","expression","abortListenersBySignal","WeakMap","signal","aborted","Promise","reject","hangingPromise","_","boundRejection","currentListeners","listeners","addEventListener","i","once","catch","ignoreReject","METADATA_BOUNDARY_NAME","OUTLET_BOUNDARY_NAME","VIEWPORT_BOUNDARY_NAME","atLeastOneTask","scheduleImmediate","scheduleOnNextTick","waitAtLeastOneReactRenderTask","cb","resolve","then","process","env","NEXT_RUNTIME","setTimeout","nextTick","setImmediate","r","Postpone","abortAndThrowOnSynchronousRequestDataAccess","abortOnSynchronousPlatformIOAccess","accessedDynamicData","annotateDynamicAccess","consumeDynamicAccess","createDynamicTrackingState","createDynamicValidationState","createHangingInputAbortSignal","createPostponedAbortSignal","formatDynamicAPIAccesses","getFirstDynamicReason","isDynamicPostpone","isPrerenderInterruptedError","markCurrentScopeAsDynamic","postponeWithTracking","throwIfDisallowedDynamic","throwToInterruptStaticGeneration","trackAllowedDynamicAccess","trackDynamicDataInDynamicRender","trackFallbackParamAccessed","trackSynchronousPlatformIOAccessInDev","trackSynchronousRequestDataAccessInDev","useDynamicRouteParams","hasPostpone","React","unstable_postpone","isDebugDynamicAccesses","dynamicAccesses","syncDynamicExpression","syncDynamicErrorWithStack","hasSuspendedDynamic","hasDynamicMetadata","hasDynamicViewport","hasSyncDynamicErrors","dynamicErrors","trackingState","store","forceDynamic","forceStatic","dynamicShouldError","route","dynamicTracking","revalidate","dynamicUsageDescription","dynamicUsageStack","stack","usedDynamic","prerenderStore","_store","abortOnSynchronousDynamicDataAccess","reason","createPrerenderInterruptedError","controller","abort","errorWithStack","prerenderPhase","prerenderSignal","validating","syncDynamicLogged","assertPostpone","createPostponeReason","message","isDynamicPostponeReason","includes","NEXT_PRERENDER_INTERRUPTED","serverDynamic","clientDynamic","access","map","split","slice","line","join","AbortController","x","cacheSignal","inputReady","isStaticGeneration","fallbackRouteParams","size","use","renderSignal","hasSuspenseRegex","hasMetadataRegex","RegExp","hasViewportRegex","hasOutletRegex","componentStack","dynamicValidation","test","createErrorWithComponentStack","syncError","syncExpression","syncLogged","console","createDedupedByCallsiteServerErrorLoggerDev","errorRef","current","cache","logErrorOrWarn","__NEXT_DYNAMIC_IO","warn","flushCurrentErrorIfNew","key","getMessage","logDedupedError","callStackFrames","afterTaskAsyncStorageInstance","afterTaskAsyncStorage","isRequestAPICallableInsideAfter","throwForSearchParamsAccessInUseCache","throwWithStaticGenerationBailoutError","throwWithStaticGenerationBailoutErrorWithDynamicError","invalidUsageError","afterTaskStore","rootTaskSpawnPhase","underlyingCookies","createEmptyCookies","makeUntrackedExoticCookies","makeDynamicallyTrackedExoticCookies","userspaceMutableCookies","isPrefetchRequest","makeUntrackedExoticCookiesWithDevWarnings","CachedCookies","cachedPromise","promise","Object","defineProperties","iterator","createCookiesAccessError","arguments","describeNameArg","arg","clear","cachedCookies","polyfilledResponseCookiesIterator","polyfilledResponseCookiesClear","syncIODev","apply","call","writable","warnForSyncAccess","prefix","values","returnable","HeadersAdapter","ReadonlyHeadersError","lowercased","toLowerCase","original","keys","find","o","merge","from","append","existing","forEach","callbackfn","thisArg","entries","underlyingHeaders","makeUntrackedExoticHeaders","makeDynamicallyTrackedExoticHeaders","makeUntrackedExoticHeadersWithDevWarnings","CachedHeaders","cachedHeaders","createHeadersAccessError","_delete","getSetCookie","createOrGetCachedExoticDraftMode","draftModeProvider","createExoticDraftModeWithDevWarnings","createExoticDraftMode","cachedDraftMode","CachedDraftModes","underlyingProvider","instance","DraftMode","defineProperty","isEnabled","newValue","enumerable","configurable","enable","provider","_provider","trackDynamicDraftMode","createDraftModeAccessError","require_headers"],"mappings":"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","sourcesContent":["\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// src/index.ts\nvar src_exports = {};\n__export(src_exports, {\n RequestCookies: () => RequestCookies,\n ResponseCookies: () => ResponseCookies,\n parseCookie: () => parseCookie,\n parseSetCookie: () => parseSetCookie,\n stringifyCookie: () => stringifyCookie\n});\nmodule.exports = __toCommonJS(src_exports);\n\n// src/serialize.ts\nfunction stringifyCookie(c) {\n var _a;\n const attrs = [\n \"path\" in c && c.path && `Path=${c.path}`,\n \"expires\" in c && (c.expires || c.expires === 0) && `Expires=${(typeof c.expires === \"number\" ? new Date(c.expires) : c.expires).toUTCString()}`,\n \"maxAge\" in c && typeof c.maxAge === \"number\" && `Max-Age=${c.maxAge}`,\n \"domain\" in c && c.domain && `Domain=${c.domain}`,\n \"secure\" in c && c.secure && \"Secure\",\n \"httpOnly\" in c && c.httpOnly && \"HttpOnly\",\n \"sameSite\" in c && c.sameSite && `SameSite=${c.sameSite}`,\n \"partitioned\" in c && c.partitioned && \"Partitioned\",\n \"priority\" in c && c.priority && `Priority=${c.priority}`\n ].filter(Boolean);\n const stringified = `${c.name}=${encodeURIComponent((_a = c.value) != null ? _a : \"\")}`;\n return attrs.length === 0 ? stringified : `${stringified}; ${attrs.join(\"; \")}`;\n}\nfunction parseCookie(cookie) {\n const map = /* @__PURE__ */ new Map();\n for (const pair of cookie.split(/; */)) {\n if (!pair)\n continue;\n const splitAt = pair.indexOf(\"=\");\n if (splitAt === -1) {\n map.set(pair, \"true\");\n continue;\n }\n const [key, value] = [pair.slice(0, splitAt), pair.slice(splitAt + 1)];\n try {\n map.set(key, decodeURIComponent(value != null ? value : \"true\"));\n } catch {\n }\n }\n return map;\n}\nfunction parseSetCookie(setCookie) {\n if (!setCookie) {\n return void 0;\n }\n const [[name, value], ...attributes] = parseCookie(setCookie);\n const {\n domain,\n expires,\n httponly,\n maxage,\n path,\n samesite,\n secure,\n partitioned,\n priority\n } = Object.fromEntries(\n attributes.map(([key, value2]) => [\n key.toLowerCase().replace(/-/g, \"\"),\n value2\n ])\n );\n const cookie = {\n name,\n value: decodeURIComponent(value),\n domain,\n ...expires && { expires: new Date(expires) },\n ...httponly && { httpOnly: true },\n ...typeof maxage === \"string\" && { maxAge: Number(maxage) },\n path,\n ...samesite && { sameSite: parseSameSite(samesite) },\n ...secure && { secure: true },\n ...priority && { priority: parsePriority(priority) },\n ...partitioned && { partitioned: true }\n };\n return compact(cookie);\n}\nfunction compact(t) {\n const newT = {};\n for (const key in t) {\n if (t[key]) {\n newT[key] = t[key];\n }\n }\n return newT;\n}\nvar SAME_SITE = [\"strict\", \"lax\", \"none\"];\nfunction parseSameSite(string) {\n string = string.toLowerCase();\n return SAME_SITE.includes(string) ? string : void 0;\n}\nvar PRIORITY = [\"low\", \"medium\", \"high\"];\nfunction parsePriority(string) {\n string = string.toLowerCase();\n return PRIORITY.includes(string) ? string : void 0;\n}\nfunction splitCookiesString(cookiesString) {\n if (!cookiesString)\n return [];\n var cookiesStrings = [];\n var pos = 0;\n var start;\n var ch;\n var lastComma;\n var nextStart;\n var cookiesSeparatorFound;\n function skipWhitespace() {\n while (pos < cookiesString.length && /\\s/.test(cookiesString.charAt(pos))) {\n pos += 1;\n }\n return pos < cookiesString.length;\n }\n function notSpecialChar() {\n ch = cookiesString.charAt(pos);\n return ch !== \"=\" && ch !== \";\" && ch !== \",\";\n }\n while (pos < cookiesString.length) {\n start = pos;\n cookiesSeparatorFound = false;\n while (skipWhitespace()) {\n ch = cookiesString.charAt(pos);\n if (ch === \",\") {\n lastComma = pos;\n pos += 1;\n skipWhitespace();\n nextStart = pos;\n while (pos < cookiesString.length && notSpecialChar()) {\n pos += 1;\n }\n if (pos < cookiesString.length && cookiesString.charAt(pos) === \"=\") {\n cookiesSeparatorFound = true;\n pos = nextStart;\n cookiesStrings.push(cookiesString.substring(start, lastComma));\n start = pos;\n } else {\n pos = lastComma + 1;\n }\n } else {\n pos += 1;\n }\n }\n if (!cookiesSeparatorFound || pos >= cookiesString.length) {\n cookiesStrings.push(cookiesString.substring(start, cookiesString.length));\n }\n }\n return cookiesStrings;\n}\n\n// src/request-cookies.ts\nvar RequestCookies = class {\n constructor(requestHeaders) {\n /** @internal */\n this._parsed = /* @__PURE__ */ new Map();\n this._headers = requestHeaders;\n const header = requestHeaders.get(\"cookie\");\n if (header) {\n const parsed = parseCookie(header);\n for (const [name, value] of parsed) {\n this._parsed.set(name, { name, value });\n }\n }\n }\n [Symbol.iterator]() {\n return this._parsed[Symbol.iterator]();\n }\n /**\n * The amount of cookies received from the client\n */\n get size() {\n return this._parsed.size;\n }\n get(...args) {\n const name = typeof args[0] === \"string\" ? args[0] : args[0].name;\n return this._parsed.get(name);\n }\n getAll(...args) {\n var _a;\n const all = Array.from(this._parsed);\n if (!args.length) {\n return all.map(([_, value]) => value);\n }\n const name = typeof args[0] === \"string\" ? args[0] : (_a = args[0]) == null ? void 0 : _a.name;\n return all.filter(([n]) => n === name).map(([_, value]) => value);\n }\n has(name) {\n return this._parsed.has(name);\n }\n set(...args) {\n const [name, value] = args.length === 1 ? [args[0].name, args[0].value] : args;\n const map = this._parsed;\n map.set(name, { name, value });\n this._headers.set(\n \"cookie\",\n Array.from(map).map(([_, value2]) => stringifyCookie(value2)).join(\"; \")\n );\n return this;\n }\n /**\n * Delete the cookies matching the passed name or names in the request.\n */\n delete(names) {\n const map = this._parsed;\n const result = !Array.isArray(names) ? map.delete(names) : names.map((name) => map.delete(name));\n this._headers.set(\n \"cookie\",\n Array.from(map).map(([_, value]) => stringifyCookie(value)).join(\"; \")\n );\n return result;\n }\n /**\n * Delete all the cookies in the cookies in the request.\n */\n clear() {\n this.delete(Array.from(this._parsed.keys()));\n return this;\n }\n /**\n * Format the cookies in the request as a string for logging\n */\n [Symbol.for(\"edge-runtime.inspect.custom\")]() {\n return `RequestCookies ${JSON.stringify(Object.fromEntries(this._parsed))}`;\n }\n toString() {\n return [...this._parsed.values()].map((v) => `${v.name}=${encodeURIComponent(v.value)}`).join(\"; \");\n }\n};\n\n// src/response-cookies.ts\nvar ResponseCookies = class {\n constructor(responseHeaders) {\n /** @internal */\n this._parsed = /* @__PURE__ */ new Map();\n var _a, _b, _c;\n this._headers = responseHeaders;\n const setCookie = (_c = (_b = (_a = responseHeaders.getSetCookie) == null ? void 0 : _a.call(responseHeaders)) != null ? _b : responseHeaders.get(\"set-cookie\")) != null ? _c : [];\n const cookieStrings = Array.isArray(setCookie) ? setCookie : splitCookiesString(setCookie);\n for (const cookieString of cookieStrings) {\n const parsed = parseSetCookie(cookieString);\n if (parsed)\n this._parsed.set(parsed.name, parsed);\n }\n }\n /**\n * {@link https://wicg.github.io/cookie-store/#CookieStore-get CookieStore#get} without the Promise.\n */\n get(...args) {\n const key = typeof args[0] === \"string\" ? args[0] : args[0].name;\n return this._parsed.get(key);\n }\n /**\n * {@link https://wicg.github.io/cookie-store/#CookieStore-getAll CookieStore#getAll} without the Promise.\n */\n getAll(...args) {\n var _a;\n const all = Array.from(this._parsed.values());\n if (!args.length) {\n return all;\n }\n const key = typeof args[0] === \"string\" ? args[0] : (_a = args[0]) == null ? void 0 : _a.name;\n return all.filter((c) => c.name === key);\n }\n has(name) {\n return this._parsed.has(name);\n }\n /**\n * {@link https://wicg.github.io/cookie-store/#CookieStore-set CookieStore#set} without the Promise.\n */\n set(...args) {\n const [name, value, cookie] = args.length === 1 ? [args[0].name, args[0].value, args[0]] : args;\n const map = this._parsed;\n map.set(name, normalizeCookie({ name, value, ...cookie }));\n replace(map, this._headers);\n return this;\n }\n /**\n * {@link https://wicg.github.io/cookie-store/#CookieStore-delete CookieStore#delete} without the Promise.\n */\n delete(...args) {\n const [name, options] = typeof args[0] === \"string\" ? [args[0]] : [args[0].name, args[0]];\n return this.set({ ...options, name, value: \"\", expires: /* @__PURE__ */ new Date(0) });\n }\n [Symbol.for(\"edge-runtime.inspect.custom\")]() {\n return `ResponseCookies ${JSON.stringify(Object.fromEntries(this._parsed))}`;\n }\n toString() {\n return [...this._parsed.values()].map(stringifyCookie).join(\"; \");\n }\n};\nfunction replace(bag, headers) {\n headers.delete(\"set-cookie\");\n for (const [, value] of bag) {\n const serialized = stringifyCookie(value);\n headers.append(\"set-cookie\", serialized);\n }\n}\nfunction normalizeCookie(cookie = { name: \"\", value: \"\" }) {\n if (typeof cookie.expires === \"number\") {\n cookie.expires = new Date(cookie.expires);\n }\n if (cookie.maxAge) {\n cookie.expires = new Date(Date.now() + cookie.maxAge * 1e3);\n }\n if (cookie.path === null || cookie.path === void 0) {\n cookie.path = \"/\";\n }\n return cookie;\n}\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n RequestCookies,\n ResponseCookies,\n parseCookie,\n parseSetCookie,\n stringifyCookie\n});\n","export {\n RequestCookies,\n ResponseCookies,\n stringifyCookie,\n} from 'next/dist/compiled/@edge-runtime/cookies'\n","export class ReflectAdapter {\n static get<T extends object>(\n target: T,\n prop: string | symbol,\n receiver: unknown\n ): any {\n const value = Reflect.get(target, prop, receiver)\n if (typeof value === 'function') {\n return value.bind(target)\n }\n\n return value\n }\n\n static set<T extends object>(\n target: T,\n prop: string | symbol,\n value: any,\n receiver: any\n ): boolean {\n return Reflect.set(target, prop, value, receiver)\n }\n\n static has<T extends object>(target: T, prop: string | symbol): boolean {\n return Reflect.has(target, prop)\n }\n\n static deleteProperty<T extends object>(\n target: T,\n prop: string | symbol\n ): boolean {\n return Reflect.deleteProperty(target, prop)\n }\n}\n","import type { AsyncLocalStorage } from 'async_hooks'\n\nconst sharedAsyncLocalStorageNotAvailableError = new Error(\n 'Invariant: AsyncLocalStorage accessed in runtime where it is not available'\n)\n\nclass FakeAsyncLocalStorage<Store extends {}>\n implements AsyncLocalStorage<Store>\n{\n disable(): void {\n throw sharedAsyncLocalStorageNotAvailableError\n }\n\n getStore(): Store | undefined {\n // This fake implementation of AsyncLocalStorage always returns `undefined`.\n return undefined\n }\n\n run<R>(): R {\n throw sharedAsyncLocalStorageNotAvailableError\n }\n\n exit<R>(): R {\n throw sharedAsyncLocalStorageNotAvailableError\n }\n\n enterWith(): void {\n throw sharedAsyncLocalStorageNotAvailableError\n }\n\n static bind<T>(fn: T): T {\n return fn\n }\n}\n\nconst maybeGlobalAsyncLocalStorage =\n typeof globalThis !== 'undefined' && (globalThis as any).AsyncLocalStorage\n\nexport function createAsyncLocalStorage<\n Store extends {},\n>(): AsyncLocalStorage<Store> {\n if (maybeGlobalAsyncLocalStorage) {\n return new maybeGlobalAsyncLocalStorage()\n }\n return new FakeAsyncLocalStorage()\n}\n\nexport function bindSnapshot<T>(fn: T): T {\n if (maybeGlobalAsyncLocalStorage) {\n return maybeGlobalAsyncLocalStorage.bind(fn)\n }\n return FakeAsyncLocalStorage.bind(fn)\n}\n\nexport function createSnapshot(): <R, TArgs extends any[]>(\n fn: (...args: TArgs) => R,\n ...args: TArgs\n) => R {\n if (maybeGlobalAsyncLocalStorage) {\n return maybeGlobalAsyncLocalStorage.snapshot()\n }\n return function (fn: any, ...args: any[]) {\n return fn(...args)\n }\n}\n","import type { WorkAsyncStorage } from './work-async-storage.external'\nimport { createAsyncLocalStorage } from './async-local-storage'\n\nexport const workAsyncStorageInstance: WorkAsyncStorage =\n createAsyncLocalStorage()\n","import type { AsyncLocalStorage } from 'async_hooks'\nimport type { IncrementalCache } from '../lib/incremental-cache'\nimport type { FetchMetrics } from '../base-http'\nimport type { FallbackRouteParams } from '../request/fallback-params'\nimport type { DeepReadonly } from '../../shared/lib/deep-readonly'\nimport type { AppSegmentConfig } from '../../build/segment-config/app/app-segment-config'\nimport type { AfterContext } from '../after/after-context'\nimport type { CacheLife } from '../use-cache/cache-life'\n\n// Share the instance module in the next-shared layer\nimport { workAsyncStorageInstance } from './work-async-storage-instance' with { 'turbopack-transition': 'next-shared' }\nimport type { LazyResult } from '../lib/lazy-result'\n\nexport interface WorkStore {\n readonly isStaticGeneration: boolean\n\n /**\n * The page that is being rendered. This relates to the path to the page file.\n */\n readonly page: string\n\n /**\n * The route that is being rendered. This is the page property without the\n * trailing `/page` or `/route` suffix.\n */\n readonly route: string\n\n /**\n * The set of unknown route parameters. Accessing these will be tracked as\n * a dynamic access.\n */\n readonly fallbackRouteParams: FallbackRouteParams | null\n\n readonly incrementalCache?: IncrementalCache\n readonly cacheLifeProfiles?: { [profile: string]: CacheLife }\n\n readonly isOnDemandRevalidate?: boolean\n readonly isPrerendering?: boolean\n readonly isRevalidate?: boolean\n\n forceDynamic?: boolean\n fetchCache?: AppSegmentConfig['fetchCache']\n\n forceStatic?: boolean\n dynamicShouldError?: boolean\n pendingRevalidates?: Record<string, Promise<any>>\n pendingRevalidateWrites?: Array<Promise<void>> // This is like pendingRevalidates but isn't used for deduping.\n readonly afterContext: AfterContext\n\n dynamicUsageDescription?: string\n dynamicUsageStack?: string\n\n /**\n * Invalid usage errors might be caught in userland. We attach them to the\n * work store to ensure we can still fail the build or dev render.\n */\n // TODO: Collect an array of errors, and throw as AggregateError when\n // `serializeError` and the Dev Overlay support it.\n invalidUsageError?: Error\n\n nextFetchId?: number\n pathWasRevalidated?: boolean\n\n /**\n * Tags that were revalidated during the current request. They need to be sent\n * to cache handlers to propagate their revalidation.\n */\n pendingRevalidatedTags?: string[]\n\n /**\n * Tags that were previously revalidated (e.g. by a redirecting server action)\n * and have already been sent to cache handlers. Retrieved cache entries that\n * include any of these tags must be discarded.\n */\n readonly previouslyRevalidatedTags: readonly string[]\n\n /**\n * This map contains lazy results so that we can evaluate them when the first\n * cache entry is read. It allows us to skip refreshing tags if no caches are\n * read at all.\n */\n readonly refreshTagsByCacheKind: Map<string, LazyResult<void>>\n\n fetchMetrics?: FetchMetrics\n\n isDraftMode?: boolean\n isUnstableNoStore?: boolean\n isPrefetchRequest?: boolean\n\n requestEndedState?: { ended?: boolean }\n\n buildId: string\n\n readonly reactLoadableManifest?: DeepReadonly<\n Record<string, { files: string[] }>\n >\n readonly assetPrefix?: string\n\n dynamicIOEnabled: boolean\n dev: boolean\n}\n\nexport type WorkAsyncStorage = AsyncLocalStorage<WorkStore>\n\nexport { workAsyncStorageInstance as workAsyncStorage }\n","import { createAsyncLocalStorage } from './async-local-storage'\nimport type { WorkUnitAsyncStorage } from './work-unit-async-storage.external'\n\nexport const workUnitAsyncStorageInstance: WorkUnitAsyncStorage =\n createAsyncLocalStorage()\n","export const RSC_HEADER = 'RSC' as const\nexport const ACTION_HEADER = 'Next-Action' as const\n// TODO: Instead of sending the full router state, we only need to send the\n// segment path. Saves bytes. Then we could also use this field for segment\n// prefetches, which also need to specify a particular segment.\nexport const NEXT_ROUTER_STATE_TREE_HEADER = 'Next-Router-State-Tree' as const\nexport const NEXT_ROUTER_PREFETCH_HEADER = 'Next-Router-Prefetch' as const\n// This contains the path to the segment being prefetched.\n// TODO: If we change Next-Router-State-Tree to be a segment path, we can use\n// that instead. Then Next-Router-Prefetch and Next-Router-Segment-Prefetch can\n// be merged into a single enum.\nexport const NEXT_ROUTER_SEGMENT_PREFETCH_HEADER =\n 'Next-Router-Segment-Prefetch' as const\nexport const NEXT_HMR_REFRESH_HEADER = 'Next-HMR-Refresh' as const\nexport const NEXT_HMR_REFRESH_HASH_COOKIE = '__next_hmr_refresh_hash__' as const\nexport const NEXT_URL = 'Next-Url' as const\nexport const RSC_CONTENT_TYPE_HEADER = 'text/x-component' as const\n\nexport const FLIGHT_HEADERS = [\n RSC_HEADER,\n NEXT_ROUTER_STATE_TREE_HEADER,\n NEXT_ROUTER_PREFETCH_HEADER,\n NEXT_HMR_REFRESH_HEADER,\n NEXT_ROUTER_SEGMENT_PREFETCH_HEADER,\n] as const\n\nexport const NEXT_RSC_UNION_QUERY = '_rsc' as const\n\nexport const NEXT_ROUTER_STALE_TIME_HEADER = 'x-nextjs-stale-time' as const\nexport const NEXT_DID_POSTPONE_HEADER = 'x-nextjs-postponed' as const\nexport const NEXT_REWRITTEN_PATH_HEADER = 'x-nextjs-rewritten-path' as const\nexport const NEXT_REWRITTEN_QUERY_HEADER = 'x-nextjs-rewritten-query' as const\nexport const NEXT_IS_PRERENDER_HEADER = 'x-nextjs-prerender' as const\n","import type { AsyncLocalStorage } from 'async_hooks'\nimport type { DraftModeProvider } from '../async-storage/draft-mode-provider'\nimport type { ResponseCookies } from '../web/spec-extension/cookies'\nimport type { ReadonlyHeaders } from '../web/spec-extension/adapters/headers'\nimport type { ReadonlyRequestCookies } from '../web/spec-extension/adapters/request-cookies'\nimport type { CacheSignal } from './cache-signal'\nimport type { DynamicTrackingState } from './dynamic-rendering'\n\n// Share the instance module in the next-shared layer\nimport { workUnitAsyncStorageInstance } from './work-unit-async-storage-instance' with { 'turbopack-transition': 'next-shared' }\nimport type { ServerComponentsHmrCache } from '../response-cache'\nimport type {\n RenderResumeDataCache,\n PrerenderResumeDataCache,\n} from '../resume-data-cache/resume-data-cache'\nimport type { Params } from '../request/params'\nimport type { ImplicitTags } from '../lib/implicit-tags'\nimport type { WorkStore } from './work-async-storage.external'\nimport { NEXT_HMR_REFRESH_HASH_COOKIE } from '../../client/components/app-router-headers'\n\nexport type WorkUnitPhase = 'action' | 'render' | 'after'\n\nexport interface CommonWorkUnitStore {\n /** NOTE: Will be mutated as phases change */\n phase: WorkUnitPhase\n readonly implicitTags: ImplicitTags\n}\n\nexport interface RequestStore extends CommonWorkUnitStore {\n type: 'request'\n\n /**\n * The URL of the request. This only specifies the pathname and the search\n * part of the URL.\n */\n readonly url: {\n /**\n * The pathname of the requested URL.\n */\n readonly pathname: string\n\n /**\n * The search part of the requested URL. If the request did not provide a\n * search part, this will be an empty string.\n */\n readonly search: string\n }\n\n readonly headers: ReadonlyHeaders\n // This is mutable because we need to reassign it when transitioning from the action phase to the render phase.\n // The cookie object itself is deliberately read only and thus can't be updated.\n cookies: ReadonlyRequestCookies\n readonly mutableCookies: ResponseCookies\n readonly userspaceMutableCookies: ResponseCookies\n readonly draftMode: DraftModeProvider\n readonly isHmrRefresh?: boolean\n readonly serverComponentsHmrCache?: ServerComponentsHmrCache\n\n readonly rootParams: Params\n\n /**\n * The resume data cache for this request. This will be a immutable cache.\n */\n renderResumeDataCache: RenderResumeDataCache | null\n\n // DEV-only\n usedDynamic?: boolean\n prerenderPhase?: boolean\n}\n\n/**\n * The Prerender store is for tracking information related to prerenders.\n *\n * It can be used for both RSC and SSR prerendering and should be scoped as close\n * to the individual `renderTo...` API call as possible. To keep the type simple\n * we don't distinguish between RSC and SSR prerendering explicitly but instead\n * use conditional object properties to infer which mode we are in. For instance cache tracking\n * only needs to happen during the RSC prerender when we are prospectively prerendering\n * to fill all caches.\n */\nexport interface PrerenderStoreModern extends CommonWorkUnitStore {\n type: 'prerender'\n\n /**\n * This signal is aborted when the React render is complete. (i.e. it is the same signal passed to react)\n */\n readonly renderSignal: AbortSignal\n /**\n * This is the AbortController which represents the boundary between Prerender and dynamic. In some renders it is\n * the same as the controller for the renderSignal but in others it is a separate controller. It should be aborted\n * whenever the we are no longer in the prerender phase of rendering. Typically this is after one task or when you call\n * a sync API which requires the prerender to end immediately\n */\n readonly controller: AbortController\n\n /**\n * when not null this signal is used to track cache reads during prerendering and\n * to await all cache reads completing before aborting the prerender.\n */\n readonly cacheSignal: null | CacheSignal\n\n /**\n * During some prerenders we want to track dynamic access.\n */\n readonly dynamicTracking: null | DynamicTrackingState\n\n readonly rootParams: Params\n\n // Collected revalidate times and tags for this document during the prerender.\n revalidate: number // in seconds. 0 means dynamic. INFINITE_CACHE and higher means never revalidate.\n expire: number // server expiration time\n stale: number // client expiration time\n tags: null | string[]\n\n /**\n * The resume data cache for this prerender.\n */\n prerenderResumeDataCache: PrerenderResumeDataCache | null\n\n // DEV ONLY\n // When used this flag informs certain APIs to skip logging because we're\n // not part of the primary render path and are just prerendering to produce\n // validation results\n validating?: boolean\n\n /**\n * The HMR refresh hash is only provided in dev mode. It is needed for the dev\n * warmup render to ensure that the cache keys will be identical for the\n * subsequent dynamic render.\n */\n readonly hmrRefreshHash: string | undefined\n}\n\nexport interface PrerenderStorePPR extends CommonWorkUnitStore {\n type: 'prerender-ppr'\n readonly rootParams: Params\n readonly dynamicTracking: null | DynamicTrackingState\n // Collected revalidate times and tags for this document during the prerender.\n revalidate: number // in seconds. 0 means dynamic. INFINITE_CACHE and higher means never revalidate.\n expire: number // server expiration time\n stale: number // client expiration time\n tags: null | string[]\n\n /**\n * The resume data cache for this prerender.\n */\n prerenderResumeDataCache: PrerenderResumeDataCache\n}\n\nexport interface PrerenderStoreLegacy extends CommonWorkUnitStore {\n type: 'prerender-legacy'\n readonly rootParams: Params\n // Collected revalidate times and tags for this document during the prerender.\n revalidate: number // in seconds. 0 means dynamic. INFINITE_CACHE and higher means never revalidate.\n expire: number // server expiration time\n stale: number // client expiration time\n tags: null | string[]\n}\n\nexport type PrerenderStore =\n | PrerenderStoreLegacy\n | PrerenderStorePPR\n | PrerenderStoreModern\n\nexport interface CommonCacheStore\n extends Omit<CommonWorkUnitStore, 'implicitTags'> {\n /**\n * A cache work unit store might not always have an outer work unit store,\n * from which implicit tags could be inherited.\n */\n readonly implicitTags: ImplicitTags | undefined\n}\n\nexport interface UseCacheStore extends CommonCacheStore {\n type: 'cache'\n // Collected revalidate times and tags for this cache entry during the cache render.\n revalidate: number // implicit revalidate time from inner caches / fetches\n expire: number // server expiration time\n stale: number // client expiration time\n explicitRevalidate: undefined | number // explicit revalidate time from cacheLife() calls\n explicitExpire: undefined | number // server expiration time\n explicitStale: undefined | number // client expiration time\n tags: null | string[]\n readonly hmrRefreshHash: string | undefined\n readonly isHmrRefresh: boolean\n readonly serverComponentsHmrCache: ServerComponentsHmrCache | undefined\n readonly forceRevalidate: boolean\n // Draft mode is only available if the outer work unit store is a request\n // store and draft mode is enabled.\n readonly draftMode: DraftModeProvider | undefined\n}\n\nexport interface UnstableCacheStore extends CommonCacheStore {\n type: 'unstable-cache'\n // Draft mode is only available if the outer work unit store is a request\n // store and draft mode is enabled.\n readonly draftMode: DraftModeProvider | undefined\n}\n\n/**\n * The Cache store is for tracking information inside a \"use cache\" or unstable_cache context.\n * Inside this context we should never expose any request or page specific information.\n */\nexport type CacheStore = UseCacheStore | UnstableCacheStore\n\nexport type WorkUnitStore = RequestStore | CacheStore | PrerenderStore\n\nexport type WorkUnitAsyncStorage = AsyncLocalStorage<WorkUnitStore>\n\nexport { workUnitAsyncStorageInstance as workUnitAsyncStorage }\n\nexport function getExpectedRequestStore(\n callingExpression: string\n): RequestStore {\n const workUnitStore = workUnitAsyncStorageInstance.getStore()\n\n if (!workUnitStore) {\n throwForMissingRequestStore(callingExpression)\n }\n\n switch (workUnitStore.type) {\n case 'request':\n return workUnitStore\n\n case 'prerender':\n case 'prerender-ppr':\n case 'prerender-legacy':\n // This should not happen because we should have checked it already.\n throw new Error(\n `\\`${callingExpression}\\` cannot be called inside a prerender. This is a bug in Next.js.`\n )\n\n case 'cache':\n throw new Error(\n `\\`${callingExpression}\\` cannot be called inside \"use cache\". Call it outside and pass an argument instead. Read more: https://nextjs.org/docs/messages/next-request-in-use-cache`\n )\n\n case 'unstable-cache':\n throw new Error(\n `\\`${callingExpression}\\` cannot be called inside unstable_cache. Call it outside and pass an argument instead. Read more: https://nextjs.org/docs/app/api-reference/functions/unstable_cache`\n )\n\n default:\n const _exhaustiveCheck: never = workUnitStore\n return _exhaustiveCheck\n }\n}\n\nexport function throwForMissingRequestStore(callingExpression: string): never {\n throw new Error(\n `\\`${callingExpression}\\` was called outside a request scope. Read more: https://nextjs.org/docs/messages/next-dynamic-api-wrong-context`\n )\n}\n\nexport function getPrerenderResumeDataCache(\n workUnitStore: WorkUnitStore\n): PrerenderResumeDataCache | null {\n if (\n workUnitStore.type === 'prerender' ||\n workUnitStore.type === 'prerender-ppr'\n ) {\n return workUnitStore.prerenderResumeDataCache\n }\n\n return null\n}\n\nexport function getRenderResumeDataCache(\n workUnitStore: WorkUnitStore\n): RenderResumeDataCache | null {\n if (\n workUnitStore.type !== 'prerender-legacy' &&\n workUnitStore.type !== 'cache' &&\n workUnitStore.type !== 'unstable-cache'\n ) {\n if (workUnitStore.type === 'request') {\n return workUnitStore.renderResumeDataCache\n }\n\n // We return the mutable resume data cache here as an immutable version of\n // the cache as it can also be used for reading.\n return workUnitStore.prerenderResumeDataCache\n }\n\n return null\n}\n\nexport function getHmrRefreshHash(\n workStore: WorkStore,\n workUnitStore: WorkUnitStore\n): string | undefined {\n if (!workStore.dev) {\n return undefined\n }\n\n return workUnitStore.type === 'cache' || workUnitStore.type === 'prerender'\n ? workUnitStore.hmrRefreshHash\n : workUnitStore.type === 'request'\n ? workUnitStore.cookies.get(NEXT_HMR_REFRESH_HASH_COOKIE)?.value\n : undefined\n}\n\n/**\n * Returns a draft mode provider only if draft mode is enabled.\n */\nexport function getDraftModeProviderForCacheScope(\n workStore: WorkStore,\n workUnitStore: WorkUnitStore\n): DraftModeProvider | undefined {\n if (workStore.isDraftMode) {\n switch (workUnitStore.type) {\n case 'cache':\n case 'unstable-cache':\n case 'request':\n return workUnitStore.draftMode\n default:\n return undefined\n }\n }\n\n return undefined\n}\n","import { RequestCookies } from '../cookies'\n\nimport { ResponseCookies } from '../cookies'\nimport { ReflectAdapter } from './reflect'\nimport { workAsyncStorage } from '../../../app-render/work-async-storage.external'\nimport {\n getExpectedRequestStore,\n type RequestStore,\n} from '../../../app-render/work-unit-async-storage.external'\n\n/**\n * @internal\n */\nexport class ReadonlyRequestCookiesError extends Error {\n constructor() {\n super(\n 'Cookies can only be modified in a Server Action or Route Handler. Read more: https://nextjs.org/docs/app/api-reference/functions/cookies#options'\n )\n }\n\n public static callable() {\n throw new ReadonlyRequestCookiesError()\n }\n}\n\n// We use this to type some APIs but we don't construct instances directly\nexport type { ResponseCookies }\n\n// The `cookies()` API is a mix of request and response cookies. For `.get()` methods,\n// we want to return the request cookie if it exists. For mutative methods like `.set()`,\n// we want to return the response cookie.\nexport type ReadonlyRequestCookies = Omit<\n RequestCookies,\n 'set' | 'clear' | 'delete'\n> &\n Pick<ResponseCookies, 'set' | 'delete'>\n\nexport class RequestCookiesAdapter {\n public static seal(cookies: RequestCookies): ReadonlyRequestCookies {\n return new Proxy(cookies as any, {\n get(target, prop, receiver) {\n switch (prop) {\n case 'clear':\n case 'delete':\n case 'set':\n return ReadonlyRequestCookiesError.callable\n default:\n return ReflectAdapter.get(target, prop, receiver)\n }\n },\n })\n }\n}\n\nconst SYMBOL_MODIFY_COOKIE_VALUES = Symbol.for('next.mutated.cookies')\n\nexport function getModifiedCookieValues(\n cookies: ResponseCookies\n): ResponseCookie[] {\n const modified: ResponseCookie[] | undefined = (cookies as unknown as any)[\n SYMBOL_MODIFY_COOKIE_VALUES\n ]\n if (!modified || !Array.isArray(modified) || modified.length === 0) {\n return []\n }\n\n return modified\n}\n\ntype SetCookieArgs =\n | [key: string, value: string, cookie?: Partial<ResponseCookie>]\n | [options: ResponseCookie]\n\nexport function appendMutableCookies(\n headers: Headers,\n mutableCookies: ResponseCookies\n): boolean {\n const modifiedCookieValues = getModifiedCookieValues(mutableCookies)\n if (modifiedCookieValues.length === 0) {\n return false\n }\n\n // Return a new response that extends the response with\n // the modified cookies as fallbacks. `res` cookies\n // will still take precedence.\n const resCookies = new ResponseCookies(headers)\n const returnedCookies = resCookies.getAll()\n\n // Set the modified cookies as fallbacks.\n for (const cookie of modifiedCookieValues) {\n resCookies.set(cookie)\n }\n\n // Set the original cookies as the final values.\n for (const cookie of returnedCookies) {\n resCookies.set(cookie)\n }\n\n return true\n}\n\ntype ResponseCookie = NonNullable<\n ReturnType<InstanceType<typeof ResponseCookies>['get']>\n>\n\nexport class MutableRequestCookiesAdapter {\n public static wrap(\n cookies: RequestCookies,\n onUpdateCookies?: (cookies: string[]) => void\n ): ResponseCookies {\n const responseCookies = new ResponseCookies(new Headers())\n for (const cookie of cookies.getAll()) {\n responseCookies.set(cookie)\n }\n\n let modifiedValues: ResponseCookie[] = []\n const modifiedCookies = new Set<string>()\n const updateResponseCookies = () => {\n // TODO-APP: change method of getting workStore\n const workStore = workAsyncStorage.getStore()\n if (workStore) {\n workStore.pathWasRevalidated = true\n }\n\n const allCookies = responseCookies.getAll()\n modifiedValues = allCookies.filter((c) => modifiedCookies.has(c.name))\n if (onUpdateCookies) {\n const serializedCookies: string[] = []\n for (const cookie of modifiedValues) {\n const tempCookies = new ResponseCookies(new Headers())\n tempCookies.set(cookie)\n serializedCookies.push(tempCookies.toString())\n }\n\n onUpdateCookies(serializedCookies)\n }\n }\n\n const wrappedCookies = new Proxy(responseCookies, {\n get(target, prop, receiver) {\n switch (prop) {\n // A special symbol to get the modified cookie values\n case SYMBOL_MODIFY_COOKIE_VALUES:\n return modifiedValues\n\n // TODO: Throw error if trying to set a cookie after the response\n // headers have been set.\n case 'delete':\n return function (...args: [string] | [ResponseCookie]) {\n modifiedCookies.add(\n typeof args[0] === 'string' ? args[0] : args[0].name\n )\n try {\n target.delete(...args)\n return wrappedCookies\n } finally {\n updateResponseCookies()\n }\n }\n case 'set':\n return function (...args: SetCookieArgs) {\n modifiedCookies.add(\n typeof args[0] === 'string' ? args[0] : args[0].name\n )\n try {\n target.set(...args)\n return wrappedCookies\n } finally {\n updateResponseCookies()\n }\n }\n\n default:\n return ReflectAdapter.get(target, prop, receiver)\n }\n },\n })\n\n return wrappedCookies\n }\n}\n\nexport function wrapWithMutableAccessCheck(\n responseCookies: ResponseCookies\n): ResponseCookies {\n const wrappedCookies = new Proxy(responseCookies, {\n get(target, prop, receiver) {\n switch (prop) {\n case 'delete':\n return function (...args: [string] | [ResponseCookie]) {\n ensureCookiesAreStillMutable('cookies().delete')\n target.delete(...args)\n return wrappedCookies\n }\n case 'set':\n return function (...args: SetCookieArgs) {\n ensureCookiesAreStillMutable('cookies().set')\n target.set(...args)\n return wrappedCookies\n }\n\n default:\n return ReflectAdapter.get(target, prop, receiver)\n }\n },\n })\n return wrappedCookies\n}\n\nexport function areCookiesMutableInCurrentPhase(requestStore: RequestStore) {\n return requestStore.phase === 'action'\n}\n\n/** Ensure that cookies() starts throwing on mutation\n * if we changed phases and can no longer mutate.\n *\n * This can happen when going:\n * 'render' -> 'after'\n * 'action' -> 'render'\n * */\nfunction ensureCookiesAreStillMutable(callingExpression: string) {\n const requestStore = getExpectedRequestStore(callingExpression)\n if (!areCookiesMutableInCurrentPhase(requestStore)) {\n // TODO: maybe we can give a more precise error message based on callingExpression?\n throw new ReadonlyRequestCookiesError()\n }\n}\n\nexport function responseCookiesToRequestCookies(\n responseCookies: ResponseCookies\n): RequestCookies {\n const requestCookies = new RequestCookies(new Headers())\n for (const cookie of responseCookies.getAll()) {\n requestCookies.set(cookie)\n }\n return requestCookies\n}\n","const DYNAMIC_ERROR_CODE = 'DYNAMIC_SERVER_USAGE'\n\nexport class DynamicServerError extends Error {\n digest: typeof DYNAMIC_ERROR_CODE = DYNAMIC_ERROR_CODE\n\n constructor(public readonly description: string) {\n super(`Dynamic server usage: ${description}`)\n }\n}\n\nexport function isDynamicServerError(err: unknown): err is DynamicServerError {\n if (\n typeof err !== 'object' ||\n err === null ||\n !('digest' in err) ||\n typeof err.digest !== 'string'\n ) {\n return false\n }\n\n return err.digest === DYNAMIC_ERROR_CODE\n}\n","const NEXT_STATIC_GEN_BAILOUT = 'NEXT_STATIC_GEN_BAILOUT'\n\nexport class StaticGenBailoutError extends Error {\n public readonly code = NEXT_STATIC_GEN_BAILOUT\n}\n\nexport function isStaticGenBailoutError(\n error: unknown\n): error is StaticGenBailoutError {\n if (typeof error !== 'object' || error === null || !('code' in error)) {\n return false\n }\n\n return error.code === NEXT_STATIC_GEN_BAILOUT\n}\n","export function isHangingPromiseRejectionError(\n err: unknown\n): err is HangingPromiseRejectionError {\n if (typeof err !== 'object' || err === null || !('digest' in err)) {\n return false\n }\n\n return err.digest === HANGING_PROMISE_REJECTION\n}\n\nconst HANGING_PROMISE_REJECTION = 'HANGING_PROMISE_REJECTION'\n\nclass HangingPromiseRejectionError extends Error {\n public readonly digest = HANGING_PROMISE_REJECTION\n\n constructor(public readonly expression: string) {\n super(\n `During prerendering, ${expression} rejects when the prerender is complete. Typically these errors are handled by React but if you move ${expression} to a different context by using \\`setTimeout\\`, \\`after\\`, or similar functions you may observe this error and you should handle it in that context.`\n )\n }\n}\n\ntype AbortListeners = Array<(err: unknown) => void>\nconst abortListenersBySignal = new WeakMap<AbortSignal, AbortListeners>()\n\n/**\n * This function constructs a promise that will never resolve. This is primarily\n * useful for dynamicIO where we use promise resolution timing to determine which\n * parts of a render can be included in a prerender.\n *\n * @internal\n */\nexport function makeHangingPromise<T>(\n signal: AbortSignal,\n expression: string\n): Promise<T> {\n if (signal.aborted) {\n return Promise.reject(new HangingPromiseRejectionError(expression))\n } else {\n const hangingPromise = new Promise<T>((_, reject) => {\n const boundRejection = reject.bind(\n null,\n new HangingPromiseRejectionError(expression)\n )\n let currentListeners = abortListenersBySignal.get(signal)\n if (currentListeners) {\n currentListeners.push(boundRejection)\n } else {\n const listeners = [boundRejection]\n abortListenersBySignal.set(signal, listeners)\n signal.addEventListener(\n 'abort',\n () => {\n for (let i = 0; i < listeners.length; i++) {\n listeners[i]()\n }\n },\n { once: true }\n )\n }\n })\n // We are fine if no one actually awaits this promise. We shouldn't consider this an unhandled rejection so\n // we attach a noop catch handler here to suppress this warning. If you actually await somewhere or construct\n // your own promise out of it you'll need to ensure you handle the error when it rejects.\n hangingPromise.catch(ignoreReject)\n return hangingPromise\n }\n}\n\nfunction ignoreReject() {}\n","export const METADATA_BOUNDARY_NAME = '__next_metadata_boundary__'\nexport const VIEWPORT_BOUNDARY_NAME = '__next_viewport_boundary__'\nexport const OUTLET_BOUNDARY_NAME = '__next_outlet_boundary__'\n","export type ScheduledFn<T = void> = () => T | PromiseLike<T>\nexport type SchedulerFn<T = void> = (cb: ScheduledFn<T>) => void\n\n/**\n * Schedules a function to be called on the next tick after the other promises\n * have been resolved.\n *\n * @param cb the function to schedule\n */\nexport const scheduleOnNextTick = <T = void>(cb: ScheduledFn<T>): void => {\n // We use Promise.resolve().then() here so that the operation is scheduled at\n // the end of the promise job queue, we then add it to the next process tick\n // to ensure it's evaluated afterwards.\n //\n // This was inspired by the implementation of the DataLoader interface: https://github.com/graphql/dataloader/blob/d336bd15282664e0be4b4a657cb796f09bafbc6b/src/index.js#L213-L255\n //\n Promise.resolve().then(() => {\n if (process.env.NEXT_RUNTIME === 'edge') {\n setTimeout(cb, 0)\n } else {\n process.nextTick(cb)\n }\n })\n}\n\n/**\n * Schedules a function to be called using `setImmediate` or `setTimeout` if\n * `setImmediate` is not available (like in the Edge runtime).\n *\n * @param cb the function to schedule\n */\nexport const scheduleImmediate = <T = void>(cb: ScheduledFn<T>): void => {\n if (process.env.NEXT_RUNTIME === 'edge') {\n setTimeout(cb, 0)\n } else {\n setImmediate(cb)\n }\n}\n\n/**\n * returns a promise than resolves in a future task. There is no guarantee that the task it resolves in\n * will be the next task but if you await it you can at least be sure that the current task is over and\n * most usefully that the entire microtask queue of the current task has been emptied.\n */\nexport function atLeastOneTask() {\n return new Promise<void>((resolve) => scheduleImmediate(resolve))\n}\n\n/**\n * This utility function is extracted to make it easier to find places where we are doing\n * specific timing tricks to try to schedule work after React has rendered. This is especially\n * important at the moment because Next.js uses the edge builds of React which use setTimeout to\n * schedule work when you might expect that something like setImmediate would do the trick.\n *\n * Long term we should switch to the node versions of React rendering when possible and then\n * update this to use setImmediate rather than setTimeout\n */\nexport function waitAtLeastOneReactRenderTask(): Promise<void> {\n if (process.env.NEXT_RUNTIME === 'edge') {\n return new Promise((r) => setTimeout(r, 0))\n } else {\n return new Promise((r) => setImmediate(r))\n }\n}\n","/**\n * The functions provided by this module are used to communicate certain properties\n * about the currently running code so that Next.js can make decisions on how to handle\n * the current execution in different rendering modes such as pre-rendering, resuming, and SSR.\n *\n * Today Next.js treats all code as potentially static. Certain APIs may only make sense when dynamically rendering.\n * Traditionally this meant deopting the entire render to dynamic however with PPR we can now deopt parts\n * of a React tree as dynamic while still keeping other parts static. There are really two different kinds of\n * Dynamic indications.\n *\n * The first is simply an intention to be dynamic. unstable_noStore is an example of this where\n * the currently executing code simply declares that the current scope is dynamic but if you use it\n * inside unstable_cache it can still be cached. This type of indication can be removed if we ever\n * make the default dynamic to begin with because the only way you would ever be static is inside\n * a cache scope which this indication does not affect.\n *\n * The second is an indication that a dynamic data source was read. This is a stronger form of dynamic\n * because it means that it is inappropriate to cache this at all. using a dynamic data source inside\n * unstable_cache should error. If you want to use some dynamic data inside unstable_cache you should\n * read that data outside the cache and pass it in as an argument to the cached function.\n */\n\nimport type { WorkStore } from '../app-render/work-async-storage.external'\nimport type {\n WorkUnitStore,\n RequestStore,\n PrerenderStoreLegacy,\n PrerenderStoreModern,\n} from '../app-render/work-unit-async-storage.external'\n\n// Once postpone is in stable we should switch to importing the postpone export directly\nimport React from 'react'\n\nimport { DynamicServerError } from '../../client/components/hooks-server-context'\nimport { StaticGenBailoutError } from '../../client/components/static-generation-bailout'\nimport { workUnitAsyncStorage } from './work-unit-async-storage.external'\nimport { workAsyncStorage } from '../app-render/work-async-storage.external'\nimport { makeHangingPromise } from '../dynamic-rendering-utils'\nimport {\n METADATA_BOUNDARY_NAME,\n VIEWPORT_BOUNDARY_NAME,\n OUTLET_BOUNDARY_NAME,\n} from '../../lib/metadata/metadata-constants'\nimport { scheduleOnNextTick } from '../../lib/scheduler'\n\nconst hasPostpone = typeof React.unstable_postpone === 'function'\n\nexport type DynamicAccess = {\n /**\n * If debugging, this will contain the stack trace of where the dynamic access\n * occurred. This is used to provide more information to the user about why\n * their page is being rendered dynamically.\n */\n stack?: string\n\n /**\n * The expression that was accessed dynamically.\n */\n expression: string\n}\n\n// Stores dynamic reasons used during an RSC render.\nexport type DynamicTrackingState = {\n /**\n * When true, stack information will also be tracked during dynamic access.\n */\n readonly isDebugDynamicAccesses: boolean | undefined\n\n /**\n * The dynamic accesses that occurred during the render.\n */\n readonly dynamicAccesses: Array<DynamicAccess>\n\n syncDynamicExpression: undefined | string\n syncDynamicErrorWithStack: null | Error\n // Dev only\n syncDynamicLogged?: boolean\n}\n\n// Stores dynamic reasons used during an SSR render.\nexport type DynamicValidationState = {\n hasSuspendedDynamic: boolean\n hasDynamicMetadata: boolean\n hasDynamicViewport: boolean\n hasSyncDynamicErrors: boolean\n dynamicErrors: Array<Error>\n}\n\nexport function createDynamicTrackingState(\n isDebugDynamicAccesses: boolean | undefined\n): DynamicTrackingState {\n return {\n isDebugDynamicAccesses,\n dynamicAccesses: [],\n syncDynamicExpression: undefined,\n syncDynamicErrorWithStack: null,\n }\n}\n\nexport function createDynamicValidationState(): DynamicValidationState {\n return {\n hasSuspendedDynamic: false,\n hasDynamicMetadata: false,\n hasDynamicViewport: false,\n hasSyncDynamicErrors: false,\n dynamicErrors: [],\n }\n}\n\nexport function getFirstDynamicReason(\n trackingState: DynamicTrackingState\n): undefined | string {\n return trackingState.dynamicAccesses[0]?.expression\n}\n\n/**\n * This function communicates that the current scope should be treated as dynamic.\n *\n * In most cases this function is a no-op but if called during\n * a PPR prerender it will postpone the current sub-tree and calling\n * it during a normal prerender will cause the entire prerender to abort\n */\nexport function markCurrentScopeAsDynamic(\n store: WorkStore,\n workUnitStore: undefined | Exclude<WorkUnitStore, PrerenderStoreModern>,\n expression: string\n): void {\n if (workUnitStore) {\n if (\n workUnitStore.type === 'cache' ||\n workUnitStore.type === 'unstable-cache'\n ) {\n // inside cache scopes marking a scope as dynamic has no effect because the outer cache scope\n // creates a cache boundary. This is subtly different from reading a dynamic data source which is\n // forbidden inside a cache scope.\n return\n }\n }\n\n // If we're forcing dynamic rendering or we're forcing static rendering, we\n // don't need to do anything here because the entire page is already dynamic\n // or it's static and it should not throw or postpone here.\n if (store.forceDynamic || store.forceStatic) return\n\n if (store.dynamicShouldError) {\n throw new StaticGenBailoutError(\n `Route ${store.route} with \\`dynamic = \"error\"\\` couldn't be rendered statically because it used \\`${expression}\\`. See more info here: https://nextjs.org/docs/app/building-your-application/rendering/static-and-dynamic#dynamic-rendering`\n )\n }\n\n if (workUnitStore) {\n if (workUnitStore.type === 'prerender-ppr') {\n postponeWithTracking(\n store.route,\n expression,\n workUnitStore.dynamicTracking\n )\n } else if (workUnitStore.type === 'prerender-legacy') {\n workUnitStore.revalidate = 0\n\n // We aren't prerendering but we are generating a static page. We need to bail out of static generation\n const err = new DynamicServerError(\n `Route ${store.route} couldn't be rendered statically because it used ${expression}. See more info here: https://nextjs.org/docs/messages/dynamic-server-error`\n )\n store.dynamicUsageDescription = expression\n store.dynamicUsageStack = err.stack\n\n throw err\n } else if (\n process.env.NODE_ENV === 'development' &&\n workUnitStore &&\n workUnitStore.type === 'request'\n ) {\n workUnitStore.usedDynamic = true\n }\n }\n}\n\n/**\n * This function communicates that some dynamic path parameter was read. This\n * differs from the more general `trackDynamicDataAccessed` in that it is will\n * not error when `dynamic = \"error\"` is set.\n *\n * @param store The static generation store\n * @param expression The expression that was accessed dynamically\n */\nexport function trackFallbackParamAccessed(\n store: WorkStore,\n expression: string\n): void {\n const prerenderStore = workUnitAsyncStorage.getStore()\n if (!prerenderStore || prerenderStore.type !== 'prerender-ppr') return\n\n postponeWithTracking(store.route, expression, prerenderStore.dynamicTracking)\n}\n\n/**\n * This function is meant to be used when prerendering without dynamicIO or PPR.\n * When called during a build it will cause Next.js to consider the route as dynamic.\n *\n * @internal\n */\nexport function throwToInterruptStaticGeneration(\n expression: string,\n store: WorkStore,\n prerenderStore: PrerenderStoreLegacy\n): never {\n // We aren't prerendering but we are generating a static page. We need to bail out of static generation\n const err = new DynamicServerError(\n `Route ${store.route} couldn't be rendered statically because it used \\`${expression}\\`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error`\n )\n\n prerenderStore.revalidate = 0\n\n store.dynamicUsageDescription = expression\n store.dynamicUsageStack = err.stack\n\n throw err\n}\n\n/**\n * This function should be used to track whether something dynamic happened even when\n * we are in a dynamic render. This is useful for Dev where all renders are dynamic but\n * we still track whether dynamic APIs were accessed for helpful messaging\n *\n * @internal\n */\nexport function trackDynamicDataInDynamicRender(\n _store: WorkStore,\n workUnitStore: void | WorkUnitStore\n) {\n if (workUnitStore) {\n if (\n workUnitStore.type === 'cache' ||\n workUnitStore.type === 'unstable-cache'\n ) {\n // inside cache scopes marking a scope as dynamic has no effect because the outer cache scope\n // creates a cache boundary. This is subtly different from reading a dynamic data source which is\n // forbidden inside a cache scope.\n return\n }\n if (\n workUnitStore.type === 'prerender' ||\n workUnitStore.type === 'prerender-legacy'\n ) {\n workUnitStore.revalidate = 0\n }\n if (\n process.env.NODE_ENV === 'development' &&\n workUnitStore.type === 'request'\n ) {\n workUnitStore.usedDynamic = true\n }\n }\n}\n\n// Despite it's name we don't actually abort unless we have a controller to call abort on\n// There are times when we let a prerender run long to discover caches where we want the semantics\n// of tracking dynamic access without terminating the prerender early\nfunction abortOnSynchronousDynamicDataAccess(\n route: string,\n expression: string,\n prerenderStore: PrerenderStoreModern\n): void {\n const reason = `Route ${route} needs to bail out of prerendering at this point because it used ${expression}.`\n\n const error = createPrerenderInterruptedError(reason)\n\n prerenderStore.controller.abort(error)\n\n const dynamicTracking = prerenderStore.dynamicTracking\n if (dynamicTracking) {\n dynamicTracking.dynamicAccesses.push({\n // When we aren't debugging, we don't need to create another error for the\n // stack trace.\n stack: dynamicTracking.isDebugDynamicAccesses\n ? new Error().stack\n : undefined,\n expression,\n })\n }\n}\n\nexport function abortOnSynchronousPlatformIOAccess(\n route: string,\n expression: string,\n errorWithStack: Error,\n prerenderStore: PrerenderStoreModern\n): void {\n const dynamicTracking = prerenderStore.dynamicTracking\n if (dynamicTracking) {\n if (dynamicTracking.syncDynamicErrorWithStack === null) {\n dynamicTracking.syncDynamicExpression = expression\n dynamicTracking.syncDynamicErrorWithStack = errorWithStack\n }\n }\n abortOnSynchronousDynamicDataAccess(route, expression, prerenderStore)\n}\n\nexport function trackSynchronousPlatformIOAccessInDev(\n requestStore: RequestStore\n): void {\n // We don't actually have a controller to abort but we do the semantic equivalent by\n // advancing the request store out of prerender mode\n requestStore.prerenderPhase = false\n}\n\n/**\n * use this function when prerendering with dynamicIO. If we are doing a\n * prospective prerender we don't actually abort because we want to discover\n * all caches for the shell. If this is the actual prerender we do abort.\n *\n * This function accepts a prerenderStore but the caller should ensure we're\n * actually running in dynamicIO mode.\n *\n * @internal\n */\nexport function abortAndThrowOnSynchronousRequestDataAccess(\n route: string,\n expression: string,\n errorWithStack: Error,\n prerenderStore: PrerenderStoreModern\n): never {\n const prerenderSignal = prerenderStore.controller.signal\n if (prerenderSignal.aborted === false) {\n // TODO it would be better to move this aborted check into the callsite so we can avoid making\n // the error object when it isn't relevant to the aborting of the prerender however\n // since we need the throw semantics regardless of whether we abort it is easier to land\n // this way. See how this was handled with `abortOnSynchronousPlatformIOAccess` for a closer\n // to ideal implementation\n const dynamicTracking = prerenderStore.dynamicTracking\n if (dynamicTracking) {\n if (dynamicTracking.syncDynamicErrorWithStack === null) {\n dynamicTracking.syncDynamicExpression = expression\n dynamicTracking.syncDynamicErrorWithStack = errorWithStack\n if (prerenderStore.validating === true) {\n // We always log Request Access in dev at the point of calling the function\n // So we mark the dynamic validation as not requiring it to be printed\n dynamicTracking.syncDynamicLogged = true\n }\n }\n }\n abortOnSynchronousDynamicDataAccess(route, expression, prerenderStore)\n }\n throw createPrerenderInterruptedError(\n `Route ${route} needs to bail out of prerendering at this point because it used ${expression}.`\n )\n}\n\n// For now these implementations are the same so we just reexport\nexport const trackSynchronousRequestDataAccessInDev =\n trackSynchronousPlatformIOAccessInDev\n\n/**\n * This component will call `React.postpone` that throws the postponed error.\n */\ntype PostponeProps = {\n reason: string\n route: string\n}\nexport function Postpone({ reason, route }: PostponeProps): never {\n const prerenderStore = workUnitAsyncStorage.getStore()\n const dynamicTracking =\n prerenderStore && prerenderStore.type === 'prerender-ppr'\n ? prerenderStore.dynamicTracking\n : null\n postponeWithTracking(route, reason, dynamicTracking)\n}\n\nexport function postponeWithTracking(\n route: string,\n expression: string,\n dynamicTracking: null | DynamicTrackingState\n): never {\n assertPostpone()\n if (dynamicTracking) {\n dynamicTracking.dynamicAccesses.push({\n // When we aren't debugging, we don't need to create another error for the\n // stack trace.\n stack: dynamicTracking.isDebugDynamicAccesses\n ? new Error().stack\n : undefined,\n expression,\n })\n }\n\n React.unstable_postpone(createPostponeReason(route, expression))\n}\n\nfunction createPostponeReason(route: string, expression: string) {\n return (\n `Route ${route} needs to bail out of prerendering at this point because it used ${expression}. ` +\n `React throws this special object to indicate where. It should not be caught by ` +\n `your own try/catch. Learn more: https://nextjs.org/docs/messages/ppr-caught-error`\n )\n}\n\nexport function isDynamicPostpone(err: unknown) {\n if (\n typeof err === 'object' &&\n err !== null &&\n typeof (err as any).message === 'string'\n ) {\n return isDynamicPostponeReason((err as any).message)\n }\n return false\n}\n\nfunction isDynamicPostponeReason(reason: string) {\n return (\n reason.includes(\n 'needs to bail out of prerendering at this point because it used'\n ) &&\n reason.includes(\n 'Learn more: https://nextjs.org/docs/messages/ppr-caught-error'\n )\n )\n}\n\nif (isDynamicPostponeReason(createPostponeReason('%%%', '^^^')) === false) {\n throw new Error(\n 'Invariant: isDynamicPostpone misidentified a postpone reason. This is a bug in Next.js'\n )\n}\n\nconst NEXT_PRERENDER_INTERRUPTED = 'NEXT_PRERENDER_INTERRUPTED'\n\nfunction createPrerenderInterruptedError(message: string): Error {\n const error = new Error(message)\n ;(error as any).digest = NEXT_PRERENDER_INTERRUPTED\n return error\n}\n\ntype DigestError = Error & {\n digest: string\n}\n\nexport function isPrerenderInterruptedError(\n error: unknown\n): error is DigestError {\n return (\n typeof error === 'object' &&\n error !== null &&\n (error as any).digest === NEXT_PRERENDER_INTERRUPTED &&\n 'name' in error &&\n 'message' in error &&\n error instanceof Error\n )\n}\n\nexport function accessedDynamicData(\n dynamicAccesses: Array<DynamicAccess>\n): boolean {\n return dynamicAccesses.length > 0\n}\n\nexport function consumeDynamicAccess(\n serverDynamic: DynamicTrackingState,\n clientDynamic: DynamicTrackingState\n): DynamicTrackingState['dynamicAccesses'] {\n // We mutate because we only call this once we are no longer writing\n // to the dynamicTrackingState and it's more efficient than creating a new\n // array.\n serverDynamic.dynamicAccesses.push(...clientDynamic.dynamicAccesses)\n return serverDynamic.dynamicAccesses\n}\n\nexport function formatDynamicAPIAccesses(\n dynamicAccesses: Array<DynamicAccess>\n): string[] {\n return dynamicAccesses\n .filter(\n (access): access is Required<DynamicAccess> =>\n typeof access.stack === 'string' && access.stack.length > 0\n )\n .map(({ expression, stack }) => {\n stack = stack\n .split('\\n')\n // Remove the \"Error: \" prefix from the first line of the stack trace as\n // well as the first 4 lines of the stack trace which is the distance\n // from the user code and the `new Error().stack` call.\n .slice(4)\n .filter((line) => {\n // Exclude Next.js internals from the stack trace.\n if (line.includes('node_modules/next/')) {\n return false\n }\n\n // Exclude anonymous functions from the stack trace.\n if (line.includes(' (<anonymous>)')) {\n return false\n }\n\n // Exclude Node.js internals from the stack trace.\n if (line.includes(' (node:')) {\n return false\n }\n\n return true\n })\n .join('\\n')\n return `Dynamic API Usage Debug - ${expression}:\\n${stack}`\n })\n}\n\nfunction assertPostpone() {\n if (!hasPostpone) {\n throw new Error(\n `Invariant: React.unstable_postpone is not defined. This suggests the wrong version of React was loaded. This is a bug in Next.js`\n )\n }\n}\n\n/**\n * This is a bit of a hack to allow us to abort a render using a Postpone instance instead of an Error which changes React's\n * abort semantics slightly.\n */\nexport function createPostponedAbortSignal(reason: string): AbortSignal {\n assertPostpone()\n const controller = new AbortController()\n // We get our hands on a postpone instance by calling postpone and catching the throw\n try {\n React.unstable_postpone(reason)\n } catch (x: unknown) {\n controller.abort(x)\n }\n return controller.signal\n}\n\n/**\n * In a prerender, we may end up with hanging Promises as inputs due them\n * stalling on connection() or because they're loading dynamic data. In that\n * case we need to abort the encoding of arguments since they'll never complete.\n */\nexport function createHangingInputAbortSignal(\n workUnitStore: PrerenderStoreModern\n): AbortSignal {\n const controller = new AbortController()\n\n if (workUnitStore.cacheSignal) {\n // If we have a cacheSignal it means we're in a prospective render. If the input\n // we're waiting on is coming from another cache, we do want to wait for it so that\n // we can resolve this cache entry too.\n workUnitStore.cacheSignal.inputReady().then(() => {\n controller.abort()\n })\n } else {\n // Otherwise we're in the final render and we should already have all our caches\n // filled. We might still be waiting on some microtasks so we wait one tick before\n // giving up. When we give up, we still want to render the content of this cache\n // as deeply as we can so that we can suspend as deeply as possible in the tree\n // or not at all if we don't end up waiting for the input.\n scheduleOnNextTick(() => controller.abort())\n }\n\n return controller.signal\n}\n\nexport function annotateDynamicAccess(\n expression: string,\n prerenderStore: PrerenderStoreModern\n) {\n const dynamicTracking = prerenderStore.dynamicTracking\n if (dynamicTracking) {\n dynamicTracking.dynamicAccesses.push({\n stack: dynamicTracking.isDebugDynamicAccesses\n ? new Error().stack\n : undefined,\n expression,\n })\n }\n}\n\nexport function useDynamicRouteParams(expression: string) {\n const workStore = workAsyncStorage.getStore()\n\n if (\n workStore &&\n workStore.isStaticGeneration &&\n workStore.fallbackRouteParams &&\n workStore.fallbackRouteParams.size > 0\n ) {\n // There are fallback route params, we should track these as dynamic\n // accesses.\n const workUnitStore = workUnitAsyncStorage.getStore()\n if (workUnitStore) {\n // We're prerendering with dynamicIO or PPR or both\n if (workUnitStore.type === 'prerender') {\n // We are in a prerender with dynamicIO semantics\n // We are going to hang here and never resolve. This will cause the currently\n // rendering component to effectively be a dynamic hole\n React.use(makeHangingPromise(workUnitStore.renderSignal, expression))\n } else if (workUnitStore.type === 'prerender-ppr') {\n // We're prerendering with PPR\n postponeWithTracking(\n workStore.route,\n expression,\n workUnitStore.dynamicTracking\n )\n } else if (workUnitStore.type === 'prerender-legacy') {\n throwToInterruptStaticGeneration(expression, workStore, workUnitStore)\n }\n }\n }\n}\n\nconst hasSuspenseRegex = /\\n\\s+at Suspense \\(<anonymous>\\)/\nconst hasMetadataRegex = new RegExp(\n `\\\\n\\\\s+at ${METADATA_BOUNDARY_NAME}[\\\\n\\\\s]`\n)\nconst hasViewportRegex = new RegExp(\n `\\\\n\\\\s+at ${VIEWPORT_BOUNDARY_NAME}[\\\\n\\\\s]`\n)\nconst hasOutletRegex = new RegExp(`\\\\n\\\\s+at ${OUTLET_BOUNDARY_NAME}[\\\\n\\\\s]`)\n\nexport function trackAllowedDynamicAccess(\n route: string,\n componentStack: string,\n dynamicValidation: DynamicValidationState,\n serverDynamic: DynamicTrackingState,\n clientDynamic: DynamicTrackingState\n) {\n if (hasOutletRegex.test(componentStack)) {\n // We don't need to track that this is dynamic. It is only so when something else is also dynamic.\n return\n } else if (hasMetadataRegex.test(componentStack)) {\n dynamicValidation.hasDynamicMetadata = true\n return\n } else if (hasViewportRegex.test(componentStack)) {\n dynamicValidation.hasDynamicViewport = true\n return\n } else if (hasSuspenseRegex.test(componentStack)) {\n dynamicValidation.hasSuspendedDynamic = true\n return\n } else if (\n serverDynamic.syncDynamicErrorWithStack ||\n clientDynamic.syncDynamicErrorWithStack\n ) {\n dynamicValidation.hasSyncDynamicErrors = true\n return\n } else {\n const message = `Route \"${route}\": A component accessed data, headers, params, searchParams, or a short-lived cache without a Suspense boundary nor a \"use cache\" above it. We don't have the exact line number added to error messages yet but you can see which component in the stack below. See more info: https://nextjs.org/docs/messages/next-prerender-missing-suspense`\n const error = createErrorWithComponentStack(message, componentStack)\n dynamicValidation.dynamicErrors.push(error)\n return\n }\n}\n\nfunction createErrorWithComponentStack(\n message: string,\n componentStack: string\n) {\n const error = new Error(message)\n error.stack = 'Error: ' + message + componentStack\n return error\n}\n\nexport function throwIfDisallowedDynamic(\n route: string,\n dynamicValidation: DynamicValidationState,\n serverDynamic: DynamicTrackingState,\n clientDynamic: DynamicTrackingState\n): void {\n let syncError: null | Error\n let syncExpression: undefined | string\n let syncLogged: boolean\n if (serverDynamic.syncDynamicErrorWithStack) {\n syncError = serverDynamic.syncDynamicErrorWithStack\n syncExpression = serverDynamic.syncDynamicExpression!\n syncLogged = serverDynamic.syncDynamicLogged === true\n } else if (clientDynamic.syncDynamicErrorWithStack) {\n syncError = clientDynamic.syncDynamicErrorWithStack\n syncExpression = clientDynamic.syncDynamicExpression!\n syncLogged = clientDynamic.syncDynamicLogged === true\n } else {\n syncError = null\n syncExpression = undefined\n syncLogged = false\n }\n\n if (dynamicValidation.hasSyncDynamicErrors && syncError) {\n if (!syncLogged) {\n // In dev we already log errors about sync dynamic access. But during builds we need to ensure\n // the offending sync error is logged before we exit the build\n console.error(syncError)\n }\n // The actual error should have been logged when the sync access ocurred\n throw new StaticGenBailoutError()\n }\n\n const dynamicErrors = dynamicValidation.dynamicErrors\n if (dynamicErrors.length) {\n for (let i = 0; i < dynamicErrors.length; i++) {\n console.error(dynamicErrors[i])\n }\n\n throw new StaticGenBailoutError()\n }\n\n if (!dynamicValidation.hasSuspendedDynamic) {\n if (dynamicValidation.hasDynamicMetadata) {\n if (syncError) {\n console.error(syncError)\n throw new StaticGenBailoutError(\n `Route \"${route}\" has a \\`generateMetadata\\` that could not finish rendering before ${syncExpression} was used. Follow the instructions in the error for this expression to resolve.`\n )\n }\n throw new StaticGenBailoutError(\n `Route \"${route}\" has a \\`generateMetadata\\` that depends on Request data (\\`cookies()\\`, etc...) or external data (\\`fetch(...)\\`, etc...) but the rest of the route was static or only used cached data (\\`\"use cache\"\\`). If you expected this route to be prerenderable update your \\`generateMetadata\\` to not use Request data and only use cached external data. Otherwise, add \\`await connection()\\` somewhere within this route to indicate explicitly it should not be prerendered.`\n )\n } else if (dynamicValidation.hasDynamicViewport) {\n if (syncError) {\n console.error(syncError)\n throw new StaticGenBailoutError(\n `Route \"${route}\" has a \\`generateViewport\\` that could not finish rendering before ${syncExpression} was used. Follow the instructions in the error for this expression to resolve.`\n )\n }\n throw new StaticGenBailoutError(\n `Route \"${route}\" has a \\`generateViewport\\` that depends on Request data (\\`cookies()\\`, etc...) or external data (\\`fetch(...)\\`, etc...) but the rest of the route was static or only used cached data (\\`\"use cache\"\\`). If you expected this route to be prerenderable update your \\`generateViewport\\` to not use Request data and only use cached external data. Otherwise, add \\`await connection()\\` somewhere within this route to indicate explicitly it should not be prerendered.`\n )\n }\n }\n}\n","import * as React from 'react'\n\nconst errorRef: { current: null | Error } = { current: null }\n\n// React.cache is currently only available in canary/experimental React channels.\nconst cache =\n typeof React.cache === 'function'\n ? React.cache\n : (fn: (key: unknown) => void) => fn\n\n// When Dynamic IO is enabled, we record these as errors so that they\n// are captured by the dev overlay as it's more critical to fix these\n// when enabled.\nconst logErrorOrWarn = process.env.__NEXT_DYNAMIC_IO\n ? console.error\n : console.warn\n\n// We don't want to dedupe across requests.\n// The developer might've just attempted to fix the warning so we should warn again if it still happens.\nconst flushCurrentErrorIfNew = cache(\n // eslint-disable-next-line @typescript-eslint/no-unused-vars -- cache key\n (key: unknown) => {\n try {\n logErrorOrWarn(errorRef.current)\n } finally {\n errorRef.current = null\n }\n }\n)\n\n/**\n * Creates a function that logs an error message that is deduped by the userland\n * callsite.\n * This requires no indirection between the call of this function and the userland\n * callsite i.e. there's only a single library frame above this.\n * Do not use on the Client where sourcemaps and ignore listing might be enabled.\n * Only use that for warnings need a fix independent of the callstack.\n *\n * @param getMessage\n * @returns\n */\nexport function createDedupedByCallsiteServerErrorLoggerDev<Args extends any[]>(\n getMessage: (...args: Args) => Error\n) {\n return function logDedupedError(...args: Args) {\n const message = getMessage(...args)\n\n if (process.env.NODE_ENV !== 'production') {\n const callStackFrames = new Error().stack?.split('\\n')\n if (callStackFrames === undefined || callStackFrames.length < 4) {\n logErrorOrWarn(message)\n } else {\n // Error:\n // logDedupedError\n // asyncApiBeingAccessedSynchronously\n // <userland callsite>\n // TODO: This breaks if sourcemaps with ignore lists are enabled.\n const key = callStackFrames[4]\n errorRef.current = message\n flushCurrentErrorIfNew(key)\n }\n } else {\n logErrorOrWarn(message)\n }\n }\n}\n","import type { AfterTaskAsyncStorage } from './after-task-async-storage.external'\nimport { createAsyncLocalStorage } from './async-local-storage'\n\nexport const afterTaskAsyncStorageInstance: AfterTaskAsyncStorage =\n createAsyncLocalStorage()\n","import type { AsyncLocalStorage } from 'async_hooks'\n\n// Share the instance module in the next-shared layer\nimport { afterTaskAsyncStorageInstance as afterTaskAsyncStorage } from './after-task-async-storage-instance' with { 'turbopack-transition': 'next-shared' }\nimport type { WorkUnitStore } from './work-unit-async-storage.external'\n\nexport interface AfterTaskStore {\n /** The phase in which the topmost `after` was called.\n *\n * NOTE: Can be undefined when running `generateStaticParams`,\n * where we only have a `workStore`, no `workUnitStore`.\n */\n readonly rootTaskSpawnPhase: WorkUnitStore['phase'] | undefined\n}\n\nexport type AfterTaskAsyncStorage = AsyncLocalStorage<AfterTaskStore>\n\nexport { afterTaskAsyncStorage }\n","import { StaticGenBailoutError } from '../../client/components/static-generation-bailout'\nimport { afterTaskAsyncStorage } from '../app-render/after-task-async-storage.external'\nimport type { WorkStore } from '../app-render/work-async-storage.external'\n\nexport function throwWithStaticGenerationBailoutError(\n route: string,\n expression: string\n): never {\n throw new StaticGenBailoutError(\n `Route ${route} couldn't be rendered statically because it used ${expression}. See more info here: https://nextjs.org/docs/app/building-your-application/rendering/static-and-dynamic#dynamic-rendering`\n )\n}\n\nexport function throwWithStaticGenerationBailoutErrorWithDynamicError(\n route: string,\n expression: string\n): never {\n throw new StaticGenBailoutError(\n `Route ${route} with \\`dynamic = \"error\"\\` couldn't be rendered statically because it used ${expression}. See more info here: https://nextjs.org/docs/app/building-your-application/rendering/static-and-dynamic#dynamic-rendering`\n )\n}\n\nexport function throwForSearchParamsAccessInUseCache(\n workStore: WorkStore\n): never {\n const error = new Error(\n `Route ${workStore.route} used \"searchParams\" inside \"use cache\". Accessing Dynamic data sources inside a cache scope is not supported. If you need this data inside a cached function use \"searchParams\" outside of the cached function and pass the required dynamic data in as an argument. See more info here: https://nextjs.org/docs/messages/next-request-in-use-cache`\n )\n\n workStore.invalidUsageError ??= error\n\n throw error\n}\n\nexport function isRequestAPICallableInsideAfter() {\n const afterTaskStore = afterTaskAsyncStorage.getStore()\n return afterTaskStore?.rootTaskSpawnPhase === 'action'\n}\n","import {\n type ReadonlyRequestCookies,\n type ResponseCookies,\n areCookiesMutableInCurrentPhase,\n RequestCookiesAdapter,\n} from '../web/spec-extension/adapters/request-cookies'\nimport { RequestCookies } from '../web/spec-extension/cookies'\nimport { workAsyncStorage } from '../app-render/work-async-storage.external'\nimport {\n workUnitAsyncStorage,\n type PrerenderStoreModern,\n} from '../app-render/work-unit-async-storage.external'\nimport {\n postponeWithTracking,\n abortAndThrowOnSynchronousRequestDataAccess,\n throwToInterruptStaticGeneration,\n trackDynamicDataInDynamicRender,\n trackSynchronousRequestDataAccessInDev,\n} from '../app-render/dynamic-rendering'\nimport { getExpectedRequestStore } from '../app-render/work-unit-async-storage.external'\nimport { StaticGenBailoutError } from '../../client/components/static-generation-bailout'\nimport { makeHangingPromise } from '../dynamic-rendering-utils'\nimport { createDedupedByCallsiteServerErrorLoggerDev } from '../create-deduped-by-callsite-server-error-logger'\nimport { scheduleImmediate } from '../../lib/scheduler'\nimport { isRequestAPICallableInsideAfter } from './utils'\n\n/**\n * In this version of Next.js `cookies()` returns a Promise however you can still reference the properties of the underlying cookies object\n * synchronously to facilitate migration. The `UnsafeUnwrappedCookies` type is added to your code by a codemod that attempts to automatically\n * updates callsites to reflect the new Promise return type. There are some cases where `cookies()` cannot be automatically converted, namely\n * when it is used inside a synchronous function and we can't be sure the function can be made async automatically. In these cases we add an\n * explicit type case to `UnsafeUnwrappedCookies` to enable typescript to allow for the synchronous usage only where it is actually necessary.\n *\n * You should should update these callsites to either be async functions where the `cookies()` value can be awaited or you should call `cookies()`\n * from outside and await the return value before passing it into this function.\n *\n * You can find instances that require manual migration by searching for `UnsafeUnwrappedCookies` in your codebase or by search for a comment that\n * starts with `@next-codemod-error`.\n *\n * In a future version of Next.js `cookies()` will only return a Promise and you will not be able to access the underlying cookies object directly\n * without awaiting the return value first. When this change happens the type `UnsafeUnwrappedCookies` will be updated to reflect that is it no longer\n * usable.\n *\n * This type is marked deprecated to help identify it as target for refactoring away.\n *\n * @deprecated\n */\nexport type UnsafeUnwrappedCookies = ReadonlyRequestCookies\n\nexport function cookies(): Promise<ReadonlyRequestCookies> {\n const callingExpression = 'cookies'\n const workStore = workAsyncStorage.getStore()\n const workUnitStore = workUnitAsyncStorage.getStore()\n\n if (workStore) {\n if (\n workUnitStore &&\n workUnitStore.phase === 'after' &&\n !isRequestAPICallableInsideAfter()\n ) {\n throw new Error(\n // TODO(after): clarify that this only applies to pages?\n `Route ${workStore.route} used \"cookies\" inside \"after(...)\". This is not supported. If you need this data inside an \"after\" callback, use \"cookies\" outside of the callback. See more info here: https://nextjs.org/docs/canary/app/api-reference/functions/after`\n )\n }\n\n if (workStore.forceStatic) {\n // When using forceStatic we override all other logic and always just return an empty\n // cookies object without tracking\n const underlyingCookies = createEmptyCookies()\n return makeUntrackedExoticCookies(underlyingCookies)\n }\n\n if (workUnitStore) {\n if (workUnitStore.type === 'cache') {\n throw new Error(\n `Route ${workStore.route} used \"cookies\" inside \"use cache\". Accessing Dynamic data sources inside a cache scope is not supported. If you need this data inside a cached function use \"cookies\" outside of the cached function and pass the required dynamic data in as an argument. See more info here: https://nextjs.org/docs/messages/next-request-in-use-cache`\n )\n } else if (workUnitStore.type === 'unstable-cache') {\n throw new Error(\n `Route ${workStore.route} used \"cookies\" inside a function cached with \"unstable_cache(...)\". Accessing Dynamic data sources inside a cache scope is not supported. If you need this data inside a cached function use \"cookies\" outside of the cached function and pass the required dynamic data in as an argument. See more info here: https://nextjs.org/docs/app/api-reference/functions/unstable_cache`\n )\n }\n }\n if (workStore.dynamicShouldError) {\n throw new StaticGenBailoutError(\n `Route ${workStore.route} with \\`dynamic = \"error\"\\` couldn't be rendered statically because it used \\`cookies\\`. See more info here: https://nextjs.org/docs/app/building-your-application/rendering/static-and-dynamic#dynamic-rendering`\n )\n }\n\n if (workUnitStore) {\n if (workUnitStore.type === 'prerender') {\n // dynamicIO Prerender\n // We don't track dynamic access here because access will be tracked when you access\n // one of the properties of the cookies object.\n return makeDynamicallyTrackedExoticCookies(\n workStore.route,\n workUnitStore\n )\n } else if (workUnitStore.type === 'prerender-ppr') {\n // PPR Prerender (no dynamicIO)\n // We are prerendering with PPR. We need track dynamic access here eagerly\n // to keep continuity with how cookies has worked in PPR without dynamicIO.\n postponeWithTracking(\n workStore.route,\n callingExpression,\n workUnitStore.dynamicTracking\n )\n } else if (workUnitStore.type === 'prerender-legacy') {\n // Legacy Prerender\n // We track dynamic access here so we don't need to wrap the cookies in\n // individual property access tracking.\n throwToInterruptStaticGeneration(\n callingExpression,\n workStore,\n workUnitStore\n )\n }\n }\n // We fall through to the dynamic context below but we still track dynamic access\n // because in dev we can still error for things like using cookies inside a cache context\n trackDynamicDataInDynamicRender(workStore, workUnitStore)\n }\n\n // cookies is being called in a dynamic context\n\n const requestStore = getExpectedRequestStore(callingExpression)\n\n let underlyingCookies: ReadonlyRequestCookies\n\n if (areCookiesMutableInCurrentPhase(requestStore)) {\n // We can't conditionally return different types here based on the context.\n // To avoid confusion, we always return the readonly type here.\n underlyingCookies =\n requestStore.userspaceMutableCookies as unknown as ReadonlyRequestCookies\n } else {\n underlyingCookies = requestStore.cookies\n }\n\n if (process.env.NODE_ENV === 'development' && !workStore?.isPrefetchRequest) {\n return makeUntrackedExoticCookiesWithDevWarnings(\n underlyingCookies,\n workStore?.route\n )\n } else {\n return makeUntrackedExoticCookies(underlyingCookies)\n }\n}\n\nfunction createEmptyCookies(): ReadonlyRequestCookies {\n return RequestCookiesAdapter.seal(new RequestCookies(new Headers({})))\n}\n\ninterface CacheLifetime {}\nconst CachedCookies = new WeakMap<\n CacheLifetime,\n Promise<ReadonlyRequestCookies>\n>()\n\nfunction makeDynamicallyTrackedExoticCookies(\n route: string,\n prerenderStore: PrerenderStoreModern\n): Promise<ReadonlyRequestCookies> {\n const cachedPromise = CachedCookies.get(prerenderStore)\n if (cachedPromise) {\n return cachedPromise\n }\n\n const promise = makeHangingPromise<ReadonlyRequestCookies>(\n prerenderStore.renderSignal,\n '`cookies()`'\n )\n CachedCookies.set(prerenderStore, promise)\n\n Object.defineProperties(promise, {\n [Symbol.iterator]: {\n value: function () {\n const expression = '`cookies()[Symbol.iterator]()`'\n const error = createCookiesAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n size: {\n get() {\n const expression = '`cookies().size`'\n const error = createCookiesAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n get: {\n value: function get() {\n let expression: string\n if (arguments.length === 0) {\n expression = '`cookies().get()`'\n } else {\n expression = `\\`cookies().get(${describeNameArg(arguments[0])})\\``\n }\n const error = createCookiesAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n getAll: {\n value: function getAll() {\n let expression: string\n if (arguments.length === 0) {\n expression = '`cookies().getAll()`'\n } else {\n expression = `\\`cookies().getAll(${describeNameArg(arguments[0])})\\``\n }\n const error = createCookiesAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n has: {\n value: function has() {\n let expression: string\n if (arguments.length === 0) {\n expression = '`cookies().has()`'\n } else {\n expression = `\\`cookies().has(${describeNameArg(arguments[0])})\\``\n }\n const error = createCookiesAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n set: {\n value: function set() {\n let expression: string\n if (arguments.length === 0) {\n expression = '`cookies().set()`'\n } else {\n const arg = arguments[0]\n if (arg) {\n expression = `\\`cookies().set(${describeNameArg(arg)}, ...)\\``\n } else {\n expression = '`cookies().set(...)`'\n }\n }\n const error = createCookiesAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n delete: {\n value: function () {\n let expression: string\n if (arguments.length === 0) {\n expression = '`cookies().delete()`'\n } else if (arguments.length === 1) {\n expression = `\\`cookies().delete(${describeNameArg(arguments[0])})\\``\n } else {\n expression = `\\`cookies().delete(${describeNameArg(arguments[0])}, ...)\\``\n }\n const error = createCookiesAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n clear: {\n value: function clear() {\n const expression = '`cookies().clear()`'\n const error = createCookiesAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n toString: {\n value: function toString() {\n const expression = '`cookies().toString()`'\n const error = createCookiesAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n } satisfies CookieExtensions)\n\n return promise\n}\n\nfunction makeUntrackedExoticCookies(\n underlyingCookies: ReadonlyRequestCookies\n): Promise<ReadonlyRequestCookies> {\n const cachedCookies = CachedCookies.get(underlyingCookies)\n if (cachedCookies) {\n return cachedCookies\n }\n\n const promise = Promise.resolve(underlyingCookies)\n CachedCookies.set(underlyingCookies, promise)\n\n Object.defineProperties(promise, {\n [Symbol.iterator]: {\n value: underlyingCookies[Symbol.iterator]\n ? underlyingCookies[Symbol.iterator].bind(underlyingCookies)\n : // TODO this is a polyfill for when the underlying type is ResponseCookies\n // We should remove this and unify our cookies types. We could just let this continue to throw lazily\n // but that's already a hard thing to debug so we may as well implement it consistently. The biggest problem with\n // implementing this in this way is the underlying cookie type is a ResponseCookie and not a RequestCookie and so it\n // has extra properties not available on RequestCookie instances.\n polyfilledResponseCookiesIterator.bind(underlyingCookies),\n },\n size: {\n get(): number {\n return underlyingCookies.size\n },\n },\n get: {\n value: underlyingCookies.get.bind(underlyingCookies),\n },\n getAll: {\n value: underlyingCookies.getAll.bind(underlyingCookies),\n },\n has: {\n value: underlyingCookies.has.bind(underlyingCookies),\n },\n set: {\n value: underlyingCookies.set.bind(underlyingCookies),\n },\n delete: {\n value: underlyingCookies.delete.bind(underlyingCookies),\n },\n clear: {\n value:\n // @ts-expect-error clear is defined in RequestCookies implementation but not in the type\n typeof underlyingCookies.clear === 'function'\n ? // @ts-expect-error clear is defined in RequestCookies implementation but not in the type\n underlyingCookies.clear.bind(underlyingCookies)\n : // TODO this is a polyfill for when the underlying type is ResponseCookies\n // We should remove this and unify our cookies types. We could just let this continue to throw lazily\n // but that's already a hard thing to debug so we may as well implement it consistently. The biggest problem with\n // implementing this in this way is the underlying cookie type is a ResponseCookie and not a RequestCookie and so it\n // has extra properties not available on RequestCookie instances.\n polyfilledResponseCookiesClear.bind(underlyingCookies, promise),\n },\n toString: {\n value: underlyingCookies.toString.bind(underlyingCookies),\n },\n } satisfies CookieExtensions)\n\n return promise\n}\n\nfunction makeUntrackedExoticCookiesWithDevWarnings(\n underlyingCookies: ReadonlyRequestCookies,\n route?: string\n): Promise<ReadonlyRequestCookies> {\n const cachedCookies = CachedCookies.get(underlyingCookies)\n if (cachedCookies) {\n return cachedCookies\n }\n\n const promise = new Promise<ReadonlyRequestCookies>((resolve) =>\n scheduleImmediate(() => resolve(underlyingCookies))\n )\n CachedCookies.set(underlyingCookies, promise)\n\n Object.defineProperties(promise, {\n [Symbol.iterator]: {\n value: function () {\n const expression = '`...cookies()` or similar iteration'\n syncIODev(route, expression)\n return underlyingCookies[Symbol.iterator]\n ? underlyingCookies[Symbol.iterator].apply(\n underlyingCookies,\n arguments as any\n )\n : // TODO this is a polyfill for when the underlying type is ResponseCookies\n // We should remove this and unify our cookies types. We could just let this continue to throw lazily\n // but that's already a hard thing to debug so we may as well implement it consistently. The biggest problem with\n // implementing this in this way is the underlying cookie type is a ResponseCookie and not a RequestCookie and so it\n // has extra properties not available on RequestCookie instances.\n polyfilledResponseCookiesIterator.call(underlyingCookies)\n },\n writable: false,\n },\n size: {\n get(): number {\n const expression = '`cookies().size`'\n syncIODev(route, expression)\n return underlyingCookies.size\n },\n },\n get: {\n value: function get() {\n let expression: string\n if (arguments.length === 0) {\n expression = '`cookies().get()`'\n } else {\n expression = `\\`cookies().get(${describeNameArg(arguments[0])})\\``\n }\n syncIODev(route, expression)\n return underlyingCookies.get.apply(underlyingCookies, arguments as any)\n },\n writable: false,\n },\n getAll: {\n value: function getAll() {\n let expression: string\n if (arguments.length === 0) {\n expression = '`cookies().getAll()`'\n } else {\n expression = `\\`cookies().getAll(${describeNameArg(arguments[0])})\\``\n }\n syncIODev(route, expression)\n return underlyingCookies.getAll.apply(\n underlyingCookies,\n arguments as any\n )\n },\n writable: false,\n },\n has: {\n value: function get() {\n let expression: string\n if (arguments.length === 0) {\n expression = '`cookies().has()`'\n } else {\n expression = `\\`cookies().has(${describeNameArg(arguments[0])})\\``\n }\n syncIODev(route, expression)\n return underlyingCookies.has.apply(underlyingCookies, arguments as any)\n },\n writable: false,\n },\n set: {\n value: function set() {\n let expression: string\n if (arguments.length === 0) {\n expression = '`cookies().set()`'\n } else {\n const arg = arguments[0]\n if (arg) {\n expression = `\\`cookies().set(${describeNameArg(arg)}, ...)\\``\n } else {\n expression = '`cookies().set(...)`'\n }\n }\n syncIODev(route, expression)\n return underlyingCookies.set.apply(underlyingCookies, arguments as any)\n },\n writable: false,\n },\n delete: {\n value: function () {\n let expression: string\n if (arguments.length === 0) {\n expression = '`cookies().delete()`'\n } else if (arguments.length === 1) {\n expression = `\\`cookies().delete(${describeNameArg(arguments[0])})\\``\n } else {\n expression = `\\`cookies().delete(${describeNameArg(arguments[0])}, ...)\\``\n }\n syncIODev(route, expression)\n return underlyingCookies.delete.apply(\n underlyingCookies,\n arguments as any\n )\n },\n writable: false,\n },\n clear: {\n value: function clear() {\n const expression = '`cookies().clear()`'\n syncIODev(route, expression)\n // @ts-ignore clear is defined in RequestCookies implementation but not in the type\n return typeof underlyingCookies.clear === 'function'\n ? // @ts-ignore clear is defined in RequestCookies implementation but not in the type\n underlyingCookies.clear.apply(underlyingCookies, arguments)\n : // TODO this is a polyfill for when the underlying type is ResponseCookies\n // We should remove this and unify our cookies types. We could just let this continue to throw lazily\n // but that's already a hard thing to debug so we may as well implement it consistently. The biggest problem with\n // implementing this in this way is the underlying cookie type is a ResponseCookie and not a RequestCookie and so it\n // has extra properties not available on RequestCookie instances.\n polyfilledResponseCookiesClear.call(underlyingCookies, promise)\n },\n writable: false,\n },\n toString: {\n value: function toString() {\n const expression = '`cookies().toString()` or implicit casting'\n syncIODev(route, expression)\n return underlyingCookies.toString.apply(\n underlyingCookies,\n arguments as any\n )\n },\n writable: false,\n },\n } satisfies CookieExtensions)\n\n return promise\n}\n\nfunction describeNameArg(arg: unknown) {\n return typeof arg === 'object' &&\n arg !== null &&\n typeof (arg as any).name === 'string'\n ? `'${(arg as any).name}'`\n : typeof arg === 'string'\n ? `'${arg}'`\n : '...'\n}\n\nfunction syncIODev(route: string | undefined, expression: string) {\n const workUnitStore = workUnitAsyncStorage.getStore()\n if (\n workUnitStore &&\n workUnitStore.type === 'request' &&\n workUnitStore.prerenderPhase === true\n ) {\n // When we're rendering dynamically in dev we need to advance out of the\n // Prerender environment when we read Request data synchronously\n const requestStore = workUnitStore\n trackSynchronousRequestDataAccessInDev(requestStore)\n }\n // In all cases we warn normally\n warnForSyncAccess(route, expression)\n}\n\nconst warnForSyncAccess = createDedupedByCallsiteServerErrorLoggerDev(\n createCookiesAccessError\n)\n\nfunction createCookiesAccessError(\n route: string | undefined,\n expression: string\n) {\n const prefix = route ? `Route \"${route}\" ` : 'This route '\n return new Error(\n `${prefix}used ${expression}. ` +\n `\\`cookies()\\` should be awaited before using its value. ` +\n `Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis`\n )\n}\n\nfunction polyfilledResponseCookiesIterator(\n this: ResponseCookies\n): ReturnType<ReadonlyRequestCookies[typeof Symbol.iterator]> {\n return this.getAll()\n .map((c) => [c.name, c] as [string, any])\n .values()\n}\n\nfunction polyfilledResponseCookiesClear(\n this: ResponseCookies,\n returnable: Promise<ReadonlyRequestCookies>\n): typeof returnable {\n for (const cookie of this.getAll()) {\n this.delete(cookie.name)\n }\n return returnable\n}\n\ntype CookieExtensions = {\n [K in keyof ReadonlyRequestCookies | 'clear']: unknown\n}\n","import type { IncomingHttpHeaders } from 'http'\n\nimport { ReflectAdapter } from './reflect'\n\n/**\n * @internal\n */\nexport class ReadonlyHeadersError extends Error {\n constructor() {\n super(\n 'Headers cannot be modified. Read more: https://nextjs.org/docs/app/api-reference/functions/headers'\n )\n }\n\n public static callable() {\n throw new ReadonlyHeadersError()\n }\n}\n\nexport type ReadonlyHeaders = Headers & {\n /** @deprecated Method unavailable on `ReadonlyHeaders`. Read more: https://nextjs.org/docs/app/api-reference/functions/headers */\n append(...args: any[]): void\n /** @deprecated Method unavailable on `ReadonlyHeaders`. Read more: https://nextjs.org/docs/app/api-reference/functions/headers */\n set(...args: any[]): void\n /** @deprecated Method unavailable on `ReadonlyHeaders`. Read more: https://nextjs.org/docs/app/api-reference/functions/headers */\n delete(...args: any[]): void\n}\nexport class HeadersAdapter extends Headers {\n private readonly headers: IncomingHttpHeaders\n\n constructor(headers: IncomingHttpHeaders) {\n // We've already overridden the methods that would be called, so we're just\n // calling the super constructor to ensure that the instanceof check works.\n super()\n\n this.headers = new Proxy(headers, {\n get(target, prop, receiver) {\n // Because this is just an object, we expect that all \"get\" operations\n // are for properties. If it's a \"get\" for a symbol, we'll just return\n // the symbol.\n if (typeof prop === 'symbol') {\n return ReflectAdapter.get(target, prop, receiver)\n }\n\n const lowercased = prop.toLowerCase()\n\n // Let's find the original casing of the key. This assumes that there is\n // no mixed case keys (e.g. \"Content-Type\" and \"content-type\") in the\n // headers object.\n const original = Object.keys(headers).find(\n (o) => o.toLowerCase() === lowercased\n )\n\n // If the original casing doesn't exist, return undefined.\n if (typeof original === 'undefined') return\n\n // If the original casing exists, return the value.\n return ReflectAdapter.get(target, original, receiver)\n },\n set(target, prop, value, receiver) {\n if (typeof prop === 'symbol') {\n return ReflectAdapter.set(target, prop, value, receiver)\n }\n\n const lowercased = prop.toLowerCase()\n\n // Let's find the original casing of the key. This assumes that there is\n // no mixed case keys (e.g. \"Content-Type\" and \"content-type\") in the\n // headers object.\n const original = Object.keys(headers).find(\n (o) => o.toLowerCase() === lowercased\n )\n\n // If the original casing doesn't exist, use the prop as the key.\n return ReflectAdapter.set(target, original ?? prop, value, receiver)\n },\n has(target, prop) {\n if (typeof prop === 'symbol') return ReflectAdapter.has(target, prop)\n\n const lowercased = prop.toLowerCase()\n\n // Let's find the original casing of the key. This assumes that there is\n // no mixed case keys (e.g. \"Content-Type\" and \"content-type\") in the\n // headers object.\n const original = Object.keys(headers).find(\n (o) => o.toLowerCase() === lowercased\n )\n\n // If the original casing doesn't exist, return false.\n if (typeof original === 'undefined') return false\n\n // If the original casing exists, return true.\n return ReflectAdapter.has(target, original)\n },\n deleteProperty(target, prop) {\n if (typeof prop === 'symbol')\n return ReflectAdapter.deleteProperty(target, prop)\n\n const lowercased = prop.toLowerCase()\n\n // Let's find the original casing of the key. This assumes that there is\n // no mixed case keys (e.g. \"Content-Type\" and \"content-type\") in the\n // headers object.\n const original = Object.keys(headers).find(\n (o) => o.toLowerCase() === lowercased\n )\n\n // If the original casing doesn't exist, return true.\n if (typeof original === 'undefined') return true\n\n // If the original casing exists, delete the property.\n return ReflectAdapter.deleteProperty(target, original)\n },\n })\n }\n\n /**\n * Seals a Headers instance to prevent modification by throwing an error when\n * any mutating method is called.\n */\n public static seal(headers: Headers): ReadonlyHeaders {\n return new Proxy<ReadonlyHeaders>(headers, {\n get(target, prop, receiver) {\n switch (prop) {\n case 'append':\n case 'delete':\n case 'set':\n return ReadonlyHeadersError.callable\n default:\n return ReflectAdapter.get(target, prop, receiver)\n }\n },\n })\n }\n\n /**\n * Merges a header value into a string. This stores multiple values as an\n * array, so we need to merge them into a string.\n *\n * @param value a header value\n * @returns a merged header value (a string)\n */\n private merge(value: string | string[]): string {\n if (Array.isArray(value)) return value.join(', ')\n\n return value\n }\n\n /**\n * Creates a Headers instance from a plain object or a Headers instance.\n *\n * @param headers a plain object or a Headers instance\n * @returns a headers instance\n */\n public static from(headers: IncomingHttpHeaders | Headers): Headers {\n if (headers instanceof Headers) return headers\n\n return new HeadersAdapter(headers)\n }\n\n public append(name: string, value: string): void {\n const existing = this.headers[name]\n if (typeof existing === 'string') {\n this.headers[name] = [existing, value]\n } else if (Array.isArray(existing)) {\n existing.push(value)\n } else {\n this.headers[name] = value\n }\n }\n\n public delete(name: string): void {\n delete this.headers[name]\n }\n\n public get(name: string): string | null {\n const value = this.headers[name]\n if (typeof value !== 'undefined') return this.merge(value)\n\n return null\n }\n\n public has(name: string): boolean {\n return typeof this.headers[name] !== 'undefined'\n }\n\n public set(name: string, value: string): void {\n this.headers[name] = value\n }\n\n public forEach(\n callbackfn: (value: string, name: string, parent: Headers) => void,\n thisArg?: any\n ): void {\n for (const [name, value] of this.entries()) {\n callbackfn.call(thisArg, value, name, this)\n }\n }\n\n public *entries(): HeadersIterator<[string, string]> {\n for (const key of Object.keys(this.headers)) {\n const name = key.toLowerCase()\n // We assert here that this is a string because we got it from the\n // Object.keys() call above.\n const value = this.get(name) as string\n\n yield [name, value] as [string, string]\n }\n }\n\n public *keys(): HeadersIterator<string> {\n for (const key of Object.keys(this.headers)) {\n const name = key.toLowerCase()\n yield name\n }\n }\n\n public *values(): HeadersIterator<string> {\n for (const key of Object.keys(this.headers)) {\n // We assert here that this is a string because we got it from the\n // Object.keys() call above.\n const value = this.get(key) as string\n\n yield value\n }\n }\n\n public [Symbol.iterator](): HeadersIterator<[string, string]> {\n return this.entries()\n }\n}\n","import {\n HeadersAdapter,\n type ReadonlyHeaders,\n} from '../web/spec-extension/adapters/headers'\nimport { workAsyncStorage } from '../app-render/work-async-storage.external'\nimport { getExpectedRequestStore } from '../app-render/work-unit-async-storage.external'\nimport {\n workUnitAsyncStorage,\n type PrerenderStoreModern,\n} from '../app-render/work-unit-async-storage.external'\nimport {\n postponeWithTracking,\n abortAndThrowOnSynchronousRequestDataAccess,\n throwToInterruptStaticGeneration,\n trackDynamicDataInDynamicRender,\n trackSynchronousRequestDataAccessInDev,\n} from '../app-render/dynamic-rendering'\nimport { StaticGenBailoutError } from '../../client/components/static-generation-bailout'\nimport { makeHangingPromise } from '../dynamic-rendering-utils'\nimport { createDedupedByCallsiteServerErrorLoggerDev } from '../create-deduped-by-callsite-server-error-logger'\nimport { scheduleImmediate } from '../../lib/scheduler'\nimport { isRequestAPICallableInsideAfter } from './utils'\n\n/**\n * In this version of Next.js `headers()` returns a Promise however you can still reference the properties of the underlying Headers instance\n * synchronously to facilitate migration. The `UnsafeUnwrappedHeaders` type is added to your code by a codemod that attempts to automatically\n * updates callsites to reflect the new Promise return type. There are some cases where `headers()` cannot be automatically converted, namely\n * when it is used inside a synchronous function and we can't be sure the function can be made async automatically. In these cases we add an\n * explicit type case to `UnsafeUnwrappedHeaders` to enable typescript to allow for the synchronous usage only where it is actually necessary.\n *\n * You should should update these callsites to either be async functions where the `headers()` value can be awaited or you should call `headers()`\n * from outside and await the return value before passing it into this function.\n *\n * You can find instances that require manual migration by searching for `UnsafeUnwrappedHeaders` in your codebase or by search for a comment that\n * starts with `@next-codemod-error`.\n *\n * In a future version of Next.js `headers()` will only return a Promise and you will not be able to access the underlying Headers instance\n * without awaiting the return value first. When this change happens the type `UnsafeUnwrappedHeaders` will be updated to reflect that is it no longer\n * usable.\n *\n * This type is marked deprecated to help identify it as target for refactoring away.\n *\n * @deprecated\n */\nexport type UnsafeUnwrappedHeaders = ReadonlyHeaders\n\n/**\n * This function allows you to read the HTTP incoming request headers in\n * [Server Components](https://nextjs.org/docs/app/building-your-application/rendering/server-components),\n * [Server Actions](https://nextjs.org/docs/app/building-your-application/data-fetching/server-actions-and-mutations),\n * [Route Handlers](https://nextjs.org/docs/app/building-your-application/routing/route-handlers) and\n * [Middleware](https://nextjs.org/docs/app/building-your-application/routing/middleware).\n *\n * Read more: [Next.js Docs: `headers`](https://nextjs.org/docs/app/api-reference/functions/headers)\n */\nexport function headers(): Promise<ReadonlyHeaders> {\n const workStore = workAsyncStorage.getStore()\n const workUnitStore = workUnitAsyncStorage.getStore()\n\n if (workStore) {\n if (\n workUnitStore &&\n workUnitStore.phase === 'after' &&\n !isRequestAPICallableInsideAfter()\n ) {\n throw new Error(\n `Route ${workStore.route} used \"headers\" inside \"after(...)\". This is not supported. If you need this data inside an \"after\" callback, use \"headers\" outside of the callback. See more info here: https://nextjs.org/docs/canary/app/api-reference/functions/after`\n )\n }\n\n if (workStore.forceStatic) {\n // When using forceStatic we override all other logic and always just return an empty\n // headers object without tracking\n const underlyingHeaders = HeadersAdapter.seal(new Headers({}))\n return makeUntrackedExoticHeaders(underlyingHeaders)\n }\n\n if (workUnitStore) {\n if (workUnitStore.type === 'cache') {\n throw new Error(\n `Route ${workStore.route} used \"headers\" inside \"use cache\". Accessing Dynamic data sources inside a cache scope is not supported. If you need this data inside a cached function use \"headers\" outside of the cached function and pass the required dynamic data in as an argument. See more info here: https://nextjs.org/docs/messages/next-request-in-use-cache`\n )\n } else if (workUnitStore.type === 'unstable-cache') {\n throw new Error(\n `Route ${workStore.route} used \"headers\" inside a function cached with \"unstable_cache(...)\". Accessing Dynamic data sources inside a cache scope is not supported. If you need this data inside a cached function use \"headers\" outside of the cached function and pass the required dynamic data in as an argument. See more info here: https://nextjs.org/docs/app/api-reference/functions/unstable_cache`\n )\n }\n }\n if (workStore.dynamicShouldError) {\n throw new StaticGenBailoutError(\n `Route ${workStore.route} with \\`dynamic = \"error\"\\` couldn't be rendered statically because it used \\`headers\\`. See more info here: https://nextjs.org/docs/app/building-your-application/rendering/static-and-dynamic#dynamic-rendering`\n )\n }\n\n if (workUnitStore) {\n if (workUnitStore.type === 'prerender') {\n // dynamicIO Prerender\n // We don't track dynamic access here because access will be tracked when you access\n // one of the properties of the headers object.\n return makeDynamicallyTrackedExoticHeaders(\n workStore.route,\n workUnitStore\n )\n } else if (workUnitStore.type === 'prerender-ppr') {\n // PPR Prerender (no dynamicIO)\n // We are prerendering with PPR. We need track dynamic access here eagerly\n // to keep continuity with how headers has worked in PPR without dynamicIO.\n // TODO consider switching the semantic to throw on property access instead\n postponeWithTracking(\n workStore.route,\n 'headers',\n workUnitStore.dynamicTracking\n )\n } else if (workUnitStore.type === 'prerender-legacy') {\n // Legacy Prerender\n // We are in a legacy static generation mode while prerendering\n // We track dynamic access here so we don't need to wrap the headers in\n // individual property access tracking.\n throwToInterruptStaticGeneration('headers', workStore, workUnitStore)\n }\n }\n // We fall through to the dynamic context below but we still track dynamic access\n // because in dev we can still error for things like using headers inside a cache context\n trackDynamicDataInDynamicRender(workStore, workUnitStore)\n }\n\n const requestStore = getExpectedRequestStore('headers')\n if (process.env.NODE_ENV === 'development' && !workStore?.isPrefetchRequest) {\n return makeUntrackedExoticHeadersWithDevWarnings(\n requestStore.headers,\n workStore?.route\n )\n } else {\n return makeUntrackedExoticHeaders(requestStore.headers)\n }\n}\n\ninterface CacheLifetime {}\nconst CachedHeaders = new WeakMap<CacheLifetime, Promise<ReadonlyHeaders>>()\n\nfunction makeDynamicallyTrackedExoticHeaders(\n route: string,\n prerenderStore: PrerenderStoreModern\n): Promise<ReadonlyHeaders> {\n const cachedHeaders = CachedHeaders.get(prerenderStore)\n if (cachedHeaders) {\n return cachedHeaders\n }\n\n const promise = makeHangingPromise<ReadonlyHeaders>(\n prerenderStore.renderSignal,\n '`headers()`'\n )\n CachedHeaders.set(prerenderStore, promise)\n\n Object.defineProperties(promise, {\n append: {\n value: function append() {\n const expression = `\\`headers().append(${describeNameArg(arguments[0])}, ...)\\``\n const error = createHeadersAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n delete: {\n value: function _delete() {\n const expression = `\\`headers().delete(${describeNameArg(arguments[0])})\\``\n const error = createHeadersAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n get: {\n value: function get() {\n const expression = `\\`headers().get(${describeNameArg(arguments[0])})\\``\n const error = createHeadersAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n has: {\n value: function has() {\n const expression = `\\`headers().has(${describeNameArg(arguments[0])})\\``\n const error = createHeadersAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n set: {\n value: function set() {\n const expression = `\\`headers().set(${describeNameArg(arguments[0])}, ...)\\``\n const error = createHeadersAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n getSetCookie: {\n value: function getSetCookie() {\n const expression = '`headers().getSetCookie()`'\n const error = createHeadersAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n forEach: {\n value: function forEach() {\n const expression = '`headers().forEach(...)`'\n const error = createHeadersAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n keys: {\n value: function keys() {\n const expression = '`headers().keys()`'\n const error = createHeadersAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n values: {\n value: function values() {\n const expression = '`headers().values()`'\n const error = createHeadersAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n entries: {\n value: function entries() {\n const expression = '`headers().entries()`'\n const error = createHeadersAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n [Symbol.iterator]: {\n value: function () {\n const expression = '`headers()[Symbol.iterator]()`'\n const error = createHeadersAccessError(route, expression)\n abortAndThrowOnSynchronousRequestDataAccess(\n route,\n expression,\n error,\n prerenderStore\n )\n },\n },\n } satisfies HeadersExtensions)\n\n return promise\n}\n\nfunction makeUntrackedExoticHeaders(\n underlyingHeaders: ReadonlyHeaders\n): Promise<ReadonlyHeaders> {\n const cachedHeaders = CachedHeaders.get(underlyingHeaders)\n if (cachedHeaders) {\n return cachedHeaders\n }\n\n const promise = Promise.resolve(underlyingHeaders)\n CachedHeaders.set(underlyingHeaders, promise)\n\n Object.defineProperties(promise, {\n append: {\n value: underlyingHeaders.append.bind(underlyingHeaders),\n },\n delete: {\n value: underlyingHeaders.delete.bind(underlyingHeaders),\n },\n get: {\n value: underlyingHeaders.get.bind(underlyingHeaders),\n },\n has: {\n value: underlyingHeaders.has.bind(underlyingHeaders),\n },\n set: {\n value: underlyingHeaders.set.bind(underlyingHeaders),\n },\n getSetCookie: {\n value: underlyingHeaders.getSetCookie.bind(underlyingHeaders),\n },\n forEach: {\n value: underlyingHeaders.forEach.bind(underlyingHeaders),\n },\n keys: {\n value: underlyingHeaders.keys.bind(underlyingHeaders),\n },\n values: {\n value: underlyingHeaders.values.bind(underlyingHeaders),\n },\n entries: {\n value: underlyingHeaders.entries.bind(underlyingHeaders),\n },\n [Symbol.iterator]: {\n value: underlyingHeaders[Symbol.iterator].bind(underlyingHeaders),\n },\n } satisfies HeadersExtensions)\n\n return promise\n}\n\nfunction makeUntrackedExoticHeadersWithDevWarnings(\n underlyingHeaders: ReadonlyHeaders,\n route?: string\n): Promise<ReadonlyHeaders> {\n const cachedHeaders = CachedHeaders.get(underlyingHeaders)\n if (cachedHeaders) {\n return cachedHeaders\n }\n\n const promise = new Promise<ReadonlyHeaders>((resolve) =>\n scheduleImmediate(() => resolve(underlyingHeaders))\n )\n\n CachedHeaders.set(underlyingHeaders, promise)\n\n Object.defineProperties(promise, {\n append: {\n value: function append() {\n const expression = `\\`headers().append(${describeNameArg(arguments[0])}, ...)\\``\n syncIODev(route, expression)\n return underlyingHeaders.append.apply(\n underlyingHeaders,\n arguments as any\n )\n },\n },\n delete: {\n value: function _delete() {\n const expression = `\\`headers().delete(${describeNameArg(arguments[0])})\\``\n syncIODev(route, expression)\n return underlyingHeaders.delete.apply(\n underlyingHeaders,\n arguments as any\n )\n },\n },\n get: {\n value: function get() {\n const expression = `\\`headers().get(${describeNameArg(arguments[0])})\\``\n syncIODev(route, expression)\n return underlyingHeaders.get.apply(underlyingHeaders, arguments as any)\n },\n },\n has: {\n value: function has() {\n const expression = `\\`headers().has(${describeNameArg(arguments[0])})\\``\n syncIODev(route, expression)\n return underlyingHeaders.has.apply(underlyingHeaders, arguments as any)\n },\n },\n set: {\n value: function set() {\n const expression = `\\`headers().set(${describeNameArg(arguments[0])}, ...)\\``\n syncIODev(route, expression)\n return underlyingHeaders.set.apply(underlyingHeaders, arguments as any)\n },\n },\n getSetCookie: {\n value: function getSetCookie() {\n const expression = '`headers().getSetCookie()`'\n syncIODev(route, expression)\n return underlyingHeaders.getSetCookie.apply(\n underlyingHeaders,\n arguments as any\n )\n },\n },\n forEach: {\n value: function forEach() {\n const expression = '`headers().forEach(...)`'\n syncIODev(route, expression)\n return underlyingHeaders.forEach.apply(\n underlyingHeaders,\n arguments as any\n )\n },\n },\n keys: {\n value: function keys() {\n const expression = '`headers().keys()`'\n syncIODev(route, expression)\n return underlyingHeaders.keys.apply(underlyingHeaders, arguments as any)\n },\n },\n values: {\n value: function values() {\n const expression = '`headers().values()`'\n syncIODev(route, expression)\n return underlyingHeaders.values.apply(\n underlyingHeaders,\n arguments as any\n )\n },\n },\n entries: {\n value: function entries() {\n const expression = '`headers().entries()`'\n syncIODev(route, expression)\n return underlyingHeaders.entries.apply(\n underlyingHeaders,\n arguments as any\n )\n },\n },\n [Symbol.iterator]: {\n value: function () {\n const expression = '`...headers()` or similar iteration'\n syncIODev(route, expression)\n return underlyingHeaders[Symbol.iterator].apply(\n underlyingHeaders,\n arguments as any\n )\n },\n },\n } satisfies HeadersExtensions)\n\n return promise\n}\n\nfunction describeNameArg(arg: unknown) {\n return typeof arg === 'string' ? `'${arg}'` : '...'\n}\n\nfunction syncIODev(route: string | undefined, expression: string) {\n const workUnitStore = workUnitAsyncStorage.getStore()\n if (\n workUnitStore &&\n workUnitStore.type === 'request' &&\n workUnitStore.prerenderPhase === true\n ) {\n // When we're rendering dynamically in dev we need to advance out of the\n // Prerender environment when we read Request data synchronously\n const requestStore = workUnitStore\n trackSynchronousRequestDataAccessInDev(requestStore)\n }\n // In all cases we warn normally\n warnForSyncAccess(route, expression)\n}\n\nconst warnForSyncAccess = createDedupedByCallsiteServerErrorLoggerDev(\n createHeadersAccessError\n)\n\nfunction createHeadersAccessError(\n route: string | undefined,\n expression: string\n) {\n const prefix = route ? `Route \"${route}\" ` : 'This route '\n return new Error(\n `${prefix}used ${expression}. ` +\n `\\`headers()\\` should be awaited before using its value. ` +\n `Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis`\n )\n}\n\ntype HeadersExtensions = {\n [K in keyof ReadonlyHeaders]: unknown\n}\n","import {\n getDraftModeProviderForCacheScope,\n throwForMissingRequestStore,\n} from '../app-render/work-unit-async-storage.external'\n\nimport type { DraftModeProvider } from '../async-storage/draft-mode-provider'\n\nimport {\n workAsyncStorage,\n type WorkStore,\n} from '../app-render/work-async-storage.external'\nimport { workUnitAsyncStorage } from '../app-render/work-unit-async-storage.external'\nimport {\n abortAndThrowOnSynchronousRequestDataAccess,\n postponeWithTracking,\n trackSynchronousRequestDataAccessInDev,\n} from '../app-render/dynamic-rendering'\nimport { createDedupedByCallsiteServerErrorLoggerDev } from '../create-deduped-by-callsite-server-error-logger'\nimport { StaticGenBailoutError } from '../../client/components/static-generation-bailout'\nimport { DynamicServerError } from '../../client/components/hooks-server-context'\n\n/**\n * In this version of Next.js `draftMode()` returns a Promise however you can still reference the properties of the underlying draftMode object\n * synchronously to facilitate migration. The `UnsafeUnwrappedDraftMode` type is added to your code by a codemod that attempts to automatically\n * updates callsites to reflect the new Promise return type. There are some cases where `draftMode()` cannot be automatically converted, namely\n * when it is used inside a synchronous function and we can't be sure the function can be made async automatically. In these cases we add an\n * explicit type case to `UnsafeUnwrappedDraftMode` to enable typescript to allow for the synchronous usage only where it is actually necessary.\n *\n * You should should update these callsites to either be async functions where the `draftMode()` value can be awaited or you should call `draftMode()`\n * from outside and await the return value before passing it into this function.\n *\n * You can find instances that require manual migration by searching for `UnsafeUnwrappedDraftMode` in your codebase or by search for a comment that\n * starts with `@next-codemod-error`.\n *\n * In a future version of Next.js `draftMode()` will only return a Promise and you will not be able to access the underlying draftMode object directly\n * without awaiting the return value first. When this change happens the type `UnsafeUnwrappedDraftMode` will be updated to reflect that is it no longer\n * usable.\n *\n * This type is marked deprecated to help identify it as target for refactoring away.\n *\n * @deprecated\n */\nexport type UnsafeUnwrappedDraftMode = DraftMode\n\nexport function draftMode(): Promise<DraftMode> {\n const callingExpression = 'draftMode'\n const workStore = workAsyncStorage.getStore()\n const workUnitStore = workUnitAsyncStorage.getStore()\n\n if (!workStore || !workUnitStore) {\n throwForMissingRequestStore(callingExpression)\n }\n\n switch (workUnitStore.type) {\n case 'request':\n return createOrGetCachedExoticDraftMode(\n workUnitStore.draftMode,\n workStore\n )\n\n case 'cache':\n case 'unstable-cache':\n // Inside of `\"use cache\"` or `unstable_cache`, draft mode is available if\n // the outmost work unit store is a request store, and if draft mode is\n // enabled.\n const draftModeProvider = getDraftModeProviderForCacheScope(\n workStore,\n workUnitStore\n )\n\n if (draftModeProvider) {\n return createOrGetCachedExoticDraftMode(draftModeProvider, workStore)\n }\n\n // Otherwise, we fall through to providing an empty draft mode.\n // eslint-disable-next-line no-fallthrough\n case 'prerender':\n case 'prerender-ppr':\n case 'prerender-legacy':\n // Return empty draft mode\n if (\n process.env.NODE_ENV === 'development' &&\n !workStore?.isPrefetchRequest\n ) {\n const route = workStore?.route\n return createExoticDraftModeWithDevWarnings(null, route)\n } else {\n return createExoticDraftMode(null)\n }\n\n default:\n const _exhaustiveCheck: never = workUnitStore\n return _exhaustiveCheck\n }\n}\n\nfunction createOrGetCachedExoticDraftMode(\n draftModeProvider: DraftModeProvider,\n workStore: WorkStore | undefined\n): Promise<DraftMode> {\n const cachedDraftMode = CachedDraftModes.get(draftMode)\n\n if (cachedDraftMode) {\n return cachedDraftMode\n }\n\n let promise: Promise<DraftMode>\n\n if (process.env.NODE_ENV === 'development' && !workStore?.isPrefetchRequest) {\n const route = workStore?.route\n promise = createExoticDraftModeWithDevWarnings(draftModeProvider, route)\n } else {\n promise = createExoticDraftMode(draftModeProvider)\n }\n\n CachedDraftModes.set(draftModeProvider, promise)\n\n return promise\n}\n\ninterface CacheLifetime {}\nconst CachedDraftModes = new WeakMap<CacheLifetime, Promise<DraftMode>>()\n\nfunction createExoticDraftMode(\n underlyingProvider: null | DraftModeProvider\n): Promise<DraftMode> {\n const instance = new DraftMode(underlyingProvider)\n const promise = Promise.resolve(instance)\n\n Object.defineProperty(promise, 'isEnabled', {\n get() {\n return instance.isEnabled\n },\n set(newValue) {\n Object.defineProperty(promise, 'isEnabled', {\n value: newValue,\n writable: true,\n enumerable: true,\n })\n },\n enumerable: true,\n configurable: true,\n })\n ;(promise as any).enable = instance.enable.bind(instance)\n ;(promise as any).disable = instance.disable.bind(instance)\n\n return promise\n}\n\nfunction createExoticDraftModeWithDevWarnings(\n underlyingProvider: null | DraftModeProvider,\n route: undefined | string\n): Promise<DraftMode> {\n const instance = new DraftMode(underlyingProvider)\n const promise = Promise.resolve(instance)\n\n Object.defineProperty(promise, 'isEnabled', {\n get() {\n const expression = '`draftMode().isEnabled`'\n syncIODev(route, expression)\n return instance.isEnabled\n },\n set(newValue) {\n Object.defineProperty(promise, 'isEnabled', {\n value: newValue,\n writable: true,\n enumerable: true,\n })\n },\n enumerable: true,\n configurable: true,\n })\n\n Object.defineProperty(promise, 'enable', {\n value: function get() {\n const expression = '`draftMode().enable()`'\n syncIODev(route, expression)\n return instance.enable.apply(instance, arguments as any)\n },\n })\n\n Object.defineProperty(promise, 'disable', {\n value: function get() {\n const expression = '`draftMode().disable()`'\n syncIODev(route, expression)\n return instance.disable.apply(instance, arguments as any)\n },\n })\n\n return promise\n}\n\nclass DraftMode {\n /**\n * @internal - this declaration is stripped via `tsc --stripInternal`\n */\n private readonly _provider: null | DraftModeProvider\n\n constructor(provider: null | DraftModeProvider) {\n this._provider = provider\n }\n get isEnabled() {\n if (this._provider !== null) {\n return this._provider.isEnabled\n }\n return false\n }\n public enable() {\n // We have a store we want to track dynamic data access to ensure we\n // don't statically generate routes that manipulate draft mode.\n trackDynamicDraftMode('draftMode().enable()')\n if (this._provider !== null) {\n this._provider.enable()\n }\n }\n public disable() {\n trackDynamicDraftMode('draftMode().disable()')\n if (this._provider !== null) {\n this._provider.disable()\n }\n }\n}\n\nfunction syncIODev(route: string | undefined, expression: string) {\n const workUnitStore = workUnitAsyncStorage.getStore()\n if (\n workUnitStore &&\n workUnitStore.type === 'request' &&\n workUnitStore.prerenderPhase === true\n ) {\n // When we're rendering dynamically in dev we need to advance out of the\n // Prerender environment when we read Request data synchronously\n const requestStore = workUnitStore\n trackSynchronousRequestDataAccessInDev(requestStore)\n }\n // In all cases we warn normally\n warnForSyncAccess(route, expression)\n}\n\nconst warnForSyncAccess = createDedupedByCallsiteServerErrorLoggerDev(\n createDraftModeAccessError\n)\n\nfunction createDraftModeAccessError(\n route: string | undefined,\n expression: string\n) {\n const prefix = route ? `Route \"${route}\" ` : 'This route '\n return new Error(\n `${prefix}used ${expression}. ` +\n `\\`draftMode()\\` should be awaited before using its value. ` +\n `Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis`\n )\n}\n\nfunction trackDynamicDraftMode(expression: string) {\n const store = workAsyncStorage.getStore()\n const workUnitStore = workUnitAsyncStorage.getStore()\n if (store) {\n // We have a store we want to track dynamic data access to ensure we\n // don't statically generate routes that manipulate draft mode.\n if (workUnitStore) {\n if (workUnitStore.type === 'cache') {\n throw new Error(\n `Route ${store.route} used \"${expression}\" inside \"use cache\". The enabled status of draftMode can be read in caches but you must not enable or disable draftMode inside a cache. See more info here: https://nextjs.org/docs/messages/next-request-in-use-cache`\n )\n } else if (workUnitStore.type === 'unstable-cache') {\n throw new Error(\n `Route ${store.route} used \"${expression}\" inside a function cached with \"unstable_cache(...)\". The enabled status of draftMode can be read in caches but you must not enable or disable draftMode inside a cache. See more info here: https://nextjs.org/docs/app/api-reference/functions/unstable_cache`\n )\n } else if (workUnitStore.phase === 'after') {\n throw new Error(\n `Route ${store.route} used \"${expression}\" inside \\`after\\`. The enabled status of draftMode can be read inside \\`after\\` but you cannot enable or disable draftMode. See more info here: https://nextjs.org/docs/app/api-reference/functions/after`\n )\n }\n }\n\n if (store.dynamicShouldError) {\n throw new StaticGenBailoutError(\n `Route ${store.route} with \\`dynamic = \"error\"\\` couldn't be rendered statically because it used \\`${expression}\\`. See more info here: https://nextjs.org/docs/app/building-your-application/rendering/static-and-dynamic#dynamic-rendering`\n )\n }\n\n if (workUnitStore) {\n if (workUnitStore.type === 'prerender') {\n // dynamicIO Prerender\n const error = new Error(\n `Route ${store.route} used ${expression} without first calling \\`await connection()\\`. See more info here: https://nextjs.org/docs/messages/next-prerender-sync-headers`\n )\n abortAndThrowOnSynchronousRequestDataAccess(\n store.route,\n expression,\n error,\n workUnitStore\n )\n } else if (workUnitStore.type === 'prerender-ppr') {\n // PPR Prerender\n postponeWithTracking(\n store.route,\n expression,\n workUnitStore.dynamicTracking\n )\n } else if (workUnitStore.type === 'prerender-legacy') {\n // legacy Prerender\n workUnitStore.revalidate = 0\n\n const err = new DynamicServerError(\n `Route ${store.route} couldn't be rendered statically because it used \\`${expression}\\`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error`\n )\n store.dynamicUsageDescription = expression\n store.dynamicUsageStack = err.stack\n\n throw err\n } else if (\n process.env.NODE_ENV === 'development' &&\n workUnitStore &&\n workUnitStore.type === 'request'\n ) {\n workUnitStore.usedDynamic = true\n }\n }\n }\n}\n","module.exports.cookies = require('./dist/server/request/cookies').cookies\nmodule.exports.headers = require('./dist/server/request/headers').headers\nmodule.exports.draftMode = require('./dist/server/request/draft-mode').draftMode\n","/**\n * Server-side authentication utilities for MoonUI Pro\n * These functions should ONLY run on the server\n */\n\nimport { cookies, headers } from 'next/headers';\nimport { AUTH_CONFIG } from './auth-config';\nimport crypto from 'crypto';\n\n// Encryption key for cookie values (should be in env in production)\nconst ENCRYPTION_KEY = process.env.MOONUI_ENCRYPTION_KEY || 'moonui-pro-default-key-change-in-production';\n\n/**\n * Encrypt data for secure cookie storage\n */\nexport function encryptData(data: any): string {\n const cipher = crypto.createCipher('aes-256-cbc', ENCRYPTION_KEY);\n let encrypted = cipher.update(JSON.stringify(data), 'utf8', 'hex');\n encrypted += cipher.final('hex');\n return encrypted;\n}\n\n/**\n * Decrypt data from secure cookie\n */\nexport function decryptData(encryptedData: string): any {\n try {\n const decipher = crypto.createDecipher('aes-256-cbc', ENCRYPTION_KEY);\n let decrypted = decipher.update(encryptedData, 'hex', 'utf8');\n decrypted += decipher.final('utf8');\n return JSON.parse(decrypted);\n } catch (error) {\n console.error('[Server Auth] Decryption failed:', error);\n return null;\n }\n}\n\n/**\n * Generate device fingerprint from request (server-side)\n */\nexport async function generateServerDeviceFingerprint(): Promise<string> {\n const headersList = await headers();\n\n const components = [\n headersList.get('user-agent') || 'unknown',\n headersList.get('accept-language') || 'unknown',\n headersList.get('accept-encoding') || 'unknown',\n headersList.get('x-forwarded-for') || headersList.get('x-real-ip') || 'unknown',\n ];\n\n const fingerprint = crypto\n .createHash('sha256')\n .update(components.join('|'))\n .digest('hex');\n\n return fingerprint;\n}\n\n/**\n * Validate with MoonUI server (server-to-server call)\n */\nexport async function validateWithMoonUIServer(\n token: string,\n deviceId: string\n): Promise<{\n valid: boolean;\n hasProAccess: boolean;\n plan?: string;\n error?: string;\n}> {\n try {\n const response = await fetch(AUTH_CONFIG.api.moonuiValidationEndpoint, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'Authorization': `Bearer ${token}`,\n 'X-Device-ID': deviceId,\n 'X-API-Key': process.env.MOONUI_SERVER_API_KEY || '',\n },\n body: JSON.stringify({\n token,\n deviceId,\n timestamp: Date.now(),\n }),\n signal: AbortSignal.timeout(AUTH_CONFIG.api.timeout),\n });\n\n if (!response.ok) {\n console.error('[Server Auth] Validation failed:', response.status);\n return { valid: false, hasProAccess: false, error: 'Validation failed' };\n }\n\n const data = await response.json();\n return {\n valid: data.valid,\n hasProAccess: data.valid && (\n data.user?.hasLifetimeAccess ||\n data.user?.features?.includes('pro_components') ||\n false\n ),\n plan: data.user?.plan,\n };\n } catch (error) {\n console.error('[Server Auth] Server validation error:', error);\n return {\n valid: false,\n hasProAccess: false,\n error: error instanceof Error ? error.message : 'Unknown error'\n };\n }\n}\n\n/**\n * Get validation from cookies (server-side)\n */\nexport async function getValidationFromCookies(): Promise<{\n valid: boolean;\n hasProAccess: boolean;\n timestamp: number;\n} | null> {\n const cookieStore = await cookies();\n const validationCookie = cookieStore.get(AUTH_CONFIG.cookies.validation);\n\n if (!validationCookie) {\n return null;\n }\n\n const decrypted = decryptData(validationCookie.value);\n if (!decrypted) {\n return null;\n }\n\n // Check if validation is still fresh\n const age = Date.now() - decrypted.timestamp;\n if (age > AUTH_CONFIG.cache.serverCacheDuration) {\n return null; // Expired\n }\n\n return decrypted;\n}\n\n/**\n * Set validation in cookies (server-side)\n */\nexport async function setValidationInCookies(validation: {\n valid: boolean;\n hasProAccess: boolean;\n plan?: string;\n}): Promise<void> {\n const cookieStore = await cookies();\n\n const data = {\n ...validation,\n timestamp: Date.now(),\n };\n\n const encrypted = encryptData(data);\n\n cookieStore.set(\n AUTH_CONFIG.cookies.validation,\n encrypted,\n {\n ...AUTH_CONFIG.security.cookieOptions,\n maxAge: AUTH_CONFIG.cache.cookieMaxAge,\n }\n );\n}\n\n/**\n * Clear validation cookies\n */\nexport async function clearValidationCookies(): Promise<void> {\n const cookieStore = await cookies();\n\n cookieStore.delete(AUTH_CONFIG.cookies.validation);\n cookieStore.delete(AUTH_CONFIG.cookies.session);\n cookieStore.delete(AUTH_CONFIG.cookies.device);\n}\n\n/**\n * Perform full server-side validation\n */\nexport async function performServerValidation(): Promise<{\n valid: boolean;\n hasProAccess: boolean;\n plan?: string;\n cached?: boolean;\n}> {\n // 1. Check cache first\n const cached = await getValidationFromCookies();\n if (cached) {\n console.log('[Server Auth] Using cached validation');\n return { ...cached, cached: true };\n }\n\n // 2. Get token from cookies or environment\n const cookieStore = await cookies();\n const token = cookieStore.get('moonui_auth_token')?.value ||\n process.env.MOONUI_LICENSE_KEY ||\n '';\n\n if (!token) {\n console.log('[Server Auth] No token found');\n return { valid: false, hasProAccess: false };\n }\n\n // 3. Generate device fingerprint\n const deviceId = await generateServerDeviceFingerprint();\n\n // 4. Validate with MoonUI server\n console.log('[Server Auth] Performing server validation...');\n const result = await validateWithMoonUIServer(token, deviceId);\n\n // 5. Cache the result\n if (result.valid) {\n await setValidationInCookies(result);\n }\n\n return { ...result, cached: false };\n}","/**\n * MoonUI Pro Authentication Configuration\n *\n * This configuration is determined at BUILD TIME, not runtime.\n * It ensures zero external API calls from the browser.\n */\n\n// Determine environment at build time\nconst IS_DEVELOPMENT = process.env.NODE_ENV === 'development';\nconst IS_PRODUCTION = process.env.NODE_ENV === 'production';\n\nexport const AUTH_CONFIG = {\n // Internal API endpoint (never external)\n // Developers will implement this endpoint in their own project\n internalEndpoint: '/api/moonui/validate-pro',\n\n // Cache configuration\n cache: {\n // Server-side cache duration\n serverCacheDuration: IS_PRODUCTION\n ? 24 * 60 * 60 * 1000 // 24 hours in production\n : 60 * 60 * 1000, // 1 hour in development\n\n // Cookie expiry\n cookieMaxAge: IS_PRODUCTION\n ? 7 * 24 * 60 * 60 // 7 days in production (seconds)\n : 24 * 60 * 60, // 1 day in development (seconds)\n\n // Validation refresh threshold (when to refresh in background)\n refreshThreshold: 0.5, // Refresh when 50% of cache time passed\n },\n\n // Security configuration\n security: {\n // Device fingerprint validation\n enforceDeviceFingerprint: true,\n\n // Maximum devices per license\n maxDevicesPerLicense: IS_PRODUCTION ? 3 : 5,\n\n // Session timeout\n sessionTimeout: IS_PRODUCTION\n ? 30 * 24 * 60 * 60 * 1000 // 30 days\n : 7 * 24 * 60 * 60 * 1000, // 7 days\n\n // Cookie settings\n cookieOptions: {\n httpOnly: true,\n secure: IS_PRODUCTION,\n sameSite: 'lax' as const,\n path: '/',\n },\n },\n\n // API configuration for server-to-server calls\n api: {\n // MoonUI validation server (only called from server-side)\n moonuiValidationEndpoint: IS_PRODUCTION\n ? 'https://api.moonui.dev/v1/license/validate'\n : 'https://api.moonui.dev/v1/license/validate',\n\n // Timeout for server-to-server calls\n timeout: 10000, // 10 seconds\n\n // Retry configuration\n retry: {\n attempts: IS_PRODUCTION ? 3 : 1,\n delay: 1000, // 1 second between retries\n },\n },\n\n // Cookie names\n cookies: {\n validation: 'moonui_pro_validation',\n session: 'moonui_pro_session',\n device: 'moonui_pro_device',\n },\n\n // Header names for server communication\n headers: {\n validation: 'x-moonui-pro-validation',\n device: 'x-moonui-device-id',\n session: 'x-moonui-session-id',\n },\n} as const;\n\n// Type exports\nexport type AuthConfig = typeof AUTH_CONFIG;\nexport type CacheConfig = typeof AUTH_CONFIG.cache;\nexport type SecurityConfig = typeof AUTH_CONFIG.security;","/**\n * Server-side exports for MoonUI Pro\n * These should only be imported in server environments\n */\n\n// Re-export all server utilities\nexport {\n encryptData,\n decryptData,\n generateServerDeviceFingerprint,\n validateWithMoonUIServer,\n getValidationFromCookies,\n setValidationInCookies,\n clearValidationCookies,\n performServerValidation,\n} from './lib/server-auth';\n\n// Re-export auth config\nexport { AUTH_CONFIG } from './lib/auth-config';\nexport type { AuthConfig, CacheConfig, SecurityConfig } from './lib/auth-config';\n\n// Server-side only warning\nif (typeof window !== 'undefined') {\n console.warn(\n '[MoonUI Pro] Warning: Server utilities imported in client environment. ' +\n 'These utilities should only be used in server components or API routes.'\n );\n}"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["#style-inject:#style-inject","../../src/styles/nprogress.css"],"names":[],"mappings":";;;;;;;;AACyB,SAAR,YAA6B,KAAK,EAAE,SAAS,IAAI,CAAC,GAAG;AAC1D,MAAI,CAAC,OAAO,OAAO,aAAa;AAAa;AAE7C,QAAM,OAAO,SAAS,QAAQ,SAAS,qBAAqB,MAAM,EAAE,CAAC;AACrE,QAAM,QAAQ,SAAS,cAAc,OAAO;AAC5C,QAAM,OAAO;AAEb,MAAI,aAAa,OAAO;AACtB,QAAI,KAAK,YAAY;AACnB,WAAK,aAAa,OAAO,KAAK,UAAU;AAAA,IAC1C,OAAO;AACL,WAAK,YAAY,KAAK;AAAA,IACxB;AAAA,EACF,OAAO;AACL,SAAK,YAAY,KAAK;AAAA,EACxB;AAEA,MAAI,MAAM,YAAY;AACpB,UAAM,WAAW,UAAU;AAAA,EAC7B,OAAO;AACL,UAAM,YAAY,SAAS,eAAe,GAAG,CAAC;AAAA,EAChD;AACF;;;ACvB8B,YAAY,+pCAA+pC","sourcesContent":["\n export default function styleInject(css, { insertAt } = {}) {\n if (!css || typeof document === 'undefined') return\n \n const head = document.head || document.getElementsByTagName('head')[0]\n const style = document.createElement('style')\n style.type = 'text/css'\n \n if (insertAt === 'top') {\n if (head.firstChild) {\n head.insertBefore(style, head.firstChild)\n } else {\n head.appendChild(style)\n }\n } else {\n head.appendChild(style)\n }\n \n if (style.styleSheet) {\n style.styleSheet.cssText = css\n } else {\n style.appendChild(document.createTextNode(css))\n }\n }\n ","import styleInject from '#style-inject';styleInject(\"#nprogress {\\n pointer-events: none;\\n}\\n#nprogress .bar {\\n background: linear-gradient(90deg, #8b5cf6 0%, #d946ef 50%, #8b5cf6 100%);\\n background-size: 200% 100%;\\n animation: gradient-shift 2s ease infinite;\\n position: fixed;\\n z-index: 9999;\\n top: 0;\\n left: 0;\\n width: 100%;\\n height: 3px;\\n box-shadow: 0 0 10px rgba(139, 92, 246, 0.5), 0 0 5px rgba(217, 70, 239, 0.5);\\n}\\n#nprogress .peg {\\n display: block;\\n position: absolute;\\n right: 0px;\\n width: 100px;\\n height: 100%;\\n box-shadow: 0 0 15px rgba(139, 92, 246, 0.7), 0 0 8px rgba(217, 70, 239, 0.7);\\n opacity: 1.0;\\n transform: rotate(3deg) translate(0px, -4px);\\n}\\n#nprogress .spinner {\\n display: none;\\n}\\n@keyframes gradient-shift {\\n 0% {\\n background-position: 0% 50%;\\n }\\n 50% {\\n background-position: 100% 50%;\\n }\\n 100% {\\n background-position: 0% 50%;\\n }\\n}\\n.dark #nprogress .bar {\\n background: linear-gradient(90deg, #a78bfa 0%, #e879f9 50%, #a78bfa 100%);\\n box-shadow: 0 0 15px rgba(167, 139, 250, 0.6), 0 0 8px rgba(232, 121, 249, 0.6);\\n}\\n.dark #nprogress .peg {\\n box-shadow: 0 0 20px rgba(167, 139, 250, 0.8), 0 0 10px rgba(232, 121, 249, 0.8);\\n}\\n\")"]}
|