@modern-js/server-core 3.0.0-alpha.0 → 3.0.0-alpha.2

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 (103) hide show
  1. package/dist/cjs/adapters/node/plugins/resource.js +9 -10
  2. package/dist/cjs/index.js +18 -10
  3. package/dist/cjs/plugins/render/render.js +1 -1
  4. package/dist/esm/adapters/node/helper/index.mjs +5 -5
  5. package/dist/esm/adapters/node/hono.mjs +1 -1
  6. package/dist/esm/adapters/node/index.mjs +4 -4
  7. package/dist/esm/adapters/node/node.mjs +1 -1
  8. package/dist/esm/adapters/node/plugins/index.mjs +3 -3
  9. package/dist/esm/adapters/node/plugins/resource.mjs +10 -11
  10. package/dist/esm/adapters/node/plugins/static.mjs +2 -2
  11. package/dist/esm/context.mjs +1 -1
  12. package/dist/esm/index.mjs +12 -12
  13. package/dist/esm/plugins/compat/index.mjs +1 -1
  14. package/dist/esm/plugins/default.mjs +6 -6
  15. package/dist/esm/plugins/index.mjs +8 -8
  16. package/dist/esm/plugins/log.mjs +1 -1
  17. package/dist/esm/plugins/monitors.mjs +1 -1
  18. package/dist/esm/plugins/render/csrRscRender.mjs +1 -1
  19. package/dist/esm/plugins/render/index.mjs +4 -4
  20. package/dist/esm/plugins/render/inject.mjs +1 -1
  21. package/dist/esm/plugins/render/render.mjs +8 -8
  22. package/dist/esm/plugins/render/renderRscHandler.mjs +1 -1
  23. package/dist/esm/plugins/render/ssrCache.mjs +2 -2
  24. package/dist/esm/plugins/render/ssrRender.mjs +4 -4
  25. package/dist/esm/plugins/route.mjs +1 -1
  26. package/dist/esm/serverBase.mjs +3 -3
  27. package/dist/esm/types/config/index.mjs +6 -6
  28. package/dist/esm/types/index.mjs +4 -4
  29. package/dist/esm/types/plugins/index.mjs +1 -1
  30. package/dist/esm/utils/error.mjs +1 -1
  31. package/dist/esm/utils/index.mjs +9 -9
  32. package/dist/esm-node/adapters/node/helper/index.mjs +2 -0
  33. package/dist/esm-node/adapters/node/helper/loadCache.mjs +2 -0
  34. package/dist/esm-node/adapters/node/helper/loadConfig.mjs +2 -0
  35. package/dist/esm-node/adapters/node/helper/loadEnv.mjs +2 -0
  36. package/dist/esm-node/adapters/node/helper/loadPlugin.mjs +2 -0
  37. package/dist/esm-node/adapters/node/helper/utils.mjs +2 -0
  38. package/dist/esm-node/adapters/node/hono.mjs +2 -0
  39. package/dist/esm-node/adapters/node/index.mjs +2 -0
  40. package/dist/esm-node/adapters/node/node.mjs +2 -0
  41. package/dist/esm-node/adapters/node/plugins/index.mjs +2 -0
  42. package/dist/esm-node/adapters/node/plugins/nodeServer.mjs +2 -0
  43. package/dist/esm-node/adapters/node/plugins/resource.mjs +11 -10
  44. package/dist/esm-node/adapters/node/plugins/static.mjs +2 -0
  45. package/dist/esm-node/constants.mjs +2 -0
  46. package/dist/esm-node/context.mjs +2 -0
  47. package/dist/esm-node/helper.mjs +2 -0
  48. package/dist/esm-node/hono.mjs +2 -0
  49. package/dist/esm-node/index.mjs +4 -2
  50. package/dist/esm-node/plugins/compat/hooks.mjs +2 -0
  51. package/dist/esm-node/plugins/compat/index.mjs +2 -0
  52. package/dist/esm-node/plugins/default.mjs +2 -0
  53. package/dist/esm-node/plugins/favicon.mjs +2 -0
  54. package/dist/esm-node/plugins/index.mjs +2 -0
  55. package/dist/esm-node/plugins/log.mjs +2 -0
  56. package/dist/esm-node/plugins/middlewares.mjs +2 -0
  57. package/dist/esm-node/plugins/monitors.mjs +2 -0
  58. package/dist/esm-node/plugins/processedBy.mjs +2 -0
  59. package/dist/esm-node/plugins/render/csrRscRender.mjs +2 -0
  60. package/dist/esm-node/plugins/render/dataHandler.mjs +2 -0
  61. package/dist/esm-node/plugins/render/index.mjs +2 -0
  62. package/dist/esm-node/plugins/render/inject.mjs +2 -0
  63. package/dist/esm-node/plugins/render/render.mjs +3 -1
  64. package/dist/esm-node/plugins/render/renderRscHandler.mjs +2 -0
  65. package/dist/esm-node/plugins/render/serverActionHandler.mjs +2 -0
  66. package/dist/esm-node/plugins/render/ssrCache.mjs +2 -0
  67. package/dist/esm-node/plugins/render/ssrRender.mjs +2 -0
  68. package/dist/esm-node/plugins/render/utils.mjs +2 -0
  69. package/dist/esm-node/plugins/route.mjs +2 -0
  70. package/dist/esm-node/serverBase.mjs +2 -0
  71. package/dist/esm-node/types/config/bff.mjs +2 -0
  72. package/dist/esm-node/types/config/dev.mjs +2 -0
  73. package/dist/esm-node/types/config/html.mjs +2 -0
  74. package/dist/esm-node/types/config/index.mjs +2 -0
  75. package/dist/esm-node/types/config/output.mjs +2 -0
  76. package/dist/esm-node/types/config/security.mjs +2 -0
  77. package/dist/esm-node/types/config/server.mjs +2 -0
  78. package/dist/esm-node/types/config/share.mjs +2 -0
  79. package/dist/esm-node/types/config/source.mjs +2 -0
  80. package/dist/esm-node/types/config/tools.mjs +2 -0
  81. package/dist/esm-node/types/index.mjs +2 -0
  82. package/dist/esm-node/types/plugins/base.mjs +2 -0
  83. package/dist/esm-node/types/plugins/index.mjs +2 -0
  84. package/dist/esm-node/types/plugins/plugin.mjs +2 -0
  85. package/dist/esm-node/types/render.mjs +2 -0
  86. package/dist/esm-node/types/requestHandler.mjs +2 -0
  87. package/dist/esm-node/types/server.mjs +2 -0
  88. package/dist/esm-node/utils/entry.mjs +2 -0
  89. package/dist/esm-node/utils/env.mjs +2 -0
  90. package/dist/esm-node/utils/error.mjs +2 -0
  91. package/dist/esm-node/utils/index.mjs +2 -0
  92. package/dist/esm-node/utils/middlewareCollector.mjs +2 -0
  93. package/dist/esm-node/utils/publicDir.mjs +2 -0
  94. package/dist/esm-node/utils/request.mjs +2 -0
  95. package/dist/esm-node/utils/serverConfig.mjs +2 -0
  96. package/dist/esm-node/utils/storage.mjs +2 -0
  97. package/dist/esm-node/utils/transformStream.mjs +2 -0
  98. package/dist/esm-node/utils/warmup.mjs +2 -0
  99. package/dist/types/adapters/node/plugins/resource.d.ts +3 -3
  100. package/dist/types/index.d.ts +1 -1
  101. package/dist/types/types/config/server.d.ts +1 -1
  102. package/dist/types/types/config/tools.d.ts +1 -7
  103. package/package.json +22 -13
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  export * from "./static.mjs";
2
4
  export * from "./resource.mjs";
3
5
  export * from "./nodeServer.mjs";
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  const injectNodeSeverPlugin = ({ nodeServer })=>({
2
4
  name: '@modern-js/plugin-inject-node-server',
3
5
  setup (api) {
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import path from "path";
2
4
  import { fileReader } from "@modern-js/runtime-utils/fileReader";
3
5
  import { LOADABLE_STATS_FILE, MAIN_ENTRY_NAME, NESTED_ROUTE_SPEC_FILE, ROUTE_MANIFEST_FILE, SERVER_BUNDLE_DIRECTORY, compatibleRequire, fs, isProd } from "@modern-js/utils";
@@ -27,25 +29,25 @@ function injectTemplates(pwd, routes, htmlTemplatePromise) {
27
29
  await next();
28
30
  };
29
31
  }
30
- const loadBundle = async (filepath, logger)=>{
32
+ const loadBundle = async (filepath, monitors)=>{
31
33
  if (!await fs.pathExists(filepath)) return;
32
34
  try {
33
35
  const module = await compatibleRequire(filepath, false);
34
36
  return module;
35
37
  } catch (e) {
36
- logger.error(`Load ${filepath} bundle failed, error = %s`, e instanceof Error ? e.stack || e.message : e);
38
+ monitors.error(`Load ${filepath} bundle failed, error = %s`, e instanceof Error ? e.stack || e.message : e);
37
39
  return;
38
40
  }
39
41
  };
40
- async function getServerManifest(pwd, routes, logger) {
42
+ async function getServerManifest(pwd, routes, monitors) {
41
43
  const loaderBundles = {};
42
44
  const renderBundles = {};
43
45
  await Promise.all(routes.filter((route)=>Boolean(route.bundle)).map(async (route)=>{
44
46
  const entryName = route.entryName || MAIN_ENTRY_NAME;
45
47
  const renderBundlePath = path.join(pwd, route.bundle || '');
46
48
  const loaderBundlePath = path.join(pwd, SERVER_BUNDLE_DIRECTORY, `${entryName}-server-loaders.js`);
47
- const renderBundle = await loadBundle(renderBundlePath, logger);
48
- const loaderBundle = await loadBundle(loaderBundlePath, logger);
49
+ const renderBundle = await loadBundle(renderBundlePath, monitors);
50
+ const loaderBundle = await loadBundle(loaderBundlePath, monitors);
49
51
  renderBundle && (renderBundles[entryName] = renderBundle);
50
52
  loaderBundle && (loaderBundles[entryName] = loaderBundle?.loadModules ? await loaderBundle?.loadModules() : loaderBundle);
51
53
  }));
@@ -66,8 +68,8 @@ async function getServerManifest(pwd, routes, logger) {
66
68
  function injectServerManifest(pwd, routes, manifestPromise) {
67
69
  return async (c, next)=>{
68
70
  if (routes && !c.get('serverManifest')) {
69
- const logger = c.get('logger');
70
- const serverManifest = await (manifestPromise || getServerManifest(pwd, routes, logger));
71
+ const monitors = c.get('monitors');
72
+ const serverManifest = await (manifestPromise || getServerManifest(pwd, routes, monitors));
71
73
  c.set('serverManifest', serverManifest);
72
74
  }
73
75
  await next();
@@ -85,13 +87,12 @@ async function getRscSSRManifest(pwd) {
85
87
  const rscSSRManifest = await compatibleRequire(path.join(pwd, 'react-ssr-manifest.json')).catch((_)=>void 0);
86
88
  return rscSSRManifest;
87
89
  }
88
- const injectRscManifestPlugin = ()=>({
90
+ const injectRscManifestPlugin = (enableRsc)=>({
89
91
  name: '@modern-js/plugin-inject-rsc-manifest',
90
92
  setup (api) {
91
93
  api.onPrepare(()=>{
92
94
  const { middlewares, distDirectory: pwd } = api.getServerContext();
93
- const config = api.getServerConfig();
94
- if (!config.server?.rsc) return;
95
+ if (!enableRsc) return;
95
96
  middlewares.push({
96
97
  name: 'inject-rsc-manifest',
97
98
  handler: async (c, next)=>{
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import path from "path";
2
4
  import { fileReader } from "@modern-js/runtime-utils/fileReader";
3
5
  import { fs } from "@modern-js/utils";
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  const AGGRED_DIR = {
2
4
  mock: 'config/mock',
3
5
  server: 'server',
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { createStorage } from "./utils/storage.mjs";
2
4
  const { run, useHonoContext } = createStorage();
3
5
  export { run, useHonoContext };
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  const LOADER_CONTEXT = 'loaderContext';
2
4
  function getLoaderCtx(c) {
3
5
  const loaderContext = c.get(LOADER_CONTEXT);
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { deleteCookie, getCookie, setCookie } from "hono/cookie";
2
4
  import { languageDetector } from "hono/language";
3
5
  export { deleteCookie, getCookie, languageDetector, setCookie };
@@ -1,8 +1,10 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { ErrorDigest, createErrorHtml, onError } from "./utils/index.mjs";
2
4
  import { getPublicDirConfig, getPublicDirPatterns, getPublicDirRoutePrefixes, normalizePublicDir, normalizePublicDirPath, resolvePublicDirPaths } from "./utils/publicDir.mjs";
3
5
  import { AGGRED_DIR } from "./constants.mjs";
4
6
  import { createServerBase } from "./serverBase.mjs";
5
- import { useHonoContext } from "./context.mjs";
7
+ import { run, useHonoContext } from "./context.mjs";
6
8
  import { Hono } from "hono";
7
9
  import { getLoaderCtx } from "./helper.mjs";
8
10
  export * from "./plugins/index.mjs";
@@ -10,4 +12,4 @@ export * from "./types/plugins/index.mjs";
10
12
  export * from "./types/render.mjs";
11
13
  export * from "./types/config/index.mjs";
12
14
  export * from "./types/requestHandler.mjs";
13
- export { AGGRED_DIR, ErrorDigest, Hono, createErrorHtml, createServerBase, getLoaderCtx, getPublicDirConfig, getPublicDirPatterns, getPublicDirRoutePrefixes, normalizePublicDir, normalizePublicDirPath, onError, resolvePublicDirPaths, useHonoContext };
15
+ export { AGGRED_DIR, ErrorDigest, Hono, createErrorHtml, createServerBase, getLoaderCtx, getPublicDirConfig, getPublicDirPatterns, getPublicDirRoutePrefixes, normalizePublicDir, normalizePublicDirPath, onError, resolvePublicDirPaths, run, useHonoContext };
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  function getHookRunners(context) {
2
4
  const { hooks } = context;
3
5
  return {
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { createAsyncHook, createAsyncPipelineHook } from "@modern-js/plugin";
2
4
  import { getHookRunners, handleSetupResult } from "./hooks.mjs";
3
5
  const compatPlugin = ()=>({
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { compatPlugin } from "./compat/index.mjs";
2
4
  import { logPlugin } from "./log.mjs";
3
5
  import { initMonitorsPlugin, injectServerTiming, injectloggerPlugin } from "./monitors.mjs";
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  const faviconPlugin = ()=>({
2
4
  name: '@modern-js/plugin-favicon',
3
5
  setup (api) {
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { getRenderHandler, injectRenderHandlerPlugin, renderPlugin } from "./render/index.mjs";
2
4
  import { faviconPlugin } from "./favicon.mjs";
3
5
  import { injectServerTiming, injectloggerPlugin } from "./monitors.mjs";
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { getPathname } from "../utils/index.mjs";
2
4
  const humanize = (times)=>{
3
5
  const [delimiter, separator] = [
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  const injectConfigMiddlewarePlugin = (configMiddlewares = [], configRenderMiddlewares = [])=>({
2
4
  name: '@modern-js/plugin-inject-config-middleware',
3
5
  setup (api) {
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { time } from "@modern-js/runtime-utils/time";
2
4
  import { SERVER_TIMING, ServerTimings } from "../constants.mjs";
3
5
  function createMonitors() {
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  const processedByPlugin = ()=>({
2
4
  name: '@modern-js/plugin-processed',
3
5
  setup (api) {
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { MAIN_ENTRY_NAME } from "@modern-js/utils/universal/constants";
2
4
  import { createRequestHandlerConfig } from "./utils.mjs";
3
5
  const csrRscRender = async (req, options)=>{
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { MAIN_ENTRY_NAME } from "@modern-js/utils/universal/constants";
2
4
  const dataHandler = async (request, { routeInfo, serverRoutes, monitors, onError, onTiming, serverManifest, loaderContext })=>{
3
5
  const serverLoaderModule = serverManifest?.loaderBundles?.[routeInfo.entryName || MAIN_ENTRY_NAME];
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { getLoaderCtx } from "../../helper.mjs";
2
4
  import { sortRoutes } from "../../utils/index.mjs";
3
5
  import { requestLatencyMiddleware } from "../monitors.mjs";
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { createRender } from "./render.mjs";
2
4
  const injectRenderHandlerPlugin = ({ staticGenerate, cacheConfig })=>({
3
5
  name: '@modern-js/plugin-inject-render',
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import * as __rspack_external__modern_js_runtime_utils_router_2aa8d96f from "@modern-js/runtime-utils/router";
2
4
  import { cutNameByHyphen } from "@modern-js/utils/universal";
3
5
  import { TrieRouter } from "hono/router/trie-router";
@@ -214,7 +216,7 @@ function injectFallbackReasonToHtml({ html, reason, framework }) {
214
216
  }
215
217
  async function csrRender(request, options) {
216
218
  const { html, rscClientManifest } = options;
217
- if (!rscClientManifest || process.env.MODERN_DISABLE_INJECT_RSC_DATA) return new Response(html, {
219
+ if (!rscClientManifest || process.env.MODERN_DISABLE_INJECT_RSC_DATA || !options.routeInfo.isRSC) return new Response(html, {
218
220
  status: 200,
219
221
  headers: new Headers({
220
222
  'content-type': 'text/html; charset=UTF-8',
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { MAIN_ENTRY_NAME } from "@modern-js/utils/universal/constants";
2
4
  import { createRequestHandlerConfig } from "./utils.mjs";
3
5
  const renderRscHandler = async (req, options)=>{
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { MAIN_ENTRY_NAME } from "@modern-js/utils/universal/constants";
2
4
  const serverActionHandler = async (req, { serverManifest, routeInfo, rscClientManifest })=>{
3
5
  const serverBundle = serverManifest?.renderBundles?.[routeInfo.entryName || MAIN_ENTRY_NAME];
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { createMemoryStorage } from "@modern-js/runtime-utils/storer";
2
4
  import { X_RENDER_CACHE } from "../../constants.mjs";
3
5
  import { createTransformStream, getPathname } from "../../utils/index.mjs";
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { MAIN_ENTRY_NAME } from "@modern-js/utils/universal/constants";
2
4
  import { X_MODERNJS_RENDER } from "../../constants.mjs";
3
5
  import { getPathname, parseHeaders } from "../../utils/index.mjs";
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  function createRequestHandlerConfig(userConfig) {
2
4
  const { output, server, security, html, source } = userConfig;
3
5
  return {
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { MAIN_ENTRY_NAME } from "@modern-js/utils/universal/constants";
2
4
  import { sortRoutes } from "../utils/index.mjs";
3
5
  function injectRoute(route) {
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { server as server_server } from "@modern-js/plugin/server";
2
4
  import { Hono } from "hono";
3
5
  import { run } from "./context.mjs";
@@ -0,0 +1,2 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
@@ -0,0 +1,2 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
@@ -0,0 +1,2 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  export * from "./bff.mjs";
2
4
  export * from "./html.mjs";
3
5
  export * from "./output.mjs";
@@ -0,0 +1,2 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
@@ -0,0 +1,2 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
@@ -0,0 +1,2 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
@@ -0,0 +1,2 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
@@ -0,0 +1,2 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
@@ -0,0 +1,2 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  export * from "./config/index.mjs";
2
4
  export * from "./plugins/index.mjs";
3
5
  export * from "./render.mjs";
@@ -0,0 +1,2 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
@@ -1 +1,3 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  export * from "./plugin.mjs";
@@ -0,0 +1,2 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
@@ -0,0 +1,2 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
@@ -0,0 +1,2 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
@@ -0,0 +1,2 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  const sortRoutes = (route1, route2)=>route2.urlPath.length - route1.urlPath.length;
2
4
  const uniqueKeyByRoute = (route)=>`${route.entryName}-${route.urlPath}`;
3
5
  export { sortRoutes, uniqueKeyByRoute };
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  const getRuntimeEnv = ()=>{
2
4
  if (globalThis?.process?.release?.name === 'node') return 'node';
3
5
  return 'other';
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { parseHeaders } from "./request.mjs";
2
4
  const ERROR_PAGE_TEXT = {
3
5
  404: 'This page could not be found.',
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  export * from "./env.mjs";
2
4
  export * from "./transformStream.mjs";
3
5
  export * from "./middlewareCollector.mjs";
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  const mergeExtension = (users)=>{
2
4
  const output = [];
3
5
  return {
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import path from "path";
2
4
  function normalizePublicDir(publicDir) {
3
5
  if (!publicDir) return [];
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  function parseQuery(req) {
2
4
  const query = {};
3
5
  const { url } = req;
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { merge } from "ts-deepmerge";
2
4
  const loadConfig = ({ cliConfig, serverConfig })=>{
3
5
  const config = merge({
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  import { AsyncLocalStorage } from "async_hooks";
2
4
  const createStorage = ()=>{
3
5
  let storage;
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  function createTransformStream(fn) {
2
4
  const decoder = new TextDecoder();
3
5
  const encoder = new TextEncoder();
@@ -1,3 +1,5 @@
1
+ import "node:module";
2
+ /*#__PURE__*/ import.meta.url;
1
3
  function warmup(bundles) {
2
4
  bundles.forEach((bundle)=>{
3
5
  bundle && import(bundle).catch((_)=>{});
@@ -1,11 +1,11 @@
1
- import type { Logger, ServerRoute } from '@modern-js/types';
1
+ import type { Monitors, ServerRoute } from '@modern-js/types';
2
2
  import type { Middleware, ServerEnv, ServerManifest, ServerPlugin } from '../../../types';
3
3
  export declare function getHtmlTemplates(pwd: string, routes: ServerRoute[]): Promise<Record<string, string>>;
4
4
  export declare function injectTemplates(pwd: string, routes?: ServerRoute[], htmlTemplatePromise?: ReturnType<typeof getHtmlTemplates>): Middleware<ServerEnv>;
5
- export declare function getServerManifest(pwd: string, routes: ServerRoute[], logger: Logger): Promise<ServerManifest>;
5
+ export declare function getServerManifest(pwd: string, routes: ServerRoute[], monitors: Monitors): Promise<ServerManifest>;
6
6
  export declare function injectServerManifest(pwd: string, routes?: ServerRoute[], manifestPromise?: Promise<ServerManifest>): Middleware<ServerEnv>;
7
7
  export declare function getRscServerManifest(pwd: string): Promise<any>;
8
8
  export declare function getClientManifest(pwd: string): Promise<any>;
9
9
  export declare function getRscSSRManifest(pwd: string): Promise<any>;
10
- export declare const injectRscManifestPlugin: () => ServerPlugin;
10
+ export declare const injectRscManifestPlugin: (enableRsc: boolean) => ServerPlugin;
11
11
  export declare const injectResourcePlugin: () => ServerPlugin;
@@ -3,7 +3,7 @@ export { normalizePublicDir, normalizePublicDirPath, getPublicDirRoutePrefixes,
3
3
  export { AGGRED_DIR } from './constants';
4
4
  export type { ServerBase, ServerBaseOptions } from './serverBase';
5
5
  export { createServerBase } from './serverBase';
6
- export { useHonoContext } from './context';
6
+ export { run, useHonoContext } from './context';
7
7
  export { Hono } from 'hono';
8
8
  export type { Middleware, MiddlewareHandler, Context, Next, HonoRequest as InternalRequest, ServerEnv, ServerManifest, ServerLoaderBundle, } from './types';
9
9
  export { getLoaderCtx } from './helper';
@@ -28,7 +28,7 @@ export interface ServerUserConfig {
28
28
  baseUrl?: string | string[];
29
29
  port?: number;
30
30
  watchOptions?: WatchOptions;
31
- compiler?: 'babel' | 'typescript';
31
+ compiler?: 'typescript';
32
32
  /**
33
33
  * @description use json script tag instead of inline script
34
34
  * @default false
@@ -1,8 +1,2 @@
1
- import type { BabelTransformOptions } from '@modern-js/types/common';
2
- import type { ConfigChain } from './share';
3
- type ToolsBabelConfig = ConfigChain<BabelTransformOptions, any>;
4
- export interface ToolsUserConfig {
5
- babel?: ToolsBabelConfig;
6
- }
1
+ export type ToolsUserConfig = Record<string, never>;
7
2
  export type ToolsNormalizedConfig = ToolsUserConfig;
8
- export {};
package/package.json CHANGED
@@ -15,25 +15,34 @@
15
15
  "modern",
16
16
  "modern.js"
17
17
  ],
18
- "version": "3.0.0-alpha.0",
19
- "jsnext:source": "./src/index.ts",
18
+ "version": "3.0.0-alpha.2",
20
19
  "types": "./dist/types/index.d.ts",
21
20
  "main": "./dist/cjs/index.js",
22
- "module": "./dist/esm-node/index.mjs",
23
21
  "exports": {
24
22
  ".": {
25
23
  "types": "./dist/types/index.d.ts",
26
- "import": "./dist/esm-node/index.mjs",
24
+ "modern:source": "./src/index.ts",
25
+ "node": {
26
+ "import": "./dist/esm-node/index.mjs",
27
+ "require": "./dist/cjs/index.js"
28
+ },
27
29
  "default": "./dist/cjs/index.js"
28
30
  },
29
31
  "./node": {
30
32
  "types": "./dist/types/adapters/node/index.d.ts",
31
- "import": "./dist/esm-node/adapters/node/index.mjs",
33
+ "modern:source": "./src/adapters/node/index.ts",
34
+ "node": {
35
+ "import": "./dist/esm-node/adapters/node/index.mjs",
36
+ "require": "./dist/cjs/adapters/node/index.js"
37
+ },
32
38
  "default": "./dist/cjs/adapters/node/index.js"
33
39
  },
34
40
  "./hono": {
35
41
  "types": "./dist/types/hono.d.ts",
36
- "import": "./dist/esm-node/hono.mjs",
42
+ "node": {
43
+ "import": "./dist/esm-node/hono.mjs",
44
+ "require": "./dist/cjs/hono.js"
45
+ },
37
46
  "default": "./dist/cjs/hono.js"
38
47
  }
39
48
  },
@@ -60,22 +69,22 @@
60
69
  "@web-std/stream": "^1.0.3",
61
70
  "cloneable-readable": "^3.0.0",
62
71
  "flatted": "^3.3.3",
63
- "hono": "^4.10.4",
72
+ "hono": "^4.11.7",
64
73
  "ts-deepmerge": "7.0.3",
65
- "@modern-js/plugin": "3.0.0-alpha.0",
66
- "@modern-js/runtime-utils": "3.0.0-alpha.0",
67
- "@modern-js/utils": "3.0.0-alpha.0"
74
+ "@modern-js/plugin": "3.0.0-alpha.2",
75
+ "@modern-js/runtime-utils": "3.0.0-alpha.2",
76
+ "@modern-js/utils": "3.0.0-alpha.2"
68
77
  },
69
78
  "devDependencies": {
70
- "@rslib/core": "0.18.5",
79
+ "@rslib/core": "0.19.3",
71
80
  "@types/cloneable-readable": "^2.0.3",
72
81
  "@types/merge-deep": "^3.0.3",
73
82
  "@types/node": "^20",
74
83
  "http-proxy-middleware": "^2.0.9",
75
84
  "typescript": "^5",
76
- "@modern-js/types": "3.0.0-alpha.0",
77
85
  "@modern-js/rslib": "2.68.10",
78
- "@scripts/rstest-config": "2.66.0"
86
+ "@scripts/rstest-config": "2.66.0",
87
+ "@modern-js/types": "3.0.0-alpha.2"
79
88
  },
80
89
  "sideEffects": false,
81
90
  "publishConfig": {