vite-plugin-react-server 1.4.0 → 1.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -16,7 +16,7 @@ A Vite plugin that enables React Server Components (RSC) streaming and static HT
16
16
  ## Quick Start
17
17
 
18
18
  ```sh
19
- npm install -D vite-plugin-react-server react@experimental react-dom@experimental
19
+ npm install -D vite-plugin-react-server react@19 react-dom@19
20
20
  ```
21
21
 
22
22
  **Minimal Config:**
package/dist/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "vite-plugin-react-server",
3
- "version": "1.4.0",
3
+ "version": "1.4.1",
4
4
  "description": "Vite plugin for React Server Components (RSC)",
5
5
  "type": "module",
6
6
  "main": "./dist/plugin/index.js",
@@ -82,4 +82,4 @@ const configureReactServer = function _createReactWorkerServer({
82
82
  };
83
83
 
84
84
  export { configureReactServer };
85
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"configureReactServer.client.js","sources":["../../../plugin/dev-server/configureReactServer.client.ts"],"sourcesContent":["import { configureRequestHandler } from \"./configureRequestHandler.client.js\";\nimport { MessageChannel } from \"node:worker_threads\";\nimport type { CreateReactWorkerServerFn } from \"./types.js\";\nimport { setMaxListenersOnPort, unrefPort } from \"../stream/setMaxListeners.js\";\n\n\n/**\n * Creates a React Worker Server that configures worker-based rendering\n * Sets up middleware, HMR, and worker management like react-client/plugin.client.ts\n */\nexport const configureReactServer: CreateReactWorkerServerFn =\n  function _createReactWorkerServer({\n    server,\n    autoDiscoveredFiles,\n    userOptions,\n    configEnv,\n    hmrChannel,\n    onWorkerCreated,\n    serverManifest,\n    resolvedConfig,\n  }) {\n    const logger = server.config.customLogger || server.config.logger;\n    const verbose = userOptions.verbose || false;\n\n    if (verbose) {\n      logger?.info(\n        `[createReactWorkerServer] Configuring worker-based rendering`\n      );\n    }\n\n    // Set up restart listener for worker cleanup\n    server.ws.on(\"restart\", async () => {\n      logger?.info(\n        \"[createReactWorkerServer] Server restarting, shutting down worker...\"\n      );\n      // Worker cleanup would be handled by the worker management\n    });\n\n    let restartFn: (() => Promise<void>) | null = null;\n    let currentWorker: any = null;\n\n    // Configure the worker request handler (sets up middleware)\n    const effectiveHmrChannel = (() => {\n      const channel = hmrChannel || new MessageChannel();\n      // Increase max listeners to prevent warnings during development\n      // This is a targeted fix for the memory leak warnings\n      // We need to set this on BOTH ports because listeners can be added to either side\n      // Use a high default (500) to accommodate large projects with many routes\n      // restartWorker will adjust this based on actual route count\n      const initialMaxListeners = 500;\n      setMaxListenersOnPort(channel.port1, initialMaxListeners);\n      setMaxListenersOnPort(channel.port2, initialMaxListeners);\n      unrefPort(channel.port1);\n      unrefPort(channel.port2);\n      return channel;\n    })();\n\n    configureRequestHandler({\n      server,\n      autoDiscoveredFiles,\n      userOptions,\n      configEnv,\n      hmrChannel: effectiveHmrChannel,\n      serverManifest,\n      resolvedConfig,\n      onWorkerCreated: (worker: any, restart?: () => Promise<void>) => {\n        currentWorker = worker;\n        if (restart) {\n          restartFn = restart;\n        }\n        if (onWorkerCreated) {\n          onWorkerCreated(worker, restart);\n        }\n      },\n    });\n    \n    // Return object with restart function and HMR update sender for handleHotUpdate\n    return {\n      restart: restartFn,\n      sendHmrUpdate: (file: string, routes?: string[]) => {\n        if (currentWorker) {\n          // CRITICAL: In development mode, HMR port is disabled, so send directly to worker\n          // Send HMR_UPDATE message to worker through parentPort (postMessage)\n          const normalizedPath = file.replace(userOptions.projectRoot || server.config.root, '').replace(/^\\/+/, '');\n          currentWorker.postMessage({\n            type: \"HMR_UPDATE\",\n            id: normalizedPath,\n            path: file,\n            routes: routes || [],\n            timestamp: Date.now(),\n          } satisfies any);\n          \n          // Mark that modules have been invalidated - worker will be restarted on next request\n          // This is necessary because Node.js caches ES modules and the only way to clear\n          // that cache is to restart the worker\n          // Use dynamic import to avoid circular dependency\n          import(\"./configureRequestHandler.client.js\").then(({ markModulesInvalidated }) => {\n            markModulesInvalidated();\n          });\n          \n          if (verbose) {\n            logger?.info(`[createReactWorkerServer] Sent HMR_UPDATE for ${file} to worker, marked for restart`);\n          }\n        }\n      },\n    };\n  };\n"],"names":[],"mappings":";;;;;;;;;AAUa,MAAA,oBAAA,GACX,SAAS,wBAAyB,CAAA;AAAA,EAChC,MAAA;AAAA,EACA,mBAAA;AAAA,EACA,WAAA;AAAA,EACA,SAAA;AAAA,EACA,UAAA;AAAA,EACA,eAAA;AAAA,EACA,cAAA;AAAA,EACA;AACF,CAAG,EAAA;AACD,EAAA,MAAM,MAAS,GAAA,MAAA,CAAO,MAAO,CAAA,YAAA,IAAgB,OAAO,MAAO,CAAA,MAAA;AAC3D,EAAM,MAAA,OAAA,GAAU,YAAY,OAAW,IAAA,KAAA;AAEvC,EAAA,IAAI,OAAS,EAAA;AACX,IAAQ,MAAA,EAAA,IAAA;AAAA,MACN,CAAA,4DAAA;AAAA,KACF;AAAA;AAIF,EAAO,MAAA,CAAA,EAAA,CAAG,EAAG,CAAA,SAAA,EAAW,YAAY;AAClC,IAAQ,MAAA,EAAA,IAAA;AAAA,MACN;AAAA,KACF;AAAA,GAED,CAAA;AAED,EAAA,IAAI,SAA0C,GAAA,IAAA;AAC9C,EAAA,IAAI,aAAqB,GAAA,IAAA;AAGzB,EAAA,MAAM,uBAAuB,MAAM;AACjC,IAAM,MAAA,OAAA,GAAU,UAAc,IAAA,IAAI,cAAe,EAAA;AAMjD,IAAA,MAAM,mBAAsB,GAAA,GAAA;AAC5B,IAAsB,qBAAA,CAAA,OAAA,CAAQ,OAAO,mBAAmB,CAAA;AACxD,IAAsB,qBAAA,CAAA,OAAA,CAAQ,OAAO,mBAAmB,CAAA;AACxD,IAAA,SAAA,CAAU,QAAQ,KAAK,CAAA;AACvB,IAAA,SAAA,CAAU,QAAQ,KAAK,CAAA;AACvB,IAAO,OAAA,OAAA;AAAA,GACN,GAAA;AAEH,EAAwB,uBAAA,CAAA;AAAA,IACtB,MAAA;AAAA,IACA,mBAAA;AAAA,IACA,WAAA;AAAA,IACA,SAAA;AAAA,IACA,UAAY,EAAA,mBAAA;AAAA,IACZ,cAAA;AAAA,IACA,cAAA;AAAA,IACA,eAAA,EAAiB,CAAC,MAAA,EAAa,OAAkC,KAAA;AAC/D,MAAgB,aAAA,GAAA,MAAA;AAChB,MAAA,IAAI,OAAS,EAAA;AACX,QAAY,SAAA,GAAA,OAAA;AAAA;AAEd,MAAA,IAAI,eAAiB,EAAA;AACnB,QAAA,eAAA,CAAgB,QAAQ,OAAO,CAAA;AAAA;AACjC;AACF,GACD,CAAA;AAGD,EAAO,OAAA;AAAA,IACL,OAAS,EAAA,SAAA;AAAA,IACT,aAAA,EAAe,CAAC,IAAA,EAAc,MAAsB,KAAA;AAClD,MAAA,IAAI,aAAe,EAAA;AAGjB,QAAA,MAAM,cAAiB,GAAA,IAAA,CAAK,OAAQ,CAAA,WAAA,CAAY,WAAe,IAAA,MAAA,CAAO,MAAO,CAAA,IAAA,EAAM,EAAE,CAAA,CAAE,OAAQ,CAAA,MAAA,EAAQ,EAAE,CAAA;AACzG,QAAA,aAAA,CAAc,WAAY,CAAA;AAAA,UACxB,IAAM,EAAA,YAAA;AAAA,UACN,EAAI,EAAA,cAAA;AAAA,UACJ,IAAM,EAAA,IAAA;AAAA,UACN,MAAA,EAAQ,UAAU,EAAC;AAAA,UACnB,SAAA,EAAW,KAAK,GAAI;AAAA,SACP,CAAA;AAMf,QAAA,OAAO,qCAAqC,CAAE,CAAA,IAAA,CAAK,CAAC,EAAE,wBAA6B,KAAA;AACjF,UAAuB,sBAAA,EAAA;AAAA,SACxB,CAAA;AAED,QAAA,IAAI,OAAS,EAAA;AACX,UAAQ,MAAA,EAAA,IAAA,CAAK,CAAiD,8CAAA,EAAA,IAAI,CAAgC,8BAAA,CAAA,CAAA;AAAA;AACpG;AACF;AACF,GACF;AACF;;;;"}
85
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"configureReactServer.client.js","sources":["../../../plugin/dev-server/configureReactServer.client.ts"],"sourcesContent":["import { configureRequestHandler } from \"./configureRequestHandler.client.js\";\nimport { MessageChannel } from \"node:worker_threads\";\nimport type { CreateReactWorkerServerFn } from \"./types.js\";\nimport { setMaxListenersOnPort, unrefPort } from \"../stream/setMaxListeners.js\";\n\n\n/**\n * Creates a React Worker Server that configures worker-based rendering\n * Sets up middleware, HMR, and worker management like react-client/plugin.client.ts\n */\nexport const configureReactServer: CreateReactWorkerServerFn =\n  function _createReactWorkerServer({\n    server,\n    autoDiscoveredFiles,\n    userOptions,\n    configEnv,\n    hmrChannel,\n    onWorkerCreated,\n    serverManifest,\n    resolvedConfig,\n  }) {\n    const logger = server.config.customLogger || server.config.logger;\n    const verbose = userOptions.verbose || false;\n\n    if (verbose) {\n      logger?.info(\n        `[createReactWorkerServer] Configuring worker-based rendering`\n      );\n    }\n\n    // Set up restart listener for worker cleanup\n    server.ws.on(\"restart\", async () => {\n      logger?.info(\n        \"[createReactWorkerServer] Server restarting, shutting down worker...\"\n      );\n      // Worker cleanup would be handled by the worker management\n    });\n\n    let restartFn: (() => Promise<void>) | null = null;\n    let currentWorker: any = null;\n\n    // Configure the worker request handler (sets up middleware)\n    const effectiveHmrChannel = (() => {\n      const channel = hmrChannel || new MessageChannel();\n      // Increase max listeners to prevent warnings during development\n      // This is a targeted fix for the memory leak warnings\n      // We need to set this on BOTH ports because listeners can be added to either side\n      // Use a high default (500) to accommodate large projects with many routes\n      // restartWorker will adjust this based on actual route count\n      const initialMaxListeners = 500;\n      setMaxListenersOnPort(channel.port1, initialMaxListeners);\n      setMaxListenersOnPort(channel.port2, initialMaxListeners);\n      unrefPort(channel.port1);\n      unrefPort(channel.port2);\n      return channel;\n    })();\n\n    configureRequestHandler({\n      server,\n      autoDiscoveredFiles,\n      userOptions,\n      configEnv,\n      hmrChannel: effectiveHmrChannel,\n      serverManifest,\n      resolvedConfig,\n      onWorkerCreated: (worker: any, restart?: () => Promise<void>) => {\n        currentWorker = worker;\n        if (restart) {\n          restartFn = restart;\n        }\n        if (onWorkerCreated) {\n          onWorkerCreated(worker, restart);\n        }\n      },\n    });\n    \n    // Return object with restart function and HMR update sender for hotUpdate\n    return {\n      restart: restartFn,\n      sendHmrUpdate: (file: string, routes?: string[]) => {\n        if (currentWorker) {\n          // CRITICAL: In development mode, HMR port is disabled, so send directly to worker\n          // Send HMR_UPDATE message to worker through parentPort (postMessage)\n          const normalizedPath = file.replace(userOptions.projectRoot || server.config.root, '').replace(/^\\/+/, '');\n          currentWorker.postMessage({\n            type: \"HMR_UPDATE\",\n            id: normalizedPath,\n            path: file,\n            routes: routes || [],\n            timestamp: Date.now(),\n          } satisfies any);\n          \n          // Mark that modules have been invalidated - worker will be restarted on next request\n          // This is necessary because Node.js caches ES modules and the only way to clear\n          // that cache is to restart the worker\n          // Use dynamic import to avoid circular dependency\n          import(\"./configureRequestHandler.client.js\").then(({ markModulesInvalidated }) => {\n            markModulesInvalidated();\n          });\n          \n          if (verbose) {\n            logger?.info(`[createReactWorkerServer] Sent HMR_UPDATE for ${file} to worker, marked for restart`);\n          }\n        }\n      },\n    };\n  };\n"],"names":[],"mappings":";;;;;;;;;AAUa,MAAA,oBAAA,GACX,SAAS,wBAAyB,CAAA;AAAA,EAChC,MAAA;AAAA,EACA,mBAAA;AAAA,EACA,WAAA;AAAA,EACA,SAAA;AAAA,EACA,UAAA;AAAA,EACA,eAAA;AAAA,EACA,cAAA;AAAA,EACA;AACF,CAAG,EAAA;AACD,EAAA,MAAM,MAAS,GAAA,MAAA,CAAO,MAAO,CAAA,YAAA,IAAgB,OAAO,MAAO,CAAA,MAAA;AAC3D,EAAM,MAAA,OAAA,GAAU,YAAY,OAAW,IAAA,KAAA;AAEvC,EAAA,IAAI,OAAS,EAAA;AACX,IAAQ,MAAA,EAAA,IAAA;AAAA,MACN,CAAA,4DAAA;AAAA,KACF;AAAA;AAIF,EAAO,MAAA,CAAA,EAAA,CAAG,EAAG,CAAA,SAAA,EAAW,YAAY;AAClC,IAAQ,MAAA,EAAA,IAAA;AAAA,MACN;AAAA,KACF;AAAA,GAED,CAAA;AAED,EAAA,IAAI,SAA0C,GAAA,IAAA;AAC9C,EAAA,IAAI,aAAqB,GAAA,IAAA;AAGzB,EAAA,MAAM,uBAAuB,MAAM;AACjC,IAAM,MAAA,OAAA,GAAU,UAAc,IAAA,IAAI,cAAe,EAAA;AAMjD,IAAA,MAAM,mBAAsB,GAAA,GAAA;AAC5B,IAAsB,qBAAA,CAAA,OAAA,CAAQ,OAAO,mBAAmB,CAAA;AACxD,IAAsB,qBAAA,CAAA,OAAA,CAAQ,OAAO,mBAAmB,CAAA;AACxD,IAAA,SAAA,CAAU,QAAQ,KAAK,CAAA;AACvB,IAAA,SAAA,CAAU,QAAQ,KAAK,CAAA;AACvB,IAAO,OAAA,OAAA;AAAA,GACN,GAAA;AAEH,EAAwB,uBAAA,CAAA;AAAA,IACtB,MAAA;AAAA,IACA,mBAAA;AAAA,IACA,WAAA;AAAA,IACA,SAAA;AAAA,IACA,UAAY,EAAA,mBAAA;AAAA,IACZ,cAAA;AAAA,IACA,cAAA;AAAA,IACA,eAAA,EAAiB,CAAC,MAAA,EAAa,OAAkC,KAAA;AAC/D,MAAgB,aAAA,GAAA,MAAA;AAChB,MAAA,IAAI,OAAS,EAAA;AACX,QAAY,SAAA,GAAA,OAAA;AAAA;AAEd,MAAA,IAAI,eAAiB,EAAA;AACnB,QAAA,eAAA,CAAgB,QAAQ,OAAO,CAAA;AAAA;AACjC;AACF,GACD,CAAA;AAGD,EAAO,OAAA;AAAA,IACL,OAAS,EAAA,SAAA;AAAA,IACT,aAAA,EAAe,CAAC,IAAA,EAAc,MAAsB,KAAA;AAClD,MAAA,IAAI,aAAe,EAAA;AAGjB,QAAA,MAAM,cAAiB,GAAA,IAAA,CAAK,OAAQ,CAAA,WAAA,CAAY,WAAe,IAAA,MAAA,CAAO,MAAO,CAAA,IAAA,EAAM,EAAE,CAAA,CAAE,OAAQ,CAAA,MAAA,EAAQ,EAAE,CAAA;AACzG,QAAA,aAAA,CAAc,WAAY,CAAA;AAAA,UACxB,IAAM,EAAA,YAAA;AAAA,UACN,EAAI,EAAA,cAAA;AAAA,UACJ,IAAM,EAAA,IAAA;AAAA,UACN,MAAA,EAAQ,UAAU,EAAC;AAAA,UACnB,SAAA,EAAW,KAAK,GAAI;AAAA,SACP,CAAA;AAMf,QAAA,OAAO,qCAAqC,CAAE,CAAA,IAAA,CAAK,CAAC,EAAE,wBAA6B,KAAA;AACjF,UAAuB,sBAAA,EAAA;AAAA,SACxB,CAAA;AAED,QAAA,IAAI,OAAS,EAAA;AACX,UAAQ,MAAA,EAAA,IAAA,CAAK,CAAiD,8CAAA,EAAA,IAAI,CAAgC,8BAAA,CAAA,CAAA;AAAA;AACpG;AACF;AACF,GACF;AACF;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"plugin.client.d.ts","sourceRoot":"","sources":["../../../plugin/dev-server/plugin.client.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAMnD;;;GAGG;AACH,eAAO,MAAM,wBAAwB,EAAE,YA+JtC,CAAC"}
1
+ {"version":3,"file":"plugin.client.d.ts","sourceRoot":"","sources":["../../../plugin/dev-server/plugin.client.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAMnD;;;GAGG;AACH,eAAO,MAAM,wBAAwB,EAAE,YAuJtC,CAAC"}
@@ -28,8 +28,7 @@ const vitePluginReactDevServer = function _vitePluginReactServerDevClient(option
28
28
  name: "vite-plugin-react-server:dev-server-client",
29
29
  apply: "serve",
30
30
  // Only apply in dev server mode
31
- // Note: Removed applyToEnvironment - handleHotUpdate needs to run regardless
32
- // The plugin should apply to client environment, but handleHotUpdate is a dev server hook
31
+ // No applyToEnvironment hotUpdate needs to run for all environments
33
32
  // that should work regardless of environment filtering
34
33
  config(_config, viteConfigEnv) {
35
34
  configEnv = viteConfigEnv;
@@ -61,7 +60,10 @@ const vitePluginReactDevServer = function _vitePluginReactServerDevClient(option
61
60
  resolvedConfig: server.config
62
61
  });
63
62
  },
64
- handleHotUpdate({ file, server }) {
63
+ hotUpdate(ctx) {
64
+ const { file, server } = ctx;
65
+ const envName = ctx.environment?.name ?? "unknown";
66
+ if (envName !== "client") return;
65
67
  if (isProcessingHmr) {
66
68
  return void 0;
67
69
  }
@@ -78,20 +80,11 @@ const vitePluginReactDevServer = function _vitePluginReactServerDevClient(option
78
80
  }
79
81
  })();
80
82
  const isServerFile = isSourceFile && !isClientFile;
81
- server.config.logger.info(`[vite-plugin-react-server] handleHotUpdate: file=${file}, normalized=${normalizedFile}, isServerFile=${isServerFile}, isClientFile=${isClientFile}, hasHandler=${!!hmrHandler}`);
82
83
  if (isServerFile && hmrHandler) {
83
84
  isProcessingHmr = true;
84
85
  try {
85
86
  server.config.logger.info(`[vite-plugin-react-server] File changed: ${file}, sending HMR update...`);
86
87
  hmrHandler.sendHmrUpdate(file);
87
- server.ws.send({
88
- type: "custom",
89
- event: "vite-plugin-react-server:server-component-update",
90
- data: {
91
- file: normalizedFile,
92
- path: file
93
- }
94
- });
95
88
  if (hmrHandler.restart) {
96
89
  if (restartTimeout) {
97
90
  clearTimeout(restartTimeout);
@@ -123,10 +116,9 @@ const vitePluginReactDevServer = function _vitePluginReactServerDevClient(option
123
116
  } else if (isServerFile && !hmrHandler) {
124
117
  server.config.logger.warn(`[vite-plugin-react-server] Server file changed but HMR handler not available yet: ${file}`);
125
118
  }
126
- return void 0;
127
119
  }
128
120
  };
129
121
  };
130
122
 
131
123
  export { vitePluginReactDevServer };
132
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"plugin.client.js","sources":["../../../plugin/dev-server/plugin.client.ts"],"sourcesContent":["import { readFileSync } from \"node:fs\";\nimport type { VitePluginFn } from \"../../types.js\";\nimport { configureReactServer } from \"./configureReactServer.client.js\";\nimport { resolveOptions } from \"../config/resolveOptions.js\";\nimport type { ConfigEnv } from \"vite\";\n\n\n/**\n * Dev server plugin for client environment.\n * Uses configureServer hook for proper dev server setup.\n */\nexport const vitePluginReactDevServer: VitePluginFn = function _vitePluginReactServerDevClient(options) {\n  if (options == null) {\n    throw new Error(\"options is required\");\n  }\n\n  if (options.verbose) {\n  }\n  \n  const resolvedOptions = resolveOptions(options);\n  if (resolvedOptions.type === \"error\") {\n    if (resolvedOptions.error != null) {\n      throw resolvedOptions.error;\n    }\n    throw new Error(\"Failed to resolve options\");\n  }\n  const userOptions = resolvedOptions.userOptions;\n  \n\n  let configEnv: ConfigEnv | undefined;\n  let hmrHandler: { restart: (() => Promise<void>) | null; sendHmrUpdate: (file: string, routes?: string[]) => void } | null = null;\n  let isProcessingHmr = false; // Prevent recursive HMR updates\n  let restartTimeout: NodeJS.Timeout | null = null; // Debounce worker restarts\n\n  return {\n    name: \"vite-plugin-react-server:dev-server-client\",\n    apply: \"serve\", // Only apply in dev server mode\n    // Note: Removed applyToEnvironment - handleHotUpdate needs to run regardless\n    // The plugin should apply to client environment, but handleHotUpdate is a dev server hook\n    // that should work regardless of environment filtering\n    config(_config, viteConfigEnv) {\n      configEnv = viteConfigEnv;\n  \n    },\n    configureServer(server) {      \n      // Log that plugin is being configured\n      server.config.logger.info(`[vite-plugin-react-server] Dev server plugin configured for client environment`);\n      \n      // Configure the React server for client environment (worker-based)\n      // This uses the existing configureReactServer.client.js implementation\n      hmrHandler = configureReactServer({\n        server,\n        autoDiscoveredFiles: {\n          propsMap: new Map(),\n          pageMap: new Map(),\n          rootMap: new Map(),\n          htmlMap: new Map(),\n          routeMap: new Map(),\n          urlMap: new Map(),\n          errors: [],\n          workerPaths: {},\n          serverEntry: null,\n          clientEntry: {},\n          clientInputs: {},\n          staticInputs: {},\n          serverInputs: {},\n          // staticManifest removed from AutoDiscoveredFiles\n          serverActions: {},\n        },\n        userOptions,\n        configEnv: configEnv!,\n        serverManifest: {}, \n        resolvedConfig: server.config,\n      });\n    },\n    handleHotUpdate({ file, server }) {\n      // Prevent recursive HMR updates\n      if (isProcessingHmr) {\n        return undefined;\n      }\n      \n      // Handle server component file changes\n      const moduleBase = userOptions.moduleBase || \"src\";\n      const projectRoot = userOptions.projectRoot || server.config.root;\n      \n      // Normalize paths for comparison (handle both absolute and relative)\n      const normalizedFile = file.replace(projectRoot, '').replace(/^\\/+/, '');\n      const isSourceFile = normalizedFile.startsWith(moduleBase + '/') && \n        (file.endsWith('.tsx') || file.endsWith('.ts') || file.endsWith('.jsx') || file.endsWith('.js'));\n      \n      // Skip client components — let @vitejs/plugin-react handle them with Fast Refresh\n      const isClientFile = isSourceFile && (() => {\n        try {\n          const head = readFileSync(file, 'utf-8').slice(0, 200);\n          return /^\\s*[\"']use client[\"']/.test(head.split('\\n')[0]);\n        } catch { return false; }\n      })();\n      \n      const isServerFile = isSourceFile && !isClientFile;\n      \n      // Always log for debugging\n      server.config.logger.info(`[vite-plugin-react-server] handleHotUpdate: file=${file}, normalized=${normalizedFile}, isServerFile=${isServerFile}, isClientFile=${isClientFile}, hasHandler=${!!hmrHandler}`);\n      \n      if (isServerFile && hmrHandler) {\n        isProcessingHmr = true;\n        \n        try {\n          server.config.logger.info(`[vite-plugin-react-server] File changed: ${file}, sending HMR update...`);\n          \n          // CRITICAL: Send HMR_UPDATE message to worker to invalidate modules\n          // This clears component caches, but Node.js's ES module cache persists\n          hmrHandler.sendHmrUpdate(file);\n          \n          // CRITICAL: Send custom HMR message to client via WebSocket\n          // Server components aren't in the client bundle, so vite:beforeUpdate doesn't fire\n          // We need to manually notify the client to refetch the RSC stream\n          server.ws.send({\n            type: 'custom',\n            event: 'vite-plugin-react-server:server-component-update',\n            data: {\n              file: normalizedFile,\n              path: file,\n            },\n          });\n          \n          // CRITICAL: Node.js caches ES modules, so we need to restart the worker\n          // to clear the module cache. Debounce restarts to prevent recursion.\n          if (hmrHandler.restart) {\n            // Clear any pending restart\n            if (restartTimeout) {\n              clearTimeout(restartTimeout);\n            }\n            \n            // Debounce worker restart to prevent recursion\n            // Wait 500ms after the last file change before restarting\n            restartTimeout = setTimeout(async () => {\n              try {\n                server.config.logger.info(`[vite-plugin-react-server] Restarting worker to clear Node.js module cache...`);\n                await hmrHandler!.restart!();\n                server.config.logger.info(`[vite-plugin-react-server] Worker restarted successfully`);\n              } catch (error) {\n                server.config.logger.error(`[vite-plugin-react-server] Failed to restart worker: ${error}`);\n              } finally {\n                restartTimeout = null;\n                // Reset flag after restart completes\n                setTimeout(() => {\n                  isProcessingHmr = false;\n                }, 100);\n              }\n            }, 500); // 500ms debounce\n          } else {\n            // No restart function available yet - worker hasn't been created\n            // This is expected if handleHotUpdate fires before the first request\n            server.config.logger.warn(`[vite-plugin-react-server] Restart function not available yet - worker will be created on next request`);\n            setTimeout(() => {\n              isProcessingHmr = false;\n            }, 100);\n          }\n        } catch (error) {\n          server.config.logger.error(`[vite-plugin-react-server] Error handling HMR update: ${error}`);\n          isProcessingHmr = false;\n        }\n      } else if (isServerFile && !hmrHandler) {\n        server.config.logger.warn(`[vite-plugin-react-server] Server file changed but HMR handler not available yet: ${file}`);\n      }\n      \n      // Return undefined to allow other plugins to handle the update\n      return undefined;\n    },\n  };\n};\n"],"names":[],"mappings":"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"}
124
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"plugin.client.js","sources":["../../../plugin/dev-server/plugin.client.ts"],"sourcesContent":["import { readFileSync } from \"node:fs\";\nimport type { VitePluginFn } from \"../../types.js\";\nimport { configureReactServer } from \"./configureReactServer.client.js\";\nimport { resolveOptions } from \"../config/resolveOptions.js\";\nimport type { ConfigEnv } from \"vite\";\n\n\n/**\n * Dev server plugin for client environment.\n * Uses configureServer hook for proper dev server setup.\n */\nexport const vitePluginReactDevServer: VitePluginFn = function _vitePluginReactServerDevClient(options) {\n  if (options == null) {\n    throw new Error(\"options is required\");\n  }\n\n  if (options.verbose) {\n  }\n  \n  const resolvedOptions = resolveOptions(options);\n  if (resolvedOptions.type === \"error\") {\n    if (resolvedOptions.error != null) {\n      throw resolvedOptions.error;\n    }\n    throw new Error(\"Failed to resolve options\");\n  }\n  const userOptions = resolvedOptions.userOptions;\n  \n\n  let configEnv: ConfigEnv | undefined;\n  let hmrHandler: { restart: (() => Promise<void>) | null; sendHmrUpdate: (file: string, routes?: string[]) => void } | null = null;\n  let isProcessingHmr = false; // Prevent recursive HMR updates\n  let restartTimeout: NodeJS.Timeout | null = null; // Debounce worker restarts\n\n  return {\n    name: \"vite-plugin-react-server:dev-server-client\",\n    apply: \"serve\", // Only apply in dev server mode\n    // No applyToEnvironment — hotUpdate needs to run for all environments\n    // that should work regardless of environment filtering\n    config(_config, viteConfigEnv) {\n      configEnv = viteConfigEnv;\n  \n    },\n    configureServer(server) {      \n      // Log that plugin is being configured\n      server.config.logger.info(`[vite-plugin-react-server] Dev server plugin configured for client environment`);\n      \n      // Configure the React server for client environment (worker-based)\n      // This uses the existing configureReactServer.client.js implementation\n      hmrHandler = configureReactServer({\n        server,\n        autoDiscoveredFiles: {\n          propsMap: new Map(),\n          pageMap: new Map(),\n          rootMap: new Map(),\n          htmlMap: new Map(),\n          routeMap: new Map(),\n          urlMap: new Map(),\n          errors: [],\n          workerPaths: {},\n          serverEntry: null,\n          clientEntry: {},\n          clientInputs: {},\n          staticInputs: {},\n          serverInputs: {},\n          // staticManifest removed from AutoDiscoveredFiles\n          serverActions: {},\n        },\n        userOptions,\n        configEnv: configEnv!,\n        serverManifest: {}, \n        resolvedConfig: server.config,\n      });\n    },\n    hotUpdate(ctx: any) {\n      const { file, server } = ctx;\n      const envName = ctx.environment?.name ?? 'unknown';\n      \n      // Only run worker invalidation from the client environment (once per change)\n      if (envName !== 'client') return;\n      \n      // Prevent recursive HMR updates\n      if (isProcessingHmr) {\n        return undefined;\n      }\n      \n      // Handle server component file changes\n      const moduleBase = userOptions.moduleBase || \"src\";\n      const projectRoot = userOptions.projectRoot || server.config.root;\n      \n      // Normalize paths for comparison (handle both absolute and relative)\n      const normalizedFile = file.replace(projectRoot, '').replace(/^\\/+/, '');\n      const isSourceFile = normalizedFile.startsWith(moduleBase + '/') && \n        (file.endsWith('.tsx') || file.endsWith('.ts') || file.endsWith('.jsx') || file.endsWith('.js'));\n      \n      // Skip client components — let @vitejs/plugin-react handle them with Fast Refresh\n      const isClientFile = isSourceFile && (() => {\n        try {\n          const head = readFileSync(file, 'utf-8').slice(0, 200);\n          return /^\\s*[\"']use client[\"']/.test(head.split('\\n')[0]);\n        } catch { return false; }\n      })();\n      \n      const isServerFile = isSourceFile && !isClientFile;\n      \n      if (isServerFile && hmrHandler) {\n        isProcessingHmr = true;\n        \n        try {\n          server.config.logger.info(`[vite-plugin-react-server] File changed: ${file}, sending HMR update...`);\n          \n          // CRITICAL: Send HMR_UPDATE message to worker to invalidate modules\n          // This clears component caches, but Node.js's ES module cache persists\n          hmrHandler.sendHmrUpdate(file);\n          \n          // NOTE: The WS event to notify the client is sent by the hotUpdate hook\n          // in plugin.server.ts — don't duplicate it here.\n          \n          // CRITICAL: Node.js caches ES modules, so we need to restart the worker\n          // to clear the module cache. Debounce restarts to prevent recursion.\n          if (hmrHandler.restart) {\n            // Clear any pending restart\n            if (restartTimeout) {\n              clearTimeout(restartTimeout);\n            }\n            \n            // Debounce worker restart to prevent recursion\n            // Wait 500ms after the last file change before restarting\n            restartTimeout = setTimeout(async () => {\n              try {\n                server.config.logger.info(`[vite-plugin-react-server] Restarting worker to clear Node.js module cache...`);\n                await hmrHandler!.restart!();\n                server.config.logger.info(`[vite-plugin-react-server] Worker restarted successfully`);\n              } catch (error) {\n                server.config.logger.error(`[vite-plugin-react-server] Failed to restart worker: ${error}`);\n              } finally {\n                restartTimeout = null;\n                // Reset flag after restart completes\n                setTimeout(() => {\n                  isProcessingHmr = false;\n                }, 100);\n              }\n            }, 500); // 500ms debounce\n          } else {\n            // No restart function available yet - worker hasn't been created\n            // This is expected if hotUpdate fires before the first request\n            server.config.logger.warn(`[vite-plugin-react-server] Restart function not available yet - worker will be created on next request`);\n            setTimeout(() => {\n              isProcessingHmr = false;\n            }, 100);\n          }\n        } catch (error) {\n          server.config.logger.error(`[vite-plugin-react-server] Error handling HMR update: ${error}`);\n          isProcessingHmr = false;\n        }\n      } else if (isServerFile && !hmrHandler) {\n        server.config.logger.warn(`[vite-plugin-react-server] Server file changed but HMR handler not available yet: ${file}`);\n      }\n      \n      // Don't suppress — plugin.server.ts hotUpdate handles page reload prevention\n    },\n  };\n};\n"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"requestInfo.d.ts","sourceRoot":"","sources":["../../../plugin/helpers/requestInfo.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AACxD,OAAO,EAAE,KAAK,OAAO,EAAE,MAAM,MAAM,CAAC;AAKpC;;;;;;;;;GASG;AACH,wBAAgB,WAAW,CACzB,GAAG,EAAE,OAAO,CAAC,eAAe,EAC5B,cAAc,EAAE,IAAI,CAClB,oBAAoB,EAClB,YAAY,GACZ,OAAO,GACP,cAAc,GACd,SAAS,GACT,gBAAgB,GAChB,eAAe,GACf,SAAS,GACT,QAAQ,CACX,EACD,OAAO,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA0MhB"}
1
+ {"version":3,"file":"requestInfo.d.ts","sourceRoot":"","sources":["../../../plugin/helpers/requestInfo.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AACxD,OAAO,EAAE,KAAK,OAAO,EAAE,MAAM,MAAM,CAAC;AAKpC;;;;;;;;;GASG;AACH,wBAAgB,WAAW,CACzB,GAAG,EAAE,OAAO,CAAC,eAAe,EAC5B,cAAc,EAAE,IAAI,CAClB,oBAAoB,EAClB,YAAY,GACZ,OAAO,GACP,cAAc,GACd,SAAS,GACT,gBAAgB,GAChB,eAAe,GACf,SAAS,GACT,QAAQ,CACX,EACD,OAAO,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA6MhB"}
@@ -47,6 +47,7 @@ function requestInfo(req, handlerOptions, hostDir) {
47
47
  const hasJsonHeader = req.headers["accept"]?.includes("application/json");
48
48
  const hasHtmlHeader = req.headers.accept?.includes("text/html");
49
49
  const hasRscHeader = req.headers.accept?.includes("text/x-component");
50
+ const hasRscQueryParam = /[?&]_rsc\b/.test(req.url || "");
50
51
  const hasCssHeader = req.headers.accept?.includes("text/css");
51
52
  const isFolder = !ext;
52
53
  const isFormContentType = req.headers["content-type"]?.includes(
@@ -58,8 +59,8 @@ function requestInfo(req, handlerOptions, hostDir) {
58
59
  const isFormActionRequest = !isServerActionRequest && (req.method === "POST" || isFormContentType && req.headers["sec-fetch-dest"] === "document" && req.headers["sec-fetch-mode"] === "navigate");
59
60
  const isJsRequest = !isFormActionRequest && !isJson && !isHtml && !isCss && !isRsc && (isJS || hasJsHeader);
60
61
  const isJsonRequest = isJson || hasJsonHeader && !isJsRequest;
61
- const isHtmlRequest = isHtml || hasHtmlHeader || isFolder && !hasRscHeader && !isRsc && !isJsRequest && !isFormActionRequest;
62
- const isRscRequest = !isJsRequest && !isHtmlRequest && (isRsc || hasRscHeader);
62
+ const isHtmlRequest = !hasRscQueryParam && (isHtml || hasHtmlHeader || isFolder && !hasRscHeader && !hasRscQueryParam && !isRsc && !isJsRequest && !isFormActionRequest);
63
+ const isRscRequest = hasRscQueryParam || !isJsRequest && !isHtmlRequest && (isRsc || hasRscHeader);
63
64
  const isCssRequest = !isHtmlRequest && !isRscRequest && !isJsRequest && !isJsonRequest && (isCss || hasCssHeader);
64
65
  const routeForFilePath = value;
65
66
  let filePath = resolve(hostDir, routeForFilePath);
@@ -159,4 +160,4 @@ function requestInfo(req, handlerOptions, hostDir) {
159
160
  }
160
161
 
161
162
  export { requestInfo };
162
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"requestInfo.js","sources":["../../../plugin/helpers/requestInfo.ts"],"sourcesContent":["import { resolve } from \"node:path\";\nimport type { CreateHandlerOptions } from \"../types.js\";\nimport { type Connect } from \"vite\";\nimport { MIME_TYPES } from \"../config/mimeTypes.js\";\nimport { requestToRoute } from \"./requestToRoute.js\";\nimport { routeToURL } from \"../utils/routeToURL.js\";\n\n/**\n * # Request info\n *\n * Does the initial work to check if the request is for html, rsc, json, js, css, server-action, or something else not handled by this plugin.\n *\n * @param req\n * @param handlerOptions\n * @param hostDir\n * @returns\n */\nexport function requestInfo(\n  req: Connect.IncomingMessage,\n  handlerOptions: Pick<\n    CreateHandlerOptions,\n    | \"normalizer\"\n    | \"build\"\n    | \"autoDiscover\"\n    | \"verbose\"\n    | \"moduleBasePath\"\n    | \"moduleBaseURL\"\n    | \"verbose\"\n    | \"logger\"\n  >,\n  hostDir: string,\n) {\n  const route = requestToRoute(req, {\n    moduleBasePath: handlerOptions.moduleBasePath,\n    moduleBaseURL: handlerOptions.moduleBaseURL,\n    build: handlerOptions.build,\n  });\n\n  if (!route) {\n    return {\n      route: \"/\",\n      url: routeToURL(\"/\", handlerOptions.moduleBaseURL, handlerOptions.build.rscOutputPath),\n      ext: \"\",\n    };\n  }\n\n  // Use the cleaned route for normalization, not the raw req.url\n  // This ensures base URL is properly stripped before normalization\n  const [, value] = handlerOptions.normalizer(route);\n  if (handlerOptions.verbose) {\n    if (value && value !== \"\") {\n      handlerOptions.logger.info(`[requestInfo] Value: \\\"${value}\\\"`);\n    }\n    if (hostDir && hostDir !== \"\") {\n      handlerOptions.logger.info(`[requestInfo] Host Dir: \\\"${hostDir}\\\"`);\n    }\n    if (req.url && req.url !== \"\") {\n      handlerOptions.logger.info(`[requestInfo] Request URL: \\\"${req.url}\\\"`);\n    }\n  }\n\n  const dotIndex = value.lastIndexOf(\".\");\n  const ext = dotIndex === -1 ? \"\" : value.slice(dotIndex);\n  // handle index.html\n  const isVendor = handlerOptions.autoDiscover.vendorPattern.test(value);\n  const isVirtual = handlerOptions.autoDiscover.virtualPattern.test(value);\n  const isJS = handlerOptions.autoDiscover.modulePattern.test(value);\n  const isHtml = handlerOptions.autoDiscover.htmlPattern.test(value);\n  const isCss = handlerOptions.autoDiscover.cssPattern.test(value);\n  const isJson = handlerOptions.autoDiscover.jsonPattern.test(value);\n  const isRsc = handlerOptions.autoDiscover.rscPattern.test(value);\n  const hasJsHeader =\n    req.headers[\"sec-fetch-dest\"] === \"script\" ||\n    req.headers[\"accept\"]?.includes(\"*/*\") ||\n    req.headers[\"accept\"]?.includes(\"text/javascript\");\n  const hasJsonHeader = req.headers[\"accept\"]?.includes(\"application/json\");\n  const hasHtmlHeader = req.headers.accept?.includes(\"text/html\");\n  const hasRscHeader = req.headers.accept?.includes(\"text/x-component\");\n  const hasCssHeader = req.headers.accept?.includes(\"text/css\");\n  const isFolder = !ext;\n  const isFormContentType =\n    req.headers[\"content-type\"]?.includes(\n      \"application/x-www-form-urlencoded\"\n    ) || !!req.headers[\"content-type\"]?.includes(\"multipart/form-data\");\n\n  // Server action detection\n  const hasRscActionHeader = !!req.headers[\"x-rsc-action\"];\n  const hasServerActionHeaders =\n    req.method === \"POST\" &&\n    (hasRscActionHeader || (\n      (req.headers[\"sec-fetch-dest\"] === \"empty\" ||\n        req.headers[\"sec-fetch-dest\"] === \"\") &&\n      req.headers[\"sec-fetch-mode\"] === \"cors\"\n    ));\n  const isServerActionRequest = hasServerActionHeaders;\n\n  const isFormActionRequest =\n    !isServerActionRequest &&\n    (req.method === \"POST\" ||\n      (isFormContentType &&\n        req.headers[\"sec-fetch-dest\"] === \"document\" &&\n        req.headers[\"sec-fetch-mode\"] === \"navigate\"));\n\n  const isJsRequest =\n    !isFormActionRequest &&\n    !isJson &&\n    !isHtml &&\n    !isCss &&\n    !isRsc &&\n    (isJS || hasJsHeader);\n  const isJsonRequest = isJson || (hasJsonHeader && !isJsRequest);\n  // Form action detection\n\n  const isHtmlRequest =\n    isHtml ||\n    hasHtmlHeader ||\n    (isFolder &&\n      !hasRscHeader &&\n      !isRsc &&\n      !isJsRequest &&\n      !isFormActionRequest);\n  const isRscRequest =\n    !isJsRequest && !isHtmlRequest && (isRsc || hasRscHeader);\n  const isCssRequest =\n    !isHtmlRequest &&\n    !isRscRequest &&\n    !isJsRequest &&\n    !isJsonRequest &&\n    (isCss || hasCssHeader);\n\n  // Use the normalized value for file path construction\n  // The normalizer should have already stripped base URLs properly\n  const routeForFilePath = value;\n\n  let filePath = resolve(hostDir, routeForFilePath);\n  let contentType;\n  if (isServerActionRequest) {\n    // For server actions, we'll get the actual file path from the request body\n    // The route is just a placeholder\n    filePath = resolve(hostDir, routeForFilePath);\n    contentType = \"application/json; charset=utf-8\";\n  } else if (isHtmlRequest) {\n    if (!isHtml) {\n      filePath = resolve(\n        hostDir,\n        routeForFilePath,\n        handlerOptions.build.htmlOutputPath\n      );\n    }\n    contentType = \"text/html; charset=utf-8\";\n  } else if (isRscRequest) {\n    if (!isRsc) {\n      // Value doesn't end with .rsc, append the rsc output path\n      filePath = resolve(\n        hostDir,\n        routeForFilePath,\n        handlerOptions.build.rscOutputPath\n      );\n    }\n    contentType = \"text/x-component; charset=utf-8\";\n  } else if (isCssRequest) {\n    if (!isCss) {\n      filePath = resolve(hostDir, routeForFilePath + \".css\");\n    }\n    contentType = \"text/css; charset=utf-8\";\n  } else if (isJsRequest) {\n    if (!isJS) {\n      filePath = resolve(hostDir, routeForFilePath + \".js\");\n    }\n    contentType = \"application/javascript; charset=utf-8\";\n  } else if (isJsonRequest) {\n    if (!isJson) {\n      filePath = resolve(hostDir, routeForFilePath + \".json\");\n    }\n    contentType = \"application/json; charset=utf-8\";\n  } else {\n    const mimeType = MIME_TYPES[ext];\n    if (mimeType) {\n      contentType = mimeType + \"; charset=utf-8\";\n    } else {\n      contentType = \"application/octet-stream; charset=utf-8\";\n    }\n  }\n\n  if (handlerOptions.verbose) {\n    if (isFormActionRequest) {\n      handlerOptions.logger.info(`[react-dev-server] (form-action) ${route}`);\n    } else if (isServerActionRequest) {\n      handlerOptions.logger.info(`[react-dev-server] (server-action) ${route}`);\n    } else if (isHtmlRequest) {\n      handlerOptions.logger.info(`[react-dev-server] (html) ${route}`);\n    } else if (isRscRequest) {\n      handlerOptions.logger.info(`[react-dev-server] (rsc) ${route}`);\n    } else if (isCssRequest) {\n      handlerOptions.logger.info(`[react-dev-server] (css) ${route}`);\n    } else if (isJsRequest) {\n      handlerOptions.logger.info(`[react-dev-server] (js) ${route}`);\n    } else if (isJsonRequest) {\n      handlerOptions.logger.info(`[react-dev-server] (json) ${route}`);\n    } else {\n      handlerOptions.logger.info(`[react-dev-server] (other) ${route}`);\n    }\n  }\n  return {\n    route,\n    url: routeToURL(route, handlerOptions.moduleBaseURL, handlerOptions.build.rscOutputPath),\n    ext,\n    isHtmlRequest,\n    isRscRequest,\n    isCssRequest,\n    isCss,\n    isHtml,\n    isRsc,\n    isFolder,\n    contentType,\n    filePath,\n    isJS,\n    isVendor,\n    isVirtual,\n    hasJsHeader,\n    isJsRequest,\n    isJson,\n    isJsonRequest,\n    hasCssHeader,\n    hasJsonHeader,\n    hasHtmlHeader,\n    hasRscHeader,\n    hasServerActionHeaders,\n    isServerActionRequest,\n    isFormContentType,\n    isFormActionRequest,\n  };\n}\n"],"names":[],"mappings":"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"}
163
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"requestInfo.js","sources":["../../../plugin/helpers/requestInfo.ts"],"sourcesContent":["import { resolve } from \"node:path\";\nimport type { CreateHandlerOptions } from \"../types.js\";\nimport { type Connect } from \"vite\";\nimport { MIME_TYPES } from \"../config/mimeTypes.js\";\nimport { requestToRoute } from \"./requestToRoute.js\";\nimport { routeToURL } from \"../utils/routeToURL.js\";\n\n/**\n * # Request info\n *\n * Does the initial work to check if the request is for html, rsc, json, js, css, server-action, or something else not handled by this plugin.\n *\n * @param req\n * @param handlerOptions\n * @param hostDir\n * @returns\n */\nexport function requestInfo(\n  req: Connect.IncomingMessage,\n  handlerOptions: Pick<\n    CreateHandlerOptions,\n    | \"normalizer\"\n    | \"build\"\n    | \"autoDiscover\"\n    | \"verbose\"\n    | \"moduleBasePath\"\n    | \"moduleBaseURL\"\n    | \"verbose\"\n    | \"logger\"\n  >,\n  hostDir: string,\n) {\n  const route = requestToRoute(req, {\n    moduleBasePath: handlerOptions.moduleBasePath,\n    moduleBaseURL: handlerOptions.moduleBaseURL,\n    build: handlerOptions.build,\n  });\n\n  if (!route) {\n    return {\n      route: \"/\",\n      url: routeToURL(\"/\", handlerOptions.moduleBaseURL, handlerOptions.build.rscOutputPath),\n      ext: \"\",\n    };\n  }\n\n  // Use the cleaned route for normalization, not the raw req.url\n  // This ensures base URL is properly stripped before normalization\n  const [, value] = handlerOptions.normalizer(route);\n  if (handlerOptions.verbose) {\n    if (value && value !== \"\") {\n      handlerOptions.logger.info(`[requestInfo] Value: \\\"${value}\\\"`);\n    }\n    if (hostDir && hostDir !== \"\") {\n      handlerOptions.logger.info(`[requestInfo] Host Dir: \\\"${hostDir}\\\"`);\n    }\n    if (req.url && req.url !== \"\") {\n      handlerOptions.logger.info(`[requestInfo] Request URL: \\\"${req.url}\\\"`);\n    }\n  }\n\n  const dotIndex = value.lastIndexOf(\".\");\n  const ext = dotIndex === -1 ? \"\" : value.slice(dotIndex);\n  // handle index.html\n  const isVendor = handlerOptions.autoDiscover.vendorPattern.test(value);\n  const isVirtual = handlerOptions.autoDiscover.virtualPattern.test(value);\n  const isJS = handlerOptions.autoDiscover.modulePattern.test(value);\n  const isHtml = handlerOptions.autoDiscover.htmlPattern.test(value);\n  const isCss = handlerOptions.autoDiscover.cssPattern.test(value);\n  const isJson = handlerOptions.autoDiscover.jsonPattern.test(value);\n  const isRsc = handlerOptions.autoDiscover.rscPattern.test(value);\n  const hasJsHeader =\n    req.headers[\"sec-fetch-dest\"] === \"script\" ||\n    req.headers[\"accept\"]?.includes(\"*/*\") ||\n    req.headers[\"accept\"]?.includes(\"text/javascript\");\n  const hasJsonHeader = req.headers[\"accept\"]?.includes(\"application/json\");\n  const hasHtmlHeader = req.headers.accept?.includes(\"text/html\");\n  const hasRscHeader = req.headers.accept?.includes(\"text/x-component\");\n  // Support ?_rsc query param (e.g. /?_rsc for browser debugging) as alternative to Accept header (useful for browser debugging)\n  const hasRscQueryParam = /[?&]_rsc\\b/.test(req.url || \"\");\n  const hasCssHeader = req.headers.accept?.includes(\"text/css\");\n  const isFolder = !ext;\n  const isFormContentType =\n    req.headers[\"content-type\"]?.includes(\n      \"application/x-www-form-urlencoded\"\n    ) || !!req.headers[\"content-type\"]?.includes(\"multipart/form-data\");\n\n  // Server action detection\n  const hasRscActionHeader = !!req.headers[\"x-rsc-action\"];\n  const hasServerActionHeaders =\n    req.method === \"POST\" &&\n    (hasRscActionHeader || (\n      (req.headers[\"sec-fetch-dest\"] === \"empty\" ||\n        req.headers[\"sec-fetch-dest\"] === \"\") &&\n      req.headers[\"sec-fetch-mode\"] === \"cors\"\n    ));\n  const isServerActionRequest = hasServerActionHeaders;\n\n  const isFormActionRequest =\n    !isServerActionRequest &&\n    (req.method === \"POST\" ||\n      (isFormContentType &&\n        req.headers[\"sec-fetch-dest\"] === \"document\" &&\n        req.headers[\"sec-fetch-mode\"] === \"navigate\"));\n\n  const isJsRequest =\n    !isFormActionRequest &&\n    !isJson &&\n    !isHtml &&\n    !isCss &&\n    !isRsc &&\n    (isJS || hasJsHeader);\n  const isJsonRequest = isJson || (hasJsonHeader && !isJsRequest);\n  // Form action detection\n\n  const isHtmlRequest =\n    !hasRscQueryParam && (isHtml ||\n    hasHtmlHeader ||\n    (isFolder &&\n      !hasRscHeader &&\n      !hasRscQueryParam &&\n      !isRsc &&\n      !isJsRequest &&\n      !isFormActionRequest));\n  const isRscRequest =\n    hasRscQueryParam || (!isJsRequest && !isHtmlRequest && (isRsc || hasRscHeader));\n  const isCssRequest =\n    !isHtmlRequest &&\n    !isRscRequest &&\n    !isJsRequest &&\n    !isJsonRequest &&\n    (isCss || hasCssHeader);\n\n  // Use the normalized value for file path construction\n  // The normalizer should have already stripped base URLs properly\n  const routeForFilePath = value;\n\n  let filePath = resolve(hostDir, routeForFilePath);\n  let contentType;\n  if (isServerActionRequest) {\n    // For server actions, we'll get the actual file path from the request body\n    // The route is just a placeholder\n    filePath = resolve(hostDir, routeForFilePath);\n    contentType = \"application/json; charset=utf-8\";\n  } else if (isHtmlRequest) {\n    if (!isHtml) {\n      filePath = resolve(\n        hostDir,\n        routeForFilePath,\n        handlerOptions.build.htmlOutputPath\n      );\n    }\n    contentType = \"text/html; charset=utf-8\";\n  } else if (isRscRequest) {\n    if (!isRsc) {\n      // Value doesn't end with .rsc, append the rsc output path\n      filePath = resolve(\n        hostDir,\n        routeForFilePath,\n        handlerOptions.build.rscOutputPath\n      );\n    }\n    contentType = \"text/x-component; charset=utf-8\";\n  } else if (isCssRequest) {\n    if (!isCss) {\n      filePath = resolve(hostDir, routeForFilePath + \".css\");\n    }\n    contentType = \"text/css; charset=utf-8\";\n  } else if (isJsRequest) {\n    if (!isJS) {\n      filePath = resolve(hostDir, routeForFilePath + \".js\");\n    }\n    contentType = \"application/javascript; charset=utf-8\";\n  } else if (isJsonRequest) {\n    if (!isJson) {\n      filePath = resolve(hostDir, routeForFilePath + \".json\");\n    }\n    contentType = \"application/json; charset=utf-8\";\n  } else {\n    const mimeType = MIME_TYPES[ext];\n    if (mimeType) {\n      contentType = mimeType + \"; charset=utf-8\";\n    } else {\n      contentType = \"application/octet-stream; charset=utf-8\";\n    }\n  }\n\n  if (handlerOptions.verbose) {\n    if (isFormActionRequest) {\n      handlerOptions.logger.info(`[react-dev-server] (form-action) ${route}`);\n    } else if (isServerActionRequest) {\n      handlerOptions.logger.info(`[react-dev-server] (server-action) ${route}`);\n    } else if (isHtmlRequest) {\n      handlerOptions.logger.info(`[react-dev-server] (html) ${route}`);\n    } else if (isRscRequest) {\n      handlerOptions.logger.info(`[react-dev-server] (rsc) ${route}`);\n    } else if (isCssRequest) {\n      handlerOptions.logger.info(`[react-dev-server] (css) ${route}`);\n    } else if (isJsRequest) {\n      handlerOptions.logger.info(`[react-dev-server] (js) ${route}`);\n    } else if (isJsonRequest) {\n      handlerOptions.logger.info(`[react-dev-server] (json) ${route}`);\n    } else {\n      handlerOptions.logger.info(`[react-dev-server] (other) ${route}`);\n    }\n  }\n  return {\n    route,\n    url: routeToURL(route, handlerOptions.moduleBaseURL, handlerOptions.build.rscOutputPath),\n    ext,\n    isHtmlRequest,\n    isRscRequest,\n    isCssRequest,\n    isCss,\n    isHtml,\n    isRsc,\n    isFolder,\n    contentType,\n    filePath,\n    isJS,\n    isVendor,\n    isVirtual,\n    hasJsHeader,\n    isJsRequest,\n    isJson,\n    isJsonRequest,\n    hasCssHeader,\n    hasJsonHeader,\n    hasHtmlHeader,\n    hasRscHeader,\n    hasServerActionHeaders,\n    isServerActionRequest,\n    isFormContentType,\n    isFormActionRequest,\n  };\n}\n"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"requestToRoute.d.ts","sourceRoot":"","sources":["../../../plugin/helpers/requestToRoute.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AAExD,wBAAgB,cAAc,CAC5B,GAAG,EAAE;IAAE,GAAG,CAAC,EAAE,MAAM,CAAA;CAAE,EACrB,cAAc,EAAE,IAAI,CAClB,oBAAoB,EACpB,gBAAgB,GAAG,eAAe,GAAG,OAAO,CAC7C,sBAyCF"}
1
+ {"version":3,"file":"requestToRoute.d.ts","sourceRoot":"","sources":["../../../plugin/helpers/requestToRoute.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AAExD,wBAAgB,cAAc,CAC5B,GAAG,EAAE;IAAE,GAAG,CAAC,EAAE,MAAM,CAAA;CAAE,EACrB,cAAc,EAAE,IAAI,CAClB,oBAAoB,EACpB,gBAAgB,GAAG,eAAe,GAAG,OAAO,CAC7C,sBA0CF"}
@@ -4,7 +4,7 @@
4
4
  * MIT License
5
5
  */
6
6
  function requestToRoute(req, handlerOptions) {
7
- let route = req.url?.replace(
7
+ let route = req.url?.split("?")[0].replace(
8
8
  handlerOptions.moduleBaseURL + handlerOptions.build.rscOutputPath,
9
9
  ""
10
10
  ).replace(
@@ -29,4 +29,4 @@ function requestToRoute(req, handlerOptions) {
29
29
  }
30
30
 
31
31
  export { requestToRoute };
32
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVxdWVzdFRvUm91dGUuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BsdWdpbi9oZWxwZXJzL3JlcXVlc3RUb1JvdXRlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQ3JlYXRlSGFuZGxlck9wdGlvbnMgfSBmcm9tIFwiLi4vdHlwZXMuanNcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIHJlcXVlc3RUb1JvdXRlKFxuICByZXE6IHsgdXJsPzogc3RyaW5nIH0sXG4gIGhhbmRsZXJPcHRpb25zOiBQaWNrPFxuICAgIENyZWF0ZUhhbmRsZXJPcHRpb25zLFxuICAgIFwibW9kdWxlQmFzZVBhdGhcIiB8IFwibW9kdWxlQmFzZVVSTFwiIHwgXCJidWlsZFwiXG4gID5cbikge1xuICBsZXQgcm91dGUgPSByZXEudXJsXG4gICAgPy5yZXBsYWNlKFxuICAgICAgaGFuZGxlck9wdGlvbnMubW9kdWxlQmFzZVVSTCArIGhhbmRsZXJPcHRpb25zLmJ1aWxkLnJzY091dHB1dFBhdGgsXG4gICAgICBcIlwiXG4gICAgKVxuICAgIC5yZXBsYWNlKFxuICAgICAgaGFuZGxlck9wdGlvbnMubW9kdWxlQmFzZVVSTCArIGhhbmRsZXJPcHRpb25zLmJ1aWxkLmh0bWxPdXRwdXRQYXRoLFxuICAgICAgXCJcIlxuICAgIClcbiAgICAucmVwbGFjZSgvXlxcL2luZGV4JC8sIFwiL1wiKTtcbiAgaWYgKHR5cGVvZiByb3V0ZSAhPT0gXCJzdHJpbmdcIikge1xuICAgIHJldHVybiByb3V0ZTtcbiAgfVxuICBcbiAgLy8gU3RyaXAgbW9kdWxlQmFzZVVSTCBmcm9tIHRoZSBiZWdpbm5pbmcgb2YgdGhlIHJvdXRlXG4gIGlmIChyb3V0ZS5zdGFydHNXaXRoKGhhbmRsZXJPcHRpb25zLm1vZHVsZUJhc2VVUkwpKSB7XG4gICAgcm91dGUgPSByb3V0ZS5zbGljZShoYW5kbGVyT3B0aW9ucy5tb2R1bGVCYXNlVVJMLmxlbmd0aCk7XG4gIH1cbiAgaWYocm91dGUuZW5kc1dpdGgoaGFuZGxlck9wdGlvbnMuYnVpbGQucnNjT3V0cHV0UGF0aCkpIHtcbiAgICByb3V0ZSA9IHJvdXRlLnNsaWNlKDAsIC1oYW5kbGVyT3B0aW9ucy5idWlsZC5yc2NPdXRwdXRQYXRoLmxlbmd0aCk7XG4gIH1cbiAgXG4gIGlmIChyb3V0ZS5zdGFydHNXaXRoKGhhbmRsZXJPcHRpb25zLm1vZHVsZUJhc2VQYXRoKSkge1xuICAgIHJvdXRlID0gcm91dGUuc2xpY2UoaGFuZGxlck9wdGlvbnMubW9kdWxlQmFzZVBhdGgubGVuZ3RoKTtcbiAgfVxuXG4gIGNvbnN0IHJvdXRlV2l0aG91dFRyYWlsaW5nU2xhc2ggPVxuICAgIHJvdXRlID09PSBcIlwiIHx8IHJvdXRlID09PSBcIi9cIlxuICAgICAgPyBcIi9cIlxuICAgICAgOiByb3V0ZS5lbmRzV2l0aChcIi9cIilcbiAgICAgID8gcm91dGUuc2xpY2UoMCwgLTEpXG4gICAgICA6IHJvdXRlO1xuXG4gIGNvbnN0IHJvdXRlV2l0aExlYWRpbmdTbGFzaCA9ICFyb3V0ZVdpdGhvdXRUcmFpbGluZ1NsYXNoXG4gICAgPyBcIi9cIlxuICAgIDogcm91dGVXaXRob3V0VHJhaWxpbmdTbGFzaC5zdGFydHNXaXRoKFwiL1wiKVxuICAgID8gcm91dGVXaXRob3V0VHJhaWxpbmdTbGFzaFxuICAgIDogYC8ke3JvdXRlV2l0aG91dFRyYWlsaW5nU2xhc2h9YDtcbiAgcmV0dXJuIHJvdXRlV2l0aExlYWRpbmdTbGFzaDtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUVPLFNBQVMsY0FBQSxDQUNkLEtBQ0EsY0FJQSxFQUFBO0FBQ0EsRUFBSSxJQUFBLEtBQUEsR0FBUSxJQUFJLEdBQ1osRUFBQSxPQUFBO0FBQUEsSUFDQSxjQUFBLENBQWUsYUFBZ0IsR0FBQSxjQUFBLENBQWUsS0FBTSxDQUFBLGFBQUE7QUFBQSxJQUNwRDtBQUFBLEdBRUQsQ0FBQSxPQUFBO0FBQUEsSUFDQyxjQUFBLENBQWUsYUFBZ0IsR0FBQSxjQUFBLENBQWUsS0FBTSxDQUFBLGNBQUE7QUFBQSxJQUNwRDtBQUFBLEdBQ0YsQ0FDQyxPQUFRLENBQUEsV0FBQSxFQUFhLEdBQUcsQ0FBQTtBQUMzQixFQUFJLElBQUEsT0FBTyxVQUFVLFFBQVUsRUFBQTtBQUM3QixJQUFPLE9BQUEsS0FBQTtBQUFBO0FBSVQsRUFBQSxJQUFJLEtBQU0sQ0FBQSxVQUFBLENBQVcsY0FBZSxDQUFBLGFBQWEsQ0FBRyxFQUFBO0FBQ2xELElBQUEsS0FBQSxHQUFRLEtBQU0sQ0FBQSxLQUFBLENBQU0sY0FBZSxDQUFBLGFBQUEsQ0FBYyxNQUFNLENBQUE7QUFBQTtBQUV6RCxFQUFBLElBQUcsS0FBTSxDQUFBLFFBQUEsQ0FBUyxjQUFlLENBQUEsS0FBQSxDQUFNLGFBQWEsQ0FBRyxFQUFBO0FBQ3JELElBQUEsS0FBQSxHQUFRLE1BQU0sS0FBTSxDQUFBLENBQUEsRUFBRyxDQUFDLGNBQWUsQ0FBQSxLQUFBLENBQU0sY0FBYyxNQUFNLENBQUE7QUFBQTtBQUduRSxFQUFBLElBQUksS0FBTSxDQUFBLFVBQUEsQ0FBVyxjQUFlLENBQUEsY0FBYyxDQUFHLEVBQUE7QUFDbkQsSUFBQSxLQUFBLEdBQVEsS0FBTSxDQUFBLEtBQUEsQ0FBTSxjQUFlLENBQUEsY0FBQSxDQUFlLE1BQU0sQ0FBQTtBQUFBO0FBRzFELEVBQUEsTUFBTSx5QkFDSixHQUFBLEtBQUEsS0FBVSxFQUFNLElBQUEsS0FBQSxLQUFVLE1BQ3RCLEdBQ0EsR0FBQSxLQUFBLENBQU0sUUFBUyxDQUFBLEdBQUcsQ0FDbEIsR0FBQSxLQUFBLENBQU0sS0FBTSxDQUFBLENBQUEsRUFBRyxFQUFFLENBQ2pCLEdBQUEsS0FBQTtBQUVOLEVBQU0sTUFBQSxxQkFBQSxHQUF3QixDQUFDLHlCQUFBLEdBQzNCLEdBQ0EsR0FBQSx5QkFBQSxDQUEwQixXQUFXLEdBQUcsQ0FBQSxHQUN4Qyx5QkFDQSxHQUFBLENBQUEsQ0FBQSxFQUFJLHlCQUF5QixDQUFBLENBQUE7QUFDakMsRUFBTyxPQUFBLHFCQUFBO0FBQ1Q7Ozs7In0=
32
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVxdWVzdFRvUm91dGUuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BsdWdpbi9oZWxwZXJzL3JlcXVlc3RUb1JvdXRlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQ3JlYXRlSGFuZGxlck9wdGlvbnMgfSBmcm9tIFwiLi4vdHlwZXMuanNcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIHJlcXVlc3RUb1JvdXRlKFxuICByZXE6IHsgdXJsPzogc3RyaW5nIH0sXG4gIGhhbmRsZXJPcHRpb25zOiBQaWNrPFxuICAgIENyZWF0ZUhhbmRsZXJPcHRpb25zLFxuICAgIFwibW9kdWxlQmFzZVBhdGhcIiB8IFwibW9kdWxlQmFzZVVSTFwiIHwgXCJidWlsZFwiXG4gID5cbikge1xuICAvLyBTdHJpcCBxdWVyeSBzdHJpbmcgYmVmb3JlIHJvdXRlIG1hdGNoaW5nXG4gIGxldCByb3V0ZSA9IHJlcS51cmw/LnNwbGl0KFwiP1wiKVswXVxuICAgIC5yZXBsYWNlKFxuICAgICAgaGFuZGxlck9wdGlvbnMubW9kdWxlQmFzZVVSTCArIGhhbmRsZXJPcHRpb25zLmJ1aWxkLnJzY091dHB1dFBhdGgsXG4gICAgICBcIlwiXG4gICAgKVxuICAgIC5yZXBsYWNlKFxuICAgICAgaGFuZGxlck9wdGlvbnMubW9kdWxlQmFzZVVSTCArIGhhbmRsZXJPcHRpb25zLmJ1aWxkLmh0bWxPdXRwdXRQYXRoLFxuICAgICAgXCJcIlxuICAgIClcbiAgICAucmVwbGFjZSgvXlxcL2luZGV4JC8sIFwiL1wiKTtcbiAgaWYgKHR5cGVvZiByb3V0ZSAhPT0gXCJzdHJpbmdcIikge1xuICAgIHJldHVybiByb3V0ZTtcbiAgfVxuICBcbiAgLy8gU3RyaXAgbW9kdWxlQmFzZVVSTCBmcm9tIHRoZSBiZWdpbm5pbmcgb2YgdGhlIHJvdXRlXG4gIGlmIChyb3V0ZS5zdGFydHNXaXRoKGhhbmRsZXJPcHRpb25zLm1vZHVsZUJhc2VVUkwpKSB7XG4gICAgcm91dGUgPSByb3V0ZS5zbGljZShoYW5kbGVyT3B0aW9ucy5tb2R1bGVCYXNlVVJMLmxlbmd0aCk7XG4gIH1cbiAgaWYocm91dGUuZW5kc1dpdGgoaGFuZGxlck9wdGlvbnMuYnVpbGQucnNjT3V0cHV0UGF0aCkpIHtcbiAgICByb3V0ZSA9IHJvdXRlLnNsaWNlKDAsIC1oYW5kbGVyT3B0aW9ucy5idWlsZC5yc2NPdXRwdXRQYXRoLmxlbmd0aCk7XG4gIH1cbiAgXG4gIGlmIChyb3V0ZS5zdGFydHNXaXRoKGhhbmRsZXJPcHRpb25zLm1vZHVsZUJhc2VQYXRoKSkge1xuICAgIHJvdXRlID0gcm91dGUuc2xpY2UoaGFuZGxlck9wdGlvbnMubW9kdWxlQmFzZVBhdGgubGVuZ3RoKTtcbiAgfVxuXG4gIGNvbnN0IHJvdXRlV2l0aG91dFRyYWlsaW5nU2xhc2ggPVxuICAgIHJvdXRlID09PSBcIlwiIHx8IHJvdXRlID09PSBcIi9cIlxuICAgICAgPyBcIi9cIlxuICAgICAgOiByb3V0ZS5lbmRzV2l0aChcIi9cIilcbiAgICAgID8gcm91dGUuc2xpY2UoMCwgLTEpXG4gICAgICA6IHJvdXRlO1xuXG4gIGNvbnN0IHJvdXRlV2l0aExlYWRpbmdTbGFzaCA9ICFyb3V0ZVdpdGhvdXRUcmFpbGluZ1NsYXNoXG4gICAgPyBcIi9cIlxuICAgIDogcm91dGVXaXRob3V0VHJhaWxpbmdTbGFzaC5zdGFydHNXaXRoKFwiL1wiKVxuICAgID8gcm91dGVXaXRob3V0VHJhaWxpbmdTbGFzaFxuICAgIDogYC8ke3JvdXRlV2l0aG91dFRyYWlsaW5nU2xhc2h9YDtcbiAgcmV0dXJuIHJvdXRlV2l0aExlYWRpbmdTbGFzaDtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUVPLFNBQVMsY0FBQSxDQUNkLEtBQ0EsY0FJQSxFQUFBO0FBRUEsRUFBQSxJQUFJLFFBQVEsR0FBSSxDQUFBLEdBQUEsRUFBSyxNQUFNLEdBQUcsQ0FBQSxDQUFFLENBQUMsQ0FDOUIsQ0FBQSxPQUFBO0FBQUEsSUFDQyxjQUFBLENBQWUsYUFBZ0IsR0FBQSxjQUFBLENBQWUsS0FBTSxDQUFBLGFBQUE7QUFBQSxJQUNwRDtBQUFBLEdBRUQsQ0FBQSxPQUFBO0FBQUEsSUFDQyxjQUFBLENBQWUsYUFBZ0IsR0FBQSxjQUFBLENBQWUsS0FBTSxDQUFBLGNBQUE7QUFBQSxJQUNwRDtBQUFBLEdBQ0YsQ0FDQyxPQUFRLENBQUEsV0FBQSxFQUFhLEdBQUcsQ0FBQTtBQUMzQixFQUFJLElBQUEsT0FBTyxVQUFVLFFBQVUsRUFBQTtBQUM3QixJQUFPLE9BQUEsS0FBQTtBQUFBO0FBSVQsRUFBQSxJQUFJLEtBQU0sQ0FBQSxVQUFBLENBQVcsY0FBZSxDQUFBLGFBQWEsQ0FBRyxFQUFBO0FBQ2xELElBQUEsS0FBQSxHQUFRLEtBQU0sQ0FBQSxLQUFBLENBQU0sY0FBZSxDQUFBLGFBQUEsQ0FBYyxNQUFNLENBQUE7QUFBQTtBQUV6RCxFQUFBLElBQUcsS0FBTSxDQUFBLFFBQUEsQ0FBUyxjQUFlLENBQUEsS0FBQSxDQUFNLGFBQWEsQ0FBRyxFQUFBO0FBQ3JELElBQUEsS0FBQSxHQUFRLE1BQU0sS0FBTSxDQUFBLENBQUEsRUFBRyxDQUFDLGNBQWUsQ0FBQSxLQUFBLENBQU0sY0FBYyxNQUFNLENBQUE7QUFBQTtBQUduRSxFQUFBLElBQUksS0FBTSxDQUFBLFVBQUEsQ0FBVyxjQUFlLENBQUEsY0FBYyxDQUFHLEVBQUE7QUFDbkQsSUFBQSxLQUFBLEdBQVEsS0FBTSxDQUFBLEtBQUEsQ0FBTSxjQUFlLENBQUEsY0FBQSxDQUFlLE1BQU0sQ0FBQTtBQUFBO0FBRzFELEVBQUEsTUFBTSx5QkFDSixHQUFBLEtBQUEsS0FBVSxFQUFNLElBQUEsS0FBQSxLQUFVLE1BQ3RCLEdBQ0EsR0FBQSxLQUFBLENBQU0sUUFBUyxDQUFBLEdBQUcsQ0FDbEIsR0FBQSxLQUFBLENBQU0sS0FBTSxDQUFBLENBQUEsRUFBRyxFQUFFLENBQ2pCLEdBQUEsS0FBQTtBQUVOLEVBQU0sTUFBQSxxQkFBQSxHQUF3QixDQUFDLHlCQUFBLEdBQzNCLEdBQ0EsR0FBQSx5QkFBQSxDQUEwQixXQUFXLEdBQUcsQ0FBQSxHQUN4Qyx5QkFDQSxHQUFBLENBQUEsQ0FBQSxFQUFJLHlCQUF5QixDQUFBLENBQUE7QUFDakMsRUFBTyxPQUFBLHFCQUFBO0FBQ1Q7Ozs7In0=