nitro-nightly 4.0.0-20251010-091516-7cafddba → 4.0.0-20251030-091344-d4418b98
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/dist/{_chunks/build2.mjs → _build/build.mjs} +108 -58
- package/dist/_build/build2.mjs +556 -0
- package/dist/_build/info.mjs +1002 -0
- package/dist/_build/prepare.mjs +1511 -0
- package/dist/_build/snapshot.mjs +185 -0
- package/dist/{_chunks/plugin.mjs → _build/vite.mjs} +295 -296
- package/dist/_build/vite2.mjs +149 -0
- package/dist/_chunks/_deps/@jridgewell/gen-mapping.mjs +189 -0
- package/dist/_chunks/_deps/@jridgewell/remapping.mjs +137 -0
- package/dist/_chunks/_deps/@jridgewell/resolve-uri.mjs +231 -0
- package/dist/_chunks/_deps/@jridgewell/sourcemap-codec.mjs +173 -0
- package/dist/_chunks/_deps/@jridgewell/trace-mapping.mjs +170 -0
- package/dist/_chunks/_deps/@pi0/vite-plugin-fullstack.mjs +575 -0
- package/dist/_chunks/_deps/@rollup/plugin-alias.mjs +89 -0
- package/dist/_chunks/_deps/@rollup/plugin-commonjs.mjs +2376 -0
- package/dist/_chunks/{index2.mjs → _deps/@rollup/plugin-inject.mjs} +5 -90
- package/dist/_chunks/_deps/@rollup/plugin-json.mjs +37 -0
- package/dist/_chunks/_deps/@rollup/plugin-node-resolve.mjs +1386 -0
- package/dist/_chunks/_deps/@rollup/plugin-replace.mjs +133 -0
- package/dist/_chunks/_deps/@rollup/pluginutils.mjs +346 -0
- package/dist/_chunks/_deps/acorn.mjs +6225 -0
- package/dist/_chunks/_deps/c12.mjs +510 -0
- package/dist/_chunks/_deps/chokidar.mjs +1428 -0
- package/dist/_chunks/_deps/citty.mjs +460 -0
- package/dist/_chunks/_deps/commondir.mjs +77 -0
- package/dist/_chunks/_deps/compatx.mjs +76 -0
- package/dist/_chunks/_deps/confbox.mjs +300 -0
- package/dist/_chunks/_deps/debug.mjs +885 -0
- package/dist/_chunks/_deps/deepmerge.mjs +147 -0
- package/dist/_chunks/_deps/depd.mjs +550 -0
- package/dist/_chunks/_deps/dot-prop.mjs +282 -0
- package/dist/_chunks/_deps/dotenv.mjs +555 -0
- package/dist/_chunks/_deps/duplexer.mjs +1 -0
- package/dist/_chunks/_deps/ee-first.mjs +104 -0
- package/dist/_chunks/_deps/encodeurl.mjs +69 -0
- package/dist/_chunks/_deps/escape-html.mjs +87 -0
- package/dist/_chunks/_deps/escape-string-regexp.mjs +13 -0
- package/dist/_chunks/_deps/estree-walker.mjs +433 -0
- package/dist/_chunks/_deps/etag.mjs +147 -0
- package/dist/_chunks/_deps/exsolve.mjs +1416 -0
- package/dist/_chunks/_deps/fdir.mjs +569 -0
- package/dist/_chunks/_deps/fresh.mjs +145 -0
- package/dist/_chunks/_deps/function-bind.mjs +106 -0
- package/dist/_chunks/{index4.mjs → _deps/giget.mjs} +21 -776
- package/dist/_chunks/_deps/gzip-size.mjs +19 -0
- package/dist/_chunks/_deps/hasown.mjs +19 -0
- package/dist/_chunks/_deps/http-errors.mjs +307 -0
- package/dist/_chunks/_deps/httpxy.mjs +580 -0
- package/dist/_chunks/_deps/inherits.mjs +57 -0
- package/dist/_chunks/_deps/is-core-module.mjs +596 -0
- package/dist/_chunks/_deps/is-module.mjs +25 -0
- package/dist/_chunks/_deps/is-reference.mjs +31 -0
- package/dist/_chunks/_deps/js-tokens.mjs +411 -0
- package/dist/_chunks/_deps/klona.mjs +137 -0
- package/dist/_chunks/_deps/knitwork.mjs +172 -0
- package/dist/_chunks/_deps/local-pkg.mjs +163 -0
- package/dist/_chunks/_deps/magic-string.mjs +1296 -0
- package/dist/_chunks/_deps/mime-db.mjs +11685 -0
- package/dist/_chunks/_deps/mime-types.mjs +287 -0
- package/dist/_chunks/_deps/mime.mjs +1172 -0
- package/dist/_chunks/_deps/mlly.mjs +2413 -0
- package/dist/_chunks/_deps/ms.mjs +172 -0
- package/dist/_chunks/_deps/node-fetch-native.mjs +3 -0
- package/dist/_chunks/_deps/nypm.mjs +219 -0
- package/dist/_chunks/_deps/on-finished.mjs +246 -0
- package/dist/_chunks/_deps/parseurl.mjs +168 -0
- package/dist/_chunks/_deps/path-parse.mjs +85 -0
- package/dist/_chunks/{pathe.M-eThtNZ.mjs → _deps/pathe.mjs} +48 -1
- package/dist/_chunks/_deps/perfect-debounce.mjs +88 -0
- package/dist/_chunks/_deps/picomatch.mjs +2144 -0
- package/dist/_chunks/_deps/pkg-types.mjs +247 -0
- package/dist/_chunks/{snapshot.mjs → _deps/pretty-bytes.mjs} +1 -105
- package/dist/_chunks/_deps/quansync.mjs +99 -0
- package/dist/_chunks/_deps/range-parser.mjs +171 -0
- package/dist/_chunks/_deps/rc9.mjs +219 -0
- package/dist/_chunks/_deps/readdirp.mjs +245 -0
- package/dist/_chunks/_deps/resolve.mjs +1260 -0
- package/dist/_chunks/_deps/rou3.mjs +326 -0
- package/dist/_chunks/_deps/send.mjs +1022 -0
- package/dist/_chunks/_deps/serve-static.mjs +228 -0
- package/dist/_chunks/_deps/setprototypeof.mjs +26 -0
- package/dist/_chunks/_deps/statuses.mjs +457 -0
- package/dist/_chunks/_deps/std-env.mjs +3 -0
- package/dist/_chunks/_deps/strip-literal.mjs +67 -0
- package/dist/_chunks/_deps/supports-color.mjs +44 -0
- package/dist/_chunks/_deps/tinyexec.mjs +552 -0
- package/dist/_chunks/_deps/tinyglobby.mjs +293 -0
- package/dist/_chunks/_deps/toidentifier.mjs +41 -0
- package/dist/_chunks/_deps/ultrahtml.mjs +3 -0
- package/dist/_chunks/_deps/unimport.mjs +2267 -0
- package/dist/_chunks/_deps/unplugin-utils.mjs +65 -0
- package/dist/_chunks/_deps/unplugin.mjs +1294 -0
- package/dist/_chunks/_deps/untyped.mjs +375 -0
- package/dist/_chunks/{info.mjs → _deps/unwasm.mjs} +8 -4206
- package/dist/_chunks/_deps/webpack-virtual-modules.mjs +360 -0
- package/dist/_chunks/_presets/_all.mjs +59 -0
- package/dist/_chunks/_presets/_nitro.mjs +74 -0
- package/dist/_chunks/_presets/_resolve.mjs +64 -0
- package/dist/_chunks/_presets/_static.mjs +69 -0
- package/dist/_chunks/_presets/_types.mjs +3 -0
- package/dist/_chunks/_presets/_utils.mjs +31 -0
- package/dist/_chunks/_presets/alwaysdata.mjs +17 -0
- package/dist/_chunks/_presets/aws-amplify.mjs +111 -0
- package/dist/_chunks/_presets/aws-lambda.mjs +23 -0
- package/dist/_chunks/_presets/azure.mjs +162 -0
- package/dist/_chunks/_presets/bun.mjs +19 -0
- package/dist/_chunks/_presets/cleavr.mjs +15 -0
- package/dist/_chunks/_presets/cloudflare.mjs +608 -0
- package/dist/_chunks/_presets/deno.mjs +196 -0
- package/dist/_chunks/_presets/digitalocean.mjs +14 -0
- package/dist/_chunks/_presets/firebase.mjs +47 -0
- package/dist/_chunks/_presets/flightcontrol.mjs +14 -0
- package/dist/_chunks/_presets/genezio.mjs +13 -0
- package/dist/_chunks/_presets/heroku.mjs +14 -0
- package/dist/_chunks/_presets/iis.mjs +194 -0
- package/dist/_chunks/_presets/index.mjs +62 -0
- package/dist/_chunks/_presets/koyeb.mjs +14 -0
- package/dist/_chunks/_presets/netlify.mjs +241 -0
- package/dist/_chunks/_presets/node.mjs +54 -0
- package/dist/_chunks/_presets/platform.mjs +14 -0
- package/dist/_chunks/_presets/render.mjs +14 -0
- package/dist/_chunks/_presets/standard.mjs +23 -0
- package/dist/_chunks/_presets/stormkit.mjs +18 -0
- package/dist/_chunks/_presets/vercel.mjs +375 -0
- package/dist/_chunks/_presets/winterjs.mjs +22 -0
- package/dist/_chunks/_presets/zeabur.mjs +69 -0
- package/dist/_chunks/_presets/zerops.mjs +27 -0
- package/dist/_chunks/app.mjs +9 -19206
- package/dist/_chunks/{index3.mjs → builder.mjs} +560 -970
- package/dist/_chunks/server.mjs +6 -4
- package/dist/{cli → _cli}/build.mjs +3 -8
- package/dist/{cli → _cli}/dev.mjs +38 -12
- package/dist/{cli/index2.mjs → _cli/index.mjs} +1 -2
- package/dist/{cli → _cli}/list.mjs +3 -4
- package/dist/{cli → _cli}/prepare.mjs +3 -4
- package/dist/{cli → _cli}/run.mjs +3 -4
- package/dist/{index.d.mts → builder.d.mts} +11 -11
- package/dist/builder.mjs +117 -0
- package/dist/cli/index.mjs +7 -464
- package/dist/node_modules/@speed-highlight/core/dist/index.js +1 -1
- package/dist/node_modules/@speed-highlight/core/dist/terminal.js +1 -1
- package/dist/node_modules/@speed-highlight/core/package.json +7 -3
- package/dist/node_modules/cookie-es/dist/index.mjs +262 -0
- package/dist/node_modules/cookie-es/package.json +37 -0
- package/dist/node_modules/hookable/dist/index.mjs +243 -266
- package/dist/node_modules/hookable/package.json +29 -26
- package/dist/node_modules/rendu/dist/index.mjs +380 -0
- package/dist/node_modules/rendu/package.json +47 -0
- package/dist/presets/_nitro/runtime/nitro-dev.mjs +4 -7
- package/dist/presets/_nitro/runtime/nitro-prerenderer.mjs +5 -4
- package/dist/presets/azure/runtime/azure-swa.mjs +1 -1
- package/dist/presets/cloudflare/runtime/_module-handler.mjs +7 -6
- package/dist/presets/cloudflare/runtime/cloudflare-durable.mjs +4 -5
- package/dist/presets/cloudflare/runtime/plugin.dev.mjs +7 -10
- package/dist/presets/cloudflare/runtime/shims/workers.dev.d.mts +21 -0
- package/dist/presets/cloudflare/runtime/shims/workers.dev.mjs +27 -0
- package/dist/presets/node/runtime/node-server.mjs +1 -1
- package/dist/runtime/index.d.mts +1 -1
- package/dist/runtime/index.mjs +1 -1
- package/dist/runtime/internal/app.d.mts +3 -1
- package/dist/runtime/internal/app.mjs +90 -64
- package/dist/runtime/internal/error/prod.d.mts +3 -2
- package/dist/runtime/internal/error/prod.mjs +9 -13
- package/dist/runtime/internal/renderer.mjs +4 -4
- package/dist/runtime/internal/routes/dev-tasks.d.mts +30 -2
- package/dist/runtime/internal/shutdown.d.mts +1 -2
- package/dist/runtime/internal/shutdown.mjs +3 -2
- package/dist/runtime/internal/task.mjs +1 -2
- package/dist/types/index.d.mts +1603 -10
- package/dist/vite.d.mts +5 -0
- package/dist/vite.mjs +94 -30
- package/lib/index.mjs +1 -0
- package/lib/indexd.mts +1 -0
- package/lib/runtime/meta.mjs +35 -0
- package/package.json +40 -41
- package/dist/_chunks/build.mjs +0 -84
- package/dist/_chunks/build3.mjs +0 -6452
- package/dist/_chunks/detect-acorn.mjs +0 -503
- package/dist/_chunks/index.mjs +0 -22242
- package/dist/_chunks/json5.mjs +0 -68
- package/dist/_chunks/jsonc.mjs +0 -51
- package/dist/_chunks/toml.mjs +0 -259
- package/dist/_chunks/yaml.mjs +0 -86
- package/dist/index.mjs +0 -55
- package/dist/node_modules/klona/dist/index.mjs +0 -81
- package/dist/node_modules/klona/full/index.mjs +0 -53
- package/dist/node_modules/klona/package.json +0 -74
- package/dist/node_modules/std-env/dist/index.mjs +0 -1
- package/dist/node_modules/std-env/package.json +0 -46
- package/dist/presets.mjs +0 -2460
- package/dist/runtime/internal/debug.d.mts +0 -2
- package/dist/runtime/internal/debug.mjs +0 -5
- package/lib/runtime-meta.mjs +0 -38
- /package/dist/{cli → _cli}/common.mjs +0 -0
- /package/lib/{runtime-meta.d.mts → runtime/meta.d.mts} +0 -0
|
@@ -0,0 +1,380 @@
|
|
|
1
|
+
import { FastResponse } from "srvx";
|
|
2
|
+
|
|
3
|
+
//#region src/parser.ts
|
|
4
|
+
function parseTemplate(template) {
|
|
5
|
+
if (!template) return [];
|
|
6
|
+
template = template.replace(/<script\s+server\s*>([\s\S]*?)<\/script>/gi, (_m, code) => `<?js${code}?>`);
|
|
7
|
+
template = template.replace(/{{\s*(.+)\s*}}|{{{\s*(.+)\s*}}}/g, (_m, code) => {
|
|
8
|
+
if (code[0] === "{") return `<?=${code.slice(1, -1).trim()}?>`;
|
|
9
|
+
return `<?=htmlspecialchars(${code.trim()})?>`;
|
|
10
|
+
});
|
|
11
|
+
const tokens = [];
|
|
12
|
+
const re = /<\?(?:js)?(?<equals>=)?(?<value>[\s\S]*?)\?>/g;
|
|
13
|
+
let cursor = 0;
|
|
14
|
+
let match;
|
|
15
|
+
while (match = re.exec(template)) {
|
|
16
|
+
const { equals, value } = match.groups || {};
|
|
17
|
+
const matchStart = match.index;
|
|
18
|
+
const matchEnd = matchStart + match[0].length;
|
|
19
|
+
if (matchStart > cursor) {
|
|
20
|
+
const textContent = template.slice(cursor, matchStart);
|
|
21
|
+
if (textContent) tokens.push({
|
|
22
|
+
type: "text",
|
|
23
|
+
contents: textContent
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
if (equals) tokens.push({
|
|
27
|
+
type: "expr",
|
|
28
|
+
contents: value || ""
|
|
29
|
+
});
|
|
30
|
+
else tokens.push({
|
|
31
|
+
type: "code",
|
|
32
|
+
contents: value || ""
|
|
33
|
+
});
|
|
34
|
+
cursor = matchEnd;
|
|
35
|
+
}
|
|
36
|
+
if (cursor < template.length) {
|
|
37
|
+
const remainingText = template.slice(cursor);
|
|
38
|
+
if (remainingText) tokens.push({
|
|
39
|
+
type: "text",
|
|
40
|
+
contents: remainingText
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
return tokens;
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Check if a template string contains template syntax.
|
|
47
|
+
*/
|
|
48
|
+
function hasTemplateSyntax(template) {
|
|
49
|
+
return /(?:<script\s+server\s*>[\s\S]*?<\/script>)|(?:<\?(?:js)?=?[\s\S]*?\?>)|(?:\{\{[\s\S]*?\}\})/i.test(template);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
//#endregion
|
|
53
|
+
//#region src/_runtime.ts
|
|
54
|
+
function runtimeStream(body) {
|
|
55
|
+
return `const __chunks__ = [];const echo = (chunk) => { __chunks__.push(chunk); };${body};
|
|
56
|
+
function concatStreams(chunks) {
|
|
57
|
+
const encoder = new TextEncoder();
|
|
58
|
+
return new ReadableStream({
|
|
59
|
+
async pull(controller) {
|
|
60
|
+
for (let chunk of chunks) {
|
|
61
|
+
if (typeof chunk === 'function'){
|
|
62
|
+
chunk = chunk();
|
|
63
|
+
}
|
|
64
|
+
if (chunk instanceof Promise) {
|
|
65
|
+
chunk = await chunk;
|
|
66
|
+
if (!chunk) continue;
|
|
67
|
+
if (chunk instanceof Response){
|
|
68
|
+
chunk = chunk.body;
|
|
69
|
+
}
|
|
70
|
+
if (!(chunk instanceof ReadableStream)) {
|
|
71
|
+
controller.enqueue(chunk instanceof Uint8Array ? chunk : encoder.encode(chunk));
|
|
72
|
+
continue;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
if (chunk instanceof ReadableStream) {
|
|
76
|
+
const reader = chunk.getReader();
|
|
77
|
+
while (true) {
|
|
78
|
+
const { value, done } = await reader.read();
|
|
79
|
+
if (done) break;
|
|
80
|
+
controller.enqueue(value);
|
|
81
|
+
}
|
|
82
|
+
reader.releaseLock();
|
|
83
|
+
} else {
|
|
84
|
+
controller.enqueue(chunk instanceof Uint8Array ? chunk : encoder.encode(chunk));
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
controller.close();
|
|
88
|
+
},
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
return concatStreams(__chunks__);
|
|
92
|
+
`;
|
|
93
|
+
}
|
|
94
|
+
function runtimeText(body) {
|
|
95
|
+
return `const __chunks__ = [];const echo = (chunk) => { __chunks__.push(chunk); };${body};
|
|
96
|
+
let __out__ = "";
|
|
97
|
+
for(let chunk of __chunks__){
|
|
98
|
+
if (typeof chunk === 'function'){
|
|
99
|
+
chunk = chunk();
|
|
100
|
+
}
|
|
101
|
+
if (chunk instanceof Promise){
|
|
102
|
+
chunk = await chunk;
|
|
103
|
+
}
|
|
104
|
+
if (chunk instanceof Response){
|
|
105
|
+
chunk = chunk.body;
|
|
106
|
+
}
|
|
107
|
+
if (chunk instanceof ReadableStream){
|
|
108
|
+
const reader = chunk.getReader();
|
|
109
|
+
while(true){
|
|
110
|
+
const {value, done} = await reader.read();
|
|
111
|
+
if(done) break;
|
|
112
|
+
__out__ += typeof value === "string" ? value : new TextDecoder().decode(value);
|
|
113
|
+
}
|
|
114
|
+
reader.releaseLock();
|
|
115
|
+
} else {
|
|
116
|
+
__out__ += typeof chunk === "string" ? chunk : new TextDecoder().decode(chunk);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
return __out__;
|
|
120
|
+
`;
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
//#endregion
|
|
124
|
+
//#region src/compiler.ts
|
|
125
|
+
/**
|
|
126
|
+
* Compile a template string into a render function.
|
|
127
|
+
*
|
|
128
|
+
* @example
|
|
129
|
+
* ```ts
|
|
130
|
+
* import { compileTemplate } from "rendu";
|
|
131
|
+
*
|
|
132
|
+
* const template = `
|
|
133
|
+
* <h1>{{ title }}</h1>
|
|
134
|
+
* <ul>
|
|
135
|
+
* <? for (const item of items) { ?>
|
|
136
|
+
* <li>{{ item }}</li>
|
|
137
|
+
* <? } ?>
|
|
138
|
+
* </ul>
|
|
139
|
+
* `;
|
|
140
|
+
*
|
|
141
|
+
* const render = compileTemplate(template, { stream: false });
|
|
142
|
+
*
|
|
143
|
+
* const html = await render({ title: "My List", items: ["Item 1", "Item 2", "Item 3"] });
|
|
144
|
+
* console.log(html);
|
|
145
|
+
* // Output:
|
|
146
|
+
* // <h1>My List</h1>
|
|
147
|
+
* // <ul>
|
|
148
|
+
* // <li>Item 1</li>
|
|
149
|
+
* // <li>Item 2</li>
|
|
150
|
+
* // <li>Item 3</li>
|
|
151
|
+
* // </ul>
|
|
152
|
+
* ```
|
|
153
|
+
*/
|
|
154
|
+
function compileTemplate(template, opts = {}) {
|
|
155
|
+
const body = compileTemplateToString(template, opts, false);
|
|
156
|
+
const sourcemaps = opts.filename ? `\n//# sourceURL=${opts.filename}` : "";
|
|
157
|
+
try {
|
|
158
|
+
const AsyncFunction = Object.getPrototypeOf(async () => {}).constructor;
|
|
159
|
+
return new AsyncFunction("__context__", body + sourcemaps);
|
|
160
|
+
} catch (error) {
|
|
161
|
+
throw new SyntaxError(`Template syntax error: ${error.message}`, {});
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* Compile a template string into a render function code string.
|
|
166
|
+
*
|
|
167
|
+
* **Note:** This function is for advanced use cases where you need the generated code as a string.
|
|
168
|
+
*/
|
|
169
|
+
function compileTemplateToString(template, opts, asyncWrapper) {
|
|
170
|
+
const parts = [];
|
|
171
|
+
const tokens = parseTemplate(template);
|
|
172
|
+
for (const token of tokens) switch (token.type) {
|
|
173
|
+
case "text":
|
|
174
|
+
if (opts.preserveLines) for (const line of token.contents.split("\n")) parts.push(`echo(${JSON.stringify(line + "\n")})\n`);
|
|
175
|
+
else parts.push(`echo(${JSON.stringify(token.contents)})`);
|
|
176
|
+
break;
|
|
177
|
+
case "expr":
|
|
178
|
+
parts.push(`echo(${token.contents})`);
|
|
179
|
+
break;
|
|
180
|
+
case "code":
|
|
181
|
+
parts.push(token.contents);
|
|
182
|
+
break;
|
|
183
|
+
}
|
|
184
|
+
let body = parts.join(opts.preserveLines ? ";" : "\n");
|
|
185
|
+
body = opts.contextKeys ? `const {${opts.contextKeys.join(",")}}=__context__;${body}` : `with(__context__){${body}}`;
|
|
186
|
+
body = opts.stream === false ? runtimeText(body) : runtimeStream(body);
|
|
187
|
+
return asyncWrapper === false ? body : `(async (__context__) => {${body}})`;
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
//#endregion
|
|
191
|
+
//#region node_modules/.pnpm/cookie-es@2.0.0/node_modules/cookie-es/dist/index.mjs
|
|
192
|
+
function parse(str, options) {
|
|
193
|
+
if (typeof str !== "string") throw new TypeError("argument str must be a string");
|
|
194
|
+
const obj = {};
|
|
195
|
+
const opt = options || {};
|
|
196
|
+
const dec = opt.decode || decode;
|
|
197
|
+
let index = 0;
|
|
198
|
+
while (index < str.length) {
|
|
199
|
+
const eqIdx = str.indexOf("=", index);
|
|
200
|
+
if (eqIdx === -1) break;
|
|
201
|
+
let endIdx = str.indexOf(";", index);
|
|
202
|
+
if (endIdx === -1) endIdx = str.length;
|
|
203
|
+
else if (endIdx < eqIdx) {
|
|
204
|
+
index = str.lastIndexOf(";", eqIdx - 1) + 1;
|
|
205
|
+
continue;
|
|
206
|
+
}
|
|
207
|
+
const key = str.slice(index, eqIdx).trim();
|
|
208
|
+
if (opt?.filter && !opt?.filter(key)) {
|
|
209
|
+
index = endIdx + 1;
|
|
210
|
+
continue;
|
|
211
|
+
}
|
|
212
|
+
if (void 0 === obj[key]) {
|
|
213
|
+
let val = str.slice(eqIdx + 1, endIdx).trim();
|
|
214
|
+
if (val.codePointAt(0) === 34) val = val.slice(1, -1);
|
|
215
|
+
obj[key] = tryDecode(val, dec);
|
|
216
|
+
}
|
|
217
|
+
index = endIdx + 1;
|
|
218
|
+
}
|
|
219
|
+
return obj;
|
|
220
|
+
}
|
|
221
|
+
function decode(str) {
|
|
222
|
+
return str.includes("%") ? decodeURIComponent(str) : str;
|
|
223
|
+
}
|
|
224
|
+
function tryDecode(str, decode2) {
|
|
225
|
+
try {
|
|
226
|
+
return decode2(str);
|
|
227
|
+
} catch {
|
|
228
|
+
return str;
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
const fieldContentRegExp = /^[\u0009\u0020-\u007E\u0080-\u00FF]+$/;
|
|
232
|
+
function serialize(name, value, options) {
|
|
233
|
+
const opt = options || {};
|
|
234
|
+
const enc = opt.encode || encodeURIComponent;
|
|
235
|
+
if (typeof enc !== "function") throw new TypeError("option encode is invalid");
|
|
236
|
+
if (!fieldContentRegExp.test(name)) throw new TypeError("argument name is invalid");
|
|
237
|
+
const encodedValue = enc(value);
|
|
238
|
+
if (encodedValue && !fieldContentRegExp.test(encodedValue)) throw new TypeError("argument val is invalid");
|
|
239
|
+
let str = name + "=" + encodedValue;
|
|
240
|
+
if (void 0 !== opt.maxAge && opt.maxAge !== null) {
|
|
241
|
+
const maxAge = opt.maxAge - 0;
|
|
242
|
+
if (Number.isNaN(maxAge) || !Number.isFinite(maxAge)) throw new TypeError("option maxAge is invalid");
|
|
243
|
+
str += "; Max-Age=" + Math.floor(maxAge);
|
|
244
|
+
}
|
|
245
|
+
if (opt.domain) {
|
|
246
|
+
if (!fieldContentRegExp.test(opt.domain)) throw new TypeError("option domain is invalid");
|
|
247
|
+
str += "; Domain=" + opt.domain;
|
|
248
|
+
}
|
|
249
|
+
if (opt.path) {
|
|
250
|
+
if (!fieldContentRegExp.test(opt.path)) throw new TypeError("option path is invalid");
|
|
251
|
+
str += "; Path=" + opt.path;
|
|
252
|
+
}
|
|
253
|
+
if (opt.expires) {
|
|
254
|
+
if (!isDate(opt.expires) || Number.isNaN(opt.expires.valueOf())) throw new TypeError("option expires is invalid");
|
|
255
|
+
str += "; Expires=" + opt.expires.toUTCString();
|
|
256
|
+
}
|
|
257
|
+
if (opt.httpOnly) str += "; HttpOnly";
|
|
258
|
+
if (opt.secure) str += "; Secure";
|
|
259
|
+
if (opt.priority) switch (typeof opt.priority === "string" ? opt.priority.toLowerCase() : opt.priority) {
|
|
260
|
+
case "low":
|
|
261
|
+
str += "; Priority=Low";
|
|
262
|
+
break;
|
|
263
|
+
case "medium":
|
|
264
|
+
str += "; Priority=Medium";
|
|
265
|
+
break;
|
|
266
|
+
case "high":
|
|
267
|
+
str += "; Priority=High";
|
|
268
|
+
break;
|
|
269
|
+
default: throw new TypeError("option priority is invalid");
|
|
270
|
+
}
|
|
271
|
+
if (opt.sameSite) switch (typeof opt.sameSite === "string" ? opt.sameSite.toLowerCase() : opt.sameSite) {
|
|
272
|
+
case true:
|
|
273
|
+
str += "; SameSite=Strict";
|
|
274
|
+
break;
|
|
275
|
+
case "lax":
|
|
276
|
+
str += "; SameSite=Lax";
|
|
277
|
+
break;
|
|
278
|
+
case "strict":
|
|
279
|
+
str += "; SameSite=Strict";
|
|
280
|
+
break;
|
|
281
|
+
case "none":
|
|
282
|
+
str += "; SameSite=None";
|
|
283
|
+
break;
|
|
284
|
+
default: throw new TypeError("option sameSite is invalid");
|
|
285
|
+
}
|
|
286
|
+
if (opt.partitioned) str += "; Partitioned";
|
|
287
|
+
return str;
|
|
288
|
+
}
|
|
289
|
+
function isDate(val) {
|
|
290
|
+
return Object.prototype.toString.call(val) === "[object Date]" || val instanceof Date;
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
//#endregion
|
|
294
|
+
//#region src/render.ts
|
|
295
|
+
/**
|
|
296
|
+
* Renders an HTML template to a Response object.
|
|
297
|
+
*
|
|
298
|
+
* @example
|
|
299
|
+
* ```ts
|
|
300
|
+
* import { compileTemplate, renderToResponse } from "rendu";
|
|
301
|
+
*
|
|
302
|
+
* const render = compileTemplate(template, { stream: true });
|
|
303
|
+
*
|
|
304
|
+
* const response = await renderToResponse(render, { request });
|
|
305
|
+
* ```
|
|
306
|
+
* @param htmlTemplate The compiled HTML template.
|
|
307
|
+
* @param opts Options for rendering.
|
|
308
|
+
* @returns A Response object.
|
|
309
|
+
*/
|
|
310
|
+
async function renderToResponse(htmlTemplate, opts) {
|
|
311
|
+
const ctx = createRenderContext(opts);
|
|
312
|
+
const body = await htmlTemplate(ctx);
|
|
313
|
+
if (body instanceof Response) return body;
|
|
314
|
+
return new FastResponse(body, {
|
|
315
|
+
status: ctx.$RESPONSE.status,
|
|
316
|
+
statusText: ctx.$RESPONSE.statusText,
|
|
317
|
+
headers: ctx.$RESPONSE.headers
|
|
318
|
+
});
|
|
319
|
+
}
|
|
320
|
+
const RENDER_CONTEXT_KEYS = [
|
|
321
|
+
"htmlspecialchars",
|
|
322
|
+
"setCookie",
|
|
323
|
+
"redirect",
|
|
324
|
+
"$REQUEST",
|
|
325
|
+
"$METHOD",
|
|
326
|
+
"$URL",
|
|
327
|
+
"$HEADERS",
|
|
328
|
+
"$COOKIES",
|
|
329
|
+
"$RESPONSE"
|
|
330
|
+
];
|
|
331
|
+
function createRenderContext(options) {
|
|
332
|
+
const url = new URL(options.request?.url || "http://_");
|
|
333
|
+
const response = {
|
|
334
|
+
status: 200,
|
|
335
|
+
statusText: "OK",
|
|
336
|
+
headers: new Headers({ "Content-Type": "text/html ; charset=utf-8" })
|
|
337
|
+
};
|
|
338
|
+
const $COOKIES = lazyCookies(options.request);
|
|
339
|
+
const setCookie = (name, value, sOpts = {}) => {
|
|
340
|
+
response.headers.append("Set-Cookie", serialize(name, value, sOpts));
|
|
341
|
+
};
|
|
342
|
+
const redirect = (to, status = 302) => {
|
|
343
|
+
response.status = status;
|
|
344
|
+
response.headers.set("Location", to);
|
|
345
|
+
};
|
|
346
|
+
return {
|
|
347
|
+
...options.context,
|
|
348
|
+
htmlspecialchars,
|
|
349
|
+
setCookie,
|
|
350
|
+
redirect,
|
|
351
|
+
$REQUEST: options.request,
|
|
352
|
+
$METHOD: options.request?.method,
|
|
353
|
+
$URL: url,
|
|
354
|
+
$HEADERS: options.request?.headers,
|
|
355
|
+
$COOKIES,
|
|
356
|
+
$RESPONSE: response
|
|
357
|
+
};
|
|
358
|
+
}
|
|
359
|
+
function lazyCookies(req) {
|
|
360
|
+
if (!req) return {};
|
|
361
|
+
let parsed;
|
|
362
|
+
return new Proxy(Object.freeze(Object.create(null)), { get(_, prop) {
|
|
363
|
+
if (typeof prop !== "string") return void 0;
|
|
364
|
+
parsed ??= parse(req.headers.get("cookie") || "");
|
|
365
|
+
return parsed[prop];
|
|
366
|
+
} });
|
|
367
|
+
}
|
|
368
|
+
function htmlspecialchars(s) {
|
|
369
|
+
const htmlSpecialCharsMap = {
|
|
370
|
+
"&": "&",
|
|
371
|
+
"<": "<",
|
|
372
|
+
">": ">",
|
|
373
|
+
"\"": """,
|
|
374
|
+
"'": "'"
|
|
375
|
+
};
|
|
376
|
+
return String(s).replace(/[&<>"']/g, (c) => htmlSpecialCharsMap[c] || c);
|
|
377
|
+
}
|
|
378
|
+
|
|
379
|
+
//#endregion
|
|
380
|
+
export { RENDER_CONTEXT_KEYS, compileTemplate, compileTemplateToString, createRenderContext, hasTemplateSyntax, renderToResponse };
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "rendu",
|
|
3
|
+
"version": "0.0.7",
|
|
4
|
+
"description": "",
|
|
5
|
+
"repository": "h3js/rendu",
|
|
6
|
+
"license": "MIT",
|
|
7
|
+
"sideEffects": false,
|
|
8
|
+
"type": "module",
|
|
9
|
+
"exports": {
|
|
10
|
+
".": "./dist/index.mjs"
|
|
11
|
+
},
|
|
12
|
+
"types": "./dist/index.d.mts",
|
|
13
|
+
"bin": "./dist/cli.mjs",
|
|
14
|
+
"files": [
|
|
15
|
+
"dist"
|
|
16
|
+
],
|
|
17
|
+
"scripts": {
|
|
18
|
+
"build": "obuild",
|
|
19
|
+
"dev": "vitest dev",
|
|
20
|
+
"lint": "eslint . && prettier -c .",
|
|
21
|
+
"lint:fix": "automd && eslint . --fix && prettier -w .",
|
|
22
|
+
"prepack": "pnpm build",
|
|
23
|
+
"play": "pnpm rendu playground",
|
|
24
|
+
"release": "pnpm test && pnpm build && changelogen --release && npm publish && git push --follow-tags",
|
|
25
|
+
"rendu": "node ./src/cli.ts",
|
|
26
|
+
"test": "pnpm lint && pnpm test:types && vitest run --coverage",
|
|
27
|
+
"test:types": "tsc --noEmit --skipLibCheck"
|
|
28
|
+
},
|
|
29
|
+
"dependencies": {
|
|
30
|
+
"srvx": "^0.9.1"
|
|
31
|
+
},
|
|
32
|
+
"devDependencies": {
|
|
33
|
+
"@types/node": "^24.9.1",
|
|
34
|
+
"@vitest/coverage-v8": "^4.0.4",
|
|
35
|
+
"automd": "^0.4.2",
|
|
36
|
+
"changelogen": "^0.6.2",
|
|
37
|
+
"cookie-es": "^2.0.0",
|
|
38
|
+
"eslint": "^9.38.0",
|
|
39
|
+
"eslint-config-unjs": "^0.5.0",
|
|
40
|
+
"obuild": "^0.3.0",
|
|
41
|
+
"prettier": "^3.6.2",
|
|
42
|
+
"rendu": "^0.0.6",
|
|
43
|
+
"typescript": "^5.9.3",
|
|
44
|
+
"vitest": "^4.0.4"
|
|
45
|
+
},
|
|
46
|
+
"packageManager": "pnpm@10.19.0"
|
|
47
|
+
}
|
|
@@ -1,16 +1,12 @@
|
|
|
1
1
|
import "#nitro-internal-pollyfills";
|
|
2
|
-
import { useNitroApp } from "nitro/runtime";
|
|
2
|
+
import { useNitroApp, useNitroHooks } from "nitro/runtime";
|
|
3
3
|
import { trapUnhandledNodeErrors } from "nitro/runtime/internal";
|
|
4
4
|
import { startScheduleRunner } from "nitro/runtime/internal";
|
|
5
5
|
import { Server } from "node:http";
|
|
6
|
-
import nodeCrypto from "node:crypto";
|
|
7
6
|
import { parentPort, threadId } from "node:worker_threads";
|
|
8
7
|
import wsAdapter from "crossws/adapters/node";
|
|
9
8
|
import { toNodeHandler } from "srvx/node";
|
|
10
9
|
import { getSocketAddress, isSocketSupported } from "get-port-please";
|
|
11
|
-
if (!globalThis.crypto) {
|
|
12
|
-
globalThis.crypto = nodeCrypto;
|
|
13
|
-
}
|
|
14
10
|
trapUnhandledNodeErrors();
|
|
15
11
|
parentPort?.on("message", (msg) => {
|
|
16
12
|
if (msg && msg.event === "shutdown") {
|
|
@@ -18,6 +14,7 @@ parentPort?.on("message", (msg) => {
|
|
|
18
14
|
}
|
|
19
15
|
});
|
|
20
16
|
const nitroApp = useNitroApp();
|
|
17
|
+
const nitroHooks = useNitroHooks();
|
|
21
18
|
const server = new Server(toNodeHandler(nitroApp.fetch));
|
|
22
19
|
let listener;
|
|
23
20
|
listen().catch((error) => {
|
|
@@ -56,7 +53,7 @@ async function shutdown() {
|
|
|
56
53
|
server.closeAllConnections?.();
|
|
57
54
|
await Promise.all([
|
|
58
55
|
new Promise((resolve) => listener?.close(resolve)),
|
|
59
|
-
|
|
60
|
-
]);
|
|
56
|
+
nitroHooks.callHook("close")
|
|
57
|
+
]).catch(console.error);
|
|
61
58
|
parentPort?.postMessage({ event: "exit" });
|
|
62
59
|
}
|
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import "#nitro-internal-pollyfills";
|
|
2
2
|
import consola from "consola";
|
|
3
|
-
import { useNitroApp } from "nitro/runtime";
|
|
3
|
+
import { useNitroApp, useNitroHooks } from "nitro/runtime";
|
|
4
4
|
import { trapUnhandledNodeErrors } from "nitro/runtime/internal";
|
|
5
5
|
const nitroApp = useNitroApp();
|
|
6
|
-
|
|
7
|
-
export const
|
|
8
|
-
|
|
6
|
+
const nitroHooks = useNitroHooks();
|
|
7
|
+
export const appFetch = nitroApp.request;
|
|
8
|
+
export const closePrerenderer = () => nitroHooks.callHook("close");
|
|
9
|
+
nitroHooks.hook("error", (error, context) => {
|
|
9
10
|
if (!error.unhandled && error.status >= 500 && context.event?.req?.headers instanceof Headers && context.event.req.headers.get("x-nitro-prerender")) {
|
|
10
11
|
consola.error(
|
|
11
12
|
`[prerender error]`,
|
|
@@ -11,7 +11,7 @@ export async function handle(context, req) {
|
|
|
11
11
|
} else {
|
|
12
12
|
url = "/api/" + (req.params.url || "");
|
|
13
13
|
}
|
|
14
|
-
const response = await nitroApp.
|
|
14
|
+
const response = await nitroApp.request(url, {
|
|
15
15
|
method: req.method || void 0,
|
|
16
16
|
// https://github.com/Azure/azure-functions-nodejs-worker/issues/294
|
|
17
17
|
// https://github.com/Azure/azure-functions-host/issues/293
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import "#nitro-internal-pollyfills";
|
|
2
|
-
import { useNitroApp } from "nitro/runtime";
|
|
2
|
+
import { useNitroApp, useNitroHooks } from "nitro/runtime";
|
|
3
3
|
import { runCronTasks } from "nitro/runtime/internal";
|
|
4
4
|
export function createHandler(hooks) {
|
|
5
5
|
const nitroApp = useNitroApp();
|
|
6
|
+
const nitroHooks = useNitroHooks();
|
|
6
7
|
return {
|
|
7
8
|
async fetch(request, env, context) {
|
|
8
9
|
const ctxExt = {};
|
|
@@ -18,7 +19,7 @@ export function createHandler(hooks) {
|
|
|
18
19
|
scheduled(controller, env, context) {
|
|
19
20
|
globalThis.__env__ = env;
|
|
20
21
|
context.waitUntil(
|
|
21
|
-
|
|
22
|
+
nitroHooks.callHook("cloudflare:scheduled", {
|
|
22
23
|
controller,
|
|
23
24
|
env,
|
|
24
25
|
context
|
|
@@ -41,7 +42,7 @@ export function createHandler(hooks) {
|
|
|
41
42
|
email(message, env, context) {
|
|
42
43
|
globalThis.__env__ = env;
|
|
43
44
|
context.waitUntil(
|
|
44
|
-
|
|
45
|
+
nitroHooks.callHook("cloudflare:email", {
|
|
45
46
|
message,
|
|
46
47
|
event: message,
|
|
47
48
|
// backward compat
|
|
@@ -53,7 +54,7 @@ export function createHandler(hooks) {
|
|
|
53
54
|
queue(batch, env, context) {
|
|
54
55
|
globalThis.__env__ = env;
|
|
55
56
|
context.waitUntil(
|
|
56
|
-
|
|
57
|
+
nitroHooks.callHook("cloudflare:queue", {
|
|
57
58
|
batch,
|
|
58
59
|
event: batch,
|
|
59
60
|
env,
|
|
@@ -64,7 +65,7 @@ export function createHandler(hooks) {
|
|
|
64
65
|
tail(traces, env, context) {
|
|
65
66
|
globalThis.__env__ = env;
|
|
66
67
|
context.waitUntil(
|
|
67
|
-
|
|
68
|
+
nitroHooks.callHook("cloudflare:tail", {
|
|
68
69
|
traces,
|
|
69
70
|
env,
|
|
70
71
|
context
|
|
@@ -74,7 +75,7 @@ export function createHandler(hooks) {
|
|
|
74
75
|
trace(traces, env, context) {
|
|
75
76
|
globalThis.__env__ = env;
|
|
76
77
|
context.waitUntil(
|
|
77
|
-
|
|
78
|
+
nitroHooks.callHook("cloudflare:trace", {
|
|
78
79
|
traces,
|
|
79
80
|
env,
|
|
80
81
|
context
|
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
import "#nitro-internal-pollyfills";
|
|
2
2
|
import { DurableObject } from "cloudflare:workers";
|
|
3
3
|
import wsAdapter from "crossws/adapters/cloudflare";
|
|
4
|
-
import { useNitroApp } from "nitro/runtime";
|
|
4
|
+
import { useNitroApp, useNitroHooks } from "nitro/runtime";
|
|
5
5
|
import { isPublicAssetURL } from "#nitro-internal-virtual/public-assets";
|
|
6
6
|
import { createHandler, fetchHandler } from "./_module-handler.mjs";
|
|
7
7
|
const DURABLE_BINDING = "$DurableObject";
|
|
8
8
|
const DURABLE_INSTANCE = "server";
|
|
9
9
|
const nitroApp = useNitroApp();
|
|
10
|
+
const nitroHooks = useNitroHooks();
|
|
10
11
|
const getDurableStub = (env) => {
|
|
11
12
|
const binding = env[DURABLE_BINDING];
|
|
12
13
|
if (!binding) {
|
|
@@ -38,7 +39,7 @@ export class $DurableObject extends DurableObject {
|
|
|
38
39
|
constructor(state, env) {
|
|
39
40
|
super(state, env);
|
|
40
41
|
state.waitUntil(
|
|
41
|
-
|
|
42
|
+
nitroHooks.callHook("cloudflare:durable:init", this, {
|
|
42
43
|
state,
|
|
43
44
|
env
|
|
44
45
|
})
|
|
@@ -57,9 +58,7 @@ export class $DurableObject extends DurableObject {
|
|
|
57
58
|
});
|
|
58
59
|
}
|
|
59
60
|
alarm() {
|
|
60
|
-
this.ctx.waitUntil(
|
|
61
|
-
nitroApp.hooks.callHook("cloudflare:durable:alarm", this)
|
|
62
|
-
);
|
|
61
|
+
this.ctx.waitUntil(nitroHooks.callHook("cloudflare:durable:alarm", this));
|
|
63
62
|
}
|
|
64
63
|
async webSocketMessage(client, message) {
|
|
65
64
|
if (import.meta._websocket) {
|
|
@@ -1,18 +1,15 @@
|
|
|
1
|
-
const
|
|
1
|
+
const proxy = await _getPlatformProxy().catch((error) => {
|
|
2
2
|
console.error("Failed to initialize wrangler bindings proxy", error);
|
|
3
3
|
return _createStubProxy();
|
|
4
|
-
}).then((proxy) => {
|
|
5
|
-
globalThis.__env__ = proxy.env;
|
|
6
|
-
return proxy;
|
|
7
4
|
});
|
|
8
|
-
globalThis.__env__ =
|
|
5
|
+
globalThis.__env__ = proxy.env;
|
|
6
|
+
globalThis.__wait_until__ = proxy.ctx.waitUntil.bind(proxy.ctx);
|
|
9
7
|
export default (function(nitroApp) {
|
|
10
8
|
nitroApp.hooks.hook("request", async (event) => {
|
|
11
9
|
event.req.context ??= {};
|
|
12
|
-
const proxy = await _proxy;
|
|
13
10
|
event.req.context.cf = proxy.cf;
|
|
14
11
|
event.req.context.waitUntil = proxy.ctx.waitUntil.bind(proxy.ctx);
|
|
15
|
-
const request =
|
|
12
|
+
const request = event.req;
|
|
16
13
|
request.cf = proxy.cf;
|
|
17
14
|
event.req.context.cloudflare = {
|
|
18
15
|
...event.req.context.cloudflare,
|
|
@@ -23,7 +20,7 @@ export default (function(nitroApp) {
|
|
|
23
20
|
});
|
|
24
21
|
nitroApp.hooks._hooks.request.unshift(nitroApp.hooks._hooks.request.pop());
|
|
25
22
|
nitroApp.hooks.hook("close", () => {
|
|
26
|
-
return
|
|
23
|
+
return proxy?.dispose();
|
|
27
24
|
});
|
|
28
25
|
});
|
|
29
26
|
async function _getPlatformProxy() {
|
|
@@ -47,8 +44,8 @@ async function _getPlatformProxy() {
|
|
|
47
44
|
if (runtimeConfig.wrangler.environment) {
|
|
48
45
|
proxyOptions.environment = runtimeConfig.wrangler.environment;
|
|
49
46
|
}
|
|
50
|
-
const
|
|
51
|
-
return
|
|
47
|
+
const proxy2 = await getPlatformProxy(proxyOptions);
|
|
48
|
+
return proxy2;
|
|
52
49
|
}
|
|
53
50
|
function _createStubProxy() {
|
|
54
51
|
return {
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export function waitUntil(promise: any): Promise<void>;
|
|
2
|
+
export function withEnv(newEnv: any, fn: any): void;
|
|
3
|
+
export class DurableObject extends NotImplemented {
|
|
4
|
+
}
|
|
5
|
+
export class RpcPromise extends NotImplemented {
|
|
6
|
+
}
|
|
7
|
+
export class RpcProperty extends NotImplemented {
|
|
8
|
+
}
|
|
9
|
+
export class RpcStub extends NotImplemented {
|
|
10
|
+
}
|
|
11
|
+
export class RpcTarget extends NotImplemented {
|
|
12
|
+
}
|
|
13
|
+
export class ServiceStub extends NotImplemented {
|
|
14
|
+
}
|
|
15
|
+
export class WorkerEntrypoint extends NotImplemented {
|
|
16
|
+
}
|
|
17
|
+
export class WorkflowEntrypoint extends NotImplemented {
|
|
18
|
+
}
|
|
19
|
+
declare class NotImplemented {
|
|
20
|
+
}
|
|
21
|
+
export {};
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
// Shim for "cloudflare:workers" import in dev environment
|
|
2
|
+
|
|
3
|
+
// unenv shim respects __env__
|
|
4
|
+
export { env } from "unenv/node/internal/process/env";
|
|
5
|
+
|
|
6
|
+
export async function waitUntil(promise) {
|
|
7
|
+
await globalThis.__wait_until__?.(promise);
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export function withEnv(newEnv, fn) {
|
|
11
|
+
throw new Error("cf.withEnv is not implemented in dev env currently.");
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
class NotImplemented {
|
|
15
|
+
constructor() {
|
|
16
|
+
throw new Error("Not implemented in dev env currently.");
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export class DurableObject extends NotImplemented {}
|
|
21
|
+
export class RpcPromise extends NotImplemented {}
|
|
22
|
+
export class RpcProperty extends NotImplemented {}
|
|
23
|
+
export class RpcStub extends NotImplemented {}
|
|
24
|
+
export class RpcTarget extends NotImplemented {}
|
|
25
|
+
export class ServiceStub extends NotImplemented {}
|
|
26
|
+
export class WorkerEntrypoint extends NotImplemented {}
|
|
27
|
+
export class WorkflowEntrypoint extends NotImplemented {}
|
|
@@ -33,7 +33,7 @@ const listener = server.listen(path ? { path } : { port, host }, (err) => {
|
|
|
33
33
|
console.log(`Listening on ${url}`);
|
|
34
34
|
});
|
|
35
35
|
trapUnhandledNodeErrors();
|
|
36
|
-
setupGracefulShutdown(listener
|
|
36
|
+
setupGracefulShutdown(listener);
|
|
37
37
|
if (import.meta._websocket) {
|
|
38
38
|
const { handleUpgrade } = wsAdapter(nitroApp.h3App.websocket);
|
|
39
39
|
server.on("upgrade", handleUpgrade);
|