nitro-nightly 3.1.0-20251028-090722-437659e4 → 3.1.0-20251028-131831-fe9fd554
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/_build/build.mjs +379 -14
- package/dist/_build/{rollup.mjs → build2.mjs} +218 -68
- package/dist/_build/info.mjs +963 -7
- package/dist/_build/prepare.mjs +1491 -2
- package/dist/_build/snapshot.mjs +155 -31
- package/dist/_build/vite.mjs +43 -2307
- package/dist/_build/vite2.mjs +149 -0
- package/dist/{_deps → _chunks/_deps}/c12.mjs +1 -1
- package/dist/{_deps → _chunks/_deps}/giget.mjs +1 -1
- package/dist/_chunks/_deps/klona.mjs +137 -0
- package/dist/{_deps → _chunks/_deps}/knitwork.mjs +1 -1
- package/dist/{_deps → _chunks/_deps}/local-pkg.mjs +1 -1
- package/dist/{_deps → _chunks/_deps}/mlly.mjs +1 -1
- package/dist/{_deps → _chunks/_deps}/nypm.mjs +1 -1
- package/dist/{_deps → _chunks/_deps}/pathe.mjs +1 -1
- package/dist/{_deps → _chunks/_deps}/pkg-types.mjs +2 -2
- package/dist/{_deps → _chunks/_deps}/rou3.mjs +1 -1
- package/dist/_chunks/_deps/std-env.mjs +3 -0
- package/dist/{_deps → _chunks/_deps}/unimport.mjs +2 -2
- package/dist/{_deps → _chunks/_deps}/unplugin-utils.mjs +1 -1
- package/dist/{_deps → _chunks/_deps}/untyped.mjs +1 -1
- package/dist/{_deps → _chunks/_deps}/unwasm.mjs +2 -2
- package/dist/{_presets → _chunks/_presets}/_resolve.mjs +2 -2
- package/dist/{_presets → _chunks/_presets}/_utils.mjs +1 -1
- package/dist/{_presets → _chunks/_presets}/azure.mjs +1 -1
- package/dist/{_presets → _chunks/_presets}/cloudflare.mjs +4 -4
- package/dist/{_presets → _chunks/_presets}/deno.mjs +1 -1
- package/dist/{_presets → _chunks/_presets}/firebase.mjs +1 -1
- package/dist/{_presets → _chunks/_presets}/iis.mjs +1 -1
- package/dist/{_presets → _chunks/_presets}/index.mjs +1 -1
- package/dist/{_presets → _chunks/_presets}/vercel.mjs +3 -3
- package/dist/{_presets → _chunks/_presets}/zeabur.mjs +1 -1
- package/dist/_chunks/app.mjs +600 -0
- package/dist/_chunks/index.mjs +648 -0
- package/dist/_chunks/server.mjs +256 -0
- package/dist/_cli/build.mjs +2 -2
- package/dist/_cli/dev.mjs +46 -130
- package/dist/_cli/index.mjs +1 -1
- package/dist/_cli/list.mjs +2 -2
- package/dist/_cli/prepare.mjs +2 -2
- package/dist/_cli/run.mjs +2 -2
- package/dist/cli/index.mjs +1 -1
- package/dist/index.mjs +94 -120
- 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/rendu/dist/index.mjs +380 -0
- package/dist/node_modules/rendu/package.json +47 -0
- package/dist/runtime/internal/task.mjs +1 -2
- package/dist/types/index.d.mts +2 -1
- package/dist/vite.mjs +103 -114
- package/lib/runtime/meta.mjs +18 -25
- package/package.json +9 -10
- package/dist/_build/assets.mjs +0 -235
- package/dist/_build/config.mjs +0 -124
- package/dist/_build/plugins.mjs +0 -1041
- package/dist/_build/rolldown.mjs +0 -494
- package/dist/_build/types.mjs +0 -268
- 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/{_deps → _chunks/_deps}/@jridgewell/gen-mapping.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/@jridgewell/remapping.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/@jridgewell/resolve-uri.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/@jridgewell/sourcemap-codec.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/@jridgewell/trace-mapping.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/@pi0/vite-plugin-fullstack.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/@rollup/plugin-alias.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/@rollup/plugin-commonjs.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/@rollup/plugin-inject.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/@rollup/plugin-json.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/@rollup/plugin-node-resolve.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/@rollup/plugin-replace.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/@rollup/pluginutils.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/acorn.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/chokidar.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/citty.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/commondir.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/compatx.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/confbox.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/debug.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/deepmerge.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/depd.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/dot-prop.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/dotenv.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/duplexer.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/ee-first.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/encodeurl.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/escape-html.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/escape-string-regexp.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/estree-walker.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/etag.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/exsolve.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/fdir.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/fresh.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/function-bind.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/gzip-size.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/hasown.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/http-errors.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/httpxy.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/inherits.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/is-core-module.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/is-module.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/is-reference.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/js-tokens.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/magic-string.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/mime-db.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/mime-types.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/mime.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/ms.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/node-fetch-native.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/on-finished.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/parseurl.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/path-parse.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/perfect-debounce.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/picomatch.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/pretty-bytes.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/quansync.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/range-parser.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/rc9.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/readdirp.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/resolve.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/send.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/serve-static.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/setprototypeof.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/statuses.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/strip-literal.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/supports-color.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/tinyexec.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/tinyglobby.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/toidentifier.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/ultrahtml.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/unplugin.mjs +0 -0
- /package/dist/{_deps → _chunks/_deps}/webpack-virtual-modules.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/_all.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/_nitro.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/_static.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/_types.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/alwaysdata.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/aws-amplify.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/aws-lambda.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/bun.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/cleavr.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/digitalocean.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/flightcontrol.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/genezio.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/heroku.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/koyeb.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/netlify.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/node.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/platform.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/render.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/standard.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/stormkit.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/winterjs.mjs +0 -0
- /package/dist/{_presets → _chunks/_presets}/zerops.mjs +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,6 +1,5 @@
|
|
|
1
1
|
import { Cron } from "croner";
|
|
2
2
|
import { HTTPError } from "h3";
|
|
3
|
-
import { isTest } from "std-env";
|
|
4
3
|
import { scheduledTasks, tasks } from "#nitro-internal-virtual/tasks";
|
|
5
4
|
export function defineTask(def) {
|
|
6
5
|
if (typeof def.run !== "function") {
|
|
@@ -41,7 +40,7 @@ export async function runTask(name, {
|
|
|
41
40
|
}
|
|
42
41
|
}
|
|
43
42
|
export function startScheduleRunner() {
|
|
44
|
-
if (!scheduledTasks || scheduledTasks.length === 0 ||
|
|
43
|
+
if (!scheduledTasks || scheduledTasks.length === 0 || process.env.TEST) {
|
|
45
44
|
return;
|
|
46
45
|
}
|
|
47
46
|
const payload = {
|
package/dist/types/index.d.mts
CHANGED
|
@@ -17,7 +17,6 @@ import { Storage, BuiltinDriverName } from 'unstorage';
|
|
|
17
17
|
import { IncomingMessage, OutgoingMessage } from 'node:http';
|
|
18
18
|
import { TransformOptions, Loader } from 'esbuild';
|
|
19
19
|
import { InputOptions, OutputOptions } from 'rollup';
|
|
20
|
-
import { ProviderName } from 'std-env';
|
|
21
20
|
import { ExternalsPluginOptions } from 'nf3';
|
|
22
21
|
export { ExternalsPluginOptions as NodeExternalsOptions } from 'nf3';
|
|
23
22
|
|
|
@@ -4068,6 +4067,8 @@ interface NitroOpenAPIConfig {
|
|
|
4068
4067
|
};
|
|
4069
4068
|
}
|
|
4070
4069
|
|
|
4070
|
+
type ProviderName = "" | "appveyor" | "aws_amplify" | "azure_pipelines" | "azure_static" | "appcircle" | "bamboo" | "bitbucket" | "bitrise" | "buddy" | "buildkite" | "circle" | "cirrus" | "cloudflare_pages" | "cloudflare_workers" | "codebuild" | "codefresh" | "drone" | "drone" | "dsari" | "github_actions" | "gitlab" | "gocd" | "layerci" | "hudson" | "jenkins" | "magnum" | "netlify" | "nevercode" | "render" | "sail" | "semaphore" | "screwdriver" | "shippable" | "solano" | "strider" | "teamcity" | "travis" | "vercel" | "appcenter" | "codesandbox" | "stackblitz" | "stormkit" | "cleavr" | "zeabur" | "codesphere" | "railway" | "deno-deploy" | "firebase_app_hosting";
|
|
4071
|
+
|
|
4071
4072
|
type NitroPreset = NitroConfig | (() => NitroConfig);
|
|
4072
4073
|
interface NitroPresetMeta {
|
|
4073
4074
|
name: string;
|