nitro-nightly 3.0.1-20251211-104342-6f7889e0 → 3.0.1-20251211-155448-9dc8f6b6

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.
@@ -448,7 +448,7 @@ function routing(nitro) {
448
448
  ...nitro.routing.globalMiddleware
449
449
  ], "_importHash");
450
450
  return `
451
- import * as __routeRules__ from "nitro/~internal/runtime/route-rules";
451
+ import * as __routeRules__ from "#runtime/route-rules";
452
452
  import * as srvxNode from "srvx/node"
453
453
  import * as h3 from "h3";
454
454
 
package/dist/_nitro.mjs CHANGED
@@ -239,7 +239,7 @@ async function resolveOpenAPIOptions(options) {
239
239
  async function resolveTsconfig(options) {
240
240
  const root = resolve(options.rootDir || ".") + "/";
241
241
  if (!options.typescript.tsConfig) options.typescript.tsConfig = await loadTsconfig(root);
242
- if (options.experimental.tsconfigPaths !== false && options.typescript.tsConfig.compilerOptions?.paths) options.alias = {
242
+ if (options.experimental.tsconfigPaths && options.typescript.tsConfig.compilerOptions?.paths) options.alias = {
243
243
  ...tsConfigToAliasObj(options.typescript.tsConfig, root),
244
244
  ...options.alias
245
245
  };
@@ -5,9 +5,9 @@ import wsAdapter from "crossws/adapters/node";
5
5
  import { toNodeHandler } from "srvx/node";
6
6
  import { getSocketAddress, isSocketSupported } from "get-port-please";
7
7
  import { useNitroApp, useNitroHooks } from "nitro/app";
8
- import { startScheduleRunner } from "nitro/~internal/runtime/task";
9
- import { trapUnhandledErrors } from "nitro/~internal/runtime/error/hooks";
10
- import { resolveWebsocketHooks } from "nitro/~internal/runtime/app";
8
+ import { startScheduleRunner } from "#runtime/task";
9
+ import { trapUnhandledErrors } from "#runtime/error/hooks";
10
+ import { resolveWebsocketHooks } from "#runtime/app";
11
11
  import { hasWebSocket } from "#nitro-internal-virtual/feature-flags";
12
12
  // Listen for shutdown signal from runner
13
13
  parentPort?.on("message", (msg) => {
@@ -2,9 +2,9 @@ import "#nitro-internal-polyfills";
2
2
  import { serve } from "srvx/bun";
3
3
  import wsAdapter from "crossws/adapters/bun";
4
4
  import { useNitroApp } from "nitro/app";
5
- import { startScheduleRunner } from "nitro/~internal/runtime/task";
6
- import { trapUnhandledErrors } from "nitro/~internal/runtime/error/hooks";
7
- import { resolveWebsocketHooks } from "nitro/~internal/runtime/app";
5
+ import { startScheduleRunner } from "#runtime/task";
6
+ import { trapUnhandledErrors } from "#runtime/error/hooks";
7
+ import { resolveWebsocketHooks } from "#runtime/app";
8
8
  import { hasWebSocket } from "#nitro-internal-virtual/feature-flags";
9
9
  const port = Number.parseInt(process.env.NITRO_PORT || process.env.PORT || "") || 3e3;
10
10
  const host = process.env.NITRO_HOST || process.env.HOST;
@@ -1,5 +1,5 @@
1
1
  import "#nitro-internal-polyfills";
2
- import { runCronTasks } from "nitro/~internal/runtime/task";
2
+ import { runCronTasks } from "#runtime/task";
3
3
  import { useNitroApp, useNitroHooks } from "nitro/app";
4
4
  export function createHandler(hooks) {
5
5
  const nitroApp = useNitroApp();
@@ -4,7 +4,7 @@ import wsAdapter from "crossws/adapters/cloudflare";
4
4
  import { createHandler, fetchHandler } from "./_module-handler.mjs";
5
5
  import { useNitroApp, useNitroHooks } from "nitro/app";
6
6
  import { isPublicAssetURL } from "#nitro-internal-virtual/public-assets";
7
- import { resolveWebsocketHooks } from "nitro/~internal/runtime/app";
7
+ import { resolveWebsocketHooks } from "#runtime/app";
8
8
  import { hasWebSocket } from "#nitro-internal-virtual/feature-flags";
9
9
  const DURABLE_BINDING = "$DurableObject";
10
10
  const DURABLE_INSTANCE = "server";
@@ -2,7 +2,7 @@ import "#nitro-internal-polyfills";
2
2
  import wsAdapter from "crossws/adapters/cloudflare";
3
3
  import { isPublicAssetURL } from "#nitro-internal-virtual/public-assets";
4
4
  import { createHandler } from "./_module-handler.mjs";
5
- import { resolveWebsocketHooks } from "nitro/~internal/runtime/app";
5
+ import { resolveWebsocketHooks } from "#runtime/app";
6
6
  import { hasWebSocket } from "#nitro-internal-virtual/feature-flags";
7
7
  const ws = hasWebSocket ? wsAdapter({ resolve: resolveWebsocketHooks }) : undefined;
8
8
  export default createHandler({ fetch(request, env, context, url) {
@@ -2,8 +2,8 @@ import "#nitro-internal-polyfills";
2
2
  import wsAdapter from "crossws/adapters/cloudflare";
3
3
  import { useNitroApp } from "nitro/app";
4
4
  import { isPublicAssetURL } from "#nitro-internal-virtual/public-assets";
5
- import { runCronTasks } from "nitro/~internal/runtime/task";
6
- import { resolveWebsocketHooks } from "nitro/~internal/runtime/app";
5
+ import { runCronTasks } from "#runtime/task";
6
+ import { resolveWebsocketHooks } from "#runtime/app";
7
7
  import { hasWebSocket } from "#nitro-internal-virtual/feature-flags";
8
8
  const nitroApp = useNitroApp();
9
9
  const ws = hasWebSocket ? wsAdapter({ resolve: resolveWebsocketHooks }) : undefined;
@@ -1,7 +1,7 @@
1
1
  import "#nitro-internal-polyfills";
2
2
  import wsAdapter from "crossws/adapters/deno";
3
3
  import { useNitroApp } from "nitro/app";
4
- import { resolveWebsocketHooks } from "nitro/~internal/runtime/app";
4
+ import { resolveWebsocketHooks } from "#runtime/app";
5
5
  import { hasWebSocket } from "#nitro-internal-virtual/feature-flags";
6
6
  const nitroApp = useNitroApp();
7
7
  const ws = hasWebSocket ? wsAdapter({ resolve: resolveWebsocketHooks }) : undefined;
@@ -2,9 +2,9 @@ import "#nitro-internal-polyfills";
2
2
  import { serve } from "srvx/deno";
3
3
  import wsAdapter from "crossws/adapters/deno";
4
4
  import { useNitroApp } from "nitro/app";
5
- import { startScheduleRunner } from "nitro/~internal/runtime/task";
6
- import { trapUnhandledErrors } from "nitro/~internal/runtime/error/hooks";
7
- import { resolveWebsocketHooks } from "nitro/~internal/runtime/app";
5
+ import { startScheduleRunner } from "#runtime/task";
6
+ import { trapUnhandledErrors } from "#runtime/error/hooks";
7
+ import { resolveWebsocketHooks } from "#runtime/app";
8
8
  import { hasWebSocket } from "#nitro-internal-virtual/feature-flags";
9
9
  const port = Number.parseInt(process.env.NITRO_PORT || process.env.PORT || "") || 3e3;
10
10
  const host = process.env.NITRO_HOST || process.env.HOST;
@@ -3,9 +3,9 @@ import cluster from "node:cluster";
3
3
  import { NodeRequest, serve } from "srvx/node";
4
4
  import wsAdapter from "crossws/adapters/node";
5
5
  import { useNitroApp } from "nitro/app";
6
- import { startScheduleRunner } from "nitro/~internal/runtime/task";
7
- import { trapUnhandledErrors } from "nitro/~internal/runtime/error/hooks";
8
- import { resolveWebsocketHooks } from "nitro/~internal/runtime/app";
6
+ import { startScheduleRunner } from "#runtime/task";
7
+ import { trapUnhandledErrors } from "#runtime/error/hooks";
8
+ import { resolveWebsocketHooks } from "#runtime/app";
9
9
  import { hasWebSocket } from "#nitro-internal-virtual/feature-flags";
10
10
  const port = Number.parseInt(process.env.NITRO_PORT || process.env.PORT || "") || 3e3;
11
11
  const host = process.env.NITRO_HOST || process.env.HOST;
@@ -2,8 +2,8 @@ import "#nitro-internal-polyfills";
2
2
  import { toNodeHandler } from "srvx/node";
3
3
  import wsAdapter from "crossws/adapters/node";
4
4
  import { useNitroApp } from "nitro/app";
5
- import { startScheduleRunner } from "nitro/~internal/runtime/task";
6
- import { resolveWebsocketHooks } from "nitro/~internal/runtime/app";
5
+ import { startScheduleRunner } from "#runtime/task";
6
+ import { resolveWebsocketHooks } from "#runtime/app";
7
7
  import { hasWebSocket } from "#nitro-internal-virtual/feature-flags";
8
8
  const nitroApp = useNitroApp();
9
9
  export const middleware = toNodeHandler(nitroApp.fetch);
@@ -2,9 +2,9 @@ import "#nitro-internal-polyfills";
2
2
  import { NodeRequest, serve } from "srvx/node";
3
3
  import wsAdapter from "crossws/adapters/node";
4
4
  import { useNitroApp } from "nitro/app";
5
- import { startScheduleRunner } from "nitro/~internal/runtime/task";
6
- import { trapUnhandledErrors } from "nitro/~internal/runtime/error/hooks";
7
- import { resolveWebsocketHooks } from "nitro/~internal/runtime/app";
5
+ import { startScheduleRunner } from "#runtime/task";
6
+ import { trapUnhandledErrors } from "#runtime/error/hooks";
7
+ import { resolveWebsocketHooks } from "#runtime/app";
8
8
  import { hasWebSocket } from "#nitro-internal-virtual/feature-flags";
9
9
  const port = Number.parseInt(process.env.NITRO_PORT || process.env.PORT || "") || 3e3;
10
10
  const host = process.env.NITRO_HOST || process.env.HOST;
@@ -1,9 +1,2 @@
1
1
  import type { NitroRuntimeConfig } from "nitro/types";
2
2
  export declare function useRuntimeConfig(): NitroRuntimeConfig;
3
- type EnvOptions = {
4
- prefix?: string;
5
- altPrefix?: string;
6
- envExpansion?: boolean;
7
- };
8
- export declare function applyEnv(obj: Record<string, any>, opts: EnvOptions, parentKey?: string);
9
- export {};
@@ -1,5 +1,5 @@
1
+ import { applyEnv } from "./runtime-config.utils.mjs";
1
2
  import { runtimeConfig } from "#nitro-internal-virtual/runtime-config";
2
- import { snakeCase } from "scule";
3
3
  export function useRuntimeConfig() {
4
4
  return useRuntimeConfig._cached ||= getRuntimeConfig();
5
5
  }
@@ -12,43 +12,3 @@ function getRuntimeConfig() {
12
12
  });
13
13
  return runtimeConfig;
14
14
  }
15
- function getEnv(key, opts) {
16
- const envKey = snakeCase(key).toUpperCase();
17
- return process.env[opts.prefix + envKey] ?? process.env[opts.altPrefix + envKey];
18
- }
19
- function _isObject(input) {
20
- return typeof input === "object" && !Array.isArray(input);
21
- }
22
- export function applyEnv(obj, opts, parentKey = "") {
23
- for (const key in obj) {
24
- const subKey = parentKey ? `${parentKey}_${key}` : key;
25
- const envValue = getEnv(subKey, opts);
26
- if (_isObject(obj[key])) {
27
- // Same as before
28
- if (_isObject(envValue)) {
29
- obj[key] = {
30
- ...obj[key],
31
- ...envValue
32
- };
33
- applyEnv(obj[key], opts, subKey);
34
- } else if (envValue === undefined) {
35
- applyEnv(obj[key], opts, subKey);
36
- } else {
37
- obj[key] = envValue ?? obj[key];
38
- }
39
- } else {
40
- obj[key] = envValue ?? obj[key];
41
- }
42
- // Experimental env expansion
43
- if (opts.envExpansion && typeof obj[key] === "string") {
44
- obj[key] = _expandFromEnv(obj[key]);
45
- }
46
- }
47
- return obj;
48
- }
49
- const envExpandRx = /\{\{([^{}]*)\}\}/g;
50
- function _expandFromEnv(value) {
51
- return value.replace(envExpandRx, (match, key) => {
52
- return process.env[key] || match;
53
- });
54
- }
@@ -0,0 +1,7 @@
1
+ type EnvOptions = {
2
+ prefix?: string;
3
+ altPrefix?: string;
4
+ envExpansion?: boolean;
5
+ };
6
+ export declare function applyEnv(obj: Record<string, any>, opts: EnvOptions, parentKey?: string);
7
+ export {};
@@ -0,0 +1,41 @@
1
+ import { snakeCase } from "scule";
2
+ export function applyEnv(obj, opts, parentKey = "") {
3
+ for (const key in obj) {
4
+ const subKey = parentKey ? `${parentKey}_${key}` : key;
5
+ const envValue = getEnv(subKey, opts);
6
+ if (_isObject(obj[key])) {
7
+ // Same as before
8
+ if (_isObject(envValue)) {
9
+ obj[key] = {
10
+ ...obj[key],
11
+ ...envValue
12
+ };
13
+ applyEnv(obj[key], opts, subKey);
14
+ } else if (envValue === undefined) {
15
+ applyEnv(obj[key], opts, subKey);
16
+ } else {
17
+ obj[key] = envValue ?? obj[key];
18
+ }
19
+ } else {
20
+ obj[key] = envValue ?? obj[key];
21
+ }
22
+ // Experimental env expansion
23
+ if (opts.envExpansion && typeof obj[key] === "string") {
24
+ obj[key] = _expandFromEnv(obj[key]);
25
+ }
26
+ }
27
+ return obj;
28
+ }
29
+ const envExpandRx = /\{\{([^{}]*)\}\}/g;
30
+ function _expandFromEnv(value) {
31
+ return value.replace(envExpandRx, (match, key) => {
32
+ return process.env[key] || match;
33
+ });
34
+ }
35
+ function getEnv(key, opts) {
36
+ const envKey = snakeCase(key).toUpperCase();
37
+ return process.env[opts.prefix + envKey] ?? process.env[opts.altPrefix + envKey];
38
+ }
39
+ function _isObject(input) {
40
+ return typeof input === "object" && !Array.isArray(input);
41
+ }
@@ -2,7 +2,7 @@ import "#nitro-internal-polyfills";
2
2
  import wsAdapter from "crossws/adapters/node";
3
3
 
4
4
  import { useNitroApp } from "nitro/app";
5
- import { resolveWebsocketHooks } from "nitro/~internal/runtime/app";
5
+ import { resolveWebsocketHooks } from "#runtime/app";
6
6
  import { hasWebSocket } from "#nitro-internal-virtual/feature-flags";
7
7
 
8
8
  const nitroApp = useNitroApp();
@@ -1,4 +1,4 @@
1
- import { fetchViteEnv } from "nitro/vite/runtime";
1
+ import { fetchViteEnv } from "#vite-runtime";
2
2
 
3
3
  /** @param {{ req: Request }} HTTPEvent */
4
4
  export default function ssrRenderer({ req }) {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nitro-nightly",
3
- "version": "3.0.1-20251211-104342-6f7889e0",
3
+ "version": "3.0.1-20251211-155448-9dc8f6b6",
4
4
  "description": "Build and Deploy Universal JavaScript Servers",
5
5
  "homepage": "https://nitro.build",
6
6
  "repository": "nitrojs/nitro",
@@ -24,9 +24,11 @@
24
24
  "./task": "./dist/runtime/task.mjs",
25
25
  "./tsconfig": "./lib/tsconfig.json",
26
26
  "./types": "./dist/types/index.mjs",
27
- "./vite": "./dist/vite.mjs",
28
- "./vite/runtime": "./dist/runtime/vite-runtime.mjs",
29
- "./~internal/runtime/*": "./dist/runtime/internal/*.mjs"
27
+ "./vite": "./dist/vite.mjs"
28
+ },
29
+ "imports": {
30
+ "#runtime/*": "./dist/runtime/internal/*.mjs",
31
+ "#vite-runtime": "./dist/runtime/vite-runtime.mjs"
30
32
  },
31
33
  "types": "./lib/index.d.mts",
32
34
  "bin": {