wexts 3.0.1 → 4.0.0

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 (276) hide show
  1. package/README.md +49 -346
  2. package/bin/wexts.cjs +2 -0
  3. package/dist/chunk-2KAQYLVN.js +0 -0
  4. package/dist/chunk-2KAQYLVN.js.map +1 -1
  5. package/dist/{chunk-O42L6HOX.js → chunk-2LJVUMXW.js} +79 -93
  6. package/dist/chunk-2LJVUMXW.js.map +1 -0
  7. package/dist/chunk-7QKLIVRF.js +94 -0
  8. package/dist/chunk-7QKLIVRF.js.map +1 -0
  9. package/dist/{chunk-FCEZDH42.mjs → chunk-7WULUGLH.mjs} +5 -3
  10. package/dist/chunk-7WULUGLH.mjs.map +1 -0
  11. package/dist/{chunk-WF65EDRZ.js → chunk-BG56B4DE.js} +20 -2
  12. package/dist/chunk-BG56B4DE.js.map +1 -0
  13. package/dist/chunk-CLM5PNSG.mjs +496 -0
  14. package/dist/chunk-CLM5PNSG.mjs.map +1 -0
  15. package/dist/chunk-DNLGCKTT.js +31 -0
  16. package/dist/chunk-DNLGCKTT.js.map +1 -0
  17. package/dist/{chunk-VNNVLQLJ.mjs → chunk-JHOVXH3X.mjs} +2 -2
  18. package/dist/chunk-JHOVXH3X.mjs.map +1 -0
  19. package/dist/chunk-MXINIFPC.js +105 -0
  20. package/dist/chunk-MXINIFPC.js.map +1 -0
  21. package/dist/chunk-SE32ZPOZ.js +496 -0
  22. package/dist/chunk-SE32ZPOZ.js.map +1 -0
  23. package/dist/{chunk-STTOPUZ2.mjs → chunk-UAL54DVV.mjs} +21 -3
  24. package/dist/chunk-UAL54DVV.mjs.map +1 -0
  25. package/dist/{chunk-3OM7CHCA.js → chunk-WCKSKU3C.js} +1 -1
  26. package/dist/chunk-WCKSKU3C.js.map +1 -0
  27. package/dist/chunk-WU6FW77M.mjs +105 -0
  28. package/dist/chunk-WU6FW77M.mjs.map +1 -0
  29. package/dist/chunk-XE4OXN2W.js +0 -0
  30. package/dist/chunk-XE4OXN2W.js.map +1 -1
  31. package/dist/chunk-YBM3IJEA.mjs +94 -0
  32. package/dist/chunk-YBM3IJEA.mjs.map +1 -0
  33. package/dist/{chunk-KXYLEUSW.mjs → chunk-YN6WIWNQ.mjs} +69 -83
  34. package/dist/chunk-YN6WIWNQ.mjs.map +1 -0
  35. package/dist/chunk-YSLEF5C5.mjs +0 -0
  36. package/dist/chunk-YSLEF5C5.mjs.map +0 -0
  37. package/dist/chunk-ZX7QIN24.mjs +31 -0
  38. package/dist/chunk-ZX7QIN24.mjs.map +1 -0
  39. package/dist/cli/index.d.mts +10 -0
  40. package/dist/cli/index.d.ts +10 -0
  41. package/dist/cli/index.js +292 -292
  42. package/dist/cli/index.js.map +1 -1
  43. package/dist/cli/index.mjs +294 -293
  44. package/dist/cli/index.mjs.map +1 -1
  45. package/dist/client/index.d.mts +10 -1
  46. package/dist/client/index.d.ts +10 -1
  47. package/dist/client/index.js +4 -2
  48. package/dist/client/index.js.map +1 -1
  49. package/dist/client/index.mjs +6 -4
  50. package/dist/client/index.mjs.map +0 -0
  51. package/dist/codegen/index.d.mts +2 -1
  52. package/dist/codegen/index.d.ts +2 -1
  53. package/dist/codegen/index.js +5 -3
  54. package/dist/codegen/index.js.map +1 -1
  55. package/dist/codegen/index.mjs +7 -5
  56. package/dist/codegen/index.mjs.map +0 -0
  57. package/dist/decorators-BT1FFqN0.d.mts +29 -0
  58. package/dist/decorators-DvS58PqC.d.ts +29 -0
  59. package/dist/dev-server/index.d.mts +1 -1
  60. package/dist/dev-server/index.d.ts +1 -1
  61. package/dist/dev-server/index.js +3 -3
  62. package/dist/dev-server/index.js.map +1 -1
  63. package/dist/dev-server/index.mjs +3 -3
  64. package/dist/dev-server/index.mjs.map +0 -0
  65. package/dist/{index-SjUaHgFr.d.ts → index-7QeQEf37.d.ts} +27 -10
  66. package/dist/{index-tFGPFVfQ.d.mts → index-7RvU-jGE.d.mts} +0 -1
  67. package/dist/{index-tFGPFVfQ.d.ts → index-7RvU-jGE.d.ts} +0 -1
  68. package/dist/{index-SjUaHgFr.d.mts → index-8nzxy0NN.d.mts} +27 -10
  69. package/dist/index-Co5ZsLqq.d.ts +58 -0
  70. package/dist/index-D94W1__r.d.mts +58 -0
  71. package/dist/index-DQmyVp6F.d.mts +27 -0
  72. package/dist/index-KL_1BrQb.d.ts +27 -0
  73. package/dist/index.d.mts +17 -6
  74. package/dist/index.d.ts +17 -6
  75. package/dist/index.js +57 -30
  76. package/dist/index.js.map +1 -1
  77. package/dist/index.mjs +48 -21
  78. package/dist/index.mjs.map +1 -1
  79. package/dist/nest/index.d.mts +3 -1
  80. package/dist/nest/index.d.ts +3 -1
  81. package/dist/nest/index.js +20 -2
  82. package/dist/nest/index.js.map +1 -1
  83. package/dist/nest/index.mjs +21 -3
  84. package/dist/nest/index.mjs.map +0 -0
  85. package/dist/next/index.d.mts +7 -2
  86. package/dist/next/index.d.ts +7 -2
  87. package/dist/next/index.js +72 -5
  88. package/dist/next/index.js.map +1 -1
  89. package/dist/next/index.mjs +70 -4
  90. package/dist/next/index.mjs.map +1 -1
  91. package/dist/rpc/index.d.mts +2 -0
  92. package/dist/rpc/index.d.ts +2 -0
  93. package/dist/rpc/index.js +23 -0
  94. package/dist/rpc/index.js.map +1 -0
  95. package/dist/rpc/index.mjs +23 -0
  96. package/dist/{chunk-7NSRDJ5C.mjs.map → rpc/index.mjs.map} +0 -0
  97. package/dist/runtime/index.d.mts +55 -0
  98. package/dist/runtime/index.d.ts +55 -0
  99. package/dist/runtime/index.js +213 -0
  100. package/dist/runtime/index.js.map +1 -0
  101. package/dist/runtime/index.mjs +213 -0
  102. package/dist/runtime/index.mjs.map +1 -0
  103. package/dist/types/index.d.mts +0 -0
  104. package/dist/types/index.d.ts +0 -0
  105. package/dist/types/index.js +0 -0
  106. package/dist/types/index.js.map +1 -1
  107. package/dist/types/index.mjs +1 -1
  108. package/dist/types/index.mjs.map +0 -0
  109. package/dist/types-7d_fC-C3.d.mts +32 -0
  110. package/dist/types-7d_fC-C3.d.ts +32 -0
  111. package/dist/vercel-builder/index.d.mts +58 -0
  112. package/dist/vercel-builder/index.d.ts +58 -0
  113. package/dist/vercel-builder/index.js +330 -0
  114. package/dist/vercel-builder/index.js.map +1 -0
  115. package/dist/vercel-builder/index.mjs +330 -0
  116. package/dist/vercel-builder/index.mjs.map +1 -0
  117. package/package.json +37 -16
  118. package/templates/.dockerignore +43 -43
  119. package/templates/.env.example +0 -0
  120. package/templates/Dockerfile +60 -60
  121. package/templates/Procfile +1 -1
  122. package/templates/README.md +67 -58
  123. package/templates/api-sdk.ts +115 -115
  124. package/templates/docker-compose.yml +34 -34
  125. package/templates/nestjs-api/.env.example +0 -0
  126. package/templates/nestjs-api/README.md +87 -79
  127. package/templates/nestjs-api/nest-cli.json +6 -6
  128. package/templates/nestjs-api/package-lock.json +5623 -5623
  129. package/templates/nestjs-api/package.json +40 -40
  130. package/templates/nestjs-api/prisma/dev.db +0 -0
  131. package/templates/nestjs-api/prisma/migrations/20251123205437_init/migration.sql +0 -0
  132. package/templates/nestjs-api/prisma/migrations/migration_lock.toml +0 -0
  133. package/templates/nestjs-api/prisma/schema.prisma +29 -29
  134. package/templates/nestjs-api/src/app.module.ts +17 -17
  135. package/templates/nestjs-api/src/auth/auth.controller.ts +27 -27
  136. package/templates/nestjs-api/src/auth/auth.module.ts +37 -29
  137. package/templates/nestjs-api/src/auth/auth.service.ts +86 -86
  138. package/templates/nestjs-api/src/auth/dto/auth.dto.ts +22 -22
  139. package/templates/nestjs-api/src/auth/guards/jwt-auth.guard.ts +5 -5
  140. package/templates/nestjs-api/src/auth/strategies/jwt.strategy.ts +27 -19
  141. package/templates/nestjs-api/src/main.ts +32 -32
  142. package/templates/nestjs-api/src/prisma/prisma.module.ts +9 -9
  143. package/templates/nestjs-api/src/prisma/prisma.service.ts +14 -14
  144. package/templates/nestjs-api/src/todos/dto/todo.dto.ts +24 -24
  145. package/templates/nestjs-api/src/todos/todos.controller.ts +39 -39
  146. package/templates/nestjs-api/src/todos/todos.module.ts +11 -11
  147. package/templates/nestjs-api/src/todos/todos.service.ts +53 -53
  148. package/templates/nestjs-api/src/users/users.controller.ts +14 -14
  149. package/templates/nestjs-api/src/users/users.module.ts +12 -12
  150. package/templates/nestjs-api/src/users/users.service.ts +19 -19
  151. package/templates/nestjs-api/tsconfig.json +39 -39
  152. package/templates/nextjs-web/README.md +76 -68
  153. package/templates/nextjs-web/app/actions/auth.ts +108 -108
  154. package/templates/nextjs-web/app/dashboard/error.tsx +39 -39
  155. package/templates/nextjs-web/app/dashboard/loading.tsx +14 -14
  156. package/templates/nextjs-web/app/dashboard/page.tsx +5 -5
  157. package/templates/nextjs-web/app/globals.css +93 -93
  158. package/templates/nextjs-web/app/layout.tsx +29 -29
  159. package/templates/nextjs-web/app/login/page.tsx +5 -5
  160. package/templates/nextjs-web/app/page.tsx +28 -28
  161. package/templates/nextjs-web/app/register/page.tsx +5 -5
  162. package/templates/nextjs-web/components/ui/button.tsx +56 -56
  163. package/templates/nextjs-web/components/ui/card.tsx +79 -79
  164. package/templates/nextjs-web/components/ui/input.tsx +25 -25
  165. package/templates/nextjs-web/components/ui/label.tsx +24 -24
  166. package/templates/nextjs-web/features/auth/LoginForm.tsx +140 -140
  167. package/templates/nextjs-web/features/auth/RegisterForm.tsx +159 -159
  168. package/templates/nextjs-web/features/auth/api.ts +35 -35
  169. package/templates/nextjs-web/features/auth/index.ts +3 -3
  170. package/templates/nextjs-web/features/dashboard/DashboardView.tsx +204 -204
  171. package/templates/nextjs-web/features/dashboard/api.ts +9 -9
  172. package/templates/nextjs-web/features/dashboard/components.tsx +74 -74
  173. package/templates/nextjs-web/features/dashboard/index.ts +3 -3
  174. package/templates/nextjs-web/hooks/index.ts +4 -4
  175. package/templates/nextjs-web/lib/api-client.ts +89 -89
  176. package/templates/nextjs-web/lib/api.ts +115 -115
  177. package/templates/nextjs-web/lib/axios-global-config.ts +17 -17
  178. package/templates/nextjs-web/lib/utils.ts +6 -6
  179. package/templates/nextjs-web/lib/wexts-client.ts +4 -4
  180. package/templates/nextjs-web/next-env.d.ts +6 -6
  181. package/templates/nextjs-web/next.config.ts +20 -20
  182. package/templates/nextjs-web/package-lock.json +3254 -3254
  183. package/templates/nextjs-web/package.json +37 -37
  184. package/templates/nextjs-web/postcss.config.js +6 -6
  185. package/templates/nextjs-web/tailwind.config.ts +69 -69
  186. package/templates/nextjs-web/tsconfig.json +1 -1
  187. package/templates/nixpacks.toml +11 -11
  188. package/templates/root-package.json +31 -31
  189. package/templates/server.ts +66 -66
  190. package/templates/tsconfig.json +30 -30
  191. package/dist/chunk-2MCBBWEA.js +0 -1
  192. package/dist/chunk-2MCBBWEA.js.map +0 -1
  193. package/dist/chunk-3OM7CHCA.js.map +0 -1
  194. package/dist/chunk-63MTCWU2.mjs +0 -361
  195. package/dist/chunk-63MTCWU2.mjs.map +0 -1
  196. package/dist/chunk-667BQCEM.js +0 -375
  197. package/dist/chunk-667BQCEM.js.map +0 -1
  198. package/dist/chunk-67IJ6H4J.mjs +0 -44
  199. package/dist/chunk-67IJ6H4J.mjs.map +0 -1
  200. package/dist/chunk-6SVQEGEX.mjs +0 -44
  201. package/dist/chunk-6SVQEGEX.mjs.map +0 -1
  202. package/dist/chunk-7NSRDJ5C.mjs +0 -1
  203. package/dist/chunk-ASDXAK6G.js +0 -44
  204. package/dist/chunk-ASDXAK6G.js.map +0 -1
  205. package/dist/chunk-CKZ4VSCB.mjs +0 -18
  206. package/dist/chunk-CKZ4VSCB.mjs.map +0 -1
  207. package/dist/chunk-DW6GOKMF.js +0 -57
  208. package/dist/chunk-DW6GOKMF.js.map +0 -1
  209. package/dist/chunk-EFZPSZWO.mjs +0 -1
  210. package/dist/chunk-EFZPSZWO.mjs.map +0 -1
  211. package/dist/chunk-FCEZDH42.mjs.map +0 -1
  212. package/dist/chunk-FYGXL4V7.js +0 -361
  213. package/dist/chunk-FYGXL4V7.js.map +0 -1
  214. package/dist/chunk-GKVPGKAH.js +0 -66
  215. package/dist/chunk-GKVPGKAH.js.map +0 -1
  216. package/dist/chunk-GWP6PNSP.js +0 -225
  217. package/dist/chunk-GWP6PNSP.js.map +0 -1
  218. package/dist/chunk-HQKTXE7E.mjs +0 -225
  219. package/dist/chunk-HQKTXE7E.mjs.map +0 -1
  220. package/dist/chunk-HSFLZUJN.mjs +0 -57
  221. package/dist/chunk-HSFLZUJN.mjs.map +0 -1
  222. package/dist/chunk-HU63F22V.js +0 -361
  223. package/dist/chunk-HU63F22V.js.map +0 -1
  224. package/dist/chunk-J5LGTIGS.mjs +0 -10
  225. package/dist/chunk-J5LGTIGS.mjs.map +0 -1
  226. package/dist/chunk-JMBD6DOP.js +0 -225
  227. package/dist/chunk-JMBD6DOP.js.map +0 -1
  228. package/dist/chunk-K7EIJSYQ.js +0 -1
  229. package/dist/chunk-K7EIJSYQ.js.map +0 -1
  230. package/dist/chunk-KXYLEUSW.mjs.map +0 -1
  231. package/dist/chunk-MTHKZO55.js +0 -44
  232. package/dist/chunk-MTHKZO55.js.map +0 -1
  233. package/dist/chunk-NNQFLD7O.mjs +0 -361
  234. package/dist/chunk-NNQFLD7O.mjs.map +0 -1
  235. package/dist/chunk-NU2UB242.js +0 -82
  236. package/dist/chunk-NU2UB242.js.map +0 -1
  237. package/dist/chunk-NULGSZFE.mjs +0 -57
  238. package/dist/chunk-NULGSZFE.mjs.map +0 -1
  239. package/dist/chunk-O42L6HOX.js.map +0 -1
  240. package/dist/chunk-ONXNE2A6.mjs +0 -375
  241. package/dist/chunk-ONXNE2A6.mjs.map +0 -1
  242. package/dist/chunk-OTBYRUBE.mjs +0 -225
  243. package/dist/chunk-OTBYRUBE.mjs.map +0 -1
  244. package/dist/chunk-OTSAVKLY.mjs +0 -66
  245. package/dist/chunk-OTSAVKLY.mjs.map +0 -1
  246. package/dist/chunk-PZ5AY32C.js +0 -10
  247. package/dist/chunk-PZ5AY32C.js.map +0 -1
  248. package/dist/chunk-QP2TMRLG.js +0 -57
  249. package/dist/chunk-QP2TMRLG.js.map +0 -1
  250. package/dist/chunk-RS23R3ZQ.mjs +0 -82
  251. package/dist/chunk-RS23R3ZQ.mjs.map +0 -1
  252. package/dist/chunk-STTOPUZ2.mjs.map +0 -1
  253. package/dist/chunk-VMT3LALB.mjs +0 -51
  254. package/dist/chunk-VMT3LALB.mjs.map +0 -1
  255. package/dist/chunk-VNNVLQLJ.mjs.map +0 -1
  256. package/dist/chunk-W3YRVEFQ.js +0 -66
  257. package/dist/chunk-W3YRVEFQ.js.map +0 -1
  258. package/dist/chunk-WF65EDRZ.js.map +0 -1
  259. package/dist/chunk-WMHVXEYQ.mjs +0 -66
  260. package/dist/chunk-WMHVXEYQ.mjs.map +0 -1
  261. package/dist/chunk-XVKTIYHY.js +0 -51
  262. package/dist/chunk-XVKTIYHY.js.map +0 -1
  263. package/dist/codegen-MRZDLCYI.js +0 -13
  264. package/dist/codegen-MRZDLCYI.js.map +0 -1
  265. package/dist/codegen-UI5HTMXE.mjs +0 -13
  266. package/dist/codegen-UI5HTMXE.mjs.map +0 -1
  267. package/dist/dev-server-JKRVBWPY.mjs +0 -13
  268. package/dist/dev-server-JKRVBWPY.mjs.map +0 -1
  269. package/dist/dev-server-TLL7UQMR.js +0 -13
  270. package/dist/dev-server-TLL7UQMR.js.map +0 -1
  271. package/dist/index-BsNaOUtH.d.mts +0 -44
  272. package/dist/index-BsNaOUtH.d.ts +0 -44
  273. package/dist/index-CrbXnXsO.d.ts +0 -62
  274. package/dist/index-kEbGExWM.d.mts +0 -62
  275. package/templates/nestjs-api/.env +0 -4
  276. package/templates/nextjs-web/.env +0 -1
@@ -1,225 +0,0 @@
1
- import {
2
- logger
3
- } from "./chunk-NULGSZFE.mjs";
4
- import {
5
- __export
6
- } from "./chunk-J5LGTIGS.mjs";
7
-
8
- // src/dev-server/index.ts
9
- var dev_server_exports = {};
10
- __export(dev_server_exports, {
11
- FusionDevServer: () => FusionDevServer,
12
- ProcessRunner: () => ProcessRunner,
13
- ProxyServer: () => ProxyServer
14
- });
15
-
16
- // src/dev-server/process-runner.ts
17
- import { spawn } from "child_process";
18
- import * as pc from "picocolors";
19
- var ProcessRunner = class {
20
- processes = /* @__PURE__ */ new Map();
21
- colors = {
22
- cyan: pc.cyan,
23
- green: pc.green,
24
- yellow: pc.yellow,
25
- magenta: pc.magenta,
26
- blue: pc.blue
27
- };
28
- async run(configs) {
29
- logger.info("\u{1F680} Starting development servers...\n");
30
- for (const config of configs) {
31
- this.startProcess(config);
32
- }
33
- process.on("SIGINT", () => this.stopAll());
34
- process.on("SIGTERM", () => this.stopAll());
35
- }
36
- startProcess(config) {
37
- const { name, command, args, cwd, color, env } = config;
38
- const colorFn = this.colors[color];
39
- const prefix = colorFn(`[${name}]`);
40
- logger.info(`${prefix} Starting...`);
41
- const proc = spawn(command, args, {
42
- cwd,
43
- stdio: "pipe",
44
- shell: true,
45
- env: { ...process.env, ...env }
46
- });
47
- this.processes.set(name, proc);
48
- proc.stdout?.on("data", (data) => {
49
- const lines = data.toString().split("\n").filter((l) => l.trim());
50
- lines.forEach((line) => {
51
- console.log(`${prefix} ${line}`);
52
- });
53
- });
54
- proc.stderr?.on("data", (data) => {
55
- const lines = data.toString().split("\n").filter((l) => l.trim());
56
- lines.forEach((line) => {
57
- console.error(`${prefix} ${pc.red(line)}`);
58
- });
59
- });
60
- proc.on("exit", (code) => {
61
- if (code !== 0 && code !== null) {
62
- logger.error(`${prefix} Exited with code ${code}`);
63
- }
64
- this.processes.delete(name);
65
- });
66
- proc.on("error", (error) => {
67
- logger.error(`${prefix} Error:`, error.message);
68
- });
69
- }
70
- stopAll() {
71
- logger.info("\n\u{1F6D1} Stopping all processes...");
72
- for (const [name, proc] of this.processes.entries()) {
73
- logger.info(`Stopping ${name}...`);
74
- proc.kill("SIGTERM");
75
- }
76
- setTimeout(() => {
77
- process.exit(0);
78
- }, 1e3);
79
- }
80
- isRunning(name) {
81
- return this.processes.has(name);
82
- }
83
- };
84
-
85
- // src/dev-server/proxy.ts
86
- import http from "http";
87
- import httpProxy from "http-proxy";
88
- import * as pc2 from "picocolors";
89
- var ProxyServer = class {
90
- server = null;
91
- proxy = null;
92
- async start(config) {
93
- const { port, apiTarget, apiPrefix } = config;
94
- this.proxy = httpProxy.createProxyServer({
95
- target: apiTarget,
96
- changeOrigin: true,
97
- ws: true
98
- // WebSocket support
99
- });
100
- this.proxy.on("error", (err, req, res) => {
101
- logger.error("Proxy error:", err.message);
102
- if (res && "headersSent" in res && !res.headersSent) {
103
- res.writeHead(502, { "Content-Type": "text/plain" });
104
- res.end("Bad Gateway - API server unavailable");
105
- }
106
- });
107
- this.server = http.createServer((req, res) => {
108
- if (req.url?.startsWith(apiPrefix)) {
109
- const newUrl = req.url.substring(apiPrefix.length) || "/";
110
- req.url = newUrl;
111
- logger.info(pc2.gray(`\u2192 ${req.method} ${apiPrefix}${newUrl}`));
112
- this.proxy.web(req, res);
113
- } else {
114
- res.writeHead(404);
115
- res.end("Not Found");
116
- }
117
- });
118
- this.server.on("upgrade", (req, socket, head) => {
119
- if (req.url?.startsWith(apiPrefix)) {
120
- const newUrl = req.url.substring(apiPrefix.length) || "/";
121
- req.url = newUrl;
122
- this.proxy.ws(req, socket, head);
123
- }
124
- });
125
- return new Promise((resolve2) => {
126
- this.server.listen(port, () => {
127
- logger.success(`\u2705 Proxy server running on port ${port}`);
128
- logger.info(` Forwarding ${pc2.cyan(apiPrefix + "/*")} \u2192 ${pc2.cyan(apiTarget)}
129
- `);
130
- resolve2();
131
- });
132
- });
133
- }
134
- stop() {
135
- if (this.server) {
136
- this.server.close();
137
- this.server = null;
138
- }
139
- if (this.proxy) {
140
- this.proxy.close();
141
- this.proxy = null;
142
- }
143
- }
144
- };
145
-
146
- // src/dev-server/dev-server.ts
147
- import * as path from "path";
148
- import * as fs from "fs";
149
- var FusionDevServer = class {
150
- processRunner;
151
- proxyServer = null;
152
- constructor() {
153
- this.processRunner = new ProcessRunner();
154
- }
155
- async start(config) {
156
- const {
157
- apiPath,
158
- webPath,
159
- webPort = 3e3,
160
- apiPort = 5050,
161
- useProxy = true
162
- } = config;
163
- if (!fs.existsSync(apiPath)) {
164
- throw new Error(`API path not found: ${apiPath}`);
165
- }
166
- if (!fs.existsSync(webPath)) {
167
- throw new Error(`Web path not found: ${webPath}`);
168
- }
169
- const processes = [];
170
- processes.push({
171
- name: "API",
172
- command: "npm",
173
- args: ["run", "start:dev"],
174
- cwd: path.resolve(apiPath),
175
- color: "cyan",
176
- env: {
177
- PORT: apiPort.toString()
178
- }
179
- });
180
- processes.push({
181
- name: "Web",
182
- command: "npm",
183
- args: ["run", "dev", "--", "-p", webPort.toString()],
184
- cwd: path.resolve(webPath),
185
- color: "green",
186
- env: {
187
- NEXT_PUBLIC_API_URL: useProxy ? `http://localhost:${webPort}/api` : `http://localhost:${apiPort}`
188
- }
189
- });
190
- if (useProxy) {
191
- this.proxyServer = new ProxyServer();
192
- setTimeout(async () => {
193
- await this.proxyServer.start({
194
- port: webPort,
195
- apiTarget: `http://localhost:${apiPort}`,
196
- apiPrefix: "/api"
197
- });
198
- }, 3e3);
199
- }
200
- await this.processRunner.run(processes);
201
- logger.info("\u2554\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2557");
202
- logger.info("\u2551 Fusion Development Server Ready \u2551");
203
- logger.info("\u255A\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u255D\n");
204
- logger.info(`\u{1F310} Web: http://localhost:${webPort}`);
205
- logger.info(`\u{1F50C} API: http://localhost:${apiPort}`);
206
- if (useProxy) {
207
- logger.info(`\u{1F504} Proxy: Enabled (${webPort}/api \u2192 ${apiPort})`);
208
- }
209
- logger.info("\n");
210
- }
211
- stop() {
212
- this.processRunner.stopAll();
213
- if (this.proxyServer) {
214
- this.proxyServer.stop();
215
- }
216
- }
217
- };
218
-
219
- export {
220
- ProcessRunner,
221
- ProxyServer,
222
- FusionDevServer,
223
- dev_server_exports
224
- };
225
- //# sourceMappingURL=chunk-HQKTXE7E.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/dev-server/index.ts","../src/dev-server/process-runner.ts","../src/dev-server/proxy.ts","../src/dev-server/dev-server.ts"],"sourcesContent":["export * from './dev-server';\r\nexport * from './process-runner';\r\nexport * from './proxy';\r\n","import { spawn, ChildProcess } from 'child_process';\r\nimport { logger } from '../core/logger';\r\nimport * as pc from 'picocolors';\r\n\r\nexport interface ProcessConfig {\r\n name: string;\r\n command: string;\r\n args: string[];\r\n cwd: string;\r\n color: 'cyan' | 'green' | 'yellow' | 'magenta' | 'blue';\r\n env?: Record<string, string>;\r\n}\r\n\r\n/**\r\n * Run multiple processes concurrently with colored output\r\n */\r\nexport class ProcessRunner {\r\n private processes: Map<string, ChildProcess> = new Map();\r\n private colors = {\r\n cyan: pc.cyan,\r\n green: pc.green,\r\n yellow: pc.yellow,\r\n magenta: pc.magenta,\r\n blue: pc.blue,\r\n };\r\n\r\n async run(configs: ProcessConfig[]): Promise<void> {\r\n logger.info('🚀 Starting development servers...\\n');\r\n\r\n for (const config of configs) {\r\n this.startProcess(config);\r\n }\r\n\r\n // Handle graceful shutdown\r\n process.on('SIGINT', () => this.stopAll());\r\n process.on('SIGTERM', () => this.stopAll());\r\n }\r\n\r\n private startProcess(config: ProcessConfig): void {\r\n const { name, command, args, cwd, color, env } = config;\r\n\r\n const colorFn = this.colors[color];\r\n const prefix = colorFn(`[${name}]`);\r\n\r\n logger.info(`${prefix} Starting...`);\r\n\r\n const proc = spawn(command, args, {\r\n cwd,\r\n stdio: 'pipe',\r\n shell: true,\r\n env: { ...process.env, ...env },\r\n });\r\n\r\n this.processes.set(name, proc);\r\n\r\n // Handle stdout\r\n proc.stdout?.on('data', (data) => {\r\n const lines = data.toString().split('\\n').filter((l: string) => l.trim());\r\n lines.forEach((line: string) => {\r\n console.log(`${prefix} ${line}`);\r\n });\r\n });\r\n\r\n // Handle stderr\r\n proc.stderr?.on('data', (data) => {\r\n const lines = data.toString().split('\\n').filter((l: string) => l.trim());\r\n lines.forEach((line: string) => {\r\n console.error(`${prefix} ${pc.red(line)}`);\r\n });\r\n });\r\n\r\n // Handle exit\r\n proc.on('exit', (code) => {\r\n if (code !== 0 && code !== null) {\r\n logger.error(`${prefix} Exited with code ${code}`);\r\n }\r\n this.processes.delete(name);\r\n });\r\n\r\n // Handle errors\r\n proc.on('error', (error) => {\r\n logger.error(`${prefix} Error:`, error.message);\r\n });\r\n }\r\n\r\n stopAll(): void {\r\n logger.info('\\n🛑 Stopping all processes...');\r\n\r\n for (const [name, proc] of this.processes.entries()) {\r\n logger.info(`Stopping ${name}...`);\r\n proc.kill('SIGTERM');\r\n }\r\n\r\n setTimeout(() => {\r\n process.exit(0);\r\n }, 1000);\r\n }\r\n\r\n isRunning(name: string): boolean {\r\n return this.processes.has(name);\r\n }\r\n}\r\n","import http from 'http';\r\nimport httpProxy from 'http-proxy';\r\nimport { logger } from '../core/logger';\r\nimport * as pc from 'picocolors';\r\n\r\nexport interface ProxyConfig {\r\n port: number;\r\n apiTarget: string;\r\n apiPrefix: string;\r\n}\r\n\r\n/**\r\n * Proxy server to forward API requests from Next.js to NestJS\r\n */\r\nexport class ProxyServer {\r\n private server: http.Server | null = null;\r\n private proxy: httpProxy | null = null;\r\n\r\n async start(config: ProxyConfig): Promise<void> {\r\n const { port, apiTarget, apiPrefix } = config;\r\n\r\n this.proxy = httpProxy.createProxyServer({\r\n target: apiTarget,\r\n changeOrigin: true,\r\n ws: true, // WebSocket support\r\n });\r\n\r\n // Handle proxy errors\r\n this.proxy.on('error', (err, req, res) => {\r\n logger.error('Proxy error:', err.message);\r\n if (res && 'headersSent' in res && !(res as any).headersSent) {\r\n (res as http.ServerResponse).writeHead(502, { 'Content-Type': 'text/plain' });\r\n (res as http.ServerResponse).end('Bad Gateway - API server unavailable');\r\n }\r\n });\r\n\r\n this.server = http.createServer((req, res) => {\r\n // Check if request is for API\r\n if (req.url?.startsWith(apiPrefix)) {\r\n // Remove prefix before forwarding\r\n const newUrl = req.url.substring(apiPrefix.length) || '/';\r\n req.url = newUrl;\r\n\r\n logger.info(pc.gray(`→ ${req.method} ${apiPrefix}${newUrl}`));\r\n this.proxy!.web(req, res);\r\n } else {\r\n // Not an API request - should not happen\r\n res.writeHead(404);\r\n res.end('Not Found');\r\n }\r\n });\r\n\r\n // Handle WebSocket upgrade\r\n this.server.on('upgrade', (req, socket, head) => {\r\n if (req.url?.startsWith(apiPrefix)) {\r\n const newUrl = req.url.substring(apiPrefix.length) || '/';\r\n req.url = newUrl;\r\n this.proxy!.ws(req, socket, head);\r\n }\r\n });\r\n\r\n return new Promise((resolve) => {\r\n this.server!.listen(port, () => {\r\n logger.success(`✅ Proxy server running on port ${port}`);\r\n logger.info(` Forwarding ${pc.cyan(apiPrefix + '/*')} → ${pc.cyan(apiTarget)}\\n`);\r\n resolve();\r\n });\r\n });\r\n }\r\n\r\n stop(): void {\r\n if (this.server) {\r\n this.server.close();\r\n this.server = null;\r\n }\r\n if (this.proxy) {\r\n this.proxy.close();\r\n this.proxy = null;\r\n }\r\n }\r\n}\r\n","import { ProcessRunner, ProcessConfig } from './process-runner';\r\nimport { ProxyServer } from './proxy';\r\nimport { logger } from '../core/logger';\r\nimport * as path from 'path';\r\nimport * as fs from 'fs';\r\n\r\nexport interface DevServerConfig {\r\n apiPath: string;\r\n webPath: string;\r\n webPort?: number;\r\n apiPort?: number;\r\n useProxy?: boolean;\r\n}\r\n\r\n/**\r\n * Unified development server for Fusion projects\r\n */\r\nexport class FusionDevServer {\r\n private processRunner: ProcessRunner;\r\n private proxyServer: ProxyServer | null = null;\r\n\r\n constructor() {\r\n this.processRunner = new ProcessRunner();\r\n }\r\n\r\n async start(config: DevServerConfig): Promise<void> {\r\n const {\r\n apiPath,\r\n webPath,\r\n webPort = 3000,\r\n apiPort = 5050,\r\n useProxy = true,\r\n } = config;\r\n\r\n // Validate paths\r\n if (!fs.existsSync(apiPath)) {\r\n throw new Error(`API path not found: ${apiPath}`);\r\n }\r\n if (!fs.existsSync(webPath)) {\r\n throw new Error(`Web path not found: ${webPath}`);\r\n }\r\n\r\n const processes: ProcessConfig[] = [];\r\n\r\n // Add API server\r\n processes.push({\r\n name: 'API',\r\n command: 'npm',\r\n args: ['run', 'start:dev'],\r\n cwd: path.resolve(apiPath),\r\n color: 'cyan',\r\n env: {\r\n PORT: apiPort.toString(),\r\n },\r\n });\r\n\r\n // Add Web server\r\n processes.push({\r\n name: 'Web',\r\n command: 'npm',\r\n args: ['run', 'dev', '--', '-p', webPort.toString()],\r\n cwd: path.resolve(webPath),\r\n color: 'green',\r\n env: {\r\n NEXT_PUBLIC_API_URL: useProxy\r\n ? `http://localhost:${webPort}/api`\r\n : `http://localhost:${apiPort}`,\r\n },\r\n });\r\n\r\n // Start proxy if enabled\r\n if (useProxy) {\r\n this.proxyServer = new ProxyServer();\r\n\r\n // Wait a bit for API to be ready\r\n setTimeout(async () => {\r\n await this.proxyServer!.start({\r\n port: webPort,\r\n apiTarget: `http://localhost:${apiPort}`,\r\n apiPrefix: '/api',\r\n });\r\n }, 3000);\r\n }\r\n\r\n // Start processes\r\n await this.processRunner.run(processes);\r\n\r\n // Log info\r\n logger.info('╔═══════════════════════════════════════╗');\r\n logger.info('║ Fusion Development Server Ready ║');\r\n logger.info('╚═══════════════════════════════════════╝\\n');\r\n logger.info(`🌐 Web: http://localhost:${webPort}`);\r\n logger.info(`🔌 API: http://localhost:${apiPort}`);\r\n if (useProxy) {\r\n logger.info(`🔄 Proxy: Enabled (${webPort}/api → ${apiPort})`);\r\n }\r\n logger.info('\\n');\r\n }\r\n\r\n stop(): void {\r\n this.processRunner.stopAll();\r\n if (this.proxyServer) {\r\n this.proxyServer.stop();\r\n }\r\n }\r\n}\r\n"],"mappings":"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","names":["pc","resolve"]}
@@ -1,57 +0,0 @@
1
- // src/core/logger.ts
2
- var LogLevel = /* @__PURE__ */ ((LogLevel2) => {
3
- LogLevel2[LogLevel2["DEBUG"] = 0] = "DEBUG";
4
- LogLevel2[LogLevel2["INFO"] = 1] = "INFO";
5
- LogLevel2[LogLevel2["WARN"] = 2] = "WARN";
6
- LogLevel2[LogLevel2["ERROR"] = 3] = "ERROR";
7
- return LogLevel2;
8
- })(LogLevel || {});
9
- var Logger = class {
10
- level;
11
- prefix;
12
- timestamp;
13
- constructor(options = {}) {
14
- this.level = options.level ?? 1 /* INFO */;
15
- this.prefix = options.prefix ?? "[Fusion]";
16
- this.timestamp = options.timestamp ?? true;
17
- }
18
- formatMessage(level, ...args) {
19
- const timestamp = this.timestamp ? `[${(/* @__PURE__ */ new Date()).toISOString()}]` : "";
20
- return `${timestamp} ${this.prefix} ${level}: ${args.join(" ")}`;
21
- }
22
- debug(...args) {
23
- if (this.level <= 0 /* DEBUG */) {
24
- console.log(this.formatMessage("DEBUG", ...args));
25
- }
26
- }
27
- info(...args) {
28
- if (this.level <= 1 /* INFO */) {
29
- console.log(this.formatMessage("INFO", ...args));
30
- }
31
- }
32
- warn(...args) {
33
- if (this.level <= 2 /* WARN */) {
34
- console.warn(this.formatMessage("WARN", ...args));
35
- }
36
- }
37
- error(...args) {
38
- if (this.level <= 3 /* ERROR */) {
39
- console.error(this.formatMessage("ERROR", ...args));
40
- }
41
- }
42
- success(...args) {
43
- console.log(this.formatMessage("\u2713", ...args));
44
- }
45
- };
46
- var logger = new Logger();
47
- function createLogger(options) {
48
- return new Logger(options);
49
- }
50
-
51
- export {
52
- LogLevel,
53
- Logger,
54
- logger,
55
- createLogger
56
- };
57
- //# sourceMappingURL=chunk-HSFLZUJN.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/core/logger.ts"],"sourcesContent":["export enum LogLevel {\r\n DEBUG = 0,\r\n INFO = 1,\r\n WARN = 2,\r\n ERROR = 3,\r\n}\r\n\r\nexport interface LoggerOptions {\r\n level?: LogLevel;\r\n prefix?: string;\r\n timestamp?: boolean;\r\n}\r\n\r\nexport class Logger {\r\n private level: LogLevel;\r\n private prefix: string;\r\n private timestamp: boolean;\r\n\r\n constructor(options: LoggerOptions = {}) {\r\n this.level = options.level ?? LogLevel.INFO;\r\n this.prefix = options.prefix ?? '[Fusion]';\r\n this.timestamp = options.timestamp ?? true;\r\n }\r\n\r\n private formatMessage(level: string, ...args: any[]): string {\r\n const timestamp = this.timestamp ? `[${new Date().toISOString()}]` : '';\r\n return `${timestamp} ${this.prefix} ${level}: ${args.join(' ')}`;\r\n }\r\n\r\n debug(...args: any[]): void {\r\n if (this.level <= LogLevel.DEBUG) {\r\n console.log(this.formatMessage('DEBUG', ...args));\r\n }\r\n }\r\n\r\n info(...args: any[]): void {\r\n if (this.level <= LogLevel.INFO) {\r\n console.log(this.formatMessage('INFO', ...args));\r\n }\r\n }\r\n\r\n warn(...args: any[]): void {\r\n if (this.level <= LogLevel.WARN) {\r\n console.warn(this.formatMessage('WARN', ...args));\r\n }\r\n }\r\n\r\n error(...args: any[]): void {\r\n if (this.level <= LogLevel.ERROR) {\r\n console.error(this.formatMessage('ERROR', ...args));\r\n }\r\n }\r\n\r\n success(...args: any[]): void {\r\n console.log(this.formatMessage('✓', ...args));\r\n }\r\n}\r\n\r\n// Export singleton instance\r\nexport const logger = new Logger();\r\n\r\n// Export factory\r\nexport function createLogger(options: LoggerOptions): Logger {\r\n return new Logger(options);\r\n}\r\n"],"mappings":";AAAO,IAAK,WAAL,kBAAKA,cAAL;AACH,EAAAA,oBAAA,WAAQ,KAAR;AACA,EAAAA,oBAAA,UAAO,KAAP;AACA,EAAAA,oBAAA,UAAO,KAAP;AACA,EAAAA,oBAAA,WAAQ,KAAR;AAJQ,SAAAA;AAAA,GAAA;AAaL,IAAM,SAAN,MAAa;AAAA,EACR;AAAA,EACA;AAAA,EACA;AAAA,EAER,YAAY,UAAyB,CAAC,GAAG;AACrC,SAAK,QAAQ,QAAQ,SAAS;AAC9B,SAAK,SAAS,QAAQ,UAAU;AAChC,SAAK,YAAY,QAAQ,aAAa;AAAA,EAC1C;AAAA,EAEQ,cAAc,UAAkB,MAAqB;AACzD,UAAM,YAAY,KAAK,YAAY,KAAI,oBAAI,KAAK,GAAE,YAAY,CAAC,MAAM;AACrE,WAAO,GAAG,SAAS,IAAI,KAAK,MAAM,IAAI,KAAK,KAAK,KAAK,KAAK,GAAG,CAAC;AAAA,EAClE;AAAA,EAEA,SAAS,MAAmB;AACxB,QAAI,KAAK,SAAS,eAAgB;AAC9B,cAAQ,IAAI,KAAK,cAAc,SAAS,GAAG,IAAI,CAAC;AAAA,IACpD;AAAA,EACJ;AAAA,EAEA,QAAQ,MAAmB;AACvB,QAAI,KAAK,SAAS,cAAe;AAC7B,cAAQ,IAAI,KAAK,cAAc,QAAQ,GAAG,IAAI,CAAC;AAAA,IACnD;AAAA,EACJ;AAAA,EAEA,QAAQ,MAAmB;AACvB,QAAI,KAAK,SAAS,cAAe;AAC7B,cAAQ,KAAK,KAAK,cAAc,QAAQ,GAAG,IAAI,CAAC;AAAA,IACpD;AAAA,EACJ;AAAA,EAEA,SAAS,MAAmB;AACxB,QAAI,KAAK,SAAS,eAAgB;AAC9B,cAAQ,MAAM,KAAK,cAAc,SAAS,GAAG,IAAI,CAAC;AAAA,IACtD;AAAA,EACJ;AAAA,EAEA,WAAW,MAAmB;AAC1B,YAAQ,IAAI,KAAK,cAAc,UAAK,GAAG,IAAI,CAAC;AAAA,EAChD;AACJ;AAGO,IAAM,SAAS,IAAI,OAAO;AAG1B,SAAS,aAAa,SAAgC;AACzD,SAAO,IAAI,OAAO,OAAO;AAC7B;","names":["LogLevel"]}
@@ -1,361 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; } var _class;
2
-
3
- var _chunkDW6GOKMFjs = require('./chunk-DW6GOKMF.js');
4
-
5
-
6
- var _chunkPZ5AY32Cjs = require('./chunk-PZ5AY32C.js');
7
-
8
- // src/codegen/index.ts
9
- var codegen_exports = {};
10
- _chunkPZ5AY32Cjs.__export.call(void 0, codegen_exports, {
11
- ClientGenerator: () => ClientGenerator,
12
- CodegenWatcher: () => CodegenWatcher,
13
- NestJSParser: () => NestJSParser
14
- });
15
-
16
- // src/codegen/parser.ts
17
- var _typescript = require('typescript'); var ts = _interopRequireWildcard(_typescript);
18
- var _path = require('path'); var path = _interopRequireWildcard(_path); var path2 = _interopRequireWildcard(_path); var path3 = _interopRequireWildcard(_path);
19
- var NestJSParser = class {
20
- constructor(projectPath) {
21
- this.projectPath = projectPath;
22
- const configPath = ts.findConfigFile(projectPath, ts.sys.fileExists, "tsconfig.json");
23
- if (!configPath) {
24
- throw new Error("tsconfig.json not found");
25
- }
26
- const config = ts.readConfigFile(configPath, ts.sys.readFile);
27
- const parsedConfig = ts.parseJsonConfigFileContent(
28
- config.config,
29
- ts.sys,
30
- path.dirname(configPath)
31
- );
32
- this.program = ts.createProgram(parsedConfig.fileNames, parsedConfig.options);
33
- }
34
-
35
- /**
36
- * Find all controllers with @FusionController decorator
37
- */
38
- findFusionControllers() {
39
- const controllers = [];
40
- const sourceFiles = this.program.getSourceFiles();
41
- for (const sourceFile of sourceFiles) {
42
- if (sourceFile.fileName.includes("node_modules")) continue;
43
- if (!sourceFile.fileName.includes(".controller.ts")) continue;
44
- const fileControllers = this.parseSourceFile(sourceFile);
45
- controllers.push(...fileControllers);
46
- }
47
- return controllers;
48
- }
49
- parseSourceFile(sourceFile) {
50
- const controllers = [];
51
- ts.forEachChild(sourceFile, (node) => {
52
- if (ts.isClassDeclaration(node) && node.name) {
53
- const controllerInfo = this.parseController(node);
54
- if (controllerInfo) {
55
- controllers.push(controllerInfo);
56
- }
57
- }
58
- });
59
- return controllers;
60
- }
61
- parseController(classNode) {
62
- const decorators = ts.getDecorators(classNode);
63
- if (!decorators) return null;
64
- let controllerPrefix = "";
65
- let isFusionController = false;
66
- for (const decorator of decorators) {
67
- const expr = decorator.expression;
68
- if (ts.isCallExpression(expr) && ts.isIdentifier(expr.expression)) {
69
- const decoratorName = expr.expression.text;
70
- if (decoratorName === "FusionController") {
71
- isFusionController = true;
72
- if (expr.arguments.length > 0) {
73
- const arg = expr.arguments[0];
74
- if (ts.isStringLiteral(arg)) {
75
- controllerPrefix = arg.text;
76
- }
77
- }
78
- }
79
- }
80
- }
81
- if (!isFusionController) return null;
82
- const routes = this.parseRoutes(classNode);
83
- const className = _optionalChain([classNode, 'access', _ => _.name, 'optionalAccess', _2 => _2.text]) || "Unknown";
84
- return {
85
- name: className,
86
- prefix: controllerPrefix,
87
- routes: routes.map((r) => ({ ...r, controllerName: className }))
88
- };
89
- }
90
- parseRoutes(classNode) {
91
- const routes = [];
92
- classNode.members.forEach((member) => {
93
- if (ts.isMethodDeclaration(member)) {
94
- const decorators = ts.getDecorators(member);
95
- if (!decorators) return;
96
- for (const decorator of decorators) {
97
- const expr = decorator.expression;
98
- if (ts.isCallExpression(expr) && ts.isIdentifier(expr.expression)) {
99
- const decoratorName = expr.expression.text;
100
- let method = null;
101
- let routePath = "";
102
- if (decoratorName === "FusionGet") method = "GET";
103
- else if (decoratorName === "FusionPost") method = "POST";
104
- else if (decoratorName === "FusionPut") method = "PUT";
105
- else if (decoratorName === "FusionDelete") method = "DELETE";
106
- if (method) {
107
- if (expr.arguments.length > 0) {
108
- const arg = expr.arguments[0];
109
- if (ts.isStringLiteral(arg)) {
110
- routePath = arg.text;
111
- }
112
- }
113
- const handlerName = member.name.text;
114
- routes.push({
115
- method,
116
- path: routePath,
117
- handler: handlerName,
118
- controllerName: ""
119
- // Will be set by caller
120
- });
121
- }
122
- }
123
- }
124
- }
125
- });
126
- return routes;
127
- }
128
- };
129
-
130
- // src/core/filesystem.ts
131
- var _fs = require('fs'); var fs = _interopRequireWildcard(_fs);
132
-
133
- var _util = require('util');
134
- var readFile2 = _util.promisify.call(void 0, fs.readFile);
135
- var writeFile2 = _util.promisify.call(void 0, fs.writeFile);
136
- var mkdir2 = _util.promisify.call(void 0, fs.mkdir);
137
- var access2 = _util.promisify.call(void 0, fs.access);
138
- var FileSystem = class {
139
- /**
140
- * Read file as string
141
- */
142
- async readFile(filePath, encoding = "utf-8") {
143
- return readFile2(filePath, encoding);
144
- }
145
- /**
146
- * Write file
147
- */
148
- async writeFile(filePath, content) {
149
- await this.ensureDir(path2.dirname(filePath));
150
- return writeFile2(filePath, content, "utf-8");
151
- }
152
- /**
153
- * Read JSON file
154
- */
155
- async readJSON(filePath) {
156
- const content = await this.readFile(filePath);
157
- return JSON.parse(content);
158
- }
159
- /**
160
- * Write JSON file
161
- */
162
- async writeJSON(filePath, data, pretty = true) {
163
- const content = pretty ? JSON.stringify(data, null, 2) : JSON.stringify(data);
164
- return this.writeFile(filePath, content);
165
- }
166
- /**
167
- * Check if file/directory exists
168
- */
169
- async exists(filePath) {
170
- try {
171
- await access2(filePath, fs.constants.F_OK);
172
- return true;
173
- } catch (e) {
174
- return false;
175
- }
176
- }
177
- /**
178
- * Ensure directory exists (create if not)
179
- */
180
- async ensureDir(dirPath) {
181
- if (!await this.exists(dirPath)) {
182
- await mkdir2(dirPath, { recursive: true });
183
- }
184
- }
185
- /**
186
- * Copy file
187
- */
188
- async copyFile(src, dest) {
189
- const content = await this.readFile(src);
190
- await this.writeFile(dest, content);
191
- }
192
- /**
193
- * Read directory
194
- */
195
- readDir(dirPath) {
196
- return _util.promisify.call(void 0, fs.readdir)(dirPath);
197
- }
198
- };
199
- var filesystem = new FileSystem();
200
-
201
- // src/codegen/generator.ts
202
-
203
- var ClientGenerator = class {
204
- async generate(options) {
205
- const { controllers, outputPath } = options;
206
- const clientCode = this.generateClientCode(controllers, options.baseUrl);
207
- await filesystem.writeFile(path3.join(outputPath, "client.ts"), clientCode);
208
- const indexCode = `export * from './client';
209
- `;
210
- await filesystem.writeFile(path3.join(outputPath, "index.ts"), indexCode);
211
- console.log(`\u2705 Generated API client at ${outputPath}`);
212
- }
213
- generateClientCode(controllers, baseUrl = "/api") {
214
- const imports = `import { FusionFetcher } from 'wexts/client';
215
-
216
- `;
217
- const clientClass = this.generateClientClass(controllers, baseUrl);
218
- const exports = `
219
- // Export singleton instance
220
- export const apiClient = new ApiClient();
221
- `;
222
- return imports + clientClass + exports;
223
- }
224
- generateClientClass(controllers, baseUrl) {
225
- let code = `export class ApiClient {
226
- `;
227
- code += ` private client: FusionFetcher;
228
-
229
- `;
230
- code += ` constructor(baseUrl: string = '${baseUrl}') {
231
- `;
232
- code += ` this.client = new FusionFetcher(baseUrl);
233
- `;
234
- code += ` }
235
-
236
- `;
237
- for (const controller of controllers) {
238
- const methods = this.generateControllerMethods(controller);
239
- code += methods;
240
- }
241
- code += `}
242
- `;
243
- return code;
244
- }
245
- generateControllerMethods(controller) {
246
- let code = ` // ${controller.name} endpoints
247
- `;
248
- for (const route of controller.routes) {
249
- const methodName = this.generateMethodName(controller, route);
250
- const methodCode = this.generateMethod(controller, route, methodName);
251
- code += methodCode + "\n";
252
- }
253
- return code;
254
- }
255
- generateMethodName(controller, route) {
256
- const controllerBase = controller.name.replace("Controller", "").toLowerCase();
257
- if (route.handler === "findAll") {
258
- return `get${this.capitalize(controllerBase)}`;
259
- } else if (route.handler === "findOne") {
260
- return `get${this.capitalize(controllerBase)}ById`;
261
- } else if (route.handler === "create") {
262
- return `create${this.capitalize(controllerBase.replace(/s$/, ""))}`;
263
- } else if (route.handler === "update") {
264
- return `update${this.capitalize(controllerBase.replace(/s$/, ""))}`;
265
- } else if (route.handler === "remove" || route.handler === "delete") {
266
- return `delete${this.capitalize(controllerBase.replace(/s$/, ""))}`;
267
- }
268
- return route.handler;
269
- }
270
- generateMethod(controller, route, methodName) {
271
- const fullPath = `/${controller.prefix}${route.path}`;
272
- const hasPathParam = fullPath.includes(":");
273
- let params = "";
274
- let pathExpr = `'${fullPath}'`;
275
- if (hasPathParam) {
276
- const paramMatch = fullPath.match(/:(\w+)/);
277
- const paramName = paramMatch ? paramMatch[1] : "id";
278
- params = `${paramName}: string`;
279
- pathExpr = `'${fullPath.replace(`:${paramName}`, "${" + paramName + "}")}'`;
280
- }
281
- if (route.method === "POST" || route.method === "PUT") {
282
- if (params) params += ", ";
283
- params += "data: any";
284
- }
285
- let methodBody = "";
286
- if (route.method === "GET" || route.method === "DELETE") {
287
- methodBody = ` return this.client.${route.method.toLowerCase()}<any>(${pathExpr});`;
288
- } else {
289
- methodBody = ` return this.client.${route.method.toLowerCase()}<any>(${pathExpr}, data);`;
290
- }
291
- return ` async ${methodName}(${params}): Promise<any> {
292
- ${methodBody}
293
- }
294
- `;
295
- }
296
- capitalize(str) {
297
- return str.charAt(0).toUpperCase() + str.slice(1);
298
- }
299
- };
300
-
301
- // src/codegen/watcher.ts
302
- var _chokidar = require('chokidar'); var chokidar = _interopRequireWildcard(_chokidar);
303
- var CodegenWatcher = (_class = class {constructor() { _class.prototype.__init.call(this); }
304
- __init() {this.watcher = null}
305
- async watch(options) {
306
- const { projectPath, outputPath, pattern = "**/*.controller.ts" } = options;
307
- _chunkDW6GOKMFjs.logger.info("\u{1F440} Watching for controller changes...");
308
- await this.generateClient(projectPath, outputPath);
309
- this.watcher = chokidar.watch(pattern, {
310
- cwd: projectPath,
311
- ignored: /node_modules/,
312
- persistent: true
313
- });
314
- this.watcher.on("change", async (path4) => {
315
- _chunkDW6GOKMFjs.logger.info(`\u{1F4DD} Controller changed: ${path4}`);
316
- await this.generateClient(projectPath, outputPath);
317
- });
318
- this.watcher.on("add", async (path4) => {
319
- _chunkDW6GOKMFjs.logger.info(`\u2795 New controller: ${path4}`);
320
- await this.generateClient(projectPath, outputPath);
321
- });
322
- this.watcher.on("unlink", async (path4) => {
323
- _chunkDW6GOKMFjs.logger.info(`\u2796 Controller removed: ${path4}`);
324
- await this.generateClient(projectPath, outputPath);
325
- });
326
- }
327
- async stop() {
328
- if (this.watcher) {
329
- await this.watcher.close();
330
- this.watcher = null;
331
- }
332
- }
333
- async generateClient(projectPath, outputPath) {
334
- try {
335
- const parser = new NestJSParser(projectPath);
336
- const controllers = parser.findFusionControllers();
337
- if (controllers.length === 0) {
338
- _chunkDW6GOKMFjs.logger.warn("No Fusion controllers found");
339
- return;
340
- }
341
- const generator = new ClientGenerator();
342
- await generator.generate({
343
- controllers,
344
- outputPath
345
- });
346
- _chunkDW6GOKMFjs.logger.success(`Generated client for ${controllers.length} controller(s)`);
347
- } catch (error) {
348
- _chunkDW6GOKMFjs.logger.error("Failed to generate client:", error.message);
349
- }
350
- }
351
- }, _class);
352
-
353
-
354
-
355
-
356
-
357
-
358
-
359
-
360
- exports.FileSystem = FileSystem; exports.filesystem = filesystem; exports.NestJSParser = NestJSParser; exports.ClientGenerator = ClientGenerator; exports.CodegenWatcher = CodegenWatcher; exports.codegen_exports = codegen_exports;
361
- //# sourceMappingURL=chunk-HU63F22V.js.map