vinext 0.0.24 → 0.0.25

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (92) hide show
  1. package/README.md +24 -0
  2. package/dist/check.d.ts.map +1 -1
  3. package/dist/check.js +3 -2
  4. package/dist/check.js.map +1 -1
  5. package/dist/client/entry.js +1 -1
  6. package/dist/client/entry.js.map +1 -1
  7. package/dist/config/config-matchers.d.ts +21 -0
  8. package/dist/config/config-matchers.d.ts.map +1 -1
  9. package/dist/config/config-matchers.js +46 -6
  10. package/dist/config/config-matchers.js.map +1 -1
  11. package/dist/config/next-config.d.ts +8 -2
  12. package/dist/config/next-config.d.ts.map +1 -1
  13. package/dist/config/next-config.js +90 -35
  14. package/dist/config/next-config.js.map +1 -1
  15. package/dist/deploy.d.ts +10 -0
  16. package/dist/deploy.d.ts.map +1 -1
  17. package/dist/deploy.js +70 -35
  18. package/dist/deploy.js.map +1 -1
  19. package/dist/index.d.ts +3 -0
  20. package/dist/index.d.ts.map +1 -1
  21. package/dist/index.js +172 -18
  22. package/dist/index.js.map +1 -1
  23. package/dist/plugins/async-hooks-stub.d.ts +16 -0
  24. package/dist/plugins/async-hooks-stub.d.ts.map +1 -0
  25. package/dist/plugins/async-hooks-stub.js +45 -0
  26. package/dist/plugins/async-hooks-stub.js.map +1 -0
  27. package/dist/routing/app-router.d.ts +12 -6
  28. package/dist/routing/app-router.d.ts.map +1 -1
  29. package/dist/routing/app-router.js +19 -40
  30. package/dist/routing/app-router.js.map +1 -1
  31. package/dist/routing/pages-router.d.ts.map +1 -1
  32. package/dist/routing/pages-router.js +3 -9
  33. package/dist/routing/pages-router.js.map +1 -1
  34. package/dist/routing/utils.d.ts +9 -0
  35. package/dist/routing/utils.d.ts.map +1 -1
  36. package/dist/routing/utils.js +10 -0
  37. package/dist/routing/utils.js.map +1 -1
  38. package/dist/server/api-handler.d.ts.map +1 -1
  39. package/dist/server/api-handler.js +6 -0
  40. package/dist/server/api-handler.js.map +1 -1
  41. package/dist/server/app-dev-server.d.ts +2 -2
  42. package/dist/server/app-dev-server.d.ts.map +1 -1
  43. package/dist/server/app-dev-server.js +238 -114
  44. package/dist/server/app-dev-server.js.map +1 -1
  45. package/dist/server/dev-module-runner.d.ts +84 -0
  46. package/dist/server/dev-module-runner.d.ts.map +1 -0
  47. package/dist/server/dev-module-runner.js +105 -0
  48. package/dist/server/dev-module-runner.js.map +1 -0
  49. package/dist/server/dev-server.js.map +1 -1
  50. package/dist/server/instrumentation.d.ts +52 -9
  51. package/dist/server/instrumentation.d.ts.map +1 -1
  52. package/dist/server/instrumentation.js +52 -15
  53. package/dist/server/instrumentation.js.map +1 -1
  54. package/dist/server/middleware.d.ts +7 -3
  55. package/dist/server/middleware.d.ts.map +1 -1
  56. package/dist/server/middleware.js +16 -6
  57. package/dist/server/middleware.js.map +1 -1
  58. package/dist/server/prod-server.d.ts.map +1 -1
  59. package/dist/server/prod-server.js +15 -25
  60. package/dist/server/prod-server.js.map +1 -1
  61. package/dist/shims/cache.d.ts.map +1 -1
  62. package/dist/shims/cache.js +14 -2
  63. package/dist/shims/cache.js.map +1 -1
  64. package/dist/shims/fetch-cache.d.ts.map +1 -1
  65. package/dist/shims/fetch-cache.js +139 -29
  66. package/dist/shims/fetch-cache.js.map +1 -1
  67. package/dist/shims/form.d.ts.map +1 -1
  68. package/dist/shims/form.js +2 -3
  69. package/dist/shims/form.js.map +1 -1
  70. package/dist/shims/layout-segment-context.d.ts +5 -4
  71. package/dist/shims/layout-segment-context.d.ts.map +1 -1
  72. package/dist/shims/layout-segment-context.js +6 -5
  73. package/dist/shims/layout-segment-context.js.map +1 -1
  74. package/dist/shims/link.d.ts.map +1 -1
  75. package/dist/shims/link.js +32 -17
  76. package/dist/shims/link.js.map +1 -1
  77. package/dist/shims/navigation.d.ts +14 -11
  78. package/dist/shims/navigation.d.ts.map +1 -1
  79. package/dist/shims/navigation.js +122 -102
  80. package/dist/shims/navigation.js.map +1 -1
  81. package/dist/shims/router.d.ts.map +1 -1
  82. package/dist/shims/router.js +37 -21
  83. package/dist/shims/router.js.map +1 -1
  84. package/dist/shims/server.d.ts +2 -0
  85. package/dist/shims/server.d.ts.map +1 -1
  86. package/dist/shims/server.js +4 -0
  87. package/dist/shims/server.js.map +1 -1
  88. package/dist/shims/url-utils.d.ts +13 -0
  89. package/dist/shims/url-utils.d.ts.map +1 -0
  90. package/dist/shims/url-utils.js +28 -0
  91. package/dist/shims/url-utils.js.map +1 -0
  92. package/package.json +1 -1
package/dist/deploy.d.ts CHANGED
@@ -103,6 +103,16 @@ interface GeneratedFile {
103
103
  content: string;
104
104
  description: string;
105
105
  }
106
+ /**
107
+ * Check whether an existing vite.config file already imports and uses the
108
+ * Cloudflare Vite plugin. This is a heuristic text scan — it doesn't execute
109
+ * the config — so it may produce false negatives for unusual configurations.
110
+ *
111
+ * Returns true if `@cloudflare/vite-plugin` appears to be configured, false
112
+ * if it is missing (meaning the build will fail with "could not resolve
113
+ * virtual:vinext-rsc-entry").
114
+ */
115
+ export declare function viteConfigHasCloudflarePlugin(root: string): boolean;
106
116
  export declare function getFilesToGenerate(info: ProjectInfo): GeneratedFile[];
107
117
  export interface WranglerDeployArgs {
108
118
  args: string[];
@@ -1 +1 @@
1
- {"version":3,"file":"deploy.d.ts","sourceRoot":"","sources":["../src/deploy.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"deploy.d.ts","sourceRoot":"","sources":["../src/deploy.ts"],"names":[],"mappings":"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"}
package/dist/deploy.js CHANGED
@@ -367,6 +367,7 @@ import {
367
367
  matchRewrite,
368
368
  matchHeaders,
369
369
  requestContextFromRequest,
370
+ applyMiddlewareRequestHeaders,
370
371
  isExternalUrl,
371
372
  proxyExternalRequest,
372
373
  sanitizeDestination,
@@ -386,6 +387,11 @@ interface Env {
386
387
  };
387
388
  }
388
389
 
390
+ interface ExecutionContext {
391
+ waitUntil(promise: Promise<unknown>): void;
392
+ passThroughOnException(): void;
393
+ }
394
+
389
395
  // Extract config values (embedded at build time in the server entry)
390
396
  const basePath: string = vinextConfig?.basePath ?? "";
391
397
  const trailingSlash: boolean = vinextConfig?.trailingSlash ?? false;
@@ -399,7 +405,7 @@ const imageConfig: ImageConfig | undefined = vinextConfig?.images ? {
399
405
  } : undefined;
400
406
 
401
407
  export default {
402
- async fetch(request: Request, env: Env): Promise<Response> {
408
+ async fetch(request: Request, env: Env, ctx: ExecutionContext): Promise<Response> {
403
409
  try {
404
410
  const url = new URL(request.url);
405
411
  let pathname = url.pathname;
@@ -471,7 +477,7 @@ export default {
471
477
  const middlewareHeaders: Record<string, string | string[]> = {};
472
478
  let middlewareRewriteStatus: number | undefined;
473
479
  if (typeof runMiddleware === "function") {
474
- const result = await runMiddleware(request);
480
+ const result = await runMiddleware(request, ctx);
475
481
 
476
482
  if (!result.continue) {
477
483
  if (result.redirectUrl) {
@@ -513,38 +519,12 @@ export default {
513
519
  middlewareRewriteStatus = result.rewriteStatus;
514
520
  }
515
521
 
516
- // Unpack x-middleware-request-* headers into the actual request so
517
- // that renderPage / handleApiRoute see middleware-modified headers.
518
- // Workers incoming request headers are immutable, so clone if needed.
519
- const mwReqPrefix = "x-middleware-request-";
520
- const mwReqHeaders: Record<string, string> = {};
521
- for (const key of Object.keys(middlewareHeaders)) {
522
- if (key.startsWith(mwReqPrefix)) {
523
- const realName = key.slice(mwReqPrefix.length);
524
- mwReqHeaders[realName] = middlewareHeaders[key] as string;
525
- delete middlewareHeaders[key];
526
- } else if (key.startsWith("x-middleware-")) {
527
- delete middlewareHeaders[key];
528
- }
529
- }
530
- if (Object.keys(mwReqHeaders).length > 0) {
531
- const newHeaders = new Headers(request.headers);
532
- for (const [k, v] of Object.entries(mwReqHeaders)) {
533
- newHeaders.set(k, v);
534
- }
535
- request = new Request(request.url, {
536
- method: request.method,
537
- headers: newHeaders,
538
- body: request.body,
539
- // @ts-expect-error -- duplex needed for streaming request bodies
540
- duplex: request.body ? "half" : undefined,
541
- });
542
- }
543
-
544
- // Rebuild context after middleware has unpacked x-middleware-request-*
545
- // headers into the cloned request. Used only for afterFiles and fallback
546
- // rewrites, which run after middleware in the App Router execution order.
547
- const postMwReqCtx = requestContextFromRequest(request);
522
+ // Unpack x-middleware-request-* headers into the actual request and strip
523
+ // all x-middleware-* internal signals. Rebuilds postMwReqCtx for use by
524
+ // beforeFiles, afterFiles, and fallback config rules (which run after
525
+ // middleware per the Next.js execution order).
526
+ const { postMwReqCtx, request: postMwReq } = applyMiddlewareRequestHeaders(middlewareHeaders, request);
527
+ request = postMwReq;
548
528
 
549
529
  let resolvedPathname = resolvedUrl.split("?")[0];
550
530
 
@@ -553,6 +533,8 @@ export default {
553
533
  // Set-Cookie) and override for everything else. Vary values are
554
534
  // comma-joined per HTTP spec. Set-Cookie values are accumulated
555
535
  // as arrays (RFC 6265 forbids comma-joining cookies).
536
+ // Middleware headers take precedence: skip config keys already set
537
+ // by middleware so middleware always wins for the same key.
556
538
  if (configHeaders.length) {
557
539
  const matched = matchHeaders(resolvedPathname, configHeaders, reqCtx);
558
540
  for (const h of matched) {
@@ -568,7 +550,9 @@ export default {
568
550
  }
569
551
  } else if (lk === "vary" && middlewareHeaders[lk]) {
570
552
  middlewareHeaders[lk] += ", " + h.value;
571
- } else {
553
+ } else if (!(lk in middlewareHeaders)) {
554
+ // Middleware headers take precedence: only set if middleware
555
+ // did not already place this key on the response.
572
556
  middlewareHeaders[lk] = h.value;
573
557
  }
574
558
  }
@@ -819,6 +803,35 @@ function installDeps(root, deps) {
819
803
  });
820
804
  }
821
805
  const detectPackageManager = _detectPackageManager;
806
+ /**
807
+ * Check whether an existing vite.config file already imports and uses the
808
+ * Cloudflare Vite plugin. This is a heuristic text scan — it doesn't execute
809
+ * the config — so it may produce false negatives for unusual configurations.
810
+ *
811
+ * Returns true if `@cloudflare/vite-plugin` appears to be configured, false
812
+ * if it is missing (meaning the build will fail with "could not resolve
813
+ * virtual:vinext-rsc-entry").
814
+ */
815
+ export function viteConfigHasCloudflarePlugin(root) {
816
+ const candidates = [
817
+ path.join(root, "vite.config.ts"),
818
+ path.join(root, "vite.config.js"),
819
+ path.join(root, "vite.config.mjs"),
820
+ ];
821
+ for (const candidate of candidates) {
822
+ if (fs.existsSync(candidate)) {
823
+ try {
824
+ const content = fs.readFileSync(candidate, "utf-8");
825
+ return content.includes("@cloudflare/vite-plugin");
826
+ }
827
+ catch {
828
+ // unreadable — assume it might be fine
829
+ return true;
830
+ }
831
+ }
832
+ }
833
+ return false;
834
+ }
822
835
  export function getFilesToGenerate(info) {
823
836
  const files = [];
824
837
  if (!info.hasWranglerConfig) {
@@ -974,6 +987,28 @@ export async function deploy(options) {
974
987
  console.log();
975
988
  writeGeneratedFiles(filesToGenerate);
976
989
  }
990
+ // Warn if an existing vite.config.ts is missing the Cloudflare plugin.
991
+ // This is the most common cause of "could not resolve virtual:vinext-rsc-entry"
992
+ // errors — `vinext init` generates a minimal local-dev config without it.
993
+ if (info.hasViteConfig && !viteConfigHasCloudflarePlugin(root)) {
994
+ console.warn(`
995
+ Warning: your vite.config.ts does not appear to import @cloudflare/vite-plugin.
996
+ Cloudflare Workers deployment requires it. Add the plugin to your config:
997
+
998
+ import { cloudflare } from "@cloudflare/vite-plugin";
999
+
1000
+ export default defineConfig({
1001
+ plugins: [
1002
+ vinext(),
1003
+ cloudflare(${info.isAppRouter ? `{
1004
+ viteEnvironment: { name: "rsc", childEnvironments: ["ssr"] },
1005
+ }` : ""}),
1006
+ ],
1007
+ });
1008
+
1009
+ Or delete vite.config.ts and re-run \`vinext deploy\` to auto-generate it.
1010
+ `);
1011
+ }
977
1012
  if (options.dryRun) {
978
1013
  console.log("\n Dry run complete. Files generated but no build or deploy performed.\n");
979
1014
  return;
@@ -1 +1 @@
1
- {"version":3,"file":"deploy.js","sourceRoot":"","sources":["../src/deploy.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * vinext deploy — one-command Cloudflare Workers deployment.\n *\n * Takes any Next.js app and deploys it to Cloudflare Workers:\n *\n * 1. Detects App Router vs Pages Router\n * 2. Auto-generates missing config files (wrangler.jsonc, worker/index.ts, vite.config.ts)\n * 3. Ensures dependencies are installed (@cloudflare/vite-plugin, wrangler, @vitejs/plugin-rsc)\n * 4. Runs the Vite build\n * 5. Deploys to Cloudflare Workers via wrangler\n *\n * Design: Everything is auto-generated into a `.vinext/` directory (not the\n * project root) to avoid cluttering the user's project. If the user already\n * has these files, we use theirs.\n */\n\nimport fs from \"node:fs\";\nimport path from \"node:path\";\nimport { createRequire } from \"node:module\";\nimport { execFileSync, type ExecSyncOptions } from \"node:child_process\";\nimport { parseArgs as nodeParseArgs } from \"node:util\";\nimport { createBuilder, build } from \"vite\";\nimport {\n ensureESModule as _ensureESModule,\n renameCJSConfigs as _renameCJSConfigs,\n detectPackageManager as _detectPackageManager,\n findInNodeModules as _findInNodeModules,\n} from \"./utils/project.js\";\nimport { getReactUpgradeDeps } from \"./init.js\";\nimport { runTPR } from \"./cloudflare/tpr.js\";\nimport { loadDotenv } from \"./config/dotenv.js\";\n\n// ─── Types ───────────────────────────────────────────────────────────────────\n\nexport interface DeployOptions {\n /** Project root directory */\n root: string;\n /** Deploy to preview environment (default: production) */\n preview?: boolean;\n /** Wrangler environment name from wrangler.jsonc env.<name> */\n env?: string;\n /** Custom project name for the Worker */\n name?: string;\n /** Skip the build step (assume already built) */\n skipBuild?: boolean;\n /** Dry run — generate config files but don't build or deploy */\n dryRun?: boolean;\n /** Enable experimental TPR (Traffic-aware Pre-Rendering) */\n experimentalTPR?: boolean;\n /** TPR: traffic coverage percentage target (0–100, default: 90) */\n tprCoverage?: number;\n /** TPR: hard cap on number of pages to pre-render (default: 1000) */\n tprLimit?: number;\n /** TPR: analytics lookback window in hours (default: 24) */\n tprWindow?: number;\n}\n\n// ─── CLI arg parsing (uses Node.js util.parseArgs) ──────────────────────────\n\n/** Deploy command flag definitions for util.parseArgs. */\nconst deployArgOptions = {\n help: { type: \"boolean\", short: \"h\", default: false },\n preview: { type: \"boolean\", default: false },\n env: { type: \"string\" },\n name: { type: \"string\" },\n \"skip-build\": { type: \"boolean\", default: false },\n \"dry-run\": { type: \"boolean\", default: false },\n \"experimental-tpr\": { type: \"boolean\", default: false },\n \"tpr-coverage\": { type: \"string\" },\n \"tpr-limit\": { type: \"string\" },\n \"tpr-window\": { type: \"string\" },\n} as const;\n\nexport function parseDeployArgs(args: string[]) {\n const { values } = nodeParseArgs({ args, options: deployArgOptions, strict: true });\n return {\n help: values.help,\n preview: values.preview,\n env: values.env?.trim() || undefined,\n name: values.name?.trim() || undefined,\n skipBuild: values[\"skip-build\"],\n dryRun: values[\"dry-run\"],\n experimentalTPR: values[\"experimental-tpr\"],\n tprCoverage: values[\"tpr-coverage\"] ? parseInt(values[\"tpr-coverage\"], 10) : undefined,\n tprLimit: values[\"tpr-limit\"] ? parseInt(values[\"tpr-limit\"], 10) : undefined,\n tprWindow: values[\"tpr-window\"] ? parseInt(values[\"tpr-window\"], 10) : undefined,\n };\n}\n\n// ─── Project Detection ──────────────────────────────────────────────────────\n\ninterface ProjectInfo {\n root: string;\n isAppRouter: boolean;\n isPagesRouter: boolean;\n hasViteConfig: boolean;\n hasWranglerConfig: boolean;\n hasWorkerEntry: boolean;\n hasCloudflarePlugin: boolean;\n hasRscPlugin: boolean;\n hasWrangler: boolean;\n projectName: string;\n /** Pages that use `revalidate` (ISR) */\n hasISR: boolean;\n /** package.json has \"type\": \"module\" */\n hasTypeModule: boolean;\n /** .mdx files detected in app/ or pages/ */\n hasMDX: boolean;\n /** CodeHike is a dependency */\n hasCodeHike: boolean;\n /** Native Node modules that need stubbing for Workers */\n nativeModulesToStub: string[];\n}\n\n// ─── Detection ───────────────────────────────────────────────────────────────\n\nexport function detectProject(root: string): ProjectInfo {\n const hasApp =\n fs.existsSync(path.join(root, \"app\")) ||\n fs.existsSync(path.join(root, \"src\", \"app\"));\n const hasPages =\n fs.existsSync(path.join(root, \"pages\")) ||\n fs.existsSync(path.join(root, \"src\", \"pages\"));\n\n // Prefer App Router if both exist\n const isAppRouter = hasApp;\n const isPagesRouter = !hasApp && hasPages;\n\n const hasViteConfig =\n fs.existsSync(path.join(root, \"vite.config.ts\")) ||\n fs.existsSync(path.join(root, \"vite.config.js\")) ||\n fs.existsSync(path.join(root, \"vite.config.mjs\"));\n\n const hasWranglerConfig =\n fs.existsSync(path.join(root, \"wrangler.jsonc\")) ||\n fs.existsSync(path.join(root, \"wrangler.json\")) ||\n fs.existsSync(path.join(root, \"wrangler.toml\"));\n\n const hasWorkerEntry =\n fs.existsSync(path.join(root, \"worker\", \"index.ts\")) ||\n fs.existsSync(path.join(root, \"worker\", \"index.js\"));\n\n // Check node_modules for installed packages.\n // Walk up ancestor directories so that monorepo-hoisted packages are found\n // even when node_modules lives at the workspace root rather than app root.\n const hasCloudflarePlugin = _findInNodeModules(root, \"@cloudflare/vite-plugin\") !== null;\n const hasRscPlugin = _findInNodeModules(root, \"@vitejs/plugin-rsc\") !== null;\n const hasWrangler = _findInNodeModules(root, \".bin/wrangler\") !== null;\n\n // Derive project name from package.json or directory name\n let projectName = path.basename(root);\n const pkgPath = path.join(root, \"package.json\");\n if (fs.existsSync(pkgPath)) {\n try {\n const pkg = JSON.parse(fs.readFileSync(pkgPath, \"utf-8\"));\n if (pkg.name) {\n // Sanitize: Workers names must be lowercase alphanumeric + hyphens\n projectName = pkg.name\n .replace(/^@[^/]+\\//, \"\") // strip npm scope\n .toLowerCase() // lowercase BEFORE stripping invalid chars\n .replace(/[^a-z0-9-]/g, \"-\")\n .replace(/-+/g, \"-\")\n .replace(/^-|-$/g, \"\");\n }\n } catch {\n // ignore parse errors\n }\n }\n\n // Detect ISR usage (rough heuristic: search for `revalidate` exports)\n const hasISR = detectISR(root, isAppRouter);\n\n // Detect \"type\": \"module\" in package.json\n let hasTypeModule = false;\n if (fs.existsSync(pkgPath)) {\n try {\n const pkg = JSON.parse(fs.readFileSync(pkgPath, \"utf-8\"));\n hasTypeModule = pkg.type === \"module\";\n } catch {\n // ignore\n }\n }\n\n // Detect MDX usage\n const hasMDX = detectMDX(root, isAppRouter, hasPages);\n\n // Detect CodeHike dependency\n let hasCodeHike = false;\n if (fs.existsSync(pkgPath)) {\n try {\n const pkg = JSON.parse(fs.readFileSync(pkgPath, \"utf-8\"));\n const allDeps = { ...pkg.dependencies, ...pkg.devDependencies };\n hasCodeHike = \"codehike\" in allDeps;\n } catch {\n // ignore\n }\n }\n\n // Detect native Node modules that need stubbing for Workers\n const nativeModulesToStub = detectNativeModules(root);\n\n return {\n root,\n isAppRouter,\n isPagesRouter,\n hasViteConfig,\n hasWranglerConfig,\n hasWorkerEntry,\n hasCloudflarePlugin,\n hasRscPlugin,\n hasWrangler,\n projectName,\n hasISR,\n hasTypeModule,\n hasMDX,\n hasCodeHike,\n nativeModulesToStub,\n };\n}\n\nfunction detectISR(root: string, isAppRouter: boolean): boolean {\n if (!isAppRouter) return false;\n try {\n // Check root-level app/ first, then fall back to src/app/\n let appDir = path.join(root, \"app\");\n if (!fs.existsSync(appDir)) {\n appDir = path.join(root, \"src\", \"app\");\n }\n if (!fs.existsSync(appDir)) return false;\n // Quick check: search .ts/.tsx files in app/ for `export const revalidate`\n return scanDirForPattern(appDir, /export\\s+const\\s+revalidate\\s*=/);\n } catch {\n return false;\n }\n}\n\nfunction scanDirForPattern(dir: string, pattern: RegExp): boolean {\n const entries = fs.readdirSync(dir, { withFileTypes: true });\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name);\n if (entry.isDirectory() && !entry.name.startsWith(\".\") && entry.name !== \"node_modules\") {\n if (scanDirForPattern(fullPath, pattern)) return true;\n } else if (entry.isFile() && /\\.(ts|tsx|js|jsx)$/.test(entry.name)) {\n try {\n const content = fs.readFileSync(fullPath, \"utf-8\");\n if (pattern.test(content)) return true;\n } catch {\n // skip unreadable files\n }\n }\n }\n return false;\n}\n\n/**\n * Detect .mdx files in the project's app/ or pages/ directory,\n * or `pageExtensions` including \"mdx\" in next.config.\n */\nfunction detectMDX(root: string, isAppRouter: boolean, hasPages: boolean): boolean {\n // Check next.config for pageExtensions with mdx\n const configFiles = [\"next.config.ts\", \"next.config.mjs\", \"next.config.js\", \"next.config.cjs\"];\n for (const f of configFiles) {\n const p = path.join(root, f);\n if (fs.existsSync(p)) {\n try {\n const content = fs.readFileSync(p, \"utf-8\");\n if (/pageExtensions.*mdx/i.test(content) || /@next\\/mdx/.test(content)) return true;\n } catch {\n // ignore\n }\n }\n }\n\n // Check for .mdx files in app/ or pages/ (with src/ fallback)\n const dirs: string[] = [];\n if (isAppRouter) {\n const appDir = fs.existsSync(path.join(root, \"app\"))\n ? path.join(root, \"app\")\n : path.join(root, \"src\", \"app\");\n dirs.push(appDir);\n }\n if (hasPages) {\n const pagesDir = fs.existsSync(path.join(root, \"pages\"))\n ? path.join(root, \"pages\")\n : path.join(root, \"src\", \"pages\");\n dirs.push(pagesDir);\n }\n\n for (const dir of dirs) {\n if (fs.existsSync(dir) && scanDirForExtension(dir, \".mdx\")) return true;\n }\n\n return false;\n}\n\nfunction scanDirForExtension(dir: string, ext: string): boolean {\n const entries = fs.readdirSync(dir, { withFileTypes: true });\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name);\n if (entry.isDirectory() && !entry.name.startsWith(\".\") && entry.name !== \"node_modules\") {\n if (scanDirForExtension(fullPath, ext)) return true;\n } else if (entry.isFile() && entry.name.endsWith(ext)) {\n return true;\n }\n }\n return false;\n}\n\n/** Known native Node modules that can't run in Workers */\nconst NATIVE_MODULES_TO_STUB = [\n \"@resvg/resvg-js\",\n \"satori\",\n \"lightningcss\",\n \"@napi-rs/canvas\",\n \"sharp\",\n];\n\n/**\n * Detect native Node modules in dependencies that need stubbing for Workers.\n */\nfunction detectNativeModules(root: string): string[] {\n const pkgPath = path.join(root, \"package.json\");\n if (!fs.existsSync(pkgPath)) return [];\n\n try {\n const pkg = JSON.parse(fs.readFileSync(pkgPath, \"utf-8\"));\n const allDeps = { ...pkg.dependencies, ...pkg.devDependencies };\n return NATIVE_MODULES_TO_STUB.filter((mod) => mod in allDeps);\n } catch {\n return [];\n }\n}\n\n// ─── Project Preparation (pre-build transforms) ─────────────────────────────\n//\n// These are delegated to shared utilities in ./utils/project.ts so they can\n// be reused by both `vinext deploy` and `vinext init`.\n\n/** @see {@link _ensureESModule} */\nexport const ensureESModule = _ensureESModule;\n\n/** @see {@link _renameCJSConfigs} */\nexport const renameCJSConfigs = _renameCJSConfigs;\n\n// ─── File Generation ─────────────────────────────────────────────────────────\n\n/** Generate wrangler.jsonc content */\nexport function generateWranglerConfig(info: ProjectInfo): string {\n const today = new Date().toISOString().split(\"T\")[0];\n\n const config: Record<string, unknown> = {\n $schema: \"node_modules/wrangler/config-schema.json\",\n name: info.projectName,\n compatibility_date: today,\n compatibility_flags: [\"nodejs_compat\"],\n main: \"./worker/index.ts\",\n assets: {\n not_found_handling: \"none\",\n // Expose static assets to the Worker via env.ASSETS so the image\n // optimization handler can fetch source images programmatically.\n binding: \"ASSETS\",\n },\n // Cloudflare Images binding for next/image optimization.\n // Enables resize, format negotiation (AVIF/WebP), and quality transforms\n // at the edge. No user setup needed — wrangler creates the binding automatically.\n images: {\n binding: \"IMAGES\",\n },\n };\n\n if (info.hasISR) {\n config.kv_namespaces = [\n {\n binding: \"VINEXT_CACHE\",\n id: \"<your-kv-namespace-id>\",\n },\n ];\n }\n\n return JSON.stringify(config, null, 2) + \"\\n\";\n}\n\n/** Generate worker/index.ts for App Router */\nexport function generateAppRouterWorkerEntry(): string {\n return `/**\n * Cloudflare Worker entry point — auto-generated by vinext deploy.\n * Edit freely or delete to regenerate on next deploy.\n *\n * For apps without image optimization, you can use vinext/server/app-router-entry\n * directly in wrangler.jsonc: \"main\": \"vinext/server/app-router-entry\"\n */\nimport { handleImageOptimization, DEFAULT_DEVICE_SIZES, DEFAULT_IMAGE_SIZES } from \"vinext/server/image-optimization\";\nimport type { ImageConfig } from \"vinext/server/image-optimization\";\nimport handler from \"vinext/server/app-router-entry\";\n\ninterface Env {\n ASSETS: Fetcher;\n IMAGES: {\n input(stream: ReadableStream): {\n transform(options: Record<string, unknown>): {\n output(options: { format: string; quality: number }): Promise<{ response(): Response }>;\n };\n };\n };\n}\n\n// Image security config. SVG sources with .svg extension auto-skip the\n// optimization endpoint on the client side (served directly, no proxy).\n// To route SVGs through the optimizer (with security headers), set\n// dangerouslyAllowSVG: true in next.config.js and uncomment below:\n// const imageConfig: ImageConfig = { dangerouslyAllowSVG: true };\n\nexport default {\n async fetch(request: Request, env: Env): Promise<Response> {\n const url = new URL(request.url);\n\n // Image optimization via Cloudflare Images binding.\n // The parseImageParams validation inside handleImageOptimization\n // normalizes backslashes and validates the origin hasn't changed.\n if (url.pathname === \"/_vinext/image\") {\n const allowedWidths = [...DEFAULT_DEVICE_SIZES, ...DEFAULT_IMAGE_SIZES];\n return handleImageOptimization(request, {\n fetchAsset: (path) => env.ASSETS.fetch(new Request(new URL(path, request.url))),\n transformImage: async (body, { width, format, quality }) => {\n const result = await env.IMAGES.input(body).transform(width > 0 ? { width } : {}).output({ format, quality });\n return result.response();\n },\n }, allowedWidths);\n }\n\n // Delegate everything else to vinext\n return handler.fetch(request);\n },\n};\n`;\n}\n\n/** Generate worker/index.ts for Pages Router */\nexport function generatePagesRouterWorkerEntry(): string {\n return `/**\n * Cloudflare Worker entry point -- auto-generated by vinext deploy.\n * Edit freely or delete to regenerate on next deploy.\n */\nimport { handleImageOptimization, DEFAULT_DEVICE_SIZES, DEFAULT_IMAGE_SIZES } from \"vinext/server/image-optimization\";\nimport type { ImageConfig } from \"vinext/server/image-optimization\";\nimport {\n matchRedirect,\n matchRewrite,\n matchHeaders,\n requestContextFromRequest,\n isExternalUrl,\n proxyExternalRequest,\n sanitizeDestination,\n} from \"vinext/config/config-matchers\";\n\n// @ts-expect-error -- virtual module resolved by vinext at build time\nimport { renderPage, handleApiRoute, runMiddleware, vinextConfig } from \"virtual:vinext-server-entry\";\n\ninterface Env {\n ASSETS: Fetcher;\n IMAGES: {\n input(stream: ReadableStream): {\n transform(options: Record<string, unknown>): {\n output(options: { format: string; quality: number }): Promise<{ response(): Response }>;\n };\n };\n };\n}\n\n// Extract config values (embedded at build time in the server entry)\nconst basePath: string = vinextConfig?.basePath ?? \"\";\nconst trailingSlash: boolean = vinextConfig?.trailingSlash ?? false;\nconst configRedirects = vinextConfig?.redirects ?? [];\nconst configRewrites = vinextConfig?.rewrites ?? { beforeFiles: [], afterFiles: [], fallback: [] };\nconst configHeaders = vinextConfig?.headers ?? [];\nconst imageConfig: ImageConfig | undefined = vinextConfig?.images ? {\n dangerouslyAllowSVG: vinextConfig.images.dangerouslyAllowSVG,\n contentDispositionType: vinextConfig.images.contentDispositionType,\n contentSecurityPolicy: vinextConfig.images.contentSecurityPolicy,\n} : undefined;\n\nexport default {\n async fetch(request: Request, env: Env): Promise<Response> {\n try {\n const url = new URL(request.url);\n let pathname = url.pathname;\n let urlWithQuery = pathname + url.search;\n\n // Block protocol-relative URL open redirects (//evil.com/ or /\\\\evil.com/).\n // Normalize backslashes: browsers treat /\\\\ as // in URL context.\n const safePath = pathname.replaceAll(\"\\\\\\\\\", \"/\");\n if (safePath.startsWith(\"//\")) {\n return new Response(\"404 Not Found\", { status: 404 });\n }\n\n // ── 1. Strip basePath ─────────────────────────────────────────\n if (basePath && pathname.startsWith(basePath)) {\n const stripped = pathname.slice(basePath.length) || \"/\";\n urlWithQuery = stripped + url.search;\n pathname = stripped;\n }\n\n // ── Image optimization via Cloudflare Images binding ──────────\n // Checked after basePath stripping so /<basePath>/_vinext/image works.\n if (pathname === \"/_vinext/image\") {\n const allowedWidths = [...DEFAULT_DEVICE_SIZES, ...DEFAULT_IMAGE_SIZES];\n return handleImageOptimization(request, {\n fetchAsset: (path) => env.ASSETS.fetch(new Request(new URL(path, request.url))),\n transformImage: async (body, { width, format, quality }) => {\n const result = await env.IMAGES.input(body).transform(width > 0 ? { width } : {}).output({ format, quality });\n return result.response();\n },\n }, allowedWidths, imageConfig);\n }\n\n // ── 2. Trailing slash normalization ────────────────────────────\n if (pathname !== \"/\" && !pathname.startsWith(\"/api\")) {\n const hasTrailing = pathname.endsWith(\"/\");\n if (trailingSlash && !hasTrailing) {\n return new Response(null, {\n status: 308,\n headers: { Location: basePath + pathname + \"/\" + url.search },\n });\n } else if (!trailingSlash && hasTrailing) {\n return new Response(null, {\n status: 308,\n headers: { Location: basePath + pathname.replace(/\\\\/+$/, \"\") + url.search },\n });\n }\n }\n\n // Build a request with the basePath-stripped URL for middleware and\n // downstream handlers. In Workers the incoming request URL still\n // contains basePath; prod-server constructs its webRequest from\n // the already-stripped URL, so we replicate that here.\n if (basePath) {\n const strippedUrl = new URL(request.url);\n strippedUrl.pathname = pathname;\n request = new Request(strippedUrl, request);\n }\n\n // Build request context for has/missing condition matching.\n // headers and redirects run before middleware, so they use this\n // pre-middleware snapshot. beforeFiles, afterFiles, and fallback\n // rewrites run after middleware (App Router order), so they use\n // postMwReqCtx created after x-middleware-request-* headers are\n // unpacked into request.\n const reqCtx = requestContextFromRequest(request);\n\n // ── 3. Run middleware ──────────────────────────────────────────\n let resolvedUrl = urlWithQuery;\n const middlewareHeaders: Record<string, string | string[]> = {};\n let middlewareRewriteStatus: number | undefined;\n if (typeof runMiddleware === \"function\") {\n const result = await runMiddleware(request);\n\n if (!result.continue) {\n if (result.redirectUrl) {\n return new Response(null, {\n status: result.redirectStatus ?? 307,\n headers: { Location: result.redirectUrl },\n });\n }\n if (result.response) {\n return result.response;\n }\n }\n\n // Collect middleware response headers to merge into final response.\n // Use an array for Set-Cookie to preserve multiple values.\n if (result.responseHeaders) {\n for (const [key, value] of result.responseHeaders) {\n if (key === \"set-cookie\") {\n const existing = middlewareHeaders[key];\n if (Array.isArray(existing)) {\n existing.push(value);\n } else if (existing) {\n middlewareHeaders[key] = [existing as string, value];\n } else {\n middlewareHeaders[key] = [value];\n }\n } else {\n middlewareHeaders[key] = value;\n }\n }\n }\n\n // Apply middleware rewrite\n if (result.rewriteUrl) {\n resolvedUrl = result.rewriteUrl;\n }\n\n // Apply custom status code from middleware rewrite\n middlewareRewriteStatus = result.rewriteStatus;\n }\n\n // Unpack x-middleware-request-* headers into the actual request so\n // that renderPage / handleApiRoute see middleware-modified headers.\n // Workers incoming request headers are immutable, so clone if needed.\n const mwReqPrefix = \"x-middleware-request-\";\n const mwReqHeaders: Record<string, string> = {};\n for (const key of Object.keys(middlewareHeaders)) {\n if (key.startsWith(mwReqPrefix)) {\n const realName = key.slice(mwReqPrefix.length);\n mwReqHeaders[realName] = middlewareHeaders[key] as string;\n delete middlewareHeaders[key];\n } else if (key.startsWith(\"x-middleware-\")) {\n delete middlewareHeaders[key];\n }\n }\n if (Object.keys(mwReqHeaders).length > 0) {\n const newHeaders = new Headers(request.headers);\n for (const [k, v] of Object.entries(mwReqHeaders)) {\n newHeaders.set(k, v);\n }\n request = new Request(request.url, {\n method: request.method,\n headers: newHeaders,\n body: request.body,\n // @ts-expect-error -- duplex needed for streaming request bodies\n duplex: request.body ? \"half\" : undefined,\n });\n }\n\n // Rebuild context after middleware has unpacked x-middleware-request-*\n // headers into the cloned request. Used only for afterFiles and fallback\n // rewrites, which run after middleware in the App Router execution order.\n const postMwReqCtx = requestContextFromRequest(request);\n\n let resolvedPathname = resolvedUrl.split(\"?\")[0];\n\n // ── 4. Apply custom headers from next.config.js ───────────────\n // Config headers are additive for multi-value headers (Vary,\n // Set-Cookie) and override for everything else. Vary values are\n // comma-joined per HTTP spec. Set-Cookie values are accumulated\n // as arrays (RFC 6265 forbids comma-joining cookies).\n if (configHeaders.length) {\n const matched = matchHeaders(resolvedPathname, configHeaders, reqCtx);\n for (const h of matched) {\n const lk = h.key.toLowerCase();\n if (lk === \"set-cookie\") {\n const existing = middlewareHeaders[lk];\n if (Array.isArray(existing)) {\n existing.push(h.value);\n } else if (existing) {\n middlewareHeaders[lk] = [existing as string, h.value];\n } else {\n middlewareHeaders[lk] = [h.value];\n }\n } else if (lk === \"vary\" && middlewareHeaders[lk]) {\n middlewareHeaders[lk] += \", \" + h.value;\n } else {\n middlewareHeaders[lk] = h.value;\n }\n }\n }\n\n // ── 5. Apply redirects from next.config.js ────────────────────\n if (configRedirects.length) {\n const redirect = matchRedirect(resolvedPathname, configRedirects, reqCtx);\n if (redirect) {\n const dest = sanitizeDestination(\n basePath && !redirect.destination.startsWith(basePath)\n ? basePath + redirect.destination\n : redirect.destination,\n );\n return new Response(null, {\n status: redirect.permanent ? 308 : 307,\n headers: { Location: dest },\n });\n }\n }\n\n // ��─ 6. Apply beforeFiles rewrites from next.config.js ─────────\n if (configRewrites.beforeFiles?.length) {\n const rewritten = matchRewrite(resolvedPathname, configRewrites.beforeFiles, postMwReqCtx);\n if (rewritten) {\n if (isExternalUrl(rewritten)) {\n return proxyExternalRequest(request, rewritten);\n }\n resolvedUrl = rewritten;\n resolvedPathname = rewritten.split(\"?\")[0];\n }\n }\n\n // ── 7. API routes ─────────────────────────────────────────────\n if (resolvedPathname.startsWith(\"/api/\") || resolvedPathname === \"/api\") {\n const response = typeof handleApiRoute === \"function\"\n ? await handleApiRoute(request, resolvedUrl)\n : new Response(\"404 - API route not found\", { status: 404 });\n return mergeHeaders(response, middlewareHeaders, middlewareRewriteStatus);\n }\n\n // ── 8. Apply afterFiles rewrites from next.config.js ──────────\n if (configRewrites.afterFiles?.length) {\n const rewritten = matchRewrite(resolvedPathname, configRewrites.afterFiles, postMwReqCtx);\n if (rewritten) {\n if (isExternalUrl(rewritten)) {\n return proxyExternalRequest(request, rewritten);\n }\n resolvedUrl = rewritten;\n resolvedPathname = rewritten.split(\"?\")[0];\n }\n }\n\n // ── 9. Page routes ────────────────────────────────────────────\n let response: Response | undefined;\n if (typeof renderPage === \"function\") {\n response = await renderPage(request, resolvedUrl, null);\n\n // ── 10. Fallback rewrites (if SSR returned 404) ─────────────\n if (response && response.status === 404 && configRewrites.fallback?.length) {\n const fallbackRewrite = matchRewrite(resolvedPathname, configRewrites.fallback, postMwReqCtx);\n if (fallbackRewrite) {\n if (isExternalUrl(fallbackRewrite)) {\n return proxyExternalRequest(request, fallbackRewrite);\n }\n response = await renderPage(request, fallbackRewrite, null);\n }\n }\n }\n\n if (!response) {\n return new Response(\"404 - Not found\", { status: 404 });\n }\n\n return mergeHeaders(response, middlewareHeaders, middlewareRewriteStatus);\n } catch (error) {\n console.error(\"[vinext] Worker error:\", error);\n return new Response(\"Internal Server Error\", { status: 500 });\n }\n },\n};\n\n/**\n * Merge middleware/config headers into a response.\n * Response headers take precedence over middleware headers for all headers\n * except Set-Cookie, which is additive (both middleware and response cookies\n * are preserved). Matches the behavior in prod-server.ts. Uses getSetCookie()\n * to preserve multiple Set-Cookie values.\n */\nfunction mergeHeaders(\n response: Response,\n extraHeaders: Record<string, string | string[]>,\n statusOverride?: number,\n): Response {\n if (!Object.keys(extraHeaders).length && !statusOverride) return response;\n const merged = new Headers();\n // Middleware/config headers go in first (lower precedence)\n for (const [k, v] of Object.entries(extraHeaders)) {\n if (Array.isArray(v)) {\n for (const item of v) merged.append(k, item);\n } else {\n merged.set(k, v);\n }\n }\n // Response headers overlay them (higher precedence), except Set-Cookie\n // which is additive (both middleware and response cookies should be sent).\n response.headers.forEach((v, k) => {\n if (k === \"set-cookie\") return;\n merged.set(k, v);\n });\n const responseCookies = response.headers.getSetCookie?.() ?? [];\n for (const cookie of responseCookies) merged.append(\"set-cookie\", cookie);\n return new Response(response.body, {\n status: statusOverride ?? response.status,\n statusText: response.statusText,\n headers: merged,\n });\n}\n`;\n}\n\n/** Generate vite.config.ts for App Router */\nexport function generateAppRouterViteConfig(info?: ProjectInfo): string {\n const imports: string[] = [\n `import { defineConfig } from \"vite\";`,\n `import vinext from \"vinext\";`,\n `import { cloudflare } from \"@cloudflare/vite-plugin\";`,\n ];\n\n if (info?.nativeModulesToStub && info.nativeModulesToStub.length > 0) {\n imports.push(`import path from \"node:path\";`);\n }\n\n const plugins: string[] = [];\n\n if (info?.hasMDX) {\n plugins.push(` // vinext auto-injects @mdx-js/rollup with plugins from next.config`);\n }\n plugins.push(` vinext(),`);\n\n plugins.push(` cloudflare({\n viteEnvironment: {\n name: \"rsc\",\n childEnvironments: [\"ssr\"],\n },\n }),`);\n\n // Build resolve.alias for native module stubs (tsconfig paths are handled\n // automatically by vite-tsconfig-paths inside the vinext plugin)\n let resolveBlock = \"\";\n const aliases: string[] = [];\n\n if (info?.nativeModulesToStub && info.nativeModulesToStub.length > 0) {\n for (const mod of info.nativeModulesToStub) {\n aliases.push(` \"${mod}\": path.resolve(__dirname, \"empty-stub.js\"),`);\n }\n }\n\n if (aliases.length > 0) {\n resolveBlock = `\\n resolve: {\\n alias: {\\n${aliases.join(\"\\n\")}\\n },\\n },`;\n }\n\n return `${imports.join(\"\\n\")}\n\nexport default defineConfig({\n plugins: [\n${plugins.join(\"\\n\")}\n ],${resolveBlock}\n});\n`;\n}\n\n/** Generate vite.config.ts for Pages Router */\nexport function generatePagesRouterViteConfig(info?: ProjectInfo): string {\n const imports: string[] = [\n `import { defineConfig } from \"vite\";`,\n `import vinext from \"vinext\";`,\n `import { cloudflare } from \"@cloudflare/vite-plugin\";`,\n ];\n\n if (info?.nativeModulesToStub && info.nativeModulesToStub.length > 0) {\n imports.push(`import path from \"node:path\";`);\n }\n\n // Build resolve.alias for native module stubs (tsconfig paths are handled\n // automatically by vite-tsconfig-paths inside the vinext plugin)\n let resolveBlock = \"\";\n const aliases: string[] = [];\n\n if (info?.nativeModulesToStub && info.nativeModulesToStub.length > 0) {\n for (const mod of info.nativeModulesToStub) {\n aliases.push(` \"${mod}\": path.resolve(__dirname, \"empty-stub.js\"),`);\n }\n }\n\n if (aliases.length > 0) {\n resolveBlock = `\\n resolve: {\\n alias: {\\n${aliases.join(\"\\n\")}\\n },\\n },`;\n }\n\n return `${imports.join(\"\\n\")}\n\nexport default defineConfig({\n plugins: [\n vinext(),\n cloudflare(),\n ],${resolveBlock}\n});\n`;\n}\n\n// ─── Dependency Management ───────────────────────────────────────────────────\n\ninterface MissingDep {\n name: string;\n version: string;\n}\n\n/**\n * Check if a package is resolvable from a given root directory using\n * Node's module resolution (createRequire). Handles hoisting, pnpm\n * symlinks, monorepos, and Yarn PnP correctly.\n */\nexport function isPackageResolvable(root: string, packageName: string): boolean {\n try {\n const req = createRequire(path.join(root, \"package.json\"));\n req.resolve(packageName);\n return true;\n } catch {\n return false;\n }\n}\n\nexport function getMissingDeps(\n info: ProjectInfo,\n /** Override for testing — defaults to `isPackageResolvable` */\n _isResolvable: (root: string, pkg: string) => boolean = isPackageResolvable,\n): MissingDep[] {\n const missing: MissingDep[] = [];\n\n if (!info.hasCloudflarePlugin) {\n missing.push({ name: \"@cloudflare/vite-plugin\", version: \"latest\" });\n }\n if (!info.hasWrangler) {\n missing.push({ name: \"wrangler\", version: \"latest\" });\n }\n if (info.isAppRouter && !info.hasRscPlugin) {\n missing.push({ name: \"@vitejs/plugin-rsc\", version: \"latest\" });\n }\n if (info.isAppRouter) {\n // react-server-dom-webpack must be resolvable from the project root for Vite.\n if (!_isResolvable(info.root, \"react-server-dom-webpack\")) {\n missing.push({ name: \"react-server-dom-webpack\", version: \"latest\" });\n }\n }\n if (info.hasMDX) {\n // Check if @mdx-js/rollup is already installed (walk up for monorepo hoisting)\n const hasMdxRollup = _findInNodeModules(info.root, \"@mdx-js/rollup\") !== null;\n if (!hasMdxRollup) {\n missing.push({ name: \"@mdx-js/rollup\", version: \"latest\" });\n }\n }\n\n return missing;\n}\n\nfunction installDeps(root: string, deps: MissingDep[]): void {\n if (deps.length === 0) return;\n\n const depSpecs = deps.map((d) => `${d.name}@${d.version}`);\n const installCmd = detectPackageManager(root);\n const [pm, ...pmArgs] = installCmd.split(\" \");\n\n console.log(` Installing: ${deps.map((d) => d.name).join(\", \")}`);\n execFileSync(pm, [...pmArgs, ...depSpecs], {\n cwd: root,\n stdio: \"inherit\",\n });\n}\n\nconst detectPackageManager = _detectPackageManager;\n\n// ─── File Writing ────────────────────────────────────────────────────────────\n\ninterface GeneratedFile {\n path: string;\n content: string;\n description: string;\n}\n\nexport function getFilesToGenerate(info: ProjectInfo): GeneratedFile[] {\n const files: GeneratedFile[] = [];\n\n if (!info.hasWranglerConfig) {\n files.push({\n path: path.join(info.root, \"wrangler.jsonc\"),\n content: generateWranglerConfig(info),\n description: \"wrangler.jsonc\",\n });\n }\n\n if (!info.hasWorkerEntry) {\n const workerContent = info.isAppRouter\n ? generateAppRouterWorkerEntry()\n : generatePagesRouterWorkerEntry();\n files.push({\n path: path.join(info.root, \"worker\", \"index.ts\"),\n content: workerContent,\n description: \"worker/index.ts\",\n });\n }\n\n if (!info.hasViteConfig) {\n const viteContent = info.isAppRouter\n ? generateAppRouterViteConfig(info)\n : generatePagesRouterViteConfig(info);\n files.push({\n path: path.join(info.root, \"vite.config.ts\"),\n content: viteContent,\n description: \"vite.config.ts\",\n });\n }\n\n return files;\n}\n\nfunction writeGeneratedFiles(files: GeneratedFile[]): void {\n for (const file of files) {\n const dir = path.dirname(file.path);\n if (!fs.existsSync(dir)) {\n fs.mkdirSync(dir, { recursive: true });\n }\n fs.writeFileSync(file.path, file.content, \"utf-8\");\n console.log(` Created ${file.description}`);\n }\n}\n\n// ─── Build ───────────────────────────────────────────────────────────────────\n\nasync function runBuild(info: ProjectInfo): Promise<void> {\n console.log(\"\\n Building for Cloudflare Workers...\\n\");\n\n // Use Vite's JS API for the build. The user's vite.config.ts (or our\n // generated one) has the cloudflare() plugin which handles the Worker\n // output format. We just need to trigger the build.\n //\n // For App Router, createBuilder().buildApp() handles multi-environment builds.\n // For Pages Router, a single build() call suffices (cloudflare plugin manages it).\n\n if (info.isAppRouter) {\n const builder = await createBuilder({ root: info.root });\n await builder.buildApp();\n } else {\n await build({ root: info.root });\n }\n}\n\n// ─── Deploy ──────────────────────────────────────────────────────────────────\n\nexport interface WranglerDeployArgs {\n args: string[];\n env: string | undefined;\n}\n\nexport function buildWranglerDeployArgs(options: Pick<DeployOptions, \"preview\" | \"env\">): WranglerDeployArgs {\n const args = [\"deploy\"];\n const env = options.env || (options.preview ? \"preview\" : undefined);\n if (env) {\n args.push(\"--env\", env);\n }\n return { args, env };\n}\n\nfunction runWranglerDeploy(root: string, options: Pick<DeployOptions, \"preview\" | \"env\">): string {\n // Walk up ancestor directories so the binary is found even when node_modules\n // is hoisted to the workspace root in a monorepo.\n const wranglerBin = _findInNodeModules(root, \".bin/wrangler\") ??\n path.join(root, \"node_modules\", \".bin\", \"wrangler\"); // fallback for error message clarity\n\n const execOpts: ExecSyncOptions = {\n cwd: root,\n stdio: \"pipe\",\n encoding: \"utf-8\",\n };\n\n const { args, env } = buildWranglerDeployArgs(options);\n\n if (env) {\n console.log(`\\n Deploying to env: ${env}...`);\n } else {\n console.log(\"\\n Deploying to production...\");\n }\n\n // Use execFileSync to avoid shell injection — args are passed as an array,\n // never interpolated into a shell command string.\n const output = execFileSync(wranglerBin, args, execOpts) as string;\n\n // Parse the deployed URL from wrangler output\n // Wrangler prints: \"Published <name> (version_id)\\n https://<name>.<subdomain>.workers.dev\"\n const urlMatch = output.match(/https:\\/\\/[^\\s]+\\.workers\\.dev[^\\s]*/);\n const deployedUrl = urlMatch ? urlMatch[0] : null;\n\n // Also print raw output for transparency\n if (output.trim()) {\n for (const line of output.trim().split(\"\\n\")) {\n console.log(` ${line}`);\n }\n }\n\n return deployedUrl ?? \"(URL not detected in wrangler output)\";\n}\n\n// ─── Main Entry ──────────────────────────────────────────────────────────────\n\nexport async function deploy(options: DeployOptions): Promise<void> {\n const root = path.resolve(options.root);\n loadDotenv({ root, mode: \"production\" });\n\n console.log(\"\\n vinext deploy\\n\");\n\n // Step 1: Detect project structure\n const info = detectProject(root);\n\n if (!info.isAppRouter && !info.isPagesRouter) {\n console.error(\" Error: No app/ or pages/ directory found.\");\n console.error(\" vinext deploy requires a Next.js project with an app/ or pages/ directory\");\n console.error(\" (also checks src/app/ and src/pages/).\\n\");\n process.exit(1);\n }\n\n if (options.name) {\n info.projectName = options.name;\n }\n\n console.log(` Project: ${info.projectName}`);\n console.log(` Router: ${info.isAppRouter ? \"App Router\" : \"Pages Router\"}`);\n console.log(` ISR: ${info.hasISR ? \"detected\" : \"none\"}`);\n\n // Step 2: Check and install missing dependencies\n // For App Router: upgrade React first if needed for react-server-dom-webpack compatibility\n if (info.isAppRouter) {\n const reactUpgrade = getReactUpgradeDeps(root);\n if (reactUpgrade.length > 0) {\n const installCmd = detectPackageManager(root).replace(/ -D$/, \"\");\n const [pm, ...pmArgs] = installCmd.split(\" \");\n console.log(` Upgrading ${reactUpgrade.map(d => d.replace(/@latest$/, \"\")).join(\", \")}...`);\n execFileSync(pm, [...pmArgs, ...reactUpgrade], { cwd: root, stdio: \"inherit\" });\n }\n }\n const missingDeps = getMissingDeps(info);\n if (missingDeps.length > 0) {\n console.log();\n installDeps(root, missingDeps);\n // Re-detect after install\n info.hasCloudflarePlugin = true;\n info.hasWrangler = true;\n if (info.isAppRouter) info.hasRscPlugin = true;\n }\n\n // Step 3: Ensure ESM + rename CJS configs\n if (!info.hasTypeModule) {\n const renamedConfigs = renameCJSConfigs(root);\n for (const [oldName, newName] of renamedConfigs) {\n console.log(` Renamed ${oldName} → ${newName} (CJS → .cjs)`);\n }\n if (ensureESModule(root)) {\n console.log(` Added \"type\": \"module\" to package.json`);\n info.hasTypeModule = true;\n }\n }\n\n // Step 4: Generate missing config files\n const filesToGenerate = getFilesToGenerate(info);\n if (filesToGenerate.length > 0) {\n console.log();\n writeGeneratedFiles(filesToGenerate);\n }\n\n if (options.dryRun) {\n console.log(\"\\n Dry run complete. Files generated but no build or deploy performed.\\n\");\n return;\n }\n\n // Step 5: Build\n if (!options.skipBuild) {\n await runBuild(info);\n } else {\n console.log(\"\\n Skipping build (--skip-build)\");\n }\n\n // Step 6: TPR — pre-render hot pages into KV cache (experimental, opt-in)\n if (options.experimentalTPR) {\n console.log();\n const tprResult = await runTPR({\n root,\n coverage: Math.max(1, Math.min(100, options.tprCoverage ?? 90)),\n limit: Math.max(1, options.tprLimit ?? 1000),\n window: Math.max(1, options.tprWindow ?? 24),\n });\n\n if (tprResult.skipped) {\n console.log(` TPR: Skipped (${tprResult.skipped})`);\n }\n }\n\n // Step 7: Deploy via wrangler\n const url = runWranglerDeploy(root, {\n preview: options.preview ?? false,\n env: options.env,\n });\n\n console.log(\"\\n ─────────────────────────────────────────\");\n console.log(` Deployed to: ${url}`);\n console.log(\" ─────────────────────────────────────────\\n\");\n}\n"]}
1
+ {"version":3,"file":"deploy.js","sourceRoot":"","sources":["../src/deploy.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * vinext deploy — one-command Cloudflare Workers deployment.\n *\n * Takes any Next.js app and deploys it to Cloudflare Workers:\n *\n * 1. Detects App Router vs Pages Router\n * 2. Auto-generates missing config files (wrangler.jsonc, worker/index.ts, vite.config.ts)\n * 3. Ensures dependencies are installed (@cloudflare/vite-plugin, wrangler, @vitejs/plugin-rsc)\n * 4. Runs the Vite build\n * 5. Deploys to Cloudflare Workers via wrangler\n *\n * Design: Everything is auto-generated into a `.vinext/` directory (not the\n * project root) to avoid cluttering the user's project. If the user already\n * has these files, we use theirs.\n */\n\nimport fs from \"node:fs\";\nimport path from \"node:path\";\nimport { createRequire } from \"node:module\";\nimport { execFileSync, type ExecSyncOptions } from \"node:child_process\";\nimport { parseArgs as nodeParseArgs } from \"node:util\";\nimport { createBuilder, build } from \"vite\";\nimport {\n ensureESModule as _ensureESModule,\n renameCJSConfigs as _renameCJSConfigs,\n detectPackageManager as _detectPackageManager,\n findInNodeModules as _findInNodeModules,\n} from \"./utils/project.js\";\nimport { getReactUpgradeDeps } from \"./init.js\";\nimport { runTPR } from \"./cloudflare/tpr.js\";\nimport { loadDotenv } from \"./config/dotenv.js\";\n\n// ─── Types ───────────────────────────────────────────────────────────────────\n\nexport interface DeployOptions {\n /** Project root directory */\n root: string;\n /** Deploy to preview environment (default: production) */\n preview?: boolean;\n /** Wrangler environment name from wrangler.jsonc env.<name> */\n env?: string;\n /** Custom project name for the Worker */\n name?: string;\n /** Skip the build step (assume already built) */\n skipBuild?: boolean;\n /** Dry run — generate config files but don't build or deploy */\n dryRun?: boolean;\n /** Enable experimental TPR (Traffic-aware Pre-Rendering) */\n experimentalTPR?: boolean;\n /** TPR: traffic coverage percentage target (0–100, default: 90) */\n tprCoverage?: number;\n /** TPR: hard cap on number of pages to pre-render (default: 1000) */\n tprLimit?: number;\n /** TPR: analytics lookback window in hours (default: 24) */\n tprWindow?: number;\n}\n\n// ─── CLI arg parsing (uses Node.js util.parseArgs) ──────────────────────────\n\n/** Deploy command flag definitions for util.parseArgs. */\nconst deployArgOptions = {\n help: { type: \"boolean\", short: \"h\", default: false },\n preview: { type: \"boolean\", default: false },\n env: { type: \"string\" },\n name: { type: \"string\" },\n \"skip-build\": { type: \"boolean\", default: false },\n \"dry-run\": { type: \"boolean\", default: false },\n \"experimental-tpr\": { type: \"boolean\", default: false },\n \"tpr-coverage\": { type: \"string\" },\n \"tpr-limit\": { type: \"string\" },\n \"tpr-window\": { type: \"string\" },\n} as const;\n\nexport function parseDeployArgs(args: string[]) {\n const { values } = nodeParseArgs({ args, options: deployArgOptions, strict: true });\n return {\n help: values.help,\n preview: values.preview,\n env: values.env?.trim() || undefined,\n name: values.name?.trim() || undefined,\n skipBuild: values[\"skip-build\"],\n dryRun: values[\"dry-run\"],\n experimentalTPR: values[\"experimental-tpr\"],\n tprCoverage: values[\"tpr-coverage\"] ? parseInt(values[\"tpr-coverage\"], 10) : undefined,\n tprLimit: values[\"tpr-limit\"] ? parseInt(values[\"tpr-limit\"], 10) : undefined,\n tprWindow: values[\"tpr-window\"] ? parseInt(values[\"tpr-window\"], 10) : undefined,\n };\n}\n\n// ─── Project Detection ──────────────────────────────────────────────────────\n\ninterface ProjectInfo {\n root: string;\n isAppRouter: boolean;\n isPagesRouter: boolean;\n hasViteConfig: boolean;\n hasWranglerConfig: boolean;\n hasWorkerEntry: boolean;\n hasCloudflarePlugin: boolean;\n hasRscPlugin: boolean;\n hasWrangler: boolean;\n projectName: string;\n /** Pages that use `revalidate` (ISR) */\n hasISR: boolean;\n /** package.json has \"type\": \"module\" */\n hasTypeModule: boolean;\n /** .mdx files detected in app/ or pages/ */\n hasMDX: boolean;\n /** CodeHike is a dependency */\n hasCodeHike: boolean;\n /** Native Node modules that need stubbing for Workers */\n nativeModulesToStub: string[];\n}\n\n// ─── Detection ───────────────────────────────────────────────────────────────\n\nexport function detectProject(root: string): ProjectInfo {\n const hasApp =\n fs.existsSync(path.join(root, \"app\")) ||\n fs.existsSync(path.join(root, \"src\", \"app\"));\n const hasPages =\n fs.existsSync(path.join(root, \"pages\")) ||\n fs.existsSync(path.join(root, \"src\", \"pages\"));\n\n // Prefer App Router if both exist\n const isAppRouter = hasApp;\n const isPagesRouter = !hasApp && hasPages;\n\n const hasViteConfig =\n fs.existsSync(path.join(root, \"vite.config.ts\")) ||\n fs.existsSync(path.join(root, \"vite.config.js\")) ||\n fs.existsSync(path.join(root, \"vite.config.mjs\"));\n\n const hasWranglerConfig =\n fs.existsSync(path.join(root, \"wrangler.jsonc\")) ||\n fs.existsSync(path.join(root, \"wrangler.json\")) ||\n fs.existsSync(path.join(root, \"wrangler.toml\"));\n\n const hasWorkerEntry =\n fs.existsSync(path.join(root, \"worker\", \"index.ts\")) ||\n fs.existsSync(path.join(root, \"worker\", \"index.js\"));\n\n // Check node_modules for installed packages.\n // Walk up ancestor directories so that monorepo-hoisted packages are found\n // even when node_modules lives at the workspace root rather than app root.\n const hasCloudflarePlugin = _findInNodeModules(root, \"@cloudflare/vite-plugin\") !== null;\n const hasRscPlugin = _findInNodeModules(root, \"@vitejs/plugin-rsc\") !== null;\n const hasWrangler = _findInNodeModules(root, \".bin/wrangler\") !== null;\n\n // Derive project name from package.json or directory name\n let projectName = path.basename(root);\n const pkgPath = path.join(root, \"package.json\");\n if (fs.existsSync(pkgPath)) {\n try {\n const pkg = JSON.parse(fs.readFileSync(pkgPath, \"utf-8\"));\n if (pkg.name) {\n // Sanitize: Workers names must be lowercase alphanumeric + hyphens\n projectName = pkg.name\n .replace(/^@[^/]+\\//, \"\") // strip npm scope\n .toLowerCase() // lowercase BEFORE stripping invalid chars\n .replace(/[^a-z0-9-]/g, \"-\")\n .replace(/-+/g, \"-\")\n .replace(/^-|-$/g, \"\");\n }\n } catch {\n // ignore parse errors\n }\n }\n\n // Detect ISR usage (rough heuristic: search for `revalidate` exports)\n const hasISR = detectISR(root, isAppRouter);\n\n // Detect \"type\": \"module\" in package.json\n let hasTypeModule = false;\n if (fs.existsSync(pkgPath)) {\n try {\n const pkg = JSON.parse(fs.readFileSync(pkgPath, \"utf-8\"));\n hasTypeModule = pkg.type === \"module\";\n } catch {\n // ignore\n }\n }\n\n // Detect MDX usage\n const hasMDX = detectMDX(root, isAppRouter, hasPages);\n\n // Detect CodeHike dependency\n let hasCodeHike = false;\n if (fs.existsSync(pkgPath)) {\n try {\n const pkg = JSON.parse(fs.readFileSync(pkgPath, \"utf-8\"));\n const allDeps = { ...pkg.dependencies, ...pkg.devDependencies };\n hasCodeHike = \"codehike\" in allDeps;\n } catch {\n // ignore\n }\n }\n\n // Detect native Node modules that need stubbing for Workers\n const nativeModulesToStub = detectNativeModules(root);\n\n return {\n root,\n isAppRouter,\n isPagesRouter,\n hasViteConfig,\n hasWranglerConfig,\n hasWorkerEntry,\n hasCloudflarePlugin,\n hasRscPlugin,\n hasWrangler,\n projectName,\n hasISR,\n hasTypeModule,\n hasMDX,\n hasCodeHike,\n nativeModulesToStub,\n };\n}\n\nfunction detectISR(root: string, isAppRouter: boolean): boolean {\n if (!isAppRouter) return false;\n try {\n // Check root-level app/ first, then fall back to src/app/\n let appDir = path.join(root, \"app\");\n if (!fs.existsSync(appDir)) {\n appDir = path.join(root, \"src\", \"app\");\n }\n if (!fs.existsSync(appDir)) return false;\n // Quick check: search .ts/.tsx files in app/ for `export const revalidate`\n return scanDirForPattern(appDir, /export\\s+const\\s+revalidate\\s*=/);\n } catch {\n return false;\n }\n}\n\nfunction scanDirForPattern(dir: string, pattern: RegExp): boolean {\n const entries = fs.readdirSync(dir, { withFileTypes: true });\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name);\n if (entry.isDirectory() && !entry.name.startsWith(\".\") && entry.name !== \"node_modules\") {\n if (scanDirForPattern(fullPath, pattern)) return true;\n } else if (entry.isFile() && /\\.(ts|tsx|js|jsx)$/.test(entry.name)) {\n try {\n const content = fs.readFileSync(fullPath, \"utf-8\");\n if (pattern.test(content)) return true;\n } catch {\n // skip unreadable files\n }\n }\n }\n return false;\n}\n\n/**\n * Detect .mdx files in the project's app/ or pages/ directory,\n * or `pageExtensions` including \"mdx\" in next.config.\n */\nfunction detectMDX(root: string, isAppRouter: boolean, hasPages: boolean): boolean {\n // Check next.config for pageExtensions with mdx\n const configFiles = [\"next.config.ts\", \"next.config.mjs\", \"next.config.js\", \"next.config.cjs\"];\n for (const f of configFiles) {\n const p = path.join(root, f);\n if (fs.existsSync(p)) {\n try {\n const content = fs.readFileSync(p, \"utf-8\");\n if (/pageExtensions.*mdx/i.test(content) || /@next\\/mdx/.test(content)) return true;\n } catch {\n // ignore\n }\n }\n }\n\n // Check for .mdx files in app/ or pages/ (with src/ fallback)\n const dirs: string[] = [];\n if (isAppRouter) {\n const appDir = fs.existsSync(path.join(root, \"app\"))\n ? path.join(root, \"app\")\n : path.join(root, \"src\", \"app\");\n dirs.push(appDir);\n }\n if (hasPages) {\n const pagesDir = fs.existsSync(path.join(root, \"pages\"))\n ? path.join(root, \"pages\")\n : path.join(root, \"src\", \"pages\");\n dirs.push(pagesDir);\n }\n\n for (const dir of dirs) {\n if (fs.existsSync(dir) && scanDirForExtension(dir, \".mdx\")) return true;\n }\n\n return false;\n}\n\nfunction scanDirForExtension(dir: string, ext: string): boolean {\n const entries = fs.readdirSync(dir, { withFileTypes: true });\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name);\n if (entry.isDirectory() && !entry.name.startsWith(\".\") && entry.name !== \"node_modules\") {\n if (scanDirForExtension(fullPath, ext)) return true;\n } else if (entry.isFile() && entry.name.endsWith(ext)) {\n return true;\n }\n }\n return false;\n}\n\n/** Known native Node modules that can't run in Workers */\nconst NATIVE_MODULES_TO_STUB = [\n \"@resvg/resvg-js\",\n \"satori\",\n \"lightningcss\",\n \"@napi-rs/canvas\",\n \"sharp\",\n];\n\n/**\n * Detect native Node modules in dependencies that need stubbing for Workers.\n */\nfunction detectNativeModules(root: string): string[] {\n const pkgPath = path.join(root, \"package.json\");\n if (!fs.existsSync(pkgPath)) return [];\n\n try {\n const pkg = JSON.parse(fs.readFileSync(pkgPath, \"utf-8\"));\n const allDeps = { ...pkg.dependencies, ...pkg.devDependencies };\n return NATIVE_MODULES_TO_STUB.filter((mod) => mod in allDeps);\n } catch {\n return [];\n }\n}\n\n// ─── Project Preparation (pre-build transforms) ─────────────────────────────\n//\n// These are delegated to shared utilities in ./utils/project.ts so they can\n// be reused by both `vinext deploy` and `vinext init`.\n\n/** @see {@link _ensureESModule} */\nexport const ensureESModule = _ensureESModule;\n\n/** @see {@link _renameCJSConfigs} */\nexport const renameCJSConfigs = _renameCJSConfigs;\n\n// ─── File Generation ─────────────────────────────────────────────────────────\n\n/** Generate wrangler.jsonc content */\nexport function generateWranglerConfig(info: ProjectInfo): string {\n const today = new Date().toISOString().split(\"T\")[0];\n\n const config: Record<string, unknown> = {\n $schema: \"node_modules/wrangler/config-schema.json\",\n name: info.projectName,\n compatibility_date: today,\n compatibility_flags: [\"nodejs_compat\"],\n main: \"./worker/index.ts\",\n assets: {\n not_found_handling: \"none\",\n // Expose static assets to the Worker via env.ASSETS so the image\n // optimization handler can fetch source images programmatically.\n binding: \"ASSETS\",\n },\n // Cloudflare Images binding for next/image optimization.\n // Enables resize, format negotiation (AVIF/WebP), and quality transforms\n // at the edge. No user setup needed — wrangler creates the binding automatically.\n images: {\n binding: \"IMAGES\",\n },\n };\n\n if (info.hasISR) {\n config.kv_namespaces = [\n {\n binding: \"VINEXT_CACHE\",\n id: \"<your-kv-namespace-id>\",\n },\n ];\n }\n\n return JSON.stringify(config, null, 2) + \"\\n\";\n}\n\n/** Generate worker/index.ts for App Router */\nexport function generateAppRouterWorkerEntry(): string {\n return `/**\n * Cloudflare Worker entry point — auto-generated by vinext deploy.\n * Edit freely or delete to regenerate on next deploy.\n *\n * For apps without image optimization, you can use vinext/server/app-router-entry\n * directly in wrangler.jsonc: \"main\": \"vinext/server/app-router-entry\"\n */\nimport { handleImageOptimization, DEFAULT_DEVICE_SIZES, DEFAULT_IMAGE_SIZES } from \"vinext/server/image-optimization\";\nimport type { ImageConfig } from \"vinext/server/image-optimization\";\nimport handler from \"vinext/server/app-router-entry\";\n\ninterface Env {\n ASSETS: Fetcher;\n IMAGES: {\n input(stream: ReadableStream): {\n transform(options: Record<string, unknown>): {\n output(options: { format: string; quality: number }): Promise<{ response(): Response }>;\n };\n };\n };\n}\n\n// Image security config. SVG sources with .svg extension auto-skip the\n// optimization endpoint on the client side (served directly, no proxy).\n// To route SVGs through the optimizer (with security headers), set\n// dangerouslyAllowSVG: true in next.config.js and uncomment below:\n// const imageConfig: ImageConfig = { dangerouslyAllowSVG: true };\n\nexport default {\n async fetch(request: Request, env: Env): Promise<Response> {\n const url = new URL(request.url);\n\n // Image optimization via Cloudflare Images binding.\n // The parseImageParams validation inside handleImageOptimization\n // normalizes backslashes and validates the origin hasn't changed.\n if (url.pathname === \"/_vinext/image\") {\n const allowedWidths = [...DEFAULT_DEVICE_SIZES, ...DEFAULT_IMAGE_SIZES];\n return handleImageOptimization(request, {\n fetchAsset: (path) => env.ASSETS.fetch(new Request(new URL(path, request.url))),\n transformImage: async (body, { width, format, quality }) => {\n const result = await env.IMAGES.input(body).transform(width > 0 ? { width } : {}).output({ format, quality });\n return result.response();\n },\n }, allowedWidths);\n }\n\n // Delegate everything else to vinext\n return handler.fetch(request);\n },\n};\n`;\n}\n\n/** Generate worker/index.ts for Pages Router */\nexport function generatePagesRouterWorkerEntry(): string {\n return `/**\n * Cloudflare Worker entry point -- auto-generated by vinext deploy.\n * Edit freely or delete to regenerate on next deploy.\n */\nimport { handleImageOptimization, DEFAULT_DEVICE_SIZES, DEFAULT_IMAGE_SIZES } from \"vinext/server/image-optimization\";\nimport type { ImageConfig } from \"vinext/server/image-optimization\";\nimport {\n matchRedirect,\n matchRewrite,\n matchHeaders,\n requestContextFromRequest,\n applyMiddlewareRequestHeaders,\n isExternalUrl,\n proxyExternalRequest,\n sanitizeDestination,\n} from \"vinext/config/config-matchers\";\n\n// @ts-expect-error -- virtual module resolved by vinext at build time\nimport { renderPage, handleApiRoute, runMiddleware, vinextConfig } from \"virtual:vinext-server-entry\";\n\ninterface Env {\n ASSETS: Fetcher;\n IMAGES: {\n input(stream: ReadableStream): {\n transform(options: Record<string, unknown>): {\n output(options: { format: string; quality: number }): Promise<{ response(): Response }>;\n };\n };\n };\n}\n\ninterface ExecutionContext {\n waitUntil(promise: Promise<unknown>): void;\n passThroughOnException(): void;\n}\n\n// Extract config values (embedded at build time in the server entry)\nconst basePath: string = vinextConfig?.basePath ?? \"\";\nconst trailingSlash: boolean = vinextConfig?.trailingSlash ?? false;\nconst configRedirects = vinextConfig?.redirects ?? [];\nconst configRewrites = vinextConfig?.rewrites ?? { beforeFiles: [], afterFiles: [], fallback: [] };\nconst configHeaders = vinextConfig?.headers ?? [];\nconst imageConfig: ImageConfig | undefined = vinextConfig?.images ? {\n dangerouslyAllowSVG: vinextConfig.images.dangerouslyAllowSVG,\n contentDispositionType: vinextConfig.images.contentDispositionType,\n contentSecurityPolicy: vinextConfig.images.contentSecurityPolicy,\n} : undefined;\n\nexport default {\n async fetch(request: Request, env: Env, ctx: ExecutionContext): Promise<Response> {\n try {\n const url = new URL(request.url);\n let pathname = url.pathname;\n let urlWithQuery = pathname + url.search;\n\n // Block protocol-relative URL open redirects (//evil.com/ or /\\\\evil.com/).\n // Normalize backslashes: browsers treat /\\\\ as // in URL context.\n const safePath = pathname.replaceAll(\"\\\\\\\\\", \"/\");\n if (safePath.startsWith(\"//\")) {\n return new Response(\"404 Not Found\", { status: 404 });\n }\n\n // ── 1. Strip basePath ─────────────────────────────────────────\n if (basePath && pathname.startsWith(basePath)) {\n const stripped = pathname.slice(basePath.length) || \"/\";\n urlWithQuery = stripped + url.search;\n pathname = stripped;\n }\n\n // ── Image optimization via Cloudflare Images binding ──────────\n // Checked after basePath stripping so /<basePath>/_vinext/image works.\n if (pathname === \"/_vinext/image\") {\n const allowedWidths = [...DEFAULT_DEVICE_SIZES, ...DEFAULT_IMAGE_SIZES];\n return handleImageOptimization(request, {\n fetchAsset: (path) => env.ASSETS.fetch(new Request(new URL(path, request.url))),\n transformImage: async (body, { width, format, quality }) => {\n const result = await env.IMAGES.input(body).transform(width > 0 ? { width } : {}).output({ format, quality });\n return result.response();\n },\n }, allowedWidths, imageConfig);\n }\n\n // ── 2. Trailing slash normalization ────────────────────────────\n if (pathname !== \"/\" && !pathname.startsWith(\"/api\")) {\n const hasTrailing = pathname.endsWith(\"/\");\n if (trailingSlash && !hasTrailing) {\n return new Response(null, {\n status: 308,\n headers: { Location: basePath + pathname + \"/\" + url.search },\n });\n } else if (!trailingSlash && hasTrailing) {\n return new Response(null, {\n status: 308,\n headers: { Location: basePath + pathname.replace(/\\\\/+$/, \"\") + url.search },\n });\n }\n }\n\n // Build a request with the basePath-stripped URL for middleware and\n // downstream handlers. In Workers the incoming request URL still\n // contains basePath; prod-server constructs its webRequest from\n // the already-stripped URL, so we replicate that here.\n if (basePath) {\n const strippedUrl = new URL(request.url);\n strippedUrl.pathname = pathname;\n request = new Request(strippedUrl, request);\n }\n\n // Build request context for has/missing condition matching.\n // headers and redirects run before middleware, so they use this\n // pre-middleware snapshot. beforeFiles, afterFiles, and fallback\n // rewrites run after middleware (App Router order), so they use\n // postMwReqCtx created after x-middleware-request-* headers are\n // unpacked into request.\n const reqCtx = requestContextFromRequest(request);\n\n // ── 3. Run middleware ──────────────────────────────────────────\n let resolvedUrl = urlWithQuery;\n const middlewareHeaders: Record<string, string | string[]> = {};\n let middlewareRewriteStatus: number | undefined;\n if (typeof runMiddleware === \"function\") {\n const result = await runMiddleware(request, ctx);\n\n if (!result.continue) {\n if (result.redirectUrl) {\n return new Response(null, {\n status: result.redirectStatus ?? 307,\n headers: { Location: result.redirectUrl },\n });\n }\n if (result.response) {\n return result.response;\n }\n }\n\n // Collect middleware response headers to merge into final response.\n // Use an array for Set-Cookie to preserve multiple values.\n if (result.responseHeaders) {\n for (const [key, value] of result.responseHeaders) {\n if (key === \"set-cookie\") {\n const existing = middlewareHeaders[key];\n if (Array.isArray(existing)) {\n existing.push(value);\n } else if (existing) {\n middlewareHeaders[key] = [existing as string, value];\n } else {\n middlewareHeaders[key] = [value];\n }\n } else {\n middlewareHeaders[key] = value;\n }\n }\n }\n\n // Apply middleware rewrite\n if (result.rewriteUrl) {\n resolvedUrl = result.rewriteUrl;\n }\n\n // Apply custom status code from middleware rewrite\n middlewareRewriteStatus = result.rewriteStatus;\n }\n\n // Unpack x-middleware-request-* headers into the actual request and strip\n // all x-middleware-* internal signals. Rebuilds postMwReqCtx for use by\n // beforeFiles, afterFiles, and fallback config rules (which run after\n // middleware per the Next.js execution order).\n const { postMwReqCtx, request: postMwReq } = applyMiddlewareRequestHeaders(middlewareHeaders, request);\n request = postMwReq;\n\n let resolvedPathname = resolvedUrl.split(\"?\")[0];\n\n // ── 4. Apply custom headers from next.config.js ───────────────\n // Config headers are additive for multi-value headers (Vary,\n // Set-Cookie) and override for everything else. Vary values are\n // comma-joined per HTTP spec. Set-Cookie values are accumulated\n // as arrays (RFC 6265 forbids comma-joining cookies).\n // Middleware headers take precedence: skip config keys already set\n // by middleware so middleware always wins for the same key.\n if (configHeaders.length) {\n const matched = matchHeaders(resolvedPathname, configHeaders, reqCtx);\n for (const h of matched) {\n const lk = h.key.toLowerCase();\n if (lk === \"set-cookie\") {\n const existing = middlewareHeaders[lk];\n if (Array.isArray(existing)) {\n existing.push(h.value);\n } else if (existing) {\n middlewareHeaders[lk] = [existing as string, h.value];\n } else {\n middlewareHeaders[lk] = [h.value];\n }\n } else if (lk === \"vary\" && middlewareHeaders[lk]) {\n middlewareHeaders[lk] += \", \" + h.value;\n } else if (!(lk in middlewareHeaders)) {\n // Middleware headers take precedence: only set if middleware\n // did not already place this key on the response.\n middlewareHeaders[lk] = h.value;\n }\n }\n }\n\n // ── 5. Apply redirects from next.config.js ────────────────────\n if (configRedirects.length) {\n const redirect = matchRedirect(resolvedPathname, configRedirects, reqCtx);\n if (redirect) {\n const dest = sanitizeDestination(\n basePath && !redirect.destination.startsWith(basePath)\n ? basePath + redirect.destination\n : redirect.destination,\n );\n return new Response(null, {\n status: redirect.permanent ? 308 : 307,\n headers: { Location: dest },\n });\n }\n }\n\n // ��─ 6. Apply beforeFiles rewrites from next.config.js ─────────\n if (configRewrites.beforeFiles?.length) {\n const rewritten = matchRewrite(resolvedPathname, configRewrites.beforeFiles, postMwReqCtx);\n if (rewritten) {\n if (isExternalUrl(rewritten)) {\n return proxyExternalRequest(request, rewritten);\n }\n resolvedUrl = rewritten;\n resolvedPathname = rewritten.split(\"?\")[0];\n }\n }\n\n // ── 7. API routes ─────────────────────────────────────────────\n if (resolvedPathname.startsWith(\"/api/\") || resolvedPathname === \"/api\") {\n const response = typeof handleApiRoute === \"function\"\n ? await handleApiRoute(request, resolvedUrl)\n : new Response(\"404 - API route not found\", { status: 404 });\n return mergeHeaders(response, middlewareHeaders, middlewareRewriteStatus);\n }\n\n // ── 8. Apply afterFiles rewrites from next.config.js ──────────\n if (configRewrites.afterFiles?.length) {\n const rewritten = matchRewrite(resolvedPathname, configRewrites.afterFiles, postMwReqCtx);\n if (rewritten) {\n if (isExternalUrl(rewritten)) {\n return proxyExternalRequest(request, rewritten);\n }\n resolvedUrl = rewritten;\n resolvedPathname = rewritten.split(\"?\")[0];\n }\n }\n\n // ── 9. Page routes ────────────────────────────────────────────\n let response: Response | undefined;\n if (typeof renderPage === \"function\") {\n response = await renderPage(request, resolvedUrl, null);\n\n // ── 10. Fallback rewrites (if SSR returned 404) ─────────────\n if (response && response.status === 404 && configRewrites.fallback?.length) {\n const fallbackRewrite = matchRewrite(resolvedPathname, configRewrites.fallback, postMwReqCtx);\n if (fallbackRewrite) {\n if (isExternalUrl(fallbackRewrite)) {\n return proxyExternalRequest(request, fallbackRewrite);\n }\n response = await renderPage(request, fallbackRewrite, null);\n }\n }\n }\n\n if (!response) {\n return new Response(\"404 - Not found\", { status: 404 });\n }\n\n return mergeHeaders(response, middlewareHeaders, middlewareRewriteStatus);\n } catch (error) {\n console.error(\"[vinext] Worker error:\", error);\n return new Response(\"Internal Server Error\", { status: 500 });\n }\n },\n};\n\n/**\n * Merge middleware/config headers into a response.\n * Response headers take precedence over middleware headers for all headers\n * except Set-Cookie, which is additive (both middleware and response cookies\n * are preserved). Matches the behavior in prod-server.ts. Uses getSetCookie()\n * to preserve multiple Set-Cookie values.\n */\nfunction mergeHeaders(\n response: Response,\n extraHeaders: Record<string, string | string[]>,\n statusOverride?: number,\n): Response {\n if (!Object.keys(extraHeaders).length && !statusOverride) return response;\n const merged = new Headers();\n // Middleware/config headers go in first (lower precedence)\n for (const [k, v] of Object.entries(extraHeaders)) {\n if (Array.isArray(v)) {\n for (const item of v) merged.append(k, item);\n } else {\n merged.set(k, v);\n }\n }\n // Response headers overlay them (higher precedence), except Set-Cookie\n // which is additive (both middleware and response cookies should be sent).\n response.headers.forEach((v, k) => {\n if (k === \"set-cookie\") return;\n merged.set(k, v);\n });\n const responseCookies = response.headers.getSetCookie?.() ?? [];\n for (const cookie of responseCookies) merged.append(\"set-cookie\", cookie);\n return new Response(response.body, {\n status: statusOverride ?? response.status,\n statusText: response.statusText,\n headers: merged,\n });\n}\n`;\n}\n\n/** Generate vite.config.ts for App Router */\nexport function generateAppRouterViteConfig(info?: ProjectInfo): string {\n const imports: string[] = [\n `import { defineConfig } from \"vite\";`,\n `import vinext from \"vinext\";`,\n `import { cloudflare } from \"@cloudflare/vite-plugin\";`,\n ];\n\n if (info?.nativeModulesToStub && info.nativeModulesToStub.length > 0) {\n imports.push(`import path from \"node:path\";`);\n }\n\n const plugins: string[] = [];\n\n if (info?.hasMDX) {\n plugins.push(` // vinext auto-injects @mdx-js/rollup with plugins from next.config`);\n }\n plugins.push(` vinext(),`);\n\n plugins.push(` cloudflare({\n viteEnvironment: {\n name: \"rsc\",\n childEnvironments: [\"ssr\"],\n },\n }),`);\n\n // Build resolve.alias for native module stubs (tsconfig paths are handled\n // automatically by vite-tsconfig-paths inside the vinext plugin)\n let resolveBlock = \"\";\n const aliases: string[] = [];\n\n if (info?.nativeModulesToStub && info.nativeModulesToStub.length > 0) {\n for (const mod of info.nativeModulesToStub) {\n aliases.push(` \"${mod}\": path.resolve(__dirname, \"empty-stub.js\"),`);\n }\n }\n\n if (aliases.length > 0) {\n resolveBlock = `\\n resolve: {\\n alias: {\\n${aliases.join(\"\\n\")}\\n },\\n },`;\n }\n\n return `${imports.join(\"\\n\")}\n\nexport default defineConfig({\n plugins: [\n${plugins.join(\"\\n\")}\n ],${resolveBlock}\n});\n`;\n}\n\n/** Generate vite.config.ts for Pages Router */\nexport function generatePagesRouterViteConfig(info?: ProjectInfo): string {\n const imports: string[] = [\n `import { defineConfig } from \"vite\";`,\n `import vinext from \"vinext\";`,\n `import { cloudflare } from \"@cloudflare/vite-plugin\";`,\n ];\n\n if (info?.nativeModulesToStub && info.nativeModulesToStub.length > 0) {\n imports.push(`import path from \"node:path\";`);\n }\n\n // Build resolve.alias for native module stubs (tsconfig paths are handled\n // automatically by vite-tsconfig-paths inside the vinext plugin)\n let resolveBlock = \"\";\n const aliases: string[] = [];\n\n if (info?.nativeModulesToStub && info.nativeModulesToStub.length > 0) {\n for (const mod of info.nativeModulesToStub) {\n aliases.push(` \"${mod}\": path.resolve(__dirname, \"empty-stub.js\"),`);\n }\n }\n\n if (aliases.length > 0) {\n resolveBlock = `\\n resolve: {\\n alias: {\\n${aliases.join(\"\\n\")}\\n },\\n },`;\n }\n\n return `${imports.join(\"\\n\")}\n\nexport default defineConfig({\n plugins: [\n vinext(),\n cloudflare(),\n ],${resolveBlock}\n});\n`;\n}\n\n// ─── Dependency Management ───────────────────────────────────────────────────\n\ninterface MissingDep {\n name: string;\n version: string;\n}\n\n/**\n * Check if a package is resolvable from a given root directory using\n * Node's module resolution (createRequire). Handles hoisting, pnpm\n * symlinks, monorepos, and Yarn PnP correctly.\n */\nexport function isPackageResolvable(root: string, packageName: string): boolean {\n try {\n const req = createRequire(path.join(root, \"package.json\"));\n req.resolve(packageName);\n return true;\n } catch {\n return false;\n }\n}\n\nexport function getMissingDeps(\n info: ProjectInfo,\n /** Override for testing — defaults to `isPackageResolvable` */\n _isResolvable: (root: string, pkg: string) => boolean = isPackageResolvable,\n): MissingDep[] {\n const missing: MissingDep[] = [];\n\n if (!info.hasCloudflarePlugin) {\n missing.push({ name: \"@cloudflare/vite-plugin\", version: \"latest\" });\n }\n if (!info.hasWrangler) {\n missing.push({ name: \"wrangler\", version: \"latest\" });\n }\n if (info.isAppRouter && !info.hasRscPlugin) {\n missing.push({ name: \"@vitejs/plugin-rsc\", version: \"latest\" });\n }\n if (info.isAppRouter) {\n // react-server-dom-webpack must be resolvable from the project root for Vite.\n if (!_isResolvable(info.root, \"react-server-dom-webpack\")) {\n missing.push({ name: \"react-server-dom-webpack\", version: \"latest\" });\n }\n }\n if (info.hasMDX) {\n // Check if @mdx-js/rollup is already installed (walk up for monorepo hoisting)\n const hasMdxRollup = _findInNodeModules(info.root, \"@mdx-js/rollup\") !== null;\n if (!hasMdxRollup) {\n missing.push({ name: \"@mdx-js/rollup\", version: \"latest\" });\n }\n }\n\n return missing;\n}\n\nfunction installDeps(root: string, deps: MissingDep[]): void {\n if (deps.length === 0) return;\n\n const depSpecs = deps.map((d) => `${d.name}@${d.version}`);\n const installCmd = detectPackageManager(root);\n const [pm, ...pmArgs] = installCmd.split(\" \");\n\n console.log(` Installing: ${deps.map((d) => d.name).join(\", \")}`);\n execFileSync(pm, [...pmArgs, ...depSpecs], {\n cwd: root,\n stdio: \"inherit\",\n });\n}\n\nconst detectPackageManager = _detectPackageManager;\n\n// ─── File Writing ────────────────────────────────────────────────────────────\n\ninterface GeneratedFile {\n path: string;\n content: string;\n description: string;\n}\n\n/**\n * Check whether an existing vite.config file already imports and uses the\n * Cloudflare Vite plugin. This is a heuristic text scan — it doesn't execute\n * the config — so it may produce false negatives for unusual configurations.\n *\n * Returns true if `@cloudflare/vite-plugin` appears to be configured, false\n * if it is missing (meaning the build will fail with \"could not resolve\n * virtual:vinext-rsc-entry\").\n */\nexport function viteConfigHasCloudflarePlugin(root: string): boolean {\n const candidates = [\n path.join(root, \"vite.config.ts\"),\n path.join(root, \"vite.config.js\"),\n path.join(root, \"vite.config.mjs\"),\n ];\n for (const candidate of candidates) {\n if (fs.existsSync(candidate)) {\n try {\n const content = fs.readFileSync(candidate, \"utf-8\");\n return content.includes(\"@cloudflare/vite-plugin\");\n } catch {\n // unreadable — assume it might be fine\n return true;\n }\n }\n }\n return false;\n}\n\nexport function getFilesToGenerate(info: ProjectInfo): GeneratedFile[] {\n const files: GeneratedFile[] = [];\n\n if (!info.hasWranglerConfig) {\n files.push({\n path: path.join(info.root, \"wrangler.jsonc\"),\n content: generateWranglerConfig(info),\n description: \"wrangler.jsonc\",\n });\n }\n\n if (!info.hasWorkerEntry) {\n const workerContent = info.isAppRouter\n ? generateAppRouterWorkerEntry()\n : generatePagesRouterWorkerEntry();\n files.push({\n path: path.join(info.root, \"worker\", \"index.ts\"),\n content: workerContent,\n description: \"worker/index.ts\",\n });\n }\n\n if (!info.hasViteConfig) {\n const viteContent = info.isAppRouter\n ? generateAppRouterViteConfig(info)\n : generatePagesRouterViteConfig(info);\n files.push({\n path: path.join(info.root, \"vite.config.ts\"),\n content: viteContent,\n description: \"vite.config.ts\",\n });\n }\n\n return files;\n}\n\nfunction writeGeneratedFiles(files: GeneratedFile[]): void {\n for (const file of files) {\n const dir = path.dirname(file.path);\n if (!fs.existsSync(dir)) {\n fs.mkdirSync(dir, { recursive: true });\n }\n fs.writeFileSync(file.path, file.content, \"utf-8\");\n console.log(` Created ${file.description}`);\n }\n}\n\n// ─── Build ───────────────────────────────────────────────────────────────────\n\nasync function runBuild(info: ProjectInfo): Promise<void> {\n console.log(\"\\n Building for Cloudflare Workers...\\n\");\n\n // Use Vite's JS API for the build. The user's vite.config.ts (or our\n // generated one) has the cloudflare() plugin which handles the Worker\n // output format. We just need to trigger the build.\n //\n // For App Router, createBuilder().buildApp() handles multi-environment builds.\n // For Pages Router, a single build() call suffices (cloudflare plugin manages it).\n\n if (info.isAppRouter) {\n const builder = await createBuilder({ root: info.root });\n await builder.buildApp();\n } else {\n await build({ root: info.root });\n }\n}\n\n// ─── Deploy ──────────────────────────────────────────────────────────────────\n\nexport interface WranglerDeployArgs {\n args: string[];\n env: string | undefined;\n}\n\nexport function buildWranglerDeployArgs(options: Pick<DeployOptions, \"preview\" | \"env\">): WranglerDeployArgs {\n const args = [\"deploy\"];\n const env = options.env || (options.preview ? \"preview\" : undefined);\n if (env) {\n args.push(\"--env\", env);\n }\n return { args, env };\n}\n\nfunction runWranglerDeploy(root: string, options: Pick<DeployOptions, \"preview\" | \"env\">): string {\n // Walk up ancestor directories so the binary is found even when node_modules\n // is hoisted to the workspace root in a monorepo.\n const wranglerBin = _findInNodeModules(root, \".bin/wrangler\") ??\n path.join(root, \"node_modules\", \".bin\", \"wrangler\"); // fallback for error message clarity\n\n const execOpts: ExecSyncOptions = {\n cwd: root,\n stdio: \"pipe\",\n encoding: \"utf-8\",\n };\n\n const { args, env } = buildWranglerDeployArgs(options);\n\n if (env) {\n console.log(`\\n Deploying to env: ${env}...`);\n } else {\n console.log(\"\\n Deploying to production...\");\n }\n\n // Use execFileSync to avoid shell injection — args are passed as an array,\n // never interpolated into a shell command string.\n const output = execFileSync(wranglerBin, args, execOpts) as string;\n\n // Parse the deployed URL from wrangler output\n // Wrangler prints: \"Published <name> (version_id)\\n https://<name>.<subdomain>.workers.dev\"\n const urlMatch = output.match(/https:\\/\\/[^\\s]+\\.workers\\.dev[^\\s]*/);\n const deployedUrl = urlMatch ? urlMatch[0] : null;\n\n // Also print raw output for transparency\n if (output.trim()) {\n for (const line of output.trim().split(\"\\n\")) {\n console.log(` ${line}`);\n }\n }\n\n return deployedUrl ?? \"(URL not detected in wrangler output)\";\n}\n\n// ─── Main Entry ──────────────────────────────────────────────────────────────\n\nexport async function deploy(options: DeployOptions): Promise<void> {\n const root = path.resolve(options.root);\n loadDotenv({ root, mode: \"production\" });\n\n console.log(\"\\n vinext deploy\\n\");\n\n // Step 1: Detect project structure\n const info = detectProject(root);\n\n if (!info.isAppRouter && !info.isPagesRouter) {\n console.error(\" Error: No app/ or pages/ directory found.\");\n console.error(\" vinext deploy requires a Next.js project with an app/ or pages/ directory\");\n console.error(\" (also checks src/app/ and src/pages/).\\n\");\n process.exit(1);\n }\n\n if (options.name) {\n info.projectName = options.name;\n }\n\n console.log(` Project: ${info.projectName}`);\n console.log(` Router: ${info.isAppRouter ? \"App Router\" : \"Pages Router\"}`);\n console.log(` ISR: ${info.hasISR ? \"detected\" : \"none\"}`);\n\n // Step 2: Check and install missing dependencies\n // For App Router: upgrade React first if needed for react-server-dom-webpack compatibility\n if (info.isAppRouter) {\n const reactUpgrade = getReactUpgradeDeps(root);\n if (reactUpgrade.length > 0) {\n const installCmd = detectPackageManager(root).replace(/ -D$/, \"\");\n const [pm, ...pmArgs] = installCmd.split(\" \");\n console.log(` Upgrading ${reactUpgrade.map(d => d.replace(/@latest$/, \"\")).join(\", \")}...`);\n execFileSync(pm, [...pmArgs, ...reactUpgrade], { cwd: root, stdio: \"inherit\" });\n }\n }\n const missingDeps = getMissingDeps(info);\n if (missingDeps.length > 0) {\n console.log();\n installDeps(root, missingDeps);\n // Re-detect after install\n info.hasCloudflarePlugin = true;\n info.hasWrangler = true;\n if (info.isAppRouter) info.hasRscPlugin = true;\n }\n\n // Step 3: Ensure ESM + rename CJS configs\n if (!info.hasTypeModule) {\n const renamedConfigs = renameCJSConfigs(root);\n for (const [oldName, newName] of renamedConfigs) {\n console.log(` Renamed ${oldName} → ${newName} (CJS → .cjs)`);\n }\n if (ensureESModule(root)) {\n console.log(` Added \"type\": \"module\" to package.json`);\n info.hasTypeModule = true;\n }\n }\n\n // Step 4: Generate missing config files\n const filesToGenerate = getFilesToGenerate(info);\n if (filesToGenerate.length > 0) {\n console.log();\n writeGeneratedFiles(filesToGenerate);\n }\n\n // Warn if an existing vite.config.ts is missing the Cloudflare plugin.\n // This is the most common cause of \"could not resolve virtual:vinext-rsc-entry\"\n // errors — `vinext init` generates a minimal local-dev config without it.\n if (info.hasViteConfig && !viteConfigHasCloudflarePlugin(root)) {\n console.warn(`\n Warning: your vite.config.ts does not appear to import @cloudflare/vite-plugin.\n Cloudflare Workers deployment requires it. Add the plugin to your config:\n\n import { cloudflare } from \"@cloudflare/vite-plugin\";\n\n export default defineConfig({\n plugins: [\n vinext(),\n cloudflare(${info.isAppRouter ? `{\n viteEnvironment: { name: \"rsc\", childEnvironments: [\"ssr\"] },\n }` : \"\"}),\n ],\n });\n\n Or delete vite.config.ts and re-run \\`vinext deploy\\` to auto-generate it.\n`);\n }\n\n if (options.dryRun) {\n console.log(\"\\n Dry run complete. Files generated but no build or deploy performed.\\n\");\n return;\n }\n\n // Step 5: Build\n if (!options.skipBuild) {\n await runBuild(info);\n } else {\n console.log(\"\\n Skipping build (--skip-build)\");\n }\n\n // Step 6: TPR — pre-render hot pages into KV cache (experimental, opt-in)\n if (options.experimentalTPR) {\n console.log();\n const tprResult = await runTPR({\n root,\n coverage: Math.max(1, Math.min(100, options.tprCoverage ?? 90)),\n limit: Math.max(1, options.tprLimit ?? 1000),\n window: Math.max(1, options.tprWindow ?? 24),\n });\n\n if (tprResult.skipped) {\n console.log(` TPR: Skipped (${tprResult.skipped})`);\n }\n }\n\n // Step 7: Deploy via wrangler\n const url = runWranglerDeploy(root, {\n preview: options.preview ?? false,\n env: options.env,\n });\n\n console.log(\"\\n ─────────────────────────────────────────\");\n console.log(` Deployed to: ${url}`);\n console.log(\" ─────────────────────────────────────────\\n\");\n}\n"]}
package/dist/index.d.ts CHANGED
@@ -1,4 +1,5 @@
1
1
  import type { PluginOption } from "vite";
2
+ import { asyncHooksStubPlugin } from "./plugins/async-hooks-stub.js";
2
3
  import { Options as VitePluginReactOptions } from "@vitejs/plugin-react";
3
4
  /**
4
5
  * Safely parse a static JS object literal string into a plain object.
@@ -183,8 +184,10 @@ declare function stripServerExports(code: string): string | null;
183
184
  export declare function matchConfigPattern(pathname: string, pattern: string): Record<string, string> | null;
184
185
  export { staticExportPages, staticExportApp } from "./build/static-export.js";
185
186
  export type { StaticExportResult, StaticExportOptions, AppStaticExportOptions } from "./build/static-export.js";
187
+ export type { NextConfig } from "./config/next-config.js";
186
188
  export { clientManualChunks, clientOutputConfig, clientTreeshakeConfig, computeLazyChunks };
187
189
  export { resolvePostcssStringPlugins as _resolvePostcssStringPlugins };
188
190
  export { parseStaticObjectLiteral as _parseStaticObjectLiteral };
189
191
  export { stripServerExports as _stripServerExports };
192
+ export { asyncHooksStubPlugin as _asyncHooksStubPlugin };
190
193
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAU,YAAY,EAA6B,MAAM,MAAM,CAAC;AA0C5E,OAAc,EAAE,OAAO,IAAI,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;AA8EhF;;;;;;;;GAQG;AACH,iBAAS,wBAAwB,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAkBnF;AAuGD;;;;;;;;;;;GAWG;AACH,iBAAe,2BAA2B,CACxC,WAAW,EAAE,MAAM,GAClB,OAAO,CAAC;IAAE,OAAO,EAAE,GAAG,EAAE,CAAA;CAAE,GAAG,SAAS,CAAC,CAqEzC;AA0CD;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,iBAAS,kBAAkB,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CA8B1D;AAED;;;;;;;;GAQG;AACH,QAAA,MAAM,kBAAkB;;;CAGvB,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,QAAA,MAAM,qBAAqB;;;CAG1B,CAAC;AAEF;;;;;;;;;;;;;;;;GAgBG;AACH,iBAAS,iBAAiB,CACxB,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;IAC1B,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC;CAChB,CAAC,GACD,MAAM,EAAE,CAwDV;AAED,MAAM,WAAW,aAAa;IAC5B;;;;;;OAMG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB;;;;;OAKG;IACH,GAAG,CAAC,EAAE,OAAO,CAAC;IACd;;;;;;OAMG;IACH,KAAK,CAAC,EAAE,sBAAsB,GAAG,OAAO,CAAC;CAC1C;AAED,MAAM,CAAC,OAAO,UAAU,MAAM,CAAC,OAAO,GAAE,aAAkB,GAAG,YAAY,EAAE,CA2hG1E;AAoCD;;;;;;;;;GASG;AACH;;;;;;;;GAQG;AACH;;;;GAIG;AACH;;;;;;;;GAQG;AACH,iBAAS,kBAAkB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAuEvD;AAED,wBAAgB,kBAAkB,CAChC,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,MAAM,GACd,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,IAAI,CAuG/B;AAyMD,OAAO,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC9E,YAAY,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAGhH,OAAO,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,iBAAiB,EAAE,CAAC;AAC5F,OAAO,EAAE,2BAA2B,IAAI,4BAA4B,EAAE,CAAC;AACvE,OAAO,EAAE,wBAAwB,IAAI,yBAAyB,EAAE,CAAC;AACjE,OAAO,EAAE,kBAAkB,IAAI,mBAAmB,EAAE,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAU,YAAY,EAA6B,MAAM,MAAM,CAAC;AA0C5E,OAAO,EAAE,oBAAoB,EAAE,MAAM,+BAA+B,CAAC;AAErE,OAAc,EAAE,OAAO,IAAI,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;AA8EhF;;;;;;;;GAQG;AACH,iBAAS,wBAAwB,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAkBnF;AAuGD;;;;;;;;;;;GAWG;AACH,iBAAe,2BAA2B,CACxC,WAAW,EAAE,MAAM,GAClB,OAAO,CAAC;IAAE,OAAO,EAAE,GAAG,EAAE,CAAA;CAAE,GAAG,SAAS,CAAC,CAqEzC;AA0CD;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,iBAAS,kBAAkB,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CA8B1D;AAED;;;;;;;;GAQG;AACH,QAAA,MAAM,kBAAkB;;;CAGvB,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,QAAA,MAAM,qBAAqB;;;CAG1B,CAAC;AAEF;;;;;;;;;;;;;;;;GAgBG;AACH,iBAAS,iBAAiB,CACxB,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;IAC1B,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC;CAChB,CAAC,GACD,MAAM,EAAE,CAwDV;AAED,MAAM,WAAW,aAAa;IAC5B;;;;;;OAMG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB;;;;;OAKG;IACH,GAAG,CAAC,EAAE,OAAO,CAAC;IACd;;;;;;OAMG;IACH,KAAK,CAAC,EAAE,sBAAsB,GAAG,OAAO,CAAC;CAC1C;AAED,MAAM,CAAC,OAAO,UAAU,MAAM,CAAC,OAAO,GAAE,aAAkB,GAAG,YAAY,EAAE,CAirG1E;AAoCD;;;;;;;;;GASG;AACH;;;;;;;;GAQG;AACH;;;;GAIG;AACH;;;;;;;;GAQG;AACH,iBAAS,kBAAkB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAuEvD;AAED,wBAAgB,kBAAkB,CAChC,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,MAAM,GACd,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,IAAI,CAuG/B;AA+MD,OAAO,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC9E,YAAY,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAIhH,YAAY,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAG1D,OAAO,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,iBAAiB,EAAE,CAAC;AAC5F,OAAO,EAAE,2BAA2B,IAAI,4BAA4B,EAAE,CAAC;AACvE,OAAO,EAAE,wBAAwB,IAAI,yBAAyB,EAAE,CAAC;AACjE,OAAO,EAAE,kBAAkB,IAAI,mBAAmB,EAAE,CAAC;AACrD,OAAO,EAAE,oBAAoB,IAAI,qBAAqB,EAAE,CAAC"}