vitend 0.2.1 → 0.2.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 (49) hide show
  1. package/dist/index.d.ts +50 -3
  2. package/dist/index.js +21 -2
  3. package/dist/index.js.map +1 -0
  4. package/dist/index.mjs +20 -2
  5. package/dist/index.mjs.map +1 -0
  6. package/dist/node.d.ts +16 -3
  7. package/dist/node.js +1 -1
  8. package/dist/runtime.js +1 -1
  9. package/dist/vite.d.ts +214 -3
  10. package/dist/vite.js +276 -2
  11. package/dist/vite.js.map +1 -0
  12. package/dist/vite.mjs +247 -2
  13. package/dist/vite.mjs.map +1 -0
  14. package/package.json +11 -2
  15. package/dist/@types/node.d.ts +0 -16
  16. package/dist/@types/options/complete.d.ts +0 -158
  17. package/dist/@types/options/default.d.ts +0 -39
  18. package/dist/@types/server.d.ts +0 -32
  19. package/dist/_virtual/_rolldown/runtime.js +0 -27
  20. package/dist/functions/define.d.ts +0 -21
  21. package/dist/functions/define.js +0 -22
  22. package/dist/functions/define.js.map +0 -1
  23. package/dist/functions/define.mjs +0 -21
  24. package/dist/functions/define.mjs.map +0 -1
  25. package/dist/functions/entry.js +0 -20
  26. package/dist/functions/entry.js.map +0 -1
  27. package/dist/functions/entry.mjs +0 -17
  28. package/dist/functions/entry.mjs.map +0 -1
  29. package/dist/functions/options.js +0 -43
  30. package/dist/functions/options.js.map +0 -1
  31. package/dist/functions/options.mjs +0 -42
  32. package/dist/functions/options.mjs.map +0 -1
  33. package/dist/functions/package-json.js +0 -15
  34. package/dist/functions/package-json.js.map +0 -1
  35. package/dist/functions/package-json.mjs +0 -12
  36. package/dist/functions/package-json.mjs.map +0 -1
  37. package/dist/vite/build.js +0 -72
  38. package/dist/vite/build.js.map +0 -1
  39. package/dist/vite/build.mjs +0 -71
  40. package/dist/vite/build.mjs.map +0 -1
  41. package/dist/vite/dev.js +0 -90
  42. package/dist/vite/dev.js.map +0 -1
  43. package/dist/vite/dev.mjs +0 -89
  44. package/dist/vite/dev.mjs.map +0 -1
  45. package/dist/vite/vitend.d.ts +0 -23
  46. package/dist/vite/vitend.js +0 -45
  47. package/dist/vite/vitend.js.map +0 -1
  48. package/dist/vite/vitend.mjs +0 -42
  49. package/dist/vite/vitend.mjs.map +0 -1
@@ -1,20 +0,0 @@
1
- const require_runtime = require('../_virtual/_rolldown/runtime.js');
2
- let node_path = require("node:path");
3
- node_path = require_runtime.__toESM(node_path);
4
- let node_fs = require("node:fs");
5
- node_fs = require_runtime.__toESM(node_fs);
6
-
7
- const ENTRY_DEFAULT = ["./src/index.ts", "./src/index.js"];
8
- const getEntry = (cwd, entry) => {
9
- if (!entry) {
10
- for (const ent of ENTRY_DEFAULT) if (node_fs.existsSync(node_path.resolve(cwd, ent))) {
11
- entry = ent;
12
- break;
13
- }
14
- if (!entry) throw new Error("No entry file found");
15
- }
16
- return node_path.resolve(cwd, entry);
17
- };
18
-
19
- exports.getEntry = getEntry;
20
- //# sourceMappingURL=entry.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"entry.js","names":["Fs","Path"],"sources":["../../src/functions/entry.ts"],"sourcesContent":["import * as Fs from \"node:fs\";\nimport * as Path from \"node:path\";\n\nconst ENTRY_DEFAULT: string[] = [\n \"./src/index.ts\",\n \"./src/index.js\",\n];\n\nconst getEntry = (cwd: string, entry?: string): string => {\n if (!entry) {\n for (const ent of ENTRY_DEFAULT) {\n if (Fs.existsSync(Path.resolve(cwd, ent))) {\n entry = ent;\n break;\n }\n }\n\n if (!entry) {\n throw new Error(\"No entry file found\");\n }\n }\n\n return Path.resolve(cwd, entry);\n};\n\nexport { getEntry };\n"],"mappings":";;;;;;AAGA,MAAM,gBAA0B,CAC5B,kBACA,iBACH;AAED,MAAM,YAAY,KAAa,UAA2B;AACtD,KAAI,CAAC,OAAO;AACR,OAAK,MAAM,OAAO,cACd,KAAIA,QAAG,WAAWC,UAAK,QAAQ,KAAK,IAAI,CAAC,EAAE;AACvC,WAAQ;AACR;;AAIR,MAAI,CAAC,MACD,OAAM,IAAI,MAAM,sBAAsB;;AAI9C,QAAOA,UAAK,QAAQ,KAAK,MAAM"}
@@ -1,17 +0,0 @@
1
- import * as Path from "node:path";
2
- import * as Fs from "node:fs";
3
-
4
- const ENTRY_DEFAULT = ["./src/index.ts", "./src/index.js"];
5
- const getEntry = (cwd, entry) => {
6
- if (!entry) {
7
- for (const ent of ENTRY_DEFAULT) if (Fs.existsSync(Path.resolve(cwd, ent))) {
8
- entry = ent;
9
- break;
10
- }
11
- if (!entry) throw new Error("No entry file found");
12
- }
13
- return Path.resolve(cwd, entry);
14
- };
15
-
16
- export { getEntry };
17
- //# sourceMappingURL=entry.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"entry.mjs","names":[],"sources":["../../src/functions/entry.ts"],"sourcesContent":["import * as Fs from \"node:fs\";\nimport * as Path from \"node:path\";\n\nconst ENTRY_DEFAULT: string[] = [\n \"./src/index.ts\",\n \"./src/index.js\",\n];\n\nconst getEntry = (cwd: string, entry?: string): string => {\n if (!entry) {\n for (const ent of ENTRY_DEFAULT) {\n if (Fs.existsSync(Path.resolve(cwd, ent))) {\n entry = ent;\n break;\n }\n }\n\n if (!entry) {\n throw new Error(\"No entry file found\");\n }\n }\n\n return Path.resolve(cwd, entry);\n};\n\nexport { getEntry };\n"],"mappings":";;;AAGA,MAAM,gBAA0B,CAC5B,kBACA,iBACH;AAED,MAAM,YAAY,KAAa,UAA2B;AACtD,KAAI,CAAC,OAAO;AACR,OAAK,MAAM,OAAO,cACd,KAAI,GAAG,WAAW,KAAK,QAAQ,KAAK,IAAI,CAAC,EAAE;AACvC,WAAQ;AACR;;AAIR,MAAI,CAAC,MACD,OAAM,IAAI,MAAM,sBAAsB;;AAI9C,QAAO,KAAK,QAAQ,KAAK,MAAM"}
@@ -1,43 +0,0 @@
1
- const require_runtime = require('../_virtual/_rolldown/runtime.js');
2
- const require_entry = require('./entry.js');
3
- let es_toolkit = require("es-toolkit");
4
-
5
- const OPTIONS_BUILD_VERCEL = {
6
- target: "vercel",
7
- outputDir: "./dist",
8
- outputFile: "index.js",
9
- minify: false
10
- };
11
- const OPTIONS_BUILD_DEFAULT = {
12
- target: "default",
13
- host: "localhost",
14
- port: 3e3,
15
- outputDir: "./dist",
16
- outputFile: "index.js",
17
- minify: false,
18
- publicDir: "./public",
19
- copyPublicDir: false
20
- };
21
- const OPTIONS_DEFAULT = {
22
- cwd: process.cwd(),
23
- dev: {
24
- host: "localhost",
25
- port: 3001
26
- }
27
- };
28
- const getDefaultOptions = (isVercel) => {
29
- return {
30
- ...OPTIONS_DEFAULT,
31
- build: isVercel ? OPTIONS_BUILD_VERCEL : OPTIONS_BUILD_DEFAULT
32
- };
33
- };
34
- const createOptions = (options) => {
35
- const merged = (0, es_toolkit.toMerged)(getDefaultOptions(options?.build?.target === "vercel"), options ?? {});
36
- return {
37
- ...merged,
38
- entry: require_entry.getEntry(merged.cwd, options?.entry)
39
- };
40
- };
41
-
42
- exports.createOptions = createOptions;
43
- //# sourceMappingURL=options.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"options.js","names":["getEntry"],"sources":["../../src/functions/options.ts"],"sourcesContent":["import type { Omit } from \"ts-vista\";\n\nimport type { VitendOptions } from \"#/@types/options/default\";\nimport type {\n ResolvedDefaultBuildOptions,\n ResolvedVercelBuildOptions,\n ResolvedVitendOptions,\n} from \"#/@types/options/resolved\";\n\nimport { toMerged } from \"es-toolkit\";\n\nimport { getEntry } from \"#/functions/entry\";\n\nconst OPTIONS_BUILD_VERCEL: ResolvedVercelBuildOptions = {\n target: \"vercel\",\n outputDir: \"./dist\",\n outputFile: \"index.js\",\n minify: false,\n};\n\nconst OPTIONS_BUILD_DEFAULT: ResolvedDefaultBuildOptions = {\n target: \"default\",\n host: \"localhost\",\n port: 3000,\n outputDir: \"./dist\",\n outputFile: \"index.js\",\n minify: false,\n publicDir: \"./public\",\n copyPublicDir: false,\n};\n\nconst OPTIONS_DEFAULT: Omit<ResolvedVitendOptions, \"entry\" | \"build\"> = {\n cwd: process.cwd(),\n dev: {\n host: \"localhost\",\n port: 3001,\n },\n};\n\nconst getDefaultOptions = (\n isVercel: boolean,\n): Omit<ResolvedVitendOptions, \"entry\"> => {\n return {\n ...OPTIONS_DEFAULT,\n build: isVercel ? OPTIONS_BUILD_VERCEL : OPTIONS_BUILD_DEFAULT,\n };\n};\n\nconst createOptions = (options?: VitendOptions): ResolvedVitendOptions => {\n const isVercel: boolean = options?.build?.target === \"vercel\";\n\n const merged = toMerged(getDefaultOptions(isVercel), options ?? {});\n\n return {\n ...merged,\n entry: getEntry(merged.cwd, options?.entry),\n };\n};\n\nexport { createOptions };\n"],"mappings":";;;;AAaA,MAAM,uBAAmD;CACrD,QAAQ;CACR,WAAW;CACX,YAAY;CACZ,QAAQ;CACX;AAED,MAAM,wBAAqD;CACvD,QAAQ;CACR,MAAM;CACN,MAAM;CACN,WAAW;CACX,YAAY;CACZ,QAAQ;CACR,WAAW;CACX,eAAe;CAClB;AAED,MAAM,kBAAkE;CACpE,KAAK,QAAQ,KAAK;CAClB,KAAK;EACD,MAAM;EACN,MAAM;EACT;CACJ;AAED,MAAM,qBACF,aACuC;AACvC,QAAO;EACH,GAAG;EACH,OAAO,WAAW,uBAAuB;EAC5C;;AAGL,MAAM,iBAAiB,YAAmD;CAGtE,MAAM,kCAAkB,kBAFE,SAAS,OAAO,WAAW,SAEF,EAAE,WAAW,EAAE,CAAC;AAEnE,QAAO;EACH,GAAG;EACH,OAAOA,uBAAS,OAAO,KAAK,SAAS,MAAM;EAC9C"}
@@ -1,42 +0,0 @@
1
- import { getEntry } from "./entry.mjs";
2
- import { toMerged } from "es-toolkit";
3
-
4
- const OPTIONS_BUILD_VERCEL = {
5
- target: "vercel",
6
- outputDir: "./dist",
7
- outputFile: "index.js",
8
- minify: false
9
- };
10
- const OPTIONS_BUILD_DEFAULT = {
11
- target: "default",
12
- host: "localhost",
13
- port: 3e3,
14
- outputDir: "./dist",
15
- outputFile: "index.js",
16
- minify: false,
17
- publicDir: "./public",
18
- copyPublicDir: false
19
- };
20
- const OPTIONS_DEFAULT = {
21
- cwd: process.cwd(),
22
- dev: {
23
- host: "localhost",
24
- port: 3001
25
- }
26
- };
27
- const getDefaultOptions = (isVercel) => {
28
- return {
29
- ...OPTIONS_DEFAULT,
30
- build: isVercel ? OPTIONS_BUILD_VERCEL : OPTIONS_BUILD_DEFAULT
31
- };
32
- };
33
- const createOptions = (options) => {
34
- const merged = toMerged(getDefaultOptions(options?.build?.target === "vercel"), options ?? {});
35
- return {
36
- ...merged,
37
- entry: getEntry(merged.cwd, options?.entry)
38
- };
39
- };
40
-
41
- export { createOptions };
42
- //# sourceMappingURL=options.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"options.mjs","names":[],"sources":["../../src/functions/options.ts"],"sourcesContent":["import type { Omit } from \"ts-vista\";\n\nimport type { VitendOptions } from \"#/@types/options/default\";\nimport type {\n ResolvedDefaultBuildOptions,\n ResolvedVercelBuildOptions,\n ResolvedVitendOptions,\n} from \"#/@types/options/resolved\";\n\nimport { toMerged } from \"es-toolkit\";\n\nimport { getEntry } from \"#/functions/entry\";\n\nconst OPTIONS_BUILD_VERCEL: ResolvedVercelBuildOptions = {\n target: \"vercel\",\n outputDir: \"./dist\",\n outputFile: \"index.js\",\n minify: false,\n};\n\nconst OPTIONS_BUILD_DEFAULT: ResolvedDefaultBuildOptions = {\n target: \"default\",\n host: \"localhost\",\n port: 3000,\n outputDir: \"./dist\",\n outputFile: \"index.js\",\n minify: false,\n publicDir: \"./public\",\n copyPublicDir: false,\n};\n\nconst OPTIONS_DEFAULT: Omit<ResolvedVitendOptions, \"entry\" | \"build\"> = {\n cwd: process.cwd(),\n dev: {\n host: \"localhost\",\n port: 3001,\n },\n};\n\nconst getDefaultOptions = (\n isVercel: boolean,\n): Omit<ResolvedVitendOptions, \"entry\"> => {\n return {\n ...OPTIONS_DEFAULT,\n build: isVercel ? OPTIONS_BUILD_VERCEL : OPTIONS_BUILD_DEFAULT,\n };\n};\n\nconst createOptions = (options?: VitendOptions): ResolvedVitendOptions => {\n const isVercel: boolean = options?.build?.target === \"vercel\";\n\n const merged = toMerged(getDefaultOptions(isVercel), options ?? {});\n\n return {\n ...merged,\n entry: getEntry(merged.cwd, options?.entry),\n };\n};\n\nexport { createOptions };\n"],"mappings":";;;AAaA,MAAM,uBAAmD;CACrD,QAAQ;CACR,WAAW;CACX,YAAY;CACZ,QAAQ;CACX;AAED,MAAM,wBAAqD;CACvD,QAAQ;CACR,MAAM;CACN,MAAM;CACN,WAAW;CACX,YAAY;CACZ,QAAQ;CACR,WAAW;CACX,eAAe;CAClB;AAED,MAAM,kBAAkE;CACpE,KAAK,QAAQ,KAAK;CAClB,KAAK;EACD,MAAM;EACN,MAAM;EACT;CACJ;AAED,MAAM,qBACF,aACuC;AACvC,QAAO;EACH,GAAG;EACH,OAAO,WAAW,uBAAuB;EAC5C;;AAGL,MAAM,iBAAiB,YAAmD;CAGtE,MAAM,SAAS,SAAS,kBAFE,SAAS,OAAO,WAAW,SAEF,EAAE,WAAW,EAAE,CAAC;AAEnE,QAAO;EACH,GAAG;EACH,OAAO,SAAS,OAAO,KAAK,SAAS,MAAM;EAC9C"}
@@ -1,15 +0,0 @@
1
- const require_runtime = require('../_virtual/_rolldown/runtime.js');
2
- let node_path = require("node:path");
3
- node_path = require_runtime.__toESM(node_path);
4
- let node_fs = require("node:fs");
5
- node_fs = require_runtime.__toESM(node_fs);
6
-
7
- const getPackageJson = (cwd) => {
8
- const path = node_path.resolve(cwd, "package.json");
9
- if (!node_fs.existsSync(path)) throw new Error("Failed to find package.json");
10
- const rawPackageJson = node_fs.readFileSync(path, "utf-8");
11
- return JSON.parse(rawPackageJson);
12
- };
13
-
14
- exports.getPackageJson = getPackageJson;
15
- //# sourceMappingURL=package-json.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"package-json.js","names":["Path","Fs"],"sources":["../../src/functions/package-json.ts"],"sourcesContent":["import type { Format, Partial } from \"ts-vista\";\n\nimport * as Fs from \"node:fs\";\nimport * as Path from \"node:path\";\n\ntype CompletePackageJson = {\n type: \"module\" | \"commonjs\";\n dependencies: Record<string, string>;\n devDependencies: Record<string, string>;\n peerDependencies: Record<string, string>;\n};\n\ntype PackageJson = Format<Partial<CompletePackageJson>>;\n\nconst getPackageJson = (cwd: string): PackageJson => {\n const path: string = Path.resolve(cwd, \"package.json\");\n\n if (!Fs.existsSync(path)) {\n throw new Error(\"Failed to find package.json\");\n }\n\n const rawPackageJson: string = Fs.readFileSync(path, \"utf-8\");\n\n return JSON.parse(rawPackageJson);\n};\n\nexport type { CompletePackageJson, PackageJson };\nexport { getPackageJson };\n"],"mappings":";;;;;;AAcA,MAAM,kBAAkB,QAA6B;CACjD,MAAM,OAAeA,UAAK,QAAQ,KAAK,eAAe;AAEtD,KAAI,CAACC,QAAG,WAAW,KAAK,CACpB,OAAM,IAAI,MAAM,8BAA8B;CAGlD,MAAM,iBAAyBA,QAAG,aAAa,MAAM,QAAQ;AAE7D,QAAO,KAAK,MAAM,eAAe"}
@@ -1,12 +0,0 @@
1
- import * as Path from "node:path";
2
- import * as Fs from "node:fs";
3
-
4
- const getPackageJson = (cwd) => {
5
- const path = Path.resolve(cwd, "package.json");
6
- if (!Fs.existsSync(path)) throw new Error("Failed to find package.json");
7
- const rawPackageJson = Fs.readFileSync(path, "utf-8");
8
- return JSON.parse(rawPackageJson);
9
- };
10
-
11
- export { getPackageJson };
12
- //# sourceMappingURL=package-json.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"package-json.mjs","names":[],"sources":["../../src/functions/package-json.ts"],"sourcesContent":["import type { Format, Partial } from \"ts-vista\";\n\nimport * as Fs from \"node:fs\";\nimport * as Path from \"node:path\";\n\ntype CompletePackageJson = {\n type: \"module\" | \"commonjs\";\n dependencies: Record<string, string>;\n devDependencies: Record<string, string>;\n peerDependencies: Record<string, string>;\n};\n\ntype PackageJson = Format<Partial<CompletePackageJson>>;\n\nconst getPackageJson = (cwd: string): PackageJson => {\n const path: string = Path.resolve(cwd, \"package.json\");\n\n if (!Fs.existsSync(path)) {\n throw new Error(\"Failed to find package.json\");\n }\n\n const rawPackageJson: string = Fs.readFileSync(path, \"utf-8\");\n\n return JSON.parse(rawPackageJson);\n};\n\nexport type { CompletePackageJson, PackageJson };\nexport { getPackageJson };\n"],"mappings":";;;AAcA,MAAM,kBAAkB,QAA6B;CACjD,MAAM,OAAe,KAAK,QAAQ,KAAK,eAAe;AAEtD,KAAI,CAAC,GAAG,WAAW,KAAK,CACpB,OAAM,IAAI,MAAM,8BAA8B;CAGlD,MAAM,iBAAyB,GAAG,aAAa,MAAM,QAAQ;AAE7D,QAAO,KAAK,MAAM,eAAe"}
@@ -1,72 +0,0 @@
1
- const require_runtime = require('../_virtual/_rolldown/runtime.js');
2
- const require_package_json = require('../functions/package-json.js');
3
- let es_toolkit = require("es-toolkit");
4
- let node_module = require("node:module");
5
-
6
- const VIRTUAL_ENTRY = "virtual:vitend-entry";
7
- const VIRTUAL_ENTRY_RESOLVED = `\0${VIRTUAL_ENTRY}`;
8
- const buildPlugin = (opts) => {
9
- const build = opts.build;
10
- const packageJson = require_package_json.getPackageJson(opts.cwd);
11
- return {
12
- name: "vitend/build",
13
- apply: "build",
14
- config: (config) => {
15
- let result = {};
16
- result = (0, es_toolkit.toMerged)({
17
- ssr: {
18
- external: true,
19
- noExternal: void 0,
20
- target: "webworker"
21
- },
22
- build: { copyPublicDir: false }
23
- }, config);
24
- const overrideConfig = { build: {
25
- ssr: true,
26
- outDir: build.outputDir,
27
- rollupOptions: {
28
- input: VIRTUAL_ENTRY,
29
- output: {
30
- entryFileNames: build.outputFile,
31
- format: packageJson.type === "module" ? "esm" : "cjs"
32
- },
33
- external: [...node_module.builtinModules, /^node:/]
34
- },
35
- minify: build.minify
36
- } };
37
- result = (0, es_toolkit.toMerged)(result, overrideConfig);
38
- return result;
39
- },
40
- resolveId: (id) => {
41
- if (id !== VIRTUAL_ENTRY) return void 0;
42
- return VIRTUAL_ENTRY_RESOLVED;
43
- },
44
- load: async (id) => {
45
- if (id !== VIRTUAL_ENTRY_RESOLVED) return void 0;
46
- let code = "";
47
- code += `import options from "${opts.entry}";`;
48
- code += `import { serve } from "vitend/runtime";`;
49
- if (build.target === "vercel") {
50
- code += `const server = serve({ ...options, manual: true });`;
51
- code += `export default server;`;
52
- return code;
53
- }
54
- code += `serve({`;
55
- code += `...options,`;
56
- if (build.host !== "localhost") code += `hostname: "${build.host}",`;
57
- if (build.port !== 3e3) code += `port: ${build.port},`;
58
- if (build.https) {
59
- code += `tls: {`;
60
- if (build.https.cert) code += `cert: "${build.https.cert}",`;
61
- if (build.https.key) code += `key: "${build.https.key}",`;
62
- if (build.https.passphrase) code += `passphrase: "${build.https.passphrase}",`;
63
- code += `},`;
64
- }
65
- code += `});`;
66
- return code;
67
- }
68
- };
69
- };
70
-
71
- exports.buildPlugin = buildPlugin;
72
- //# sourceMappingURL=build.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"build.js","names":["getPackageJson","builtinModules"],"sources":["../../src/vite/build.ts"],"sourcesContent":["import type { LoadResult, ResolveIdResult } from \"rollup\";\nimport type { Plugin, UserConfig } from \"vite\";\n\nimport type {\n ResolvedBuildOptions,\n ResolvedVitendOptions,\n} from \"#/@types/options/resolved\";\nimport type { PackageJson } from \"#/functions/package-json\";\n\nimport { builtinModules } from \"node:module\";\n\nimport { toMerged } from \"es-toolkit\";\n\nimport { getPackageJson } from \"#/functions/package-json\";\n\nconst VIRTUAL_ENTRY = \"virtual:vitend-entry\" as const;\n\nconst VIRTUAL_ENTRY_RESOLVED = `\\0${VIRTUAL_ENTRY}` as const;\n\nconst buildPlugin = (opts: ResolvedVitendOptions): Plugin => {\n const build: ResolvedBuildOptions = opts.build;\n\n const packageJson: PackageJson = getPackageJson(opts.cwd);\n\n return {\n name: \"vitend/build\",\n apply: \"build\",\n config: (config: UserConfig): UserConfig => {\n let result: UserConfig = {};\n\n const baseConfig: UserConfig = {\n ssr: {\n external: true,\n noExternal: void 0,\n target: \"webworker\",\n },\n build: {\n copyPublicDir: false,\n },\n };\n\n result = toMerged(baseConfig, config);\n\n const overrideConfig: UserConfig = {\n build: {\n ssr: true,\n outDir: build.outputDir,\n rollupOptions: {\n input: VIRTUAL_ENTRY,\n output: {\n entryFileNames: build.outputFile,\n format:\n packageJson.type === \"module\" ? \"esm\" : \"cjs\",\n },\n external: [\n ...builtinModules,\n /^node:/,\n ],\n },\n minify: build.minify,\n },\n };\n\n result = toMerged(result, overrideConfig);\n\n return result;\n },\n resolveId: (id: string): ResolveIdResult => {\n if (id !== VIRTUAL_ENTRY) return void 0;\n return VIRTUAL_ENTRY_RESOLVED;\n },\n load: async (id: string): Promise<LoadResult> => {\n if (id !== VIRTUAL_ENTRY_RESOLVED) return void 0;\n\n let code: string = \"\";\n\n code += `import options from \"${opts.entry}\";`;\n code += `import { serve } from \"vitend/runtime\";`;\n\n // vercel export\n\n if (build.target === \"vercel\") {\n code += `const server = serve({ ...options, manual: true });`;\n code += `export default server;`;\n\n return code;\n }\n\n // default export\n\n code += `serve({`;\n code += `...options,`;\n\n if (build.host !== \"localhost\")\n code += `hostname: \"${build.host}\",`;\n if (build.port !== 3000) code += `port: ${build.port},`;\n\n if (build.https) {\n code += `tls: {`;\n if (build.https.cert) code += `cert: \"${build.https.cert}\",`;\n if (build.https.key) code += `key: \"${build.https.key}\",`;\n if (build.https.passphrase)\n code += `passphrase: \"${build.https.passphrase}\",`;\n code += `},`;\n }\n\n code += `});`;\n\n return code;\n },\n };\n};\n\nexport { buildPlugin };\n"],"mappings":";;;;;AAeA,MAAM,gBAAgB;AAEtB,MAAM,yBAAyB,KAAK;AAEpC,MAAM,eAAe,SAAwC;CACzD,MAAM,QAA8B,KAAK;CAEzC,MAAM,cAA2BA,oCAAe,KAAK,IAAI;AAEzD,QAAO;EACH,MAAM;EACN,OAAO;EACP,SAAS,WAAmC;GACxC,IAAI,SAAqB,EAAE;AAa3B,qCAX+B;IAC3B,KAAK;KACD,UAAU;KACV,YAAY,KAAK;KACjB,QAAQ;KACX;IACD,OAAO,EACH,eAAe,OAClB;IACJ,EAE6B,OAAO;GAErC,MAAM,iBAA6B,EAC/B,OAAO;IACH,KAAK;IACL,QAAQ,MAAM;IACd,eAAe;KACX,OAAO;KACP,QAAQ;MACJ,gBAAgB,MAAM;MACtB,QACI,YAAY,SAAS,WAAW,QAAQ;MAC/C;KACD,UAAU,CACN,GAAGC,4BACH,SACH;KACJ;IACD,QAAQ,MAAM;IACjB,EACJ;AAED,qCAAkB,QAAQ,eAAe;AAEzC,UAAO;;EAEX,YAAY,OAAgC;AACxC,OAAI,OAAO,cAAe,QAAO,KAAK;AACtC,UAAO;;EAEX,MAAM,OAAO,OAAoC;AAC7C,OAAI,OAAO,uBAAwB,QAAO,KAAK;GAE/C,IAAI,OAAe;AAEnB,WAAQ,wBAAwB,KAAK,MAAM;AAC3C,WAAQ;AAIR,OAAI,MAAM,WAAW,UAAU;AAC3B,YAAQ;AACR,YAAQ;AAER,WAAO;;AAKX,WAAQ;AACR,WAAQ;AAER,OAAI,MAAM,SAAS,YACf,SAAQ,cAAc,MAAM,KAAK;AACrC,OAAI,MAAM,SAAS,IAAM,SAAQ,SAAS,MAAM,KAAK;AAErD,OAAI,MAAM,OAAO;AACb,YAAQ;AACR,QAAI,MAAM,MAAM,KAAM,SAAQ,UAAU,MAAM,MAAM,KAAK;AACzD,QAAI,MAAM,MAAM,IAAK,SAAQ,SAAS,MAAM,MAAM,IAAI;AACtD,QAAI,MAAM,MAAM,WACZ,SAAQ,gBAAgB,MAAM,MAAM,WAAW;AACnD,YAAQ;;AAGZ,WAAQ;AAER,UAAO;;EAEd"}
@@ -1,71 +0,0 @@
1
- import { getPackageJson } from "../functions/package-json.mjs";
2
- import { builtinModules } from "node:module";
3
- import { toMerged } from "es-toolkit";
4
-
5
- const VIRTUAL_ENTRY = "virtual:vitend-entry";
6
- const VIRTUAL_ENTRY_RESOLVED = `\0${VIRTUAL_ENTRY}`;
7
- const buildPlugin = (opts) => {
8
- const build = opts.build;
9
- const packageJson = getPackageJson(opts.cwd);
10
- return {
11
- name: "vitend/build",
12
- apply: "build",
13
- config: (config) => {
14
- let result = {};
15
- result = toMerged({
16
- ssr: {
17
- external: true,
18
- noExternal: void 0,
19
- target: "webworker"
20
- },
21
- build: { copyPublicDir: false }
22
- }, config);
23
- const overrideConfig = { build: {
24
- ssr: true,
25
- outDir: build.outputDir,
26
- rollupOptions: {
27
- input: VIRTUAL_ENTRY,
28
- output: {
29
- entryFileNames: build.outputFile,
30
- format: packageJson.type === "module" ? "esm" : "cjs"
31
- },
32
- external: [...builtinModules, /^node:/]
33
- },
34
- minify: build.minify
35
- } };
36
- result = toMerged(result, overrideConfig);
37
- return result;
38
- },
39
- resolveId: (id) => {
40
- if (id !== VIRTUAL_ENTRY) return void 0;
41
- return VIRTUAL_ENTRY_RESOLVED;
42
- },
43
- load: async (id) => {
44
- if (id !== VIRTUAL_ENTRY_RESOLVED) return void 0;
45
- let code = "";
46
- code += `import options from "${opts.entry}";`;
47
- code += `import { serve } from "vitend/runtime";`;
48
- if (build.target === "vercel") {
49
- code += `const server = serve({ ...options, manual: true });`;
50
- code += `export default server;`;
51
- return code;
52
- }
53
- code += `serve({`;
54
- code += `...options,`;
55
- if (build.host !== "localhost") code += `hostname: "${build.host}",`;
56
- if (build.port !== 3e3) code += `port: ${build.port},`;
57
- if (build.https) {
58
- code += `tls: {`;
59
- if (build.https.cert) code += `cert: "${build.https.cert}",`;
60
- if (build.https.key) code += `key: "${build.https.key}",`;
61
- if (build.https.passphrase) code += `passphrase: "${build.https.passphrase}",`;
62
- code += `},`;
63
- }
64
- code += `});`;
65
- return code;
66
- }
67
- };
68
- };
69
-
70
- export { buildPlugin };
71
- //# sourceMappingURL=build.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"build.mjs","names":[],"sources":["../../src/vite/build.ts"],"sourcesContent":["import type { LoadResult, ResolveIdResult } from \"rollup\";\nimport type { Plugin, UserConfig } from \"vite\";\n\nimport type {\n ResolvedBuildOptions,\n ResolvedVitendOptions,\n} from \"#/@types/options/resolved\";\nimport type { PackageJson } from \"#/functions/package-json\";\n\nimport { builtinModules } from \"node:module\";\n\nimport { toMerged } from \"es-toolkit\";\n\nimport { getPackageJson } from \"#/functions/package-json\";\n\nconst VIRTUAL_ENTRY = \"virtual:vitend-entry\" as const;\n\nconst VIRTUAL_ENTRY_RESOLVED = `\\0${VIRTUAL_ENTRY}` as const;\n\nconst buildPlugin = (opts: ResolvedVitendOptions): Plugin => {\n const build: ResolvedBuildOptions = opts.build;\n\n const packageJson: PackageJson = getPackageJson(opts.cwd);\n\n return {\n name: \"vitend/build\",\n apply: \"build\",\n config: (config: UserConfig): UserConfig => {\n let result: UserConfig = {};\n\n const baseConfig: UserConfig = {\n ssr: {\n external: true,\n noExternal: void 0,\n target: \"webworker\",\n },\n build: {\n copyPublicDir: false,\n },\n };\n\n result = toMerged(baseConfig, config);\n\n const overrideConfig: UserConfig = {\n build: {\n ssr: true,\n outDir: build.outputDir,\n rollupOptions: {\n input: VIRTUAL_ENTRY,\n output: {\n entryFileNames: build.outputFile,\n format:\n packageJson.type === \"module\" ? \"esm\" : \"cjs\",\n },\n external: [\n ...builtinModules,\n /^node:/,\n ],\n },\n minify: build.minify,\n },\n };\n\n result = toMerged(result, overrideConfig);\n\n return result;\n },\n resolveId: (id: string): ResolveIdResult => {\n if (id !== VIRTUAL_ENTRY) return void 0;\n return VIRTUAL_ENTRY_RESOLVED;\n },\n load: async (id: string): Promise<LoadResult> => {\n if (id !== VIRTUAL_ENTRY_RESOLVED) return void 0;\n\n let code: string = \"\";\n\n code += `import options from \"${opts.entry}\";`;\n code += `import { serve } from \"vitend/runtime\";`;\n\n // vercel export\n\n if (build.target === \"vercel\") {\n code += `const server = serve({ ...options, manual: true });`;\n code += `export default server;`;\n\n return code;\n }\n\n // default export\n\n code += `serve({`;\n code += `...options,`;\n\n if (build.host !== \"localhost\")\n code += `hostname: \"${build.host}\",`;\n if (build.port !== 3000) code += `port: ${build.port},`;\n\n if (build.https) {\n code += `tls: {`;\n if (build.https.cert) code += `cert: \"${build.https.cert}\",`;\n if (build.https.key) code += `key: \"${build.https.key}\",`;\n if (build.https.passphrase)\n code += `passphrase: \"${build.https.passphrase}\",`;\n code += `},`;\n }\n\n code += `});`;\n\n return code;\n },\n };\n};\n\nexport { buildPlugin };\n"],"mappings":";;;;AAeA,MAAM,gBAAgB;AAEtB,MAAM,yBAAyB,KAAK;AAEpC,MAAM,eAAe,SAAwC;CACzD,MAAM,QAA8B,KAAK;CAEzC,MAAM,cAA2B,eAAe,KAAK,IAAI;AAEzD,QAAO;EACH,MAAM;EACN,OAAO;EACP,SAAS,WAAmC;GACxC,IAAI,SAAqB,EAAE;AAa3B,YAAS,SAXsB;IAC3B,KAAK;KACD,UAAU;KACV,YAAY,KAAK;KACjB,QAAQ;KACX;IACD,OAAO,EACH,eAAe,OAClB;IACJ,EAE6B,OAAO;GAErC,MAAM,iBAA6B,EAC/B,OAAO;IACH,KAAK;IACL,QAAQ,MAAM;IACd,eAAe;KACX,OAAO;KACP,QAAQ;MACJ,gBAAgB,MAAM;MACtB,QACI,YAAY,SAAS,WAAW,QAAQ;MAC/C;KACD,UAAU,CACN,GAAG,gBACH,SACH;KACJ;IACD,QAAQ,MAAM;IACjB,EACJ;AAED,YAAS,SAAS,QAAQ,eAAe;AAEzC,UAAO;;EAEX,YAAY,OAAgC;AACxC,OAAI,OAAO,cAAe,QAAO,KAAK;AACtC,UAAO;;EAEX,MAAM,OAAO,OAAoC;AAC7C,OAAI,OAAO,uBAAwB,QAAO,KAAK;GAE/C,IAAI,OAAe;AAEnB,WAAQ,wBAAwB,KAAK,MAAM;AAC3C,WAAQ;AAIR,OAAI,MAAM,WAAW,UAAU;AAC3B,YAAQ;AACR,YAAQ;AAER,WAAO;;AAKX,WAAQ;AACR,WAAQ;AAER,OAAI,MAAM,SAAS,YACf,SAAQ,cAAc,MAAM,KAAK;AACrC,OAAI,MAAM,SAAS,IAAM,SAAQ,SAAS,MAAM,KAAK;AAErD,OAAI,MAAM,OAAO;AACb,YAAQ;AACR,QAAI,MAAM,MAAM,KAAM,SAAQ,UAAU,MAAM,MAAM,KAAK;AACzD,QAAI,MAAM,MAAM,IAAK,SAAQ,SAAS,MAAM,MAAM,IAAI;AACtD,QAAI,MAAM,MAAM,WACZ,SAAQ,gBAAgB,MAAM,MAAM,WAAW;AACnD,YAAQ;;AAGZ,WAAQ;AAER,UAAO;;EAEd"}
package/dist/vite/dev.js DELETED
@@ -1,90 +0,0 @@
1
- const require_runtime = require('../_virtual/_rolldown/runtime.js');
2
- let es_toolkit = require("es-toolkit");
3
- let srvx = require("srvx");
4
-
5
- const createMiddleware = ({ vite, server }) => {
6
- return async (req, res, _next) => {
7
- const protocol = `http${vite.config.server.https?.cert !== void 0 && vite.config.server.https?.key !== void 0 ? "s" : ""}`;
8
- const host = process.env.HOST ?? "localhost";
9
- const port = vite.config.server.port;
10
- const path = req.url ?? "";
11
- const url = new URL(`${protocol}://${host}:${port}${path}`);
12
- const body = req.method !== "GET" && req.method !== "HEAD" ? req : void 0;
13
- const request = new Request(url, {
14
- method: req.method,
15
- headers: req.headers,
16
- body,
17
- duplex: "half"
18
- });
19
- const response = await server.fetch(request);
20
- res.statusCode = response.status;
21
- response.headers.forEach((value, key) => {
22
- res.setHeader(key, value);
23
- });
24
- if (!response.body) {
25
- res.end();
26
- return;
27
- }
28
- const reader = response.body.getReader();
29
- const stream = async () => {
30
- try {
31
- while (true) {
32
- const { done, value } = await reader.read();
33
- if (done) break;
34
- res.write(value);
35
- }
36
- res.end();
37
- } catch {
38
- res.end();
39
- }
40
- };
41
- await stream();
42
- };
43
- };
44
- const devPlugin = (opts) => {
45
- const dev = opts.dev;
46
- const https = opts.dev.https ?? {};
47
- return {
48
- name: "vitend/dev",
49
- apply: "serve",
50
- config(config) {
51
- return (0, es_toolkit.toMerged)(config, {
52
- build: {
53
- ssr: true,
54
- rollupOptions: { input: opts.entry }
55
- },
56
- server: {
57
- host: dev.host,
58
- port: dev.port,
59
- ...https.cert !== void 0 && https.key !== void 0 ? { https: {
60
- cert: https.cert,
61
- key: https.key,
62
- passphrase: https.passphrase
63
- } } : {}
64
- }
65
- });
66
- },
67
- configureServer: async (vite) => {
68
- const serverOptions = (await vite.ssrLoadModule(opts.entry)).default;
69
- const middleware = createMiddleware({
70
- vite,
71
- server: (0, srvx.serve)({
72
- gracefulShutdown: false,
73
- ...serverOptions,
74
- manual: true,
75
- hostname: dev.host,
76
- port: dev.port,
77
- tls: {
78
- cert: https.cert,
79
- key: https.key,
80
- passphrase: https.passphrase
81
- }
82
- })
83
- });
84
- vite.middlewares.use(middleware);
85
- }
86
- };
87
- };
88
-
89
- exports.devPlugin = devPlugin;
90
- //# sourceMappingURL=dev.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dev.js","names":[],"sources":["../../src/vite/dev.ts"],"sourcesContent":["import type HTTP from \"node:http\";\n\nimport type { Server, ServerHandler, ServerOptions } from \"srvx\";\nimport type { Connect, Plugin, UserConfig, ViteDevServer } from \"vite\";\n\nimport type {\n ResolvedDevOptions,\n ResolvedHttpsOptions,\n ResolvedVitendOptions,\n} from \"#/@types/options/resolved\";\n\nimport { toMerged } from \"es-toolkit\";\nimport { serve } from \"srvx\";\n\ntype CreateMiddlewareOptions = {\n vite: ViteDevServer;\n server: Server;\n};\n\nconst createMiddleware = ({ vite, server }: CreateMiddlewareOptions) => {\n return async (\n req: Connect.IncomingMessage,\n res: HTTP.ServerResponse,\n _next: Connect.NextFunction,\n ): Promise<void> => {\n const isHttps: boolean =\n vite.config.server.https?.cert !== void 0 &&\n vite.config.server.https?.key !== void 0;\n\n const protocol: string = `http${isHttps ? \"s\" : \"\"}`;\n\n const host: string = process.env.HOST ?? \"localhost\";\n\n const port: number = vite.config.server.port;\n\n const path: string = req.url ?? \"\";\n\n const url: URL = new URL(`${protocol}://${host}:${port}${path}`);\n\n const body: Connect.IncomingMessage | undefined =\n req.method !== \"GET\" && req.method !== \"HEAD\" ? req : void 0;\n\n const request: Request = new Request(url, {\n method: req.method,\n headers: req.headers,\n body,\n duplex: \"half\",\n } as RequestInit);\n\n const response: Response = await server.fetch(request);\n\n res.statusCode = response.status;\n\n response.headers.forEach((value: string, key: string): void => {\n res.setHeader(key, value);\n });\n\n if (!response.body) {\n res.end();\n return void 0;\n }\n\n const reader: ReadableStreamDefaultReader<Uint8Array<ArrayBuffer>> =\n response.body.getReader();\n\n const stream = async (): Promise<void> => {\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) break;\n\n res.write(value);\n }\n\n res.end();\n } catch {\n res.end();\n }\n };\n\n await stream();\n };\n};\n\ntype Middleware = ReturnType<typeof createMiddleware>;\n\nconst devPlugin = (opts: ResolvedVitendOptions): Plugin => {\n const dev: ResolvedDevOptions = opts.dev;\n const https: ResolvedHttpsOptions = opts.dev.https ?? {};\n\n return {\n name: \"vitend/dev\",\n apply: \"serve\",\n config(config: UserConfig): UserConfig {\n const devConfig: UserConfig = {\n build: {\n ssr: true,\n rollupOptions: {\n input: opts.entry,\n },\n },\n server: {\n host: dev.host,\n port: dev.port,\n ...(https.cert !== void 0 && https.key !== void 0\n ? {\n https: {\n cert: https.cert,\n key: https.key,\n passphrase: https.passphrase,\n },\n }\n : {}),\n },\n };\n\n return toMerged(config, devConfig);\n },\n configureServer: async (vite: ViteDevServer): Promise<void> => {\n const serverOptions: ServerOptions = (\n await vite.ssrLoadModule(opts.entry)\n ).default;\n\n const server: Server<ServerHandler> = serve({\n // base\n gracefulShutdown: false,\n // user\n ...serverOptions,\n // override\n manual: true,\n hostname: dev.host,\n port: dev.port,\n tls: {\n cert: https.cert,\n key: https.key,\n passphrase: https.passphrase,\n },\n });\n\n const middleware: Middleware = createMiddleware({\n vite,\n server,\n });\n\n vite.middlewares.use(middleware);\n },\n };\n};\n\nexport { devPlugin };\n"],"mappings":";;;;AAmBA,MAAM,oBAAoB,EAAE,MAAM,aAAsC;AACpE,QAAO,OACH,KACA,KACA,UACgB;EAKhB,MAAM,WAAmB,OAHrB,KAAK,OAAO,OAAO,OAAO,SAAS,KAAK,KACxC,KAAK,OAAO,OAAO,OAAO,QAAQ,KAAK,IAED,MAAM;EAEhD,MAAM,OAAe,QAAQ,IAAI,QAAQ;EAEzC,MAAM,OAAe,KAAK,OAAO,OAAO;EAExC,MAAM,OAAe,IAAI,OAAO;EAEhC,MAAM,MAAW,IAAI,IAAI,GAAG,SAAS,KAAK,KAAK,GAAG,OAAO,OAAO;EAEhE,MAAM,OACF,IAAI,WAAW,SAAS,IAAI,WAAW,SAAS,MAAM,KAAK;EAE/D,MAAM,UAAmB,IAAI,QAAQ,KAAK;GACtC,QAAQ,IAAI;GACZ,SAAS,IAAI;GACb;GACA,QAAQ;GACX,CAAgB;EAEjB,MAAM,WAAqB,MAAM,OAAO,MAAM,QAAQ;AAEtD,MAAI,aAAa,SAAS;AAE1B,WAAS,QAAQ,SAAS,OAAe,QAAsB;AAC3D,OAAI,UAAU,KAAK,MAAM;IAC3B;AAEF,MAAI,CAAC,SAAS,MAAM;AAChB,OAAI,KAAK;AACT;;EAGJ,MAAM,SACF,SAAS,KAAK,WAAW;EAE7B,MAAM,SAAS,YAA2B;AACtC,OAAI;AACA,WAAO,MAAM;KACT,MAAM,EAAE,MAAM,UAAU,MAAM,OAAO,MAAM;AAE3C,SAAI,KAAM;AAEV,SAAI,MAAM,MAAM;;AAGpB,QAAI,KAAK;WACL;AACJ,QAAI,KAAK;;;AAIjB,QAAM,QAAQ;;;AAMtB,MAAM,aAAa,SAAwC;CACvD,MAAM,MAA0B,KAAK;CACrC,MAAM,QAA8B,KAAK,IAAI,SAAS,EAAE;AAExD,QAAO;EACH,MAAM;EACN,OAAO;EACP,OAAO,QAAgC;AAuBnC,mCAAgB,QAtBc;IAC1B,OAAO;KACH,KAAK;KACL,eAAe,EACX,OAAO,KAAK,OACf;KACJ;IACD,QAAQ;KACJ,MAAM,IAAI;KACV,MAAM,IAAI;KACV,GAAI,MAAM,SAAS,KAAK,KAAK,MAAM,QAAQ,KAAK,IAC1C,EACI,OAAO;MACH,MAAM,MAAM;MACZ,KAAK,MAAM;MACX,YAAY,MAAM;MACrB,EACJ,GACD,EAAE;KACX;IACJ,CAEiC;;EAEtC,iBAAiB,OAAO,SAAuC;GAC3D,MAAM,iBACF,MAAM,KAAK,cAAc,KAAK,MAAM,EACtC;GAkBF,MAAM,aAAyB,iBAAiB;IAC5C;IACA,wBAlBwC;KAExC,kBAAkB;KAElB,GAAG;KAEH,QAAQ;KACR,UAAU,IAAI;KACd,MAAM,IAAI;KACV,KAAK;MACD,MAAM,MAAM;MACZ,KAAK,MAAM;MACX,YAAY,MAAM;MACrB;KACJ,CAAC;IAKD,CAAC;AAEF,QAAK,YAAY,IAAI,WAAW;;EAEvC"}
package/dist/vite/dev.mjs DELETED
@@ -1,89 +0,0 @@
1
- import { toMerged } from "es-toolkit";
2
- import { serve } from "srvx";
3
-
4
- const createMiddleware = ({ vite, server }) => {
5
- return async (req, res, _next) => {
6
- const protocol = `http${vite.config.server.https?.cert !== void 0 && vite.config.server.https?.key !== void 0 ? "s" : ""}`;
7
- const host = process.env.HOST ?? "localhost";
8
- const port = vite.config.server.port;
9
- const path = req.url ?? "";
10
- const url = new URL(`${protocol}://${host}:${port}${path}`);
11
- const body = req.method !== "GET" && req.method !== "HEAD" ? req : void 0;
12
- const request = new Request(url, {
13
- method: req.method,
14
- headers: req.headers,
15
- body,
16
- duplex: "half"
17
- });
18
- const response = await server.fetch(request);
19
- res.statusCode = response.status;
20
- response.headers.forEach((value, key) => {
21
- res.setHeader(key, value);
22
- });
23
- if (!response.body) {
24
- res.end();
25
- return;
26
- }
27
- const reader = response.body.getReader();
28
- const stream = async () => {
29
- try {
30
- while (true) {
31
- const { done, value } = await reader.read();
32
- if (done) break;
33
- res.write(value);
34
- }
35
- res.end();
36
- } catch {
37
- res.end();
38
- }
39
- };
40
- await stream();
41
- };
42
- };
43
- const devPlugin = (opts) => {
44
- const dev = opts.dev;
45
- const https = opts.dev.https ?? {};
46
- return {
47
- name: "vitend/dev",
48
- apply: "serve",
49
- config(config) {
50
- return toMerged(config, {
51
- build: {
52
- ssr: true,
53
- rollupOptions: { input: opts.entry }
54
- },
55
- server: {
56
- host: dev.host,
57
- port: dev.port,
58
- ...https.cert !== void 0 && https.key !== void 0 ? { https: {
59
- cert: https.cert,
60
- key: https.key,
61
- passphrase: https.passphrase
62
- } } : {}
63
- }
64
- });
65
- },
66
- configureServer: async (vite) => {
67
- const serverOptions = (await vite.ssrLoadModule(opts.entry)).default;
68
- const middleware = createMiddleware({
69
- vite,
70
- server: serve({
71
- gracefulShutdown: false,
72
- ...serverOptions,
73
- manual: true,
74
- hostname: dev.host,
75
- port: dev.port,
76
- tls: {
77
- cert: https.cert,
78
- key: https.key,
79
- passphrase: https.passphrase
80
- }
81
- })
82
- });
83
- vite.middlewares.use(middleware);
84
- }
85
- };
86
- };
87
-
88
- export { devPlugin };
89
- //# sourceMappingURL=dev.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dev.mjs","names":[],"sources":["../../src/vite/dev.ts"],"sourcesContent":["import type HTTP from \"node:http\";\n\nimport type { Server, ServerHandler, ServerOptions } from \"srvx\";\nimport type { Connect, Plugin, UserConfig, ViteDevServer } from \"vite\";\n\nimport type {\n ResolvedDevOptions,\n ResolvedHttpsOptions,\n ResolvedVitendOptions,\n} from \"#/@types/options/resolved\";\n\nimport { toMerged } from \"es-toolkit\";\nimport { serve } from \"srvx\";\n\ntype CreateMiddlewareOptions = {\n vite: ViteDevServer;\n server: Server;\n};\n\nconst createMiddleware = ({ vite, server }: CreateMiddlewareOptions) => {\n return async (\n req: Connect.IncomingMessage,\n res: HTTP.ServerResponse,\n _next: Connect.NextFunction,\n ): Promise<void> => {\n const isHttps: boolean =\n vite.config.server.https?.cert !== void 0 &&\n vite.config.server.https?.key !== void 0;\n\n const protocol: string = `http${isHttps ? \"s\" : \"\"}`;\n\n const host: string = process.env.HOST ?? \"localhost\";\n\n const port: number = vite.config.server.port;\n\n const path: string = req.url ?? \"\";\n\n const url: URL = new URL(`${protocol}://${host}:${port}${path}`);\n\n const body: Connect.IncomingMessage | undefined =\n req.method !== \"GET\" && req.method !== \"HEAD\" ? req : void 0;\n\n const request: Request = new Request(url, {\n method: req.method,\n headers: req.headers,\n body,\n duplex: \"half\",\n } as RequestInit);\n\n const response: Response = await server.fetch(request);\n\n res.statusCode = response.status;\n\n response.headers.forEach((value: string, key: string): void => {\n res.setHeader(key, value);\n });\n\n if (!response.body) {\n res.end();\n return void 0;\n }\n\n const reader: ReadableStreamDefaultReader<Uint8Array<ArrayBuffer>> =\n response.body.getReader();\n\n const stream = async (): Promise<void> => {\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) break;\n\n res.write(value);\n }\n\n res.end();\n } catch {\n res.end();\n }\n };\n\n await stream();\n };\n};\n\ntype Middleware = ReturnType<typeof createMiddleware>;\n\nconst devPlugin = (opts: ResolvedVitendOptions): Plugin => {\n const dev: ResolvedDevOptions = opts.dev;\n const https: ResolvedHttpsOptions = opts.dev.https ?? {};\n\n return {\n name: \"vitend/dev\",\n apply: \"serve\",\n config(config: UserConfig): UserConfig {\n const devConfig: UserConfig = {\n build: {\n ssr: true,\n rollupOptions: {\n input: opts.entry,\n },\n },\n server: {\n host: dev.host,\n port: dev.port,\n ...(https.cert !== void 0 && https.key !== void 0\n ? {\n https: {\n cert: https.cert,\n key: https.key,\n passphrase: https.passphrase,\n },\n }\n : {}),\n },\n };\n\n return toMerged(config, devConfig);\n },\n configureServer: async (vite: ViteDevServer): Promise<void> => {\n const serverOptions: ServerOptions = (\n await vite.ssrLoadModule(opts.entry)\n ).default;\n\n const server: Server<ServerHandler> = serve({\n // base\n gracefulShutdown: false,\n // user\n ...serverOptions,\n // override\n manual: true,\n hostname: dev.host,\n port: dev.port,\n tls: {\n cert: https.cert,\n key: https.key,\n passphrase: https.passphrase,\n },\n });\n\n const middleware: Middleware = createMiddleware({\n vite,\n server,\n });\n\n vite.middlewares.use(middleware);\n },\n };\n};\n\nexport { devPlugin };\n"],"mappings":";;;AAmBA,MAAM,oBAAoB,EAAE,MAAM,aAAsC;AACpE,QAAO,OACH,KACA,KACA,UACgB;EAKhB,MAAM,WAAmB,OAHrB,KAAK,OAAO,OAAO,OAAO,SAAS,KAAK,KACxC,KAAK,OAAO,OAAO,OAAO,QAAQ,KAAK,IAED,MAAM;EAEhD,MAAM,OAAe,QAAQ,IAAI,QAAQ;EAEzC,MAAM,OAAe,KAAK,OAAO,OAAO;EAExC,MAAM,OAAe,IAAI,OAAO;EAEhC,MAAM,MAAW,IAAI,IAAI,GAAG,SAAS,KAAK,KAAK,GAAG,OAAO,OAAO;EAEhE,MAAM,OACF,IAAI,WAAW,SAAS,IAAI,WAAW,SAAS,MAAM,KAAK;EAE/D,MAAM,UAAmB,IAAI,QAAQ,KAAK;GACtC,QAAQ,IAAI;GACZ,SAAS,IAAI;GACb;GACA,QAAQ;GACX,CAAgB;EAEjB,MAAM,WAAqB,MAAM,OAAO,MAAM,QAAQ;AAEtD,MAAI,aAAa,SAAS;AAE1B,WAAS,QAAQ,SAAS,OAAe,QAAsB;AAC3D,OAAI,UAAU,KAAK,MAAM;IAC3B;AAEF,MAAI,CAAC,SAAS,MAAM;AAChB,OAAI,KAAK;AACT;;EAGJ,MAAM,SACF,SAAS,KAAK,WAAW;EAE7B,MAAM,SAAS,YAA2B;AACtC,OAAI;AACA,WAAO,MAAM;KACT,MAAM,EAAE,MAAM,UAAU,MAAM,OAAO,MAAM;AAE3C,SAAI,KAAM;AAEV,SAAI,MAAM,MAAM;;AAGpB,QAAI,KAAK;WACL;AACJ,QAAI,KAAK;;;AAIjB,QAAM,QAAQ;;;AAMtB,MAAM,aAAa,SAAwC;CACvD,MAAM,MAA0B,KAAK;CACrC,MAAM,QAA8B,KAAK,IAAI,SAAS,EAAE;AAExD,QAAO;EACH,MAAM;EACN,OAAO;EACP,OAAO,QAAgC;AAuBnC,UAAO,SAAS,QAtBc;IAC1B,OAAO;KACH,KAAK;KACL,eAAe,EACX,OAAO,KAAK,OACf;KACJ;IACD,QAAQ;KACJ,MAAM,IAAI;KACV,MAAM,IAAI;KACV,GAAI,MAAM,SAAS,KAAK,KAAK,MAAM,QAAQ,KAAK,IAC1C,EACI,OAAO;MACH,MAAM,MAAM;MACZ,KAAK,MAAM;MACX,YAAY,MAAM;MACrB,EACJ,GACD,EAAE;KACX;IACJ,CAEiC;;EAEtC,iBAAiB,OAAO,SAAuC;GAC3D,MAAM,iBACF,MAAM,KAAK,cAAc,KAAK,MAAM,EACtC;GAkBF,MAAM,aAAyB,iBAAiB;IAC5C;IACA,QAlBkC,MAAM;KAExC,kBAAkB;KAElB,GAAG;KAEH,QAAQ;KACR,UAAU,IAAI;KACd,MAAM,IAAI;KACV,KAAK;MACD,MAAM,MAAM;MACZ,KAAK,MAAM;MACX,YAAY,MAAM;MACrB;KACJ,CAAC;IAKD,CAAC;AAEF,QAAK,YAAY,IAAI,WAAW;;EAEvC"}
@@ -1,23 +0,0 @@
1
- import { VitendOptions } from "../@types/options/default.js";
2
- import { Plugin } from "vite";
3
- /**
4
- * The `vitend` plugin.
5
- *
6
- * ### Example
7
- *
8
- * ```ts
9
- * // ./vite.config.ts
10
- *
11
- * import { defineConfig } from "vite";
12
- * import { vitend } from "vitend/vite";
13
- *
14
- * export default defineConfig({
15
- * plugins: [
16
- * vitend(),
17
- * ],
18
- * });
19
- * ```
20
- */
21
- declare const vitend: (options?: VitendOptions) => Plugin[];
22
- export { vitend };
23
- //# sourceMappingURL=vitend.d.ts.map
@@ -1,45 +0,0 @@
1
- const require_runtime = require('../_virtual/_rolldown/runtime.js');
2
- const require_options = require('../functions/options.js');
3
- const require_build = require('./build.js');
4
- const require_dev = require('./dev.js');
5
- let node_path = require("node:path");
6
- node_path = require_runtime.__toESM(node_path);
7
- let rollup_plugin_copy = require("rollup-plugin-copy");
8
- rollup_plugin_copy = require_runtime.__toESM(rollup_plugin_copy);
9
-
10
- /**
11
- * The `vitend` plugin.
12
- *
13
- * ### Example
14
- *
15
- * ```ts
16
- * // ./vite.config.ts
17
- *
18
- * import { defineConfig } from "vite";
19
- * import { vitend } from "vitend/vite";
20
- *
21
- * export default defineConfig({
22
- * plugins: [
23
- * vitend(),
24
- * ],
25
- * });
26
- * ```
27
- */
28
- const vitend = (options) => {
29
- const opts = require_options.createOptions(options);
30
- const build = opts.build;
31
- return [
32
- require_dev.devPlugin({ ...opts }),
33
- require_build.buildPlugin({ ...opts }),
34
- ...build.target === "default" && build.copyPublicDir ? [(0, rollup_plugin_copy.default)({
35
- hook: "closeBundle",
36
- targets: [{
37
- src: node_path.resolve(build.publicDir, "**", "*"),
38
- dest: node_path.resolve(build.outputDir, build.publicDir)
39
- }]
40
- })] : []
41
- ];
42
- };
43
-
44
- exports.vitend = vitend;
45
- //# sourceMappingURL=vitend.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"vitend.js","names":["createOptions","devPlugin","buildPlugin","Path"],"sources":["../../src/vite/vitend.ts"],"sourcesContent":["import type { Plugin } from \"vite\";\n\nimport type { VitendOptions } from \"#/@types/options/default\";\nimport type {\n ResolvedBuildOptions,\n ResolvedVitendOptions,\n} from \"#/@types/options/resolved\";\n\nimport * as Path from \"node:path\";\n\nimport copy from \"rollup-plugin-copy\";\n\nimport { createOptions } from \"#/functions/options\";\nimport { buildPlugin } from \"#/vite/build\";\nimport { devPlugin } from \"#/vite/dev\";\n\n/**\n * The `vitend` plugin.\n *\n * ### Example\n *\n * ```ts\n * // ./vite.config.ts\n *\n * import { defineConfig } from \"vite\";\n * import { vitend } from \"vitend/vite\";\n *\n * export default defineConfig({\n * plugins: [\n * vitend(),\n * ],\n * });\n * ```\n */\nconst vitend = (options?: VitendOptions): Plugin[] => {\n const opts: ResolvedVitendOptions = createOptions(options);\n\n const build: ResolvedBuildOptions = opts.build;\n\n return [\n devPlugin({\n ...opts,\n }),\n buildPlugin({\n ...opts,\n }),\n ...(build.target === \"default\" && build.copyPublicDir\n ? ([\n copy({\n hook: \"closeBundle\",\n targets: [\n {\n src: Path.resolve(build.publicDir, \"**\", \"*\"),\n dest: Path.resolve(\n build.outputDir,\n build.publicDir,\n ),\n },\n ],\n }),\n ] as Plugin[])\n : []),\n ];\n};\n\nexport { vitend };\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAkCA,MAAM,UAAU,YAAsC;CAClD,MAAM,OAA8BA,8BAAc,QAAQ;CAE1D,MAAM,QAA8B,KAAK;AAEzC,QAAO;EACHC,sBAAU,EACN,GAAG,MACN,CAAC;EACFC,0BAAY,EACR,GAAG,MACN,CAAC;EACF,GAAI,MAAM,WAAW,aAAa,MAAM,gBACjC,iCACQ;GACD,MAAM;GACN,SAAS,CACL;IACI,KAAKC,UAAK,QAAQ,MAAM,WAAW,MAAM,IAAI;IAC7C,MAAMA,UAAK,QACP,MAAM,WACN,MAAM,UACT;IACJ,CACJ;GACJ,CAAC,CACL,GACD,EAAE;EACX"}