vinext 0.0.18 → 0.0.20

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 (68) hide show
  1. package/README.md +138 -10
  2. package/dist/check.d.ts.map +1 -1
  3. package/dist/check.js +2 -1
  4. package/dist/check.js.map +1 -1
  5. package/dist/cli.js +4 -4
  6. package/dist/cli.js.map +1 -1
  7. package/dist/config/next-config.d.ts +6 -0
  8. package/dist/config/next-config.d.ts.map +1 -1
  9. package/dist/config/next-config.js.map +1 -1
  10. package/dist/deploy.d.ts.map +1 -1
  11. package/dist/deploy.js +15 -1
  12. package/dist/deploy.js.map +1 -1
  13. package/dist/index.d.ts.map +1 -1
  14. package/dist/index.js +109 -6
  15. package/dist/index.js.map +1 -1
  16. package/dist/init.d.ts +9 -1
  17. package/dist/init.d.ts.map +1 -1
  18. package/dist/init.js +31 -2
  19. package/dist/init.js.map +1 -1
  20. package/dist/server/app-dev-server.d.ts.map +1 -1
  21. package/dist/server/app-dev-server.js +34 -10
  22. package/dist/server/app-dev-server.js.map +1 -1
  23. package/dist/server/dev-server.d.ts.map +1 -1
  24. package/dist/server/dev-server.js +31 -5
  25. package/dist/server/dev-server.js.map +1 -1
  26. package/dist/server/image-optimization.d.ts +17 -3
  27. package/dist/server/image-optimization.d.ts.map +1 -1
  28. package/dist/server/image-optimization.js +31 -13
  29. package/dist/server/image-optimization.js.map +1 -1
  30. package/dist/server/prod-server.d.ts.map +1 -1
  31. package/dist/server/prod-server.js +25 -8
  32. package/dist/server/prod-server.js.map +1 -1
  33. package/dist/shims/compat-router.d.ts +12 -0
  34. package/dist/shims/compat-router.d.ts.map +1 -0
  35. package/dist/shims/compat-router.js +23 -0
  36. package/dist/shims/compat-router.js.map +1 -0
  37. package/dist/shims/font-google.generated.d.ts.map +1 -1
  38. package/dist/shims/font-google.generated.js +1923 -1923
  39. package/dist/shims/font-google.generated.js.map +1 -1
  40. package/dist/shims/image.d.ts.map +1 -1
  41. package/dist/shims/image.js +16 -3
  42. package/dist/shims/image.js.map +1 -1
  43. package/dist/shims/link.d.ts.map +1 -1
  44. package/dist/shims/link.js +15 -13
  45. package/dist/shims/link.js.map +1 -1
  46. package/dist/shims/metadata.d.ts.map +1 -1
  47. package/dist/shims/metadata.js +15 -4
  48. package/dist/shims/metadata.js.map +1 -1
  49. package/dist/shims/navigation.d.ts +1 -0
  50. package/dist/shims/navigation.d.ts.map +1 -1
  51. package/dist/shims/navigation.js +16 -0
  52. package/dist/shims/navigation.js.map +1 -1
  53. package/dist/shims/router.d.ts +18 -0
  54. package/dist/shims/router.d.ts.map +1 -1
  55. package/dist/shims/router.js +63 -30
  56. package/dist/shims/router.js.map +1 -1
  57. package/dist/shims/script.d.ts.map +1 -1
  58. package/dist/shims/script.js +18 -18
  59. package/dist/shims/script.js.map +1 -1
  60. package/dist/shims/server.d.ts +11 -2
  61. package/dist/shims/server.d.ts.map +1 -1
  62. package/dist/shims/server.js +11 -2
  63. package/dist/shims/server.js.map +1 -1
  64. package/dist/utils/project.d.ts +12 -6
  65. package/dist/utils/project.d.ts.map +1 -1
  66. package/dist/utils/project.js +56 -21
  67. package/dist/utils/project.js.map +1 -1
  68. package/package.json +1 -1
@@ -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} 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 const hasCloudflarePlugin = fs.existsSync(\n path.join(root, \"node_modules\", \"@cloudflare\", \"vite-plugin\"),\n );\n const hasRscPlugin = fs.existsSync(\n path.join(root, \"node_modules\", \"@vitejs\", \"plugin-rsc\"),\n );\n const hasWrangler = fs.existsSync(\n path.join(root, \"node_modules\", \".bin\", \"wrangler\"),\n );\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 .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 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\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 {\n matchRedirect,\n matchRewrite,\n matchHeaders,\n requestContextFromRequest,\n isExternalUrl,\n proxyExternalRequest,\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 ?? [];\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);\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 // Created before middleware runs, matching prod-server ordering.\n const reqCtx = requestContextFromRequest(request);\n\n // ── 3. Run middleware ──────────────────────────────────────────\n let resolvedUrl = urlWithQuery;\n const middlewareHeaders: Record<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 if (result.responseHeaders) {\n for (const [key, value] of result.responseHeaders) {\n middlewareHeaders[key] = value;\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];\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 let resolvedPathname = resolvedUrl.split(\"?\")[0];\n\n // ── 4. Apply custom headers from next.config.js ───────────────\n if (configHeaders.length) {\n const matched = matchHeaders(resolvedPathname, configHeaders, reqCtx);\n for (const h of matched) {\n middlewareHeaders[h.key.toLowerCase()] = h.value;\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 = basePath && !redirect.destination.startsWith(basePath)\n ? basePath + redirect.destination\n : redirect.destination;\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, reqCtx);\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, reqCtx);\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, reqCtx);\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, matching\n * the behavior in prod-server.ts.\n */\nfunction mergeHeaders(\n response: Response,\n extraHeaders: Record<string, string>,\n statusOverride?: number,\n): Response {\n if (!Object.keys(extraHeaders).length && !statusOverride) return response;\n // Middleware/config headers go in first (lower precedence), then\n // response headers overlay them (higher precedence).\n const merged: Record<string, string> = { ...extraHeaders };\n response.headers.forEach((v, k) => { merged[k] = v; });\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\n const hasMdxRollup = fs.existsSync(\n path.join(info.root, \"node_modules\", \"@mdx-js\", \"rollup\"),\n );\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 const wranglerBin = path.join(root, \"node_modules\", \".bin\", \"wrangler\");\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":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAAE,MAAM,SAAS,CAAC;AACzB,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAwB,MAAM,oBAAoB,CAAC;AACxE,OAAO,EAAE,SAAS,IAAI,aAAa,EAAE,MAAM,WAAW,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;AAC5C,OAAO,EACL,cAAc,IAAI,eAAe,EACjC,gBAAgB,IAAI,iBAAiB,EACrC,oBAAoB,IAAI,qBAAqB,GAC9C,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAC7C,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AA2BhD,+EAA+E;AAE/E,0DAA0D;AAC1D,MAAM,gBAAgB,GAAG;IACvB,IAAI,EAAgB,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE;IACnE,OAAO,EAAa,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE;IACvD,GAAG,EAAiB,EAAE,IAAI,EAAE,QAAQ,EAAE;IACtC,IAAI,EAAgB,EAAE,IAAI,EAAE,QAAQ,EAAE;IACtC,YAAY,EAAQ,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE;IACvD,SAAS,EAAW,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE;IACvD,kBAAkB,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE;IACvD,cAAc,EAAM,EAAE,IAAI,EAAE,QAAQ,EAAE;IACtC,WAAW,EAAS,EAAE,IAAI,EAAE,QAAQ,EAAE;IACtC,YAAY,EAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE;CAC9B,CAAC;AAEX,MAAM,UAAU,eAAe,CAAC,IAAc;IAC5C,MAAM,EAAE,MAAM,EAAE,GAAG,aAAa,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,gBAAgB,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;IACpF,OAAO;QACL,IAAI,EAAE,MAAM,CAAC,IAAI;QACjB,OAAO,EAAE,MAAM,CAAC,OAAO;QACvB,GAAG,EAAE,MAAM,CAAC,GAAG,EAAE,IAAI,EAAE,IAAI,SAAS;QACpC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,SAAS;QACtC,SAAS,EAAE,MAAM,CAAC,YAAY,CAAC;QAC/B,MAAM,EAAE,MAAM,CAAC,SAAS,CAAC;QACzB,eAAe,EAAE,MAAM,CAAC,kBAAkB,CAAC;QAC3C,WAAW,EAAE,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,cAAc,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS;QACtF,QAAQ,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS;QAC7E,SAAS,EAAE,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS;KACjF,CAAC;AACJ,CAAC;AA2BD,gFAAgF;AAEhF,MAAM,UAAU,aAAa,CAAC,IAAY;IACxC,MAAM,MAAM,GACV,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACrC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;IAC/C,MAAM,QAAQ,GACZ,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACvC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC;IAEjD,kCAAkC;IAClC,MAAM,WAAW,GAAG,MAAM,CAAC;IAC3B,MAAM,aAAa,GAAG,CAAC,MAAM,IAAI,QAAQ,CAAC;IAE1C,MAAM,aAAa,GACjB,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,gBAAgB,CAAC,CAAC;QAChD,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,gBAAgB,CAAC,CAAC;QAChD,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,iBAAiB,CAAC,CAAC,CAAC;IAEpD,MAAM,iBAAiB,GACrB,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,gBAAgB,CAAC,CAAC;QAChD,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC;QAC/C,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC,CAAC;IAElD,MAAM,cAAc,GAClB,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;QACpD,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC,CAAC;IAEvD,4CAA4C;IAC5C,MAAM,mBAAmB,GAAG,EAAE,CAAC,UAAU,CACvC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,cAAc,EAAE,aAAa,EAAE,aAAa,CAAC,CAC9D,CAAC;IACF,MAAM,YAAY,GAAG,EAAE,CAAC,UAAU,CAChC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,cAAc,EAAE,SAAS,EAAE,YAAY,CAAC,CACzD,CAAC;IACF,MAAM,WAAW,GAAG,EAAE,CAAC,UAAU,CAC/B,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,cAAc,EAAE,MAAM,EAAE,UAAU,CAAC,CACpD,CAAC;IAEF,0DAA0D;IAC1D,IAAI,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IACtC,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC;IAChD,IAAI,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;QAC3B,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;YAC1D,IAAI,GAAG,CAAC,IAAI,EAAE,CAAC;gBACb,mEAAmE;gBACnE,WAAW,GAAG,GAAG,CAAC,IAAI;qBACnB,OAAO,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC,kBAAkB;qBAC3C,WAAW,EAAE,CAAY,2CAA2C;qBACpE,OAAO,CAAC,aAAa,EAAE,GAAG,CAAC;qBAC3B,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC;qBACnB,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;YAC3B,CAAC;QACH,CAAC;QAAC,MAAM,CAAC;YACP,sBAAsB;QACxB,CAAC;IACH,CAAC;IAED,sEAAsE;IACtE,MAAM,MAAM,GAAG,SAAS,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;IAE5C,0CAA0C;IAC1C,IAAI,aAAa,GAAG,KAAK,CAAC;IAC1B,IAAI,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;QAC3B,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;YAC1D,aAAa,GAAG,GAAG,CAAC,IAAI,KAAK,QAAQ,CAAC;QACxC,CAAC;QAAC,MAAM,CAAC;YACP,SAAS;QACX,CAAC;IACH,CAAC;IAED,mBAAmB;IACnB,MAAM,MAAM,GAAG,SAAS,CAAC,IAAI,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAC;IAEtD,6BAA6B;IAC7B,IAAI,WAAW,GAAG,KAAK,CAAC;IACxB,IAAI,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;QAC3B,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;YAC1D,MAAM,OAAO,GAAG,EAAE,GAAG,GAAG,CAAC,YAAY,EAAE,GAAG,GAAG,CAAC,eAAe,EAAE,CAAC;YAChE,WAAW,GAAG,UAAU,IAAI,OAAO,CAAC;QACtC,CAAC;QAAC,MAAM,CAAC;YACP,SAAS;QACX,CAAC;IACH,CAAC;IAED,4DAA4D;IAC5D,MAAM,mBAAmB,GAAG,mBAAmB,CAAC,IAAI,CAAC,CAAC;IAEtD,OAAO;QACL,IAAI;QACJ,WAAW;QACX,aAAa;QACb,aAAa;QACb,iBAAiB;QACjB,cAAc;QACd,mBAAmB;QACnB,YAAY;QACZ,WAAW;QACX,WAAW;QACX,MAAM;QACN,aAAa;QACb,MAAM;QACN,WAAW;QACX,mBAAmB;KACpB,CAAC;AACJ,CAAC;AAED,SAAS,SAAS,CAAC,IAAY,EAAE,WAAoB;IACnD,IAAI,CAAC,WAAW;QAAE,OAAO,KAAK,CAAC;IAC/B,IAAI,CAAC;QACH,0DAA0D;QAC1D,IAAI,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACpC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;YAC3B,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QACzC,CAAC;QACD,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC;YAAE,OAAO,KAAK,CAAC;QACzC,2EAA2E;QAC3E,OAAO,iBAAiB,CAAC,MAAM,EAAE,iCAAiC,CAAC,CAAC;IACtE,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,KAAK,CAAC;IACf,CAAC;AACH,CAAC;AAED,SAAS,iBAAiB,CAAC,GAAW,EAAE,OAAe;IACrD,MAAM,OAAO,GAAG,EAAE,CAAC,WAAW,CAAC,GAAG,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;IAC7D,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE,CAAC;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QAC5C,IAAI,KAAK,CAAC,WAAW,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,KAAK,CAAC,IAAI,KAAK,cAAc,EAAE,CAAC;YACxF,IAAI,iBAAiB,CAAC,QAAQ,EAAE,OAAO,CAAC;gBAAE,OAAO,IAAI,CAAC;QACxD,CAAC;aAAM,IAAI,KAAK,CAAC,MAAM,EAAE,IAAI,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;YACnE,IAAI,CAAC;gBACH,MAAM,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;gBACnD,IAAI,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC;oBAAE,OAAO,IAAI,CAAC;YACzC,CAAC;YAAC,MAAM,CAAC;gBACP,wBAAwB;YAC1B,CAAC;QACH,CAAC;IACH,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED;;;GAGG;AACH,SAAS,SAAS,CAAC,IAAY,EAAE,WAAoB,EAAE,QAAiB;IACtE,gDAAgD;IAChD,MAAM,WAAW,GAAG,CAAC,gBAAgB,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,iBAAiB,CAAC,CAAC;IAC/F,KAAK,MAAM,CAAC,IAAI,WAAW,EAAE,CAAC;QAC5B,MAAM,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;QAC7B,IAAI,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC;YACrB,IAAI,CAAC;gBACH,MAAM,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;gBAC5C,IAAI,sBAAsB,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC;oBAAE,OAAO,IAAI,CAAC;YACtF,CAAC;YAAC,MAAM,CAAC;gBACP,SAAS;YACX,CAAC;QACH,CAAC;IACH,CAAC;IAED,8DAA8D;IAC9D,MAAM,IAAI,GAAa,EAAE,CAAC;IAC1B,IAAI,WAAW,EAAE,CAAC;QAChB,MAAM,MAAM,GAAG,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;YAClD,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC;YACxB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QAClC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACpB,CAAC;IACD,IAAI,QAAQ,EAAE,CAAC;QACb,MAAM,QAAQ,GAAG,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;YACtD,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC;YAC1B,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;QACpC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtB,CAAC;IAED,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,IAAI,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,mBAAmB,CAAC,GAAG,EAAE,MAAM,CAAC;YAAE,OAAO,IAAI,CAAC;IAC1E,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,mBAAmB,CAAC,GAAW,EAAE,GAAW;IACnD,MAAM,OAAO,GAAG,EAAE,CAAC,WAAW,CAAC,GAAG,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;IAC7D,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE,CAAC;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QAC5C,IAAI,KAAK,CAAC,WAAW,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,KAAK,CAAC,IAAI,KAAK,cAAc,EAAE,CAAC;YACxF,IAAI,mBAAmB,CAAC,QAAQ,EAAE,GAAG,CAAC;gBAAE,OAAO,IAAI,CAAC;QACtD,CAAC;aAAM,IAAI,KAAK,CAAC,MAAM,EAAE,IAAI,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YACtD,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED,0DAA0D;AAC1D,MAAM,sBAAsB,GAAG;IAC7B,iBAAiB;IACjB,QAAQ;IACR,cAAc;IACd,iBAAiB;IACjB,OAAO;CACR,CAAC;AAEF;;GAEG;AACH,SAAS,mBAAmB,CAAC,IAAY;IACvC,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC;IAChD,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC;QAAE,OAAO,EAAE,CAAC;IAEvC,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;QAC1D,MAAM,OAAO,GAAG,EAAE,GAAG,GAAG,CAAC,YAAY,EAAE,GAAG,GAAG,CAAC,eAAe,EAAE,CAAC;QAChE,OAAO,sBAAsB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,IAAI,OAAO,CAAC,CAAC;IAChE,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC;AAED,+EAA+E;AAC/E,EAAE;AACF,4EAA4E;AAC5E,uDAAuD;AAEvD,mCAAmC;AACnC,MAAM,CAAC,MAAM,cAAc,GAAG,eAAe,CAAC;AAE9C,qCAAqC;AACrC,MAAM,CAAC,MAAM,gBAAgB,GAAG,iBAAiB,CAAC;AAElD,gFAAgF;AAEhF,sCAAsC;AACtC,MAAM,UAAU,sBAAsB,CAAC,IAAiB;IACtD,MAAM,KAAK,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAErD,MAAM,MAAM,GAA4B;QACtC,OAAO,EAAE,0CAA0C;QACnD,IAAI,EAAE,IAAI,CAAC,WAAW;QACtB,kBAAkB,EAAE,KAAK;QACzB,mBAAmB,EAAE,CAAC,eAAe,CAAC;QACtC,IAAI,EAAE,mBAAmB;QACzB,MAAM,EAAE;YACN,kBAAkB,EAAE,MAAM;YAC1B,iEAAiE;YACjE,iEAAiE;YACjE,OAAO,EAAE,QAAQ;SAClB;QACD,yDAAyD;QACzD,yEAAyE;QACzE,kFAAkF;QAClF,MAAM,EAAE;YACN,OAAO,EAAE,QAAQ;SAClB;KACF,CAAC;IAEF,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,MAAM,CAAC,aAAa,GAAG;YACrB;gBACE,OAAO,EAAE,cAAc;gBACvB,EAAE,EAAE,wBAAwB;aAC7B;SACF,CAAC;IACJ,CAAC;IAED,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC;AAChD,CAAC;AAED,8CAA8C;AAC9C,MAAM,UAAU,4BAA4B;IAC1C,OAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAkDR,CAAC;AACF,CAAC;AAED,gDAAgD;AAChD,MAAM,UAAU,8BAA8B;IAC5C,OAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAkRR,CAAC;AACF,CAAC;AAED,6CAA6C;AAC7C,MAAM,UAAU,2BAA2B,CAAC,IAAkB;IAC5D,MAAM,OAAO,GAAa;QACxB,sCAAsC;QACtC,8BAA8B;QAC9B,uDAAuD;KACxD,CAAC;IAEF,IAAI,IAAI,EAAE,mBAAmB,IAAI,IAAI,CAAC,mBAAmB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACrE,OAAO,CAAC,IAAI,CAAC,+BAA+B,CAAC,CAAC;IAChD,CAAC;IAED,MAAM,OAAO,GAAa,EAAE,CAAC;IAE7B,IAAI,IAAI,EAAE,MAAM,EAAE,CAAC;QACjB,OAAO,CAAC,IAAI,CAAC,yEAAyE,CAAC,CAAC;IAC1F,CAAC;IACD,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAE9B,OAAO,CAAC,IAAI,CAAC;;;;;QAKP,CAAC,CAAC;IAER,0EAA0E;IAC1E,iEAAiE;IACjE,IAAI,YAAY,GAAG,EAAE,CAAC;IACtB,MAAM,OAAO,GAAa,EAAE,CAAC;IAE7B,IAAI,IAAI,EAAE,mBAAmB,IAAI,IAAI,CAAC,mBAAmB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACrE,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3C,OAAO,CAAC,IAAI,CAAC,UAAU,GAAG,8CAA8C,CAAC,CAAC;QAC5E,CAAC;IACH,CAAC;IAED,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACvB,YAAY,GAAG,iCAAiC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC;IACrF,CAAC;IAED,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC;;;;EAI5B,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC;MACd,YAAY;;CAEjB,CAAC;AACF,CAAC;AAED,+CAA+C;AAC/C,MAAM,UAAU,6BAA6B,CAAC,IAAkB;IAC9D,MAAM,OAAO,GAAa;QACxB,sCAAsC;QACtC,8BAA8B;QAC9B,uDAAuD;KACxD,CAAC;IAEF,IAAI,IAAI,EAAE,mBAAmB,IAAI,IAAI,CAAC,mBAAmB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACrE,OAAO,CAAC,IAAI,CAAC,+BAA+B,CAAC,CAAC;IAChD,CAAC;IAED,0EAA0E;IAC1E,iEAAiE;IACjE,IAAI,YAAY,GAAG,EAAE,CAAC;IACtB,MAAM,OAAO,GAAa,EAAE,CAAC;IAE7B,IAAI,IAAI,EAAE,mBAAmB,IAAI,IAAI,CAAC,mBAAmB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACrE,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3C,OAAO,CAAC,IAAI,CAAC,UAAU,GAAG,8CAA8C,CAAC,CAAC;QAC5E,CAAC;IACH,CAAC;IAED,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACvB,YAAY,GAAG,iCAAiC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC;IACrF,CAAC;IAED,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC;;;;;;MAMxB,YAAY;;CAEjB,CAAC;AACF,CAAC;AASD;;;;GAIG;AACH,MAAM,UAAU,mBAAmB,CAAC,IAAY,EAAE,WAAmB;IACnE,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC,CAAC;QAC3D,GAAG,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QACzB,OAAO,IAAI,CAAC;IACd,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,KAAK,CAAC;IACf,CAAC;AACH,CAAC;AAED,MAAM,UAAU,cAAc,CAC5B,IAAiB;AACjB,+DAA+D;AAC/D,gBAAwD,mBAAmB;IAE3E,MAAM,OAAO,GAAiB,EAAE,CAAC;IAEjC,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC9B,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,yBAAyB,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC;IACvE,CAAC;IACD,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;QACtB,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC;IACxD,CAAC;IACD,IAAI,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;QAC3C,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,oBAAoB,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC;IAClE,CAAC;IACD,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,8EAA8E;QAC9E,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,EAAE,0BAA0B,CAAC,EAAE,CAAC;YAC1D,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,0BAA0B,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC;QACxE,CAAC;IACH,CAAC;IACD,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,+CAA+C;QAC/C,MAAM,YAAY,GAAG,EAAE,CAAC,UAAU,CAChC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,cAAc,EAAE,SAAS,EAAE,QAAQ,CAAC,CAC1D,CAAC;QACF,IAAI,CAAC,YAAY,EAAE,CAAC;YAClB,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC9D,CAAC;IACH,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAS,WAAW,CAAC,IAAY,EAAE,IAAkB;IACnD,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO;IAE9B,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;IAC3D,MAAM,UAAU,GAAG,oBAAoB,CAAC,IAAI,CAAC,CAAC;IAC9C,MAAM,CAAC,EAAE,EAAE,GAAG,MAAM,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAE9C,OAAO,CAAC,GAAG,CAAC,iBAAiB,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACnE,YAAY,CAAC,EAAE,EAAE,CAAC,GAAG,MAAM,EAAE,GAAG,QAAQ,CAAC,EAAE;QACzC,GAAG,EAAE,IAAI;QACT,KAAK,EAAE,SAAS;KACjB,CAAC,CAAC;AACL,CAAC;AAED,MAAM,oBAAoB,GAAG,qBAAqB,CAAC;AAUnD,MAAM,UAAU,kBAAkB,CAAC,IAAiB;IAClD,MAAM,KAAK,GAAoB,EAAE,CAAC;IAElC,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC5B,KAAK,CAAC,IAAI,CAAC;YACT,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,gBAAgB,CAAC;YAC5C,OAAO,EAAE,sBAAsB,CAAC,IAAI,CAAC;YACrC,WAAW,EAAE,gBAAgB;SAC9B,CAAC,CAAC;IACL,CAAC;IAED,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;QACzB,MAAM,aAAa,GAAG,IAAI,CAAC,WAAW;YACpC,CAAC,CAAC,4BAA4B,EAAE;YAChC,CAAC,CAAC,8BAA8B,EAAE,CAAC;QACrC,KAAK,CAAC,IAAI,CAAC;YACT,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,UAAU,CAAC;YAChD,OAAO,EAAE,aAAa;YACtB,WAAW,EAAE,iBAAiB;SAC/B,CAAC,CAAC;IACL,CAAC;IAED,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;QACxB,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW;YAClC,CAAC,CAAC,2BAA2B,CAAC,IAAI,CAAC;YACnC,CAAC,CAAC,6BAA6B,CAAC,IAAI,CAAC,CAAC;QACxC,KAAK,CAAC,IAAI,CAAC;YACT,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,gBAAgB,CAAC;YAC5C,OAAO,EAAE,WAAW;YACpB,WAAW,EAAE,gBAAgB;SAC9B,CAAC,CAAC;IACL,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,mBAAmB,CAAC,KAAsB;IACjD,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;YACxB,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QACzC,CAAC;QACD,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QACnD,OAAO,CAAC,GAAG,CAAC,aAAa,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IAC/C,CAAC;AACH,CAAC;AAED,gFAAgF;AAEhF,KAAK,UAAU,QAAQ,CAAC,IAAiB;IACvC,OAAO,CAAC,GAAG,CAAC,0CAA0C,CAAC,CAAC;IAExD,qEAAqE;IACrE,sEAAsE;IACtE,oDAAoD;IACpD,EAAE;IACF,+EAA+E;IAC/E,mFAAmF;IAEnF,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QACzD,MAAM,OAAO,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;SAAM,CAAC;QACN,MAAM,KAAK,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IACnC,CAAC;AACH,CAAC;AASD,MAAM,UAAU,uBAAuB,CAAC,OAA+C;IACrF,MAAM,IAAI,GAAG,CAAC,QAAQ,CAAC,CAAC;IACxB,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IACrE,IAAI,GAAG,EAAE,CAAC;QACR,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;IAC1B,CAAC;IACD,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC;AACvB,CAAC;AAED,SAAS,iBAAiB,CAAC,IAAY,EAAE,OAA+C;IACtF,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,cAAc,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;IAExE,MAAM,QAAQ,GAAoB;QAChC,GAAG,EAAE,IAAI;QACT,KAAK,EAAE,MAAM;QACb,QAAQ,EAAE,OAAO;KAClB,CAAC;IAEF,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,uBAAuB,CAAC,OAAO,CAAC,CAAC;IAEvD,IAAI,GAAG,EAAE,CAAC;QACR,OAAO,CAAC,GAAG,CAAC,yBAAyB,GAAG,KAAK,CAAC,CAAC;IACjD,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,GAAG,CAAC,gCAAgC,CAAC,CAAC;IAChD,CAAC;IAED,2EAA2E;IAC3E,kDAAkD;IAClD,MAAM,MAAM,GAAG,YAAY,CAAC,WAAW,EAAE,IAAI,EAAE,QAAQ,CAAW,CAAC;IAEnE,8CAA8C;IAC9C,6FAA6F;IAC7F,MAAM,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;IACtE,MAAM,WAAW,GAAG,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAElD,yCAAyC;IACzC,IAAI,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC;QAClB,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;YAC7C,OAAO,CAAC,GAAG,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,OAAO,WAAW,IAAI,uCAAuC,CAAC;AAChE,CAAC;AAED,gFAAgF;AAEhF,MAAM,CAAC,KAAK,UAAU,MAAM,CAAC,OAAsB;IACjD,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACxC,UAAU,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC,CAAC;IAEzC,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;IAEnC,mCAAmC;IACnC,MAAM,IAAI,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC;IAEjC,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;QAC7C,OAAO,CAAC,KAAK,CAAC,6CAA6C,CAAC,CAAC;QAC7D,OAAO,CAAC,KAAK,CAAC,6EAA6E,CAAC,CAAC;QAC7F,OAAO,CAAC,KAAK,CAAC,4CAA4C,CAAC,CAAC;QAC5D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;QACjB,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAClC,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IAC9C,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC,CAAC;IAC9E,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;IAE/D,iDAAiD;IACjD,2FAA2F;IAC3F,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,MAAM,YAAY,GAAG,mBAAmB,CAAC,IAAI,CAAC,CAAC;QAC/C,IAAI,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC5B,MAAM,UAAU,GAAG,oBAAoB,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;YAClE,MAAM,CAAC,EAAE,EAAE,GAAG,MAAM,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAC9C,OAAO,CAAC,GAAG,CAAC,eAAe,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC7F,YAAY,CAAC,EAAE,EAAE,CAAC,GAAG,MAAM,EAAE,GAAG,YAAY,CAAC,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC;QAClF,CAAC;IACH,CAAC;IACD,MAAM,WAAW,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC;IACzC,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC3B,OAAO,CAAC,GAAG,EAAE,CAAC;QACd,WAAW,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;QAC/B,0BAA0B;QAC1B,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;QAChC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,IAAI,CAAC,WAAW;YAAE,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IACjD,CAAC;IAED,0CAA0C;IAC1C,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;QACxB,MAAM,cAAc,GAAG,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAC9C,KAAK,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,IAAI,cAAc,EAAE,CAAC;YAChD,OAAO,CAAC,GAAG,CAAC,aAAa,OAAO,MAAM,OAAO,eAAe,CAAC,CAAC;QAChE,CAAC;QACD,IAAI,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC;YACzB,OAAO,CAAC,GAAG,CAAC,0CAA0C,CAAC,CAAC;YACxD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC5B,CAAC;IACH,CAAC;IAED,wCAAwC;IACxC,MAAM,eAAe,GAAG,kBAAkB,CAAC,IAAI,CAAC,CAAC;IACjD,IAAI,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC/B,OAAO,CAAC,GAAG,EAAE,CAAC;QACd,mBAAmB,CAAC,eAAe,CAAC,CAAC;IACvC,CAAC;IAED,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;QACnB,OAAO,CAAC,GAAG,CAAC,2EAA2E,CAAC,CAAC;QACzF,OAAO;IACT,CAAC;IAED,gBAAgB;IAChB,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC;QACvB,MAAM,QAAQ,CAAC,IAAI,CAAC,CAAC;IACvB,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,GAAG,CAAC,mCAAmC,CAAC,CAAC;IACnD,CAAC;IAED,0EAA0E;IAC1E,IAAI,OAAO,CAAC,eAAe,EAAE,CAAC;QAC5B,OAAO,CAAC,GAAG,EAAE,CAAC;QACd,MAAM,SAAS,GAAG,MAAM,MAAM,CAAC;YAC7B,IAAI;YACJ,QAAQ,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,OAAO,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC;YAC/D,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC;YAC5C,MAAM,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,CAAC,SAAS,IAAI,EAAE,CAAC;SAC7C,CAAC,CAAC;QAEH,IAAI,SAAS,CAAC,OAAO,EAAE,CAAC;YACtB,OAAO,CAAC,GAAG,CAAC,mBAAmB,SAAS,CAAC,OAAO,GAAG,CAAC,CAAC;QACvD,CAAC;IACH,CAAC;IAED,8BAA8B;IAC9B,MAAM,GAAG,GAAG,iBAAiB,CAAC,IAAI,EAAE;QAClC,OAAO,EAAE,OAAO,CAAC,OAAO,IAAI,KAAK;QACjC,GAAG,EAAE,OAAO,CAAC,GAAG;KACjB,CAAC,CAAC;IAEH,OAAO,CAAC,GAAG,CAAC,+CAA+C,CAAC,CAAC;IAC7D,OAAO,CAAC,GAAG,CAAC,kBAAkB,GAAG,EAAE,CAAC,CAAC;IACrC,OAAO,CAAC,GAAG,CAAC,+CAA+C,CAAC,CAAC;AAC/D,CAAC","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} 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 const hasCloudflarePlugin = fs.existsSync(\n path.join(root, \"node_modules\", \"@cloudflare\", \"vite-plugin\"),\n );\n const hasRscPlugin = fs.existsSync(\n path.join(root, \"node_modules\", \"@vitejs\", \"plugin-rsc\"),\n );\n const hasWrangler = fs.existsSync(\n path.join(root, \"node_modules\", \".bin\", \"wrangler\"),\n );\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} 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 // Created before middleware runs, matching prod-server ordering.\n const reqCtx = requestContextFromRequest(request);\n\n // ── 3. Run middleware ──────────────────────────────────────────\n let resolvedUrl = urlWithQuery;\n const middlewareHeaders: Record<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 if (result.responseHeaders) {\n for (const [key, value] of result.responseHeaders) {\n middlewareHeaders[key] = value;\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];\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 let resolvedPathname = resolvedUrl.split(\"?\")[0];\n\n // ── 4. Apply custom headers from next.config.js ───────────────\n if (configHeaders.length) {\n const matched = matchHeaders(resolvedPathname, configHeaders, reqCtx);\n for (const h of matched) {\n middlewareHeaders[h.key.toLowerCase()] = h.value;\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 = basePath && !redirect.destination.startsWith(basePath)\n ? basePath + redirect.destination\n : redirect.destination;\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, reqCtx);\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, reqCtx);\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, reqCtx);\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, matching\n * the behavior in prod-server.ts.\n */\nfunction mergeHeaders(\n response: Response,\n extraHeaders: Record<string, string>,\n statusOverride?: number,\n): Response {\n if (!Object.keys(extraHeaders).length && !statusOverride) return response;\n // Middleware/config headers go in first (lower precedence), then\n // response headers overlay them (higher precedence).\n const merged: Record<string, string> = { ...extraHeaders };\n response.headers.forEach((v, k) => { merged[k] = v; });\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\n const hasMdxRollup = fs.existsSync(\n path.join(info.root, \"node_modules\", \"@mdx-js\", \"rollup\"),\n );\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 const wranglerBin = path.join(root, \"node_modules\", \".bin\", \"wrangler\");\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 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAA6B,MAAM,MAAM,CAAC;AAmH9D;;;;;;;;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;CACf;AAED,MAAM,CAAC,OAAO,UAAU,MAAM,CAAC,OAAO,GAAE,aAAkB,GAAG,MAAM,EAAE,CAgpFpE;AAoCD;;;;;;;;;GASG;AACH,wBAAgB,kBAAkB,CAChC,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,MAAM,GACd,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,IAAI,CAuG/B;AA8KD,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"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAA6B,MAAM,MAAM,CAAC;AAoH9D;;;;;;;;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;CACf;AAED,MAAM,CAAC,OAAO,UAAU,MAAM,CAAC,OAAO,GAAE,aAAkB,GAAG,MAAM,EAAE,CA6vFpE;AAoCD;;;;;;;;;GASG;AACH,wBAAgB,kBAAkB,CAChC,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,MAAM,GACd,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,IAAI,CAuG/B;AA8KD,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"}
package/dist/index.js CHANGED
@@ -1,4 +1,4 @@
1
- import { parseAst } from "vite";
1
+ import { loadEnv, parseAst } from "vite";
2
2
  import { pagesRouter, apiRouter, invalidateRouteCache, matchRoute, patternToNextFormat as pagesPatternToNextFormat } from "./routing/pages-router.js";
3
3
  import { appRouter, invalidateAppRouteCache } from "./routing/app-router.js";
4
4
  import { createSSRHandler } from "./server/dev-server.js";
@@ -12,6 +12,7 @@ import { findInstrumentationFile, runInstrumentation } from "./server/instrument
12
12
  import { validateDevRequest } from "./server/dev-origin-check.js";
13
13
  import { safeRegExp, isExternalUrl, proxyExternalRequest, parseCookies, matchHeaders, matchRedirect, matchRewrite, } from "./config/config-matchers.js";
14
14
  import { scanMetadataFiles } from "./server/metadata-routes.js";
15
+ import { detectPackageManager } from "./utils/project.js";
15
16
  import tsconfigPaths from "vite-tsconfig-paths";
16
17
  import MagicString from "magic-string";
17
18
  import path from "node:path";
@@ -554,6 +555,13 @@ export default function vinext(options = {}) {
554
555
  rewrites: nextConfig?.rewrites ?? { beforeFiles: [], afterFiles: [], fallback: [] },
555
556
  headers: nextConfig?.headers ?? [],
556
557
  i18n: nextConfig?.i18n ?? null,
558
+ images: {
559
+ deviceSizes: nextConfig?.images?.deviceSizes,
560
+ imageSizes: nextConfig?.images?.imageSizes,
561
+ dangerouslyAllowSVG: nextConfig?.images?.dangerouslyAllowSVG,
562
+ contentDispositionType: nextConfig?.images?.contentDispositionType,
563
+ contentSecurityPolicy: nextConfig?.images?.contentSecurityPolicy,
564
+ },
557
565
  });
558
566
  // Generate middleware code if middleware.ts exists
559
567
  const middlewareImportCode = middlewarePath
@@ -656,7 +664,7 @@ import React from "react";
656
664
  import { renderToReadableStream } from "react-dom/server.edge";
657
665
  import { resetSSRHead, getSSRHeadHTML } from "next/head";
658
666
  import { flushPreloads } from "next/dynamic";
659
- import { setSSRContext } from "next/router";
667
+ import { setSSRContext, wrapWithRouterContext } from "next/router";
660
668
  import { getCacheHandler } from "next/cache";
661
669
  import { runWithFetchCache } from "vinext/fetch-cache";
662
670
  import { _runWithCacheState } from "next/cache";
@@ -1221,6 +1229,7 @@ export async function renderPage(request, url, manifest) {
1221
1229
  } else {
1222
1230
  element = React.createElement(PageComponent, pageProps);
1223
1231
  }
1232
+ element = wrapWithRouterContext(element);
1224
1233
 
1225
1234
  if (typeof resetSSRHead === "function") resetSSRHead();
1226
1235
  if (typeof flushPreloads === "function") await flushPreloads();
@@ -1318,6 +1327,7 @@ export async function renderPage(request, url, manifest) {
1318
1327
  } else {
1319
1328
  isrElement = React.createElement(PageComponent, pageProps);
1320
1329
  }
1330
+ isrElement = wrapWithRouterContext(isrElement);
1321
1331
  var isrHtml = await renderToStringAsync(isrElement);
1322
1332
  var fullHtml = shellPrefix + isrHtml + shellSuffix;
1323
1333
  var isrPathname = url.split("?")[0];
@@ -1479,6 +1489,10 @@ async function hydrate() {
1479
1489
  element = React.createElement(PageComponent, pageProps);
1480
1490
  `}
1481
1491
 
1492
+ // Wrap with RouterContext.Provider so next/compat/router works during hydration
1493
+ const { wrapWithRouterContext } = await import("next/router");
1494
+ element = wrapWithRouterContext(element);
1495
+
1482
1496
  const container = document.getElementById("__next");
1483
1497
  if (!container) {
1484
1498
  console.error("[vinext] No #__next element found");
@@ -1529,7 +1543,7 @@ hydrate();
1529
1543
  if (earlyAppDirExists && autoRsc) {
1530
1544
  if (!resolvedRscPath) {
1531
1545
  throw new Error("vinext: App Router detected but @vitejs/plugin-rsc is not installed.\n" +
1532
- "Run: npm install -D @vitejs/plugin-rsc");
1546
+ "Run: " + detectPackageManager(process.cwd()) + " @vitejs/plugin-rsc");
1533
1547
  }
1534
1548
  const rscImport = import(pathToFileURL(resolvedRscPath).href);
1535
1549
  rscPluginPromise = rscImport
@@ -1555,8 +1569,36 @@ hydrate();
1555
1569
  {
1556
1570
  name: "vinext:config",
1557
1571
  enforce: "pre",
1558
- async config(config) {
1572
+ async config(config, env) {
1559
1573
  root = config.root ?? process.cwd();
1574
+ // Load .env files into process.env before anything else.
1575
+ // Next.js loads .env files before evaluating next.config.js, so
1576
+ // env vars are available in config, server-side code, and as
1577
+ // NEXT_PUBLIC_* defines for the client bundle.
1578
+ // Pass '' as prefix to load ALL vars, not just VITE_-prefixed ones.
1579
+ const mode = env?.mode ?? "development";
1580
+ const envDir = config.envDir ?? root;
1581
+ const dotenvVars = loadEnv(mode, envDir, "");
1582
+ for (const [key, value] of Object.entries(dotenvVars)) {
1583
+ if (process.env[key] === undefined) {
1584
+ process.env[key] = value;
1585
+ }
1586
+ }
1587
+ // Align NODE_ENV with Next.js semantics: build -> production, serve -> development.
1588
+ // Next.js unconditionally forces NODE_ENV during build/dev, so we do the same.
1589
+ let resolvedNodeEnv;
1590
+ if (mode === "test") {
1591
+ resolvedNodeEnv = "test";
1592
+ }
1593
+ else if (env?.command === "build") {
1594
+ resolvedNodeEnv = "production";
1595
+ }
1596
+ else {
1597
+ resolvedNodeEnv = "development";
1598
+ }
1599
+ if (process.env.NODE_ENV !== resolvedNodeEnv) {
1600
+ process.env.NODE_ENV = resolvedNodeEnv;
1601
+ }
1560
1602
  // Resolve the base directory for app/pages detection.
1561
1603
  // If appDir is provided, resolve it (supports both relative and absolute paths).
1562
1604
  // If not provided, auto-detect: check root first, then src/ subdirectory.
@@ -1593,7 +1635,16 @@ hydrate();
1593
1635
  nextConfig = await resolveNextConfig(rawConfig);
1594
1636
  // Merge env from next.config.js with NEXT_PUBLIC_* env vars
1595
1637
  const defines = getNextPublicEnvDefines();
1638
+ if (!config.define ||
1639
+ typeof config.define !== "object" ||
1640
+ !("process.env.NODE_ENV" in config.define)) {
1641
+ defines["process.env.NODE_ENV"] = JSON.stringify(resolvedNodeEnv);
1642
+ }
1596
1643
  for (const [key, value] of Object.entries(nextConfig.env)) {
1644
+ // Skip NODE_ENV from next.config.js env — Next.js ignores it too,
1645
+ // and it would silently override the value we just set above.
1646
+ if (key === "NODE_ENV")
1647
+ continue;
1597
1648
  defines[`process.env.${key}`] = JSON.stringify(value);
1598
1649
  }
1599
1650
  // Expose basePath to client-side code
@@ -1610,6 +1661,9 @@ hydrate();
1610
1661
  defines["process.env.__VINEXT_IMAGE_DEVICE_SIZES"] = JSON.stringify(JSON.stringify(deviceSizes));
1611
1662
  defines["process.env.__VINEXT_IMAGE_SIZES"] = JSON.stringify(JSON.stringify(imageSizes));
1612
1663
  }
1664
+ // Expose dangerouslyAllowSVG flag for the image shim's auto-skip logic.
1665
+ // When false (default), .svg sources bypass the optimization endpoint.
1666
+ defines["process.env.__VINEXT_IMAGE_DANGEROUSLY_ALLOW_SVG"] = JSON.stringify(String(nextConfig.images?.dangerouslyAllowSVG ?? false));
1613
1667
  // Draft mode secret — generated once at build time so the
1614
1668
  // __prerender_bypass cookie is consistent across all server
1615
1669
  // instances (e.g. multiple Cloudflare Workers isolates).
@@ -1620,6 +1674,7 @@ hydrate();
1620
1674
  "next/link": path.join(shimsDir, "link"),
1621
1675
  "next/head": path.join(shimsDir, "head"),
1622
1676
  "next/router": path.join(shimsDir, "router"),
1677
+ "next/compat/router": path.join(shimsDir, "compat-router"),
1623
1678
  "next/image": path.join(shimsDir, "image"),
1624
1679
  "next/legacy/image": path.join(shimsDir, "legacy-image"),
1625
1680
  "next/dynamic": path.join(shimsDir, "dynamic"),
@@ -1723,7 +1778,7 @@ hydrate();
1723
1778
  catch {
1724
1779
  // @mdx-js/rollup not installed — warn but don't fail
1725
1780
  console.warn("[vinext] MDX files detected but @mdx-js/rollup is not installed. " +
1726
- "Install it with: npm install -D @mdx-js/rollup");
1781
+ "Install it with: " + detectPackageManager(process.cwd()) + " @mdx-js/rollup");
1727
1782
  }
1728
1783
  }
1729
1784
  // Detect if this is a standalone SSR build (set by `vite build --ssr`
@@ -2115,12 +2170,32 @@ hydrate();
2115
2170
  configureServer(server) {
2116
2171
  // Watch pages directory for file additions/removals to invalidate route cache.
2117
2172
  const pageExtensions = /\.(tsx?|jsx?|mdx)$/;
2173
+ /**
2174
+ * Invalidate the virtual RSC entry module in Vite's module graph.
2175
+ *
2176
+ * The App Router route table is baked into the virtual RSC entry
2177
+ * at generation time. When routes are added or removed, clearing
2178
+ * the route cache alone is not enough: the virtual module must
2179
+ * also be invalidated so Vite re-calls the load() hook to
2180
+ * regenerate the entry with the updated route table.
2181
+ */
2182
+ function invalidateRscEntryModule() {
2183
+ const rscEnv = server.environments["rsc"];
2184
+ if (!rscEnv)
2185
+ return;
2186
+ const mod = rscEnv.moduleGraph.getModuleById(RESOLVED_RSC_ENTRY);
2187
+ if (mod) {
2188
+ rscEnv.moduleGraph.invalidateModule(mod);
2189
+ rscEnv.hot.send({ type: "full-reload" });
2190
+ }
2191
+ }
2118
2192
  server.watcher.on("add", (filePath) => {
2119
2193
  if (hasPagesDir && filePath.startsWith(pagesDir) && pageExtensions.test(filePath)) {
2120
2194
  invalidateRouteCache(pagesDir);
2121
2195
  }
2122
2196
  if (hasAppDir && filePath.startsWith(appDir) && pageExtensions.test(filePath)) {
2123
2197
  invalidateAppRouteCache();
2198
+ invalidateRscEntryModule();
2124
2199
  }
2125
2200
  });
2126
2201
  server.watcher.on("unlink", (filePath) => {
@@ -2129,6 +2204,7 @@ hydrate();
2129
2204
  }
2130
2205
  if (hasAppDir && filePath.startsWith(appDir) && pageExtensions.test(filePath)) {
2131
2206
  invalidateAppRouteCache();
2207
+ invalidateRscEntryModule();
2132
2208
  }
2133
2209
  });
2134
2210
  // Run instrumentation.ts register() if present (once at server startup)
@@ -2746,7 +2822,7 @@ hydrate();
2746
2822
  return null;
2747
2823
  if (!resolvedRscTransformsPath) {
2748
2824
  throw new Error("vinext: 'use cache' requires @vitejs/plugin-rsc to be installed.\n" +
2749
- "Run: npm install -D @vitejs/plugin-rsc");
2825
+ "Run: " + detectPackageManager(process.cwd()) + " @vitejs/plugin-rsc");
2750
2826
  }
2751
2827
  const { transformWrapExport, transformHoistInlineDirective } = await import(pathToFileURL(resolvedRscTransformsPath).href);
2752
2828
  const ast = parseAst(code);
@@ -2884,6 +2960,33 @@ hydrate();
2884
2960
  },
2885
2961
  },
2886
2962
  },
2963
+ // Write image config JSON for the App Router production server.
2964
+ // The App Router RSC entry doesn't export vinextConfig (that's a Pages
2965
+ // Router pattern), so we write a separate JSON file at build time that
2966
+ // prod-server.ts reads at startup for SVG/security header config.
2967
+ {
2968
+ name: "vinext:image-config",
2969
+ apply: "build",
2970
+ enforce: "post",
2971
+ writeBundle: {
2972
+ sequential: true,
2973
+ order: "post",
2974
+ handler(options) {
2975
+ const envName = this.environment?.name;
2976
+ if (envName !== "rsc")
2977
+ return;
2978
+ const outDir = options.dir;
2979
+ if (!outDir)
2980
+ return;
2981
+ const imageConfig = {
2982
+ dangerouslyAllowSVG: nextConfig?.images?.dangerouslyAllowSVG,
2983
+ contentDispositionType: nextConfig?.images?.contentDispositionType,
2984
+ contentSecurityPolicy: nextConfig?.images?.contentSecurityPolicy,
2985
+ };
2986
+ fs.writeFileSync(path.join(outDir, "image-config.json"), JSON.stringify(imageConfig));
2987
+ },
2988
+ },
2989
+ },
2887
2990
  // Cloudflare Workers production build integration:
2888
2991
  // After all environments are built, compute lazy chunks from the client
2889
2992
  // build manifest and inject globals into the worker entry.