wexts 3.0.2 → 4.1.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.
- package/README.md +49 -346
- package/bin/wexts.cjs +2 -0
- package/dist/chunk-2KAQYLVN.js +0 -0
- package/dist/chunk-2KAQYLVN.js.map +1 -1
- package/dist/{chunk-O42L6HOX.js → chunk-2LJVUMXW.js} +79 -93
- package/dist/chunk-2LJVUMXW.js.map +1 -0
- package/dist/chunk-342VRT25.mjs +504 -0
- package/dist/chunk-342VRT25.mjs.map +1 -0
- package/dist/chunk-7HNQWJWV.js +504 -0
- package/dist/chunk-7HNQWJWV.js.map +1 -0
- package/dist/chunk-7QKLIVRF.js +94 -0
- package/dist/chunk-7QKLIVRF.js.map +1 -0
- package/dist/chunk-7SSCNCTW.mjs +137 -0
- package/dist/chunk-7SSCNCTW.mjs.map +1 -0
- package/dist/chunk-7TLSPR65.mjs +95 -0
- package/dist/chunk-7TLSPR65.mjs.map +1 -0
- package/dist/{chunk-FCEZDH42.mjs → chunk-7WULUGLH.mjs} +5 -3
- package/dist/chunk-7WULUGLH.mjs.map +1 -0
- package/dist/chunk-AVMQJWYD.js +95 -0
- package/dist/chunk-AVMQJWYD.js.map +1 -0
- package/dist/{chunk-WF65EDRZ.js → chunk-BG56B4DE.js} +20 -2
- package/dist/chunk-BG56B4DE.js.map +1 -0
- package/dist/chunk-CLM5PNSG.mjs +496 -0
- package/dist/chunk-CLM5PNSG.mjs.map +1 -0
- package/dist/chunk-DNLGCKTT.js +31 -0
- package/dist/chunk-DNLGCKTT.js.map +1 -0
- package/dist/{chunk-VNNVLQLJ.mjs → chunk-JHOVXH3X.mjs} +2 -2
- package/dist/chunk-JHOVXH3X.mjs.map +1 -0
- package/dist/chunk-MXINIFPC.js +105 -0
- package/dist/chunk-MXINIFPC.js.map +1 -0
- package/dist/chunk-O4II6N34.js +137 -0
- package/dist/chunk-O4II6N34.js.map +1 -0
- package/dist/chunk-SE32ZPOZ.js +496 -0
- package/dist/chunk-SE32ZPOZ.js.map +1 -0
- package/dist/{chunk-STTOPUZ2.mjs → chunk-UAL54DVV.mjs} +21 -3
- package/dist/chunk-UAL54DVV.mjs.map +1 -0
- package/dist/{chunk-3OM7CHCA.js → chunk-WCKSKU3C.js} +1 -1
- package/dist/chunk-WCKSKU3C.js.map +1 -0
- package/dist/chunk-WU6FW77M.mjs +105 -0
- package/dist/chunk-WU6FW77M.mjs.map +1 -0
- package/dist/chunk-XE4OXN2W.js +0 -0
- package/dist/chunk-XE4OXN2W.js.map +1 -1
- package/dist/chunk-YBM3IJEA.mjs +94 -0
- package/dist/chunk-YBM3IJEA.mjs.map +1 -0
- package/dist/{chunk-KXYLEUSW.mjs → chunk-YN6WIWNQ.mjs} +69 -83
- package/dist/chunk-YN6WIWNQ.mjs.map +1 -0
- package/dist/chunk-YSLEF5C5.mjs +0 -0
- package/dist/chunk-YSLEF5C5.mjs.map +0 -0
- package/dist/chunk-ZX7QIN24.mjs +31 -0
- package/dist/chunk-ZX7QIN24.mjs.map +1 -0
- package/dist/cli/index.d.mts +22 -0
- package/dist/cli/index.d.ts +22 -0
- package/dist/cli/index.js +676 -292
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/index.mjs +678 -293
- package/dist/cli/index.mjs.map +1 -1
- package/dist/client/index.d.mts +10 -1
- package/dist/client/index.d.ts +10 -1
- package/dist/client/index.js +5 -2
- package/dist/client/index.js.map +1 -1
- package/dist/client/index.mjs +7 -4
- package/dist/client/index.mjs.map +0 -0
- package/dist/codegen/index.d.mts +2 -1
- package/dist/codegen/index.d.ts +2 -1
- package/dist/codegen/index.js +6 -3
- package/dist/codegen/index.js.map +1 -1
- package/dist/codegen/index.mjs +8 -5
- package/dist/codegen/index.mjs.map +0 -0
- package/dist/decorators-BT1FFqN0.d.mts +29 -0
- package/dist/decorators-DvS58PqC.d.ts +29 -0
- package/dist/dev-server/index.d.mts +1 -1
- package/dist/dev-server/index.d.ts +1 -1
- package/dist/dev-server/index.js +3 -3
- package/dist/dev-server/index.js.map +1 -1
- package/dist/dev-server/index.mjs +3 -3
- package/dist/dev-server/index.mjs.map +0 -0
- package/dist/{index-SjUaHgFr.d.ts → index-7QeQEf37.d.ts} +27 -10
- package/dist/{index-tFGPFVfQ.d.mts → index-7RvU-jGE.d.mts} +0 -1
- package/dist/{index-tFGPFVfQ.d.ts → index-7RvU-jGE.d.ts} +0 -1
- package/dist/{index-SjUaHgFr.d.mts → index-8nzxy0NN.d.mts} +27 -10
- package/dist/index-Co5ZsLqq.d.ts +58 -0
- package/dist/index-D94W1__r.d.mts +58 -0
- package/dist/index-DQmyVp6F.d.mts +27 -0
- package/dist/index-KL_1BrQb.d.ts +27 -0
- package/dist/index.d.mts +54 -7
- package/dist/index.d.ts +54 -7
- package/dist/index.js +70 -29
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +62 -21
- package/dist/index.mjs.map +1 -1
- package/dist/nest/index.d.mts +3 -1
- package/dist/nest/index.d.ts +3 -1
- package/dist/nest/index.js +20 -2
- package/dist/nest/index.js.map +1 -1
- package/dist/nest/index.mjs +21 -3
- package/dist/nest/index.mjs.map +0 -0
- package/dist/next/index.d.mts +7 -2
- package/dist/next/index.d.ts +7 -2
- package/dist/next/index.js +135 -5
- package/dist/next/index.js.map +1 -1
- package/dist/next/index.mjs +133 -4
- package/dist/next/index.mjs.map +1 -1
- package/dist/rpc/index.d.mts +2 -0
- package/dist/rpc/index.d.ts +2 -0
- package/dist/rpc/index.js +23 -0
- package/dist/rpc/index.js.map +1 -0
- package/dist/rpc/index.mjs +23 -0
- package/dist/{chunk-7NSRDJ5C.mjs.map → rpc/index.mjs.map} +0 -0
- package/dist/runtime/index.d.mts +55 -0
- package/dist/runtime/index.d.ts +55 -0
- package/dist/runtime/index.js +221 -0
- package/dist/runtime/index.js.map +1 -0
- package/dist/runtime/index.mjs +221 -0
- package/dist/runtime/index.mjs.map +1 -0
- package/dist/types/index.d.mts +0 -0
- package/dist/types/index.d.ts +0 -0
- package/dist/types/index.js +0 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/index.mjs +1 -1
- package/dist/types/index.mjs.map +0 -0
- package/dist/types-7d_fC-C3.d.mts +32 -0
- package/dist/types-7d_fC-C3.d.ts +32 -0
- package/dist/vercel-builder/index.d.mts +58 -0
- package/dist/vercel-builder/index.d.ts +58 -0
- package/dist/vercel-builder/index.js +330 -0
- package/dist/vercel-builder/index.js.map +1 -0
- package/dist/vercel-builder/index.mjs +330 -0
- package/dist/vercel-builder/index.mjs.map +1 -0
- package/package.json +37 -16
- package/templates/.dockerignore +43 -43
- package/templates/.env.example +0 -0
- package/templates/Dockerfile +60 -60
- package/templates/Procfile +1 -1
- package/templates/README.md +67 -58
- package/templates/api-sdk.ts +115 -115
- package/templates/docker-compose.yml +34 -34
- package/templates/nestjs-api/.env.example +0 -0
- package/templates/nestjs-api/README.md +87 -79
- package/templates/nestjs-api/nest-cli.json +6 -6
- package/templates/nestjs-api/package.json +40 -40
- package/templates/nestjs-api/prisma/dev.db +0 -0
- package/templates/nestjs-api/prisma/migrations/20251123205437_init/migration.sql +0 -0
- package/templates/nestjs-api/prisma/migrations/migration_lock.toml +0 -0
- package/templates/nestjs-api/prisma/schema.prisma +29 -29
- package/templates/nestjs-api/src/app.module.ts +17 -17
- package/templates/nestjs-api/src/auth/auth.controller.ts +27 -27
- package/templates/nestjs-api/src/auth/auth.module.ts +37 -29
- package/templates/nestjs-api/src/auth/auth.service.ts +86 -86
- package/templates/nestjs-api/src/auth/dto/auth.dto.ts +22 -22
- package/templates/nestjs-api/src/auth/guards/jwt-auth.guard.ts +5 -5
- package/templates/nestjs-api/src/auth/strategies/jwt.strategy.ts +27 -19
- package/templates/nestjs-api/src/main.ts +32 -32
- package/templates/nestjs-api/src/prisma/prisma.module.ts +9 -9
- package/templates/nestjs-api/src/prisma/prisma.service.ts +14 -14
- package/templates/nestjs-api/src/todos/dto/todo.dto.ts +24 -24
- package/templates/nestjs-api/src/todos/todos.controller.ts +39 -39
- package/templates/nestjs-api/src/todos/todos.module.ts +11 -11
- package/templates/nestjs-api/src/todos/todos.service.ts +53 -53
- package/templates/nestjs-api/src/users/users.controller.ts +14 -14
- package/templates/nestjs-api/src/users/users.module.ts +12 -12
- package/templates/nestjs-api/src/users/users.service.ts +19 -19
- package/templates/nestjs-api/tsconfig.json +39 -39
- package/templates/nextjs-web/README.md +76 -68
- package/templates/nextjs-web/app/actions/auth.ts +108 -108
- package/templates/nextjs-web/app/dashboard/error.tsx +39 -39
- package/templates/nextjs-web/app/dashboard/loading.tsx +14 -14
- package/templates/nextjs-web/app/dashboard/page.tsx +5 -5
- package/templates/nextjs-web/app/globals.css +93 -93
- package/templates/nextjs-web/app/layout.tsx +29 -29
- package/templates/nextjs-web/app/login/page.tsx +5 -5
- package/templates/nextjs-web/app/page.tsx +28 -28
- package/templates/nextjs-web/app/register/page.tsx +5 -5
- package/templates/nextjs-web/components/ui/button.tsx +56 -56
- package/templates/nextjs-web/components/ui/card.tsx +79 -79
- package/templates/nextjs-web/components/ui/input.tsx +25 -25
- package/templates/nextjs-web/components/ui/label.tsx +24 -24
- package/templates/nextjs-web/features/auth/LoginForm.tsx +140 -140
- package/templates/nextjs-web/features/auth/RegisterForm.tsx +159 -159
- package/templates/nextjs-web/features/auth/api.ts +35 -35
- package/templates/nextjs-web/features/auth/index.ts +3 -3
- package/templates/nextjs-web/features/dashboard/DashboardView.tsx +204 -204
- package/templates/nextjs-web/features/dashboard/api.ts +9 -9
- package/templates/nextjs-web/features/dashboard/components.tsx +74 -74
- package/templates/nextjs-web/features/dashboard/index.ts +3 -3
- package/templates/nextjs-web/hooks/index.ts +4 -4
- package/templates/nextjs-web/lib/api-client.ts +89 -89
- package/templates/nextjs-web/lib/api.ts +115 -115
- package/templates/nextjs-web/lib/axios-global-config.ts +17 -17
- package/templates/nextjs-web/lib/utils.ts +6 -6
- package/templates/nextjs-web/lib/wexts-client.ts +4 -4
- package/templates/nextjs-web/next-env.d.ts +6 -6
- package/templates/nextjs-web/next.config.ts +20 -20
- package/templates/nextjs-web/package.json +37 -37
- package/templates/nextjs-web/postcss.config.js +6 -6
- package/templates/nextjs-web/tailwind.config.ts +69 -69
- package/templates/nextjs-web/tsconfig.json +1 -1
- package/templates/nixpacks.toml +11 -11
- package/templates/root-package.json +31 -31
- package/templates/server.ts +66 -66
- package/templates/tsconfig.json +30 -30
- package/dist/chunk-2MCBBWEA.js +0 -1
- package/dist/chunk-2MCBBWEA.js.map +0 -1
- package/dist/chunk-3OM7CHCA.js.map +0 -1
- package/dist/chunk-63MTCWU2.mjs +0 -361
- package/dist/chunk-63MTCWU2.mjs.map +0 -1
- package/dist/chunk-667BQCEM.js +0 -375
- package/dist/chunk-667BQCEM.js.map +0 -1
- package/dist/chunk-67IJ6H4J.mjs +0 -44
- package/dist/chunk-67IJ6H4J.mjs.map +0 -1
- package/dist/chunk-6SVQEGEX.mjs +0 -44
- package/dist/chunk-6SVQEGEX.mjs.map +0 -1
- package/dist/chunk-7NSRDJ5C.mjs +0 -1
- package/dist/chunk-ASDXAK6G.js +0 -44
- package/dist/chunk-ASDXAK6G.js.map +0 -1
- package/dist/chunk-CKZ4VSCB.mjs +0 -18
- package/dist/chunk-CKZ4VSCB.mjs.map +0 -1
- package/dist/chunk-DW6GOKMF.js +0 -57
- package/dist/chunk-DW6GOKMF.js.map +0 -1
- package/dist/chunk-EFZPSZWO.mjs +0 -1
- package/dist/chunk-EFZPSZWO.mjs.map +0 -1
- package/dist/chunk-FCEZDH42.mjs.map +0 -1
- package/dist/chunk-FYGXL4V7.js +0 -361
- package/dist/chunk-FYGXL4V7.js.map +0 -1
- package/dist/chunk-GKVPGKAH.js +0 -66
- package/dist/chunk-GKVPGKAH.js.map +0 -1
- package/dist/chunk-GWP6PNSP.js +0 -225
- package/dist/chunk-GWP6PNSP.js.map +0 -1
- package/dist/chunk-HQKTXE7E.mjs +0 -225
- package/dist/chunk-HQKTXE7E.mjs.map +0 -1
- package/dist/chunk-HSFLZUJN.mjs +0 -57
- package/dist/chunk-HSFLZUJN.mjs.map +0 -1
- package/dist/chunk-HU63F22V.js +0 -361
- package/dist/chunk-HU63F22V.js.map +0 -1
- package/dist/chunk-J5LGTIGS.mjs +0 -10
- package/dist/chunk-J5LGTIGS.mjs.map +0 -1
- package/dist/chunk-JMBD6DOP.js +0 -225
- package/dist/chunk-JMBD6DOP.js.map +0 -1
- package/dist/chunk-K7EIJSYQ.js +0 -1
- package/dist/chunk-K7EIJSYQ.js.map +0 -1
- package/dist/chunk-KXYLEUSW.mjs.map +0 -1
- package/dist/chunk-MTHKZO55.js +0 -44
- package/dist/chunk-MTHKZO55.js.map +0 -1
- package/dist/chunk-NNQFLD7O.mjs +0 -361
- package/dist/chunk-NNQFLD7O.mjs.map +0 -1
- package/dist/chunk-NU2UB242.js +0 -82
- package/dist/chunk-NU2UB242.js.map +0 -1
- package/dist/chunk-NULGSZFE.mjs +0 -57
- package/dist/chunk-NULGSZFE.mjs.map +0 -1
- package/dist/chunk-O42L6HOX.js.map +0 -1
- package/dist/chunk-ONXNE2A6.mjs +0 -375
- package/dist/chunk-ONXNE2A6.mjs.map +0 -1
- package/dist/chunk-OTBYRUBE.mjs +0 -225
- package/dist/chunk-OTBYRUBE.mjs.map +0 -1
- package/dist/chunk-OTSAVKLY.mjs +0 -66
- package/dist/chunk-OTSAVKLY.mjs.map +0 -1
- package/dist/chunk-PZ5AY32C.js +0 -10
- package/dist/chunk-PZ5AY32C.js.map +0 -1
- package/dist/chunk-QP2TMRLG.js +0 -57
- package/dist/chunk-QP2TMRLG.js.map +0 -1
- package/dist/chunk-RS23R3ZQ.mjs +0 -82
- package/dist/chunk-RS23R3ZQ.mjs.map +0 -1
- package/dist/chunk-STTOPUZ2.mjs.map +0 -1
- package/dist/chunk-VMT3LALB.mjs +0 -51
- package/dist/chunk-VMT3LALB.mjs.map +0 -1
- package/dist/chunk-VNNVLQLJ.mjs.map +0 -1
- package/dist/chunk-W3YRVEFQ.js +0 -66
- package/dist/chunk-W3YRVEFQ.js.map +0 -1
- package/dist/chunk-WF65EDRZ.js.map +0 -1
- package/dist/chunk-WMHVXEYQ.mjs +0 -66
- package/dist/chunk-WMHVXEYQ.mjs.map +0 -1
- package/dist/chunk-XVKTIYHY.js +0 -51
- package/dist/chunk-XVKTIYHY.js.map +0 -1
- package/dist/codegen-MRZDLCYI.js +0 -13
- package/dist/codegen-MRZDLCYI.js.map +0 -1
- package/dist/codegen-UI5HTMXE.mjs +0 -13
- package/dist/codegen-UI5HTMXE.mjs.map +0 -1
- package/dist/dev-server-JKRVBWPY.mjs +0 -13
- package/dist/dev-server-JKRVBWPY.mjs.map +0 -1
- package/dist/dev-server-TLL7UQMR.js +0 -13
- package/dist/dev-server-TLL7UQMR.js.map +0 -1
- package/dist/index-BsNaOUtH.d.mts +0 -44
- package/dist/index-BsNaOUtH.d.ts +0 -44
- package/dist/index-CrbXnXsO.d.ts +0 -62
- package/dist/index-kEbGExWM.d.mts +0 -62
- package/templates/nestjs-api/.env +0 -4
- package/templates/nestjs-api/package-lock.json +0 -5623
- package/templates/nextjs-web/.env +0 -1
- package/templates/nextjs-web/package-lock.json +0 -3254
|
@@ -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"]}
|
package/dist/chunk-OTSAVKLY.mjs
DELETED
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
__export
|
|
3
|
-
} from "./chunk-J5LGTIGS.mjs";
|
|
4
|
-
|
|
5
|
-
// src/nest/index.ts
|
|
6
|
-
var nest_exports = {};
|
|
7
|
-
__export(nest_exports, {
|
|
8
|
-
FusionController: () => FusionController,
|
|
9
|
-
FusionDelete: () => FusionDelete,
|
|
10
|
-
FusionGet: () => FusionGet,
|
|
11
|
-
FusionPost: () => FusionPost,
|
|
12
|
-
FusionPut: () => FusionPut,
|
|
13
|
-
FusionRoute: () => FusionRoute,
|
|
14
|
-
getFusionMetadata: () => getFusionMetadata
|
|
15
|
-
});
|
|
16
|
-
|
|
17
|
-
// src/nest/decorators.ts
|
|
18
|
-
import "reflect-metadata";
|
|
19
|
-
var FUSION_METADATA_KEY = "fusion:routes";
|
|
20
|
-
function FusionController(prefix = "") {
|
|
21
|
-
return function(target) {
|
|
22
|
-
Reflect.defineMetadata("fusion:controller", { prefix }, target);
|
|
23
|
-
return target;
|
|
24
|
-
};
|
|
25
|
-
}
|
|
26
|
-
function FusionRoute(metadata) {
|
|
27
|
-
return function(target, propertyKey, descriptor) {
|
|
28
|
-
const routes = Reflect.getMetadata(FUSION_METADATA_KEY, target.constructor) || [];
|
|
29
|
-
routes.push({
|
|
30
|
-
...metadata,
|
|
31
|
-
handler: propertyKey
|
|
32
|
-
});
|
|
33
|
-
Reflect.defineMetadata(FUSION_METADATA_KEY, routes, target.constructor);
|
|
34
|
-
return descriptor;
|
|
35
|
-
};
|
|
36
|
-
}
|
|
37
|
-
function FusionGet(path = "") {
|
|
38
|
-
return FusionRoute({ method: "GET", path });
|
|
39
|
-
}
|
|
40
|
-
function FusionPost(path = "") {
|
|
41
|
-
return FusionRoute({ method: "POST", path });
|
|
42
|
-
}
|
|
43
|
-
function FusionPut(path = "") {
|
|
44
|
-
return FusionRoute({ method: "PUT", path });
|
|
45
|
-
}
|
|
46
|
-
function FusionDelete(path = "") {
|
|
47
|
-
return FusionRoute({ method: "DELETE", path });
|
|
48
|
-
}
|
|
49
|
-
function getFusionMetadata(controller) {
|
|
50
|
-
return {
|
|
51
|
-
controller: Reflect.getMetadata("fusion:controller", controller),
|
|
52
|
-
routes: Reflect.getMetadata(FUSION_METADATA_KEY, controller) || []
|
|
53
|
-
};
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
export {
|
|
57
|
-
FusionController,
|
|
58
|
-
FusionRoute,
|
|
59
|
-
FusionGet,
|
|
60
|
-
FusionPost,
|
|
61
|
-
FusionPut,
|
|
62
|
-
FusionDelete,
|
|
63
|
-
getFusionMetadata,
|
|
64
|
-
nest_exports
|
|
65
|
-
};
|
|
66
|
-
//# sourceMappingURL=chunk-OTSAVKLY.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/nest/index.ts","../src/nest/decorators.ts"],"sourcesContent":["export * from './decorators';\r\n","// NestJS Integration - Decorators for wexts\r\n// These decorators add metadata for auto API client generation\r\n\r\nimport 'reflect-metadata';\r\n\r\nexport interface FusionRouteMetadata {\r\n method: 'GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH';\r\n path: string;\r\n responseType?: string;\r\n requestType?: string;\r\n}\r\n\r\nconst FUSION_METADATA_KEY = 'fusion:routes';\r\n\r\n/**\r\n * Mark a NestJS controller for Fusion codegen\r\n * Usage: @FusionController('users')\r\n */\r\nexport function FusionController(prefix: string = ''): ClassDecorator {\r\n return function (target: any) {\r\n Reflect.defineMetadata('fusion:controller', { prefix }, target);\r\n return target;\r\n };\r\n}\r\n\r\n/**\r\n * Mark a route for API client generation\r\n * Usage: @FusionRoute({ method: 'GET', path: '/:id' })\r\n */\r\nexport function FusionRoute(metadata: FusionRouteMetadata): MethodDecorator {\r\n return function (target: any, propertyKey: string | symbol, descriptor: PropertyDescriptor) {\r\n const routes = Reflect.getMetadata(FUSION_METADATA_KEY, target.constructor) || [];\r\n routes.push({\r\n ...metadata,\r\n handler: propertyKey,\r\n });\r\n Reflect.defineMetadata(FUSION_METADATA_KEY, routes, target.constructor);\r\n return descriptor;\r\n };\r\n}\r\n\r\n/**\r\n * Helper decorators for common HTTP methods\r\n */\r\nexport function FusionGet(path: string = ''): MethodDecorator {\r\n return FusionRoute({ method: 'GET', path });\r\n}\r\n\r\nexport function FusionPost(path: string = ''): MethodDecorator {\r\n return FusionRoute({ method: 'POST', path });\r\n}\r\n\r\nexport function FusionPut(path: string = ''): MethodDecorator {\r\n return FusionRoute({ method: 'PUT', path });\r\n}\r\n\r\nexport function FusionDelete(path: string = ''): MethodDecorator {\r\n return FusionRoute({ method: 'DELETE', path });\r\n}\r\n\r\n/**\r\n * Get Fusion metadata from a controller\r\n */\r\nexport function getFusionMetadata(controller: any): {\r\n controller: any;\r\n routes: any[];\r\n} {\r\n return {\r\n controller: Reflect.getMetadata('fusion:controller', controller),\r\n routes: Reflect.getMetadata(FUSION_METADATA_KEY, controller) || [],\r\n };\r\n}\r\n"],"mappings":";;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACGA,OAAO;AASP,IAAM,sBAAsB;AAMrB,SAAS,iBAAiB,SAAiB,IAAoB;AAClE,SAAO,SAAU,QAAa;AAC1B,YAAQ,eAAe,qBAAqB,EAAE,OAAO,GAAG,MAAM;AAC9D,WAAO;AAAA,EACX;AACJ;AAMO,SAAS,YAAY,UAAgD;AACxE,SAAO,SAAU,QAAa,aAA8B,YAAgC;AACxF,UAAM,SAAS,QAAQ,YAAY,qBAAqB,OAAO,WAAW,KAAK,CAAC;AAChF,WAAO,KAAK;AAAA,MACR,GAAG;AAAA,MACH,SAAS;AAAA,IACb,CAAC;AACD,YAAQ,eAAe,qBAAqB,QAAQ,OAAO,WAAW;AACtE,WAAO;AAAA,EACX;AACJ;AAKO,SAAS,UAAU,OAAe,IAAqB;AAC1D,SAAO,YAAY,EAAE,QAAQ,OAAO,KAAK,CAAC;AAC9C;AAEO,SAAS,WAAW,OAAe,IAAqB;AAC3D,SAAO,YAAY,EAAE,QAAQ,QAAQ,KAAK,CAAC;AAC/C;AAEO,SAAS,UAAU,OAAe,IAAqB;AAC1D,SAAO,YAAY,EAAE,QAAQ,OAAO,KAAK,CAAC;AAC9C;AAEO,SAAS,aAAa,OAAe,IAAqB;AAC7D,SAAO,YAAY,EAAE,QAAQ,UAAU,KAAK,CAAC;AACjD;AAKO,SAAS,kBAAkB,YAGhC;AACE,SAAO;AAAA,IACH,YAAY,QAAQ,YAAY,qBAAqB,UAAU;AAAA,IAC/D,QAAQ,QAAQ,YAAY,qBAAqB,UAAU,KAAK,CAAC;AAAA,EACrE;AACJ;","names":[]}
|
package/dist/chunk-PZ5AY32C.js
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true});var __defProp = Object.defineProperty;
|
|
2
|
-
var __export = (target, all) => {
|
|
3
|
-
for (var name in all)
|
|
4
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
5
|
-
};
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
exports.__export = __export;
|
|
10
|
-
//# sourceMappingURL=chunk-PZ5AY32C.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["c:\\Users\\ziad\\Desktop\\wexts\\packages\\dist\\chunk-PZ5AY32C.js"],"names":[],"mappings":"AAAA,6EAAI,UAAU,EAAE,MAAM,CAAC,cAAc;AACrC,IAAI,SAAS,EAAE,CAAC,MAAM,EAAE,GAAG,EAAE,GAAG;AAChC,EAAE,IAAI,CAAC,IAAI,KAAK,GAAG,GAAG;AACtB,IAAI,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,EAAE,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;AACjE,CAAC;AACD;AACA;AACE;AACF,4BAAC","file":"C:\\Users\\ziad\\Desktop\\wexts\\packages\\dist\\chunk-PZ5AY32C.js"}
|
package/dist/chunk-QP2TMRLG.js
DELETED
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } }// 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
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
constructor(options = {}) {
|
|
14
|
-
this.level = _nullishCoalesce(options.level, () => ( 1)) /* INFO */;
|
|
15
|
-
this.prefix = _nullishCoalesce(options.prefix, () => ( "[Fusion]"));
|
|
16
|
-
this.timestamp = _nullishCoalesce(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
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
exports.LogLevel = LogLevel; exports.Logger = Logger; exports.logger = logger; exports.createLogger = createLogger;
|
|
57
|
-
//# sourceMappingURL=chunk-QP2TMRLG.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["c:\\Users\\ziad\\Desktop\\wexts\\packages\\dist\\chunk-QP2TMRLG.js"],"names":[],"mappings":"AAAA;AACA,IAAI,SAAS,kBAAkB,CAAC,CAAC,SAAS,EAAE,GAAG;AAC/C,EAAE,SAAS,CAAC,SAAS,CAAC,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,OAAO;AAC7C,EAAE,SAAS,CAAC,SAAS,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE,EAAE,MAAM;AAC3C,EAAE,SAAS,CAAC,SAAS,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE,EAAE,MAAM;AAC3C,EAAE,SAAS,CAAC,SAAS,CAAC,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,OAAO;AAC7C,EAAE,OAAO,SAAS;AAClB,CAAC,CAAC,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC;AAClB,IAAI,OAAO,EAAE,MAAM;AACnB,EAAE;AACF,EAAE;AACF,EAAE;AACF,EAAE,WAAW,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE;AAC5B,IAAI,IAAI,CAAC,MAAM,mBAAE,OAAO,CAAC,KAAM,UAAG,cAAY;AAC9C,IAAI,IAAI,CAAC,OAAO,mBAAE,OAAO,CAAC,MAAO,UAAG,YAAU;AAC9C,IAAI,IAAI,CAAC,UAAU,mBAAE,OAAO,CAAC,SAAU,UAAG,MAAI;AAC9C,EAAE;AACF,EAAE,aAAa,CAAC,KAAK,EAAE,GAAG,IAAI,EAAE;AAChC,IAAI,MAAM,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,EAAE,iBAAiB,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE;AAC7F,IAAI,OAAO,CAAC,EAAA;AACA,EAAA;AACA,EAAA;AACA,IAAA;AACA,MAAA;AACA,IAAA;AACA,EAAA;AACA,EAAA;AACA,IAAA;AACA,MAAA;AACA,IAAA;AACA,EAAA;AACA,EAAA;AACA,IAAA;AACA,MAAA;AACA,IAAA;AACA,EAAA;AACA,EAAA;AACA,IAAA;AACA,MAAA;AACA,IAAA;AACA,EAAA;AACA,EAAA;AACA,IAAA;AACA,EAAA;AACA;AACA;AACA;AACA,EAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"C:\\Users\\ziad\\Desktop\\wexts\\packages\\dist\\chunk-QP2TMRLG.js","sourcesContent":[null]}
|
package/dist/chunk-RS23R3ZQ.mjs
DELETED
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
FusionFetcher
|
|
3
|
-
} from "./chunk-6SVQEGEX.mjs";
|
|
4
|
-
import {
|
|
5
|
-
__export
|
|
6
|
-
} from "./chunk-J5LGTIGS.mjs";
|
|
7
|
-
|
|
8
|
-
// src/next/index.ts
|
|
9
|
-
var next_exports = {};
|
|
10
|
-
__export(next_exports, {
|
|
11
|
-
FusionProvider: () => FusionProvider,
|
|
12
|
-
useAuth: () => useAuth,
|
|
13
|
-
useFusion: () => useFusion
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
// src/next/provider.tsx
|
|
17
|
-
import React, { createContext, useContext } from "react";
|
|
18
|
-
var FusionContext = createContext(null);
|
|
19
|
-
function FusionProvider({ children, baseUrl = "/api" }) {
|
|
20
|
-
const client = React.useMemo(() => new FusionFetcher(baseUrl), [baseUrl]);
|
|
21
|
-
return /* @__PURE__ */ React.createElement(FusionContext.Provider, { value: { client } }, children);
|
|
22
|
-
}
|
|
23
|
-
function useFusion() {
|
|
24
|
-
const context = useContext(FusionContext);
|
|
25
|
-
if (!context) {
|
|
26
|
-
throw new Error("useFusion must be used within FusionProvider");
|
|
27
|
-
}
|
|
28
|
-
return context;
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
// src/next/useAuth.ts
|
|
32
|
-
import { useState, useEffect } from "react";
|
|
33
|
-
function useAuth() {
|
|
34
|
-
const { client } = useFusion();
|
|
35
|
-
const [user, setUser] = useState(null);
|
|
36
|
-
const [loading, setLoading] = useState(true);
|
|
37
|
-
useEffect(() => {
|
|
38
|
-
const token = localStorage.getItem("fusion_token");
|
|
39
|
-
if (token) {
|
|
40
|
-
loadUser();
|
|
41
|
-
} else {
|
|
42
|
-
setLoading(false);
|
|
43
|
-
}
|
|
44
|
-
}, []);
|
|
45
|
-
const loadUser = async () => {
|
|
46
|
-
try {
|
|
47
|
-
const userData = await client.get("/auth/me");
|
|
48
|
-
setUser(userData);
|
|
49
|
-
} catch (error) {
|
|
50
|
-
localStorage.removeItem("fusion_token");
|
|
51
|
-
} finally {
|
|
52
|
-
setLoading(false);
|
|
53
|
-
}
|
|
54
|
-
};
|
|
55
|
-
const login = async (email, password) => {
|
|
56
|
-
const response = await client.post("/auth/login", {
|
|
57
|
-
email,
|
|
58
|
-
password
|
|
59
|
-
});
|
|
60
|
-
localStorage.setItem("fusion_token", response.token);
|
|
61
|
-
setUser(response.user);
|
|
62
|
-
};
|
|
63
|
-
const logout = async () => {
|
|
64
|
-
localStorage.removeItem("fusion_token");
|
|
65
|
-
setUser(null);
|
|
66
|
-
};
|
|
67
|
-
return {
|
|
68
|
-
user,
|
|
69
|
-
loading,
|
|
70
|
-
login,
|
|
71
|
-
logout,
|
|
72
|
-
isAuthenticated: !!user
|
|
73
|
-
};
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
export {
|
|
77
|
-
FusionProvider,
|
|
78
|
-
useFusion,
|
|
79
|
-
useAuth,
|
|
80
|
-
next_exports
|
|
81
|
-
};
|
|
82
|
-
//# sourceMappingURL=chunk-RS23R3ZQ.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/next/index.ts","../src/next/provider.tsx","../src/next/useAuth.ts"],"sourcesContent":["export * from './provider';\r\nexport * from './useAuth';\r\n","'use client';\r\n\r\nimport React, { createContext, useContext, ReactNode } from 'react';\r\nimport { FusionFetcher } from '../client/fetcher';\r\n\r\ninterface FusionContextType {\r\n client: FusionFetcher;\r\n}\r\n\r\nconst FusionContext = createContext<FusionContextType | null>(null);\r\n\r\nexport interface FusionProviderProps {\r\n children: ReactNode;\r\n baseUrl?: string;\r\n}\r\n\r\n/**\r\n * FusionProvider - Provides API client to React components\r\n * Usage:\r\n * ```tsx\r\n * <FusionProvider baseUrl=\"/api\">\r\n * <App />\r\n * </FusionProvider>\r\n * ```\r\n */\r\nexport function FusionProvider({ children, baseUrl = '/api' }: FusionProviderProps) {\r\n const client = React.useMemo(() => new FusionFetcher(baseUrl), [baseUrl]);\r\n\r\n return (\r\n <FusionContext.Provider value={{ client }}>\r\n {children}\r\n </FusionContext.Provider>\r\n );\r\n}\r\n\r\n/**\r\n * useFusion hook - Access API client in components\r\n * Usage:\r\n * ```tsx\r\n * const { client } = useFusion();\r\n * const data = await client.get('/users');\r\n * ```\r\n */\r\nexport function useFusion(): FusionContextType {\r\n const context = useContext(FusionContext);\r\n if (!context) {\r\n throw new Error('useFusion must be used within FusionProvider');\r\n }\r\n return context;\r\n}\r\n","'use client';\r\n\r\nimport { useState, useEffect } from 'react';\r\nimport { useFusion } from './provider';\r\n\r\nexport interface AuthUser {\r\n id: string;\r\n email: string;\r\n name?: string;\r\n}\r\n\r\nexport interface UseAuthReturn {\r\n user: AuthUser | null;\r\n loading: boolean;\r\n login: (email: string, password: string) => Promise<void>;\r\n logout: () => Promise<void>;\r\n isAuthenticated: boolean;\r\n}\r\n\r\n/**\r\n * useAuth hook - Authentication state management\r\n * Usage:\r\n * ```tsx\r\n * const { user, login, logout, isAuthenticated } = useAuth();\r\n * ```\r\n */\r\nexport function useAuth(): UseAuthReturn {\r\n const { client } = useFusion();\r\n const [user, setUser] = useState<AuthUser | null>(null);\r\n const [loading, setLoading] = useState(true);\r\n\r\n useEffect(() => {\r\n // Check for existing session\r\n const token = localStorage.getItem('fusion_token');\r\n if (token) {\r\n // Validate token and load user\r\n loadUser();\r\n } else {\r\n setLoading(false);\r\n }\r\n }, []);\r\n\r\n const loadUser = async () => {\r\n try {\r\n const userData = await client.get<AuthUser>('/auth/me');\r\n setUser(userData);\r\n } catch (error) {\r\n localStorage.removeItem('fusion_token');\r\n } finally {\r\n setLoading(false);\r\n }\r\n };\r\n\r\n const login = async (email: string, password: string) => {\r\n const response = await client.post<{ token: string; user: AuthUser }>('/auth/login', {\r\n email,\r\n password,\r\n });\r\n localStorage.setItem('fusion_token', response.token);\r\n setUser(response.user);\r\n };\r\n\r\n const logout = async () => {\r\n localStorage.removeItem('fusion_token');\r\n setUser(null);\r\n };\r\n\r\n return {\r\n user,\r\n loading,\r\n login,\r\n logout,\r\n isAuthenticated: !!user,\r\n };\r\n}\r\n"],"mappings":";;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACEA,OAAO,SAAS,eAAe,kBAA6B;AAO5D,IAAM,gBAAgB,cAAwC,IAAI;AAgB3D,SAAS,eAAe,EAAE,UAAU,UAAU,OAAO,GAAwB;AAChF,QAAM,SAAS,MAAM,QAAQ,MAAM,IAAI,cAAc,OAAO,GAAG,CAAC,OAAO,CAAC;AAExE,SACI,oCAAC,cAAc,UAAd,EAAuB,OAAO,EAAE,OAAO,KACnC,QACL;AAER;AAUO,SAAS,YAA+B;AAC3C,QAAM,UAAU,WAAW,aAAa;AACxC,MAAI,CAAC,SAAS;AACV,UAAM,IAAI,MAAM,8CAA8C;AAAA,EAClE;AACA,SAAO;AACX;;;AC/CA,SAAS,UAAU,iBAAiB;AAwB7B,SAAS,UAAyB;AACrC,QAAM,EAAE,OAAO,IAAI,UAAU;AAC7B,QAAM,CAAC,MAAM,OAAO,IAAI,SAA0B,IAAI;AACtD,QAAM,CAAC,SAAS,UAAU,IAAI,SAAS,IAAI;AAE3C,YAAU,MAAM;AAEZ,UAAM,QAAQ,aAAa,QAAQ,cAAc;AACjD,QAAI,OAAO;AAEP,eAAS;AAAA,IACb,OAAO;AACH,iBAAW,KAAK;AAAA,IACpB;AAAA,EACJ,GAAG,CAAC,CAAC;AAEL,QAAM,WAAW,YAAY;AACzB,QAAI;AACA,YAAM,WAAW,MAAM,OAAO,IAAc,UAAU;AACtD,cAAQ,QAAQ;AAAA,IACpB,SAAS,OAAO;AACZ,mBAAa,WAAW,cAAc;AAAA,IAC1C,UAAE;AACE,iBAAW,KAAK;AAAA,IACpB;AAAA,EACJ;AAEA,QAAM,QAAQ,OAAO,OAAe,aAAqB;AACrD,UAAM,WAAW,MAAM,OAAO,KAAwC,eAAe;AAAA,MACjF;AAAA,MACA;AAAA,IACJ,CAAC;AACD,iBAAa,QAAQ,gBAAgB,SAAS,KAAK;AACnD,YAAQ,SAAS,IAAI;AAAA,EACzB;AAEA,QAAM,SAAS,YAAY;AACvB,iBAAa,WAAW,cAAc;AACtC,YAAQ,IAAI;AAAA,EAChB;AAEA,SAAO;AAAA,IACH;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,iBAAiB,CAAC,CAAC;AAAA,EACvB;AACJ;","names":[]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/nest/index.ts","../src/nest/decorators.ts"],"sourcesContent":["export * from './decorators';\r\n","// NestJS Integration - Decorators for wexts\r\n// These decorators add metadata for auto API client generation\r\n\r\nimport 'reflect-metadata';\r\n\r\nexport interface FusionRouteMetadata {\r\n method: 'GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH';\r\n path: string;\r\n responseType?: string;\r\n requestType?: string;\r\n}\r\n\r\nconst FUSION_METADATA_KEY = 'fusion:routes';\r\n\r\n/**\r\n * Mark a NestJS controller for Fusion codegen\r\n * Usage: @FusionController('users')\r\n */\r\nexport function FusionController(prefix: string = ''): ClassDecorator {\r\n return function (target: any) {\r\n Reflect.defineMetadata('fusion:controller', { prefix }, target);\r\n return target;\r\n };\r\n}\r\n\r\n/**\r\n * Mark a route for API client generation\r\n * Usage: @FusionRoute({ method: 'GET', path: '/:id' })\r\n */\r\nexport function FusionRoute(metadata: FusionRouteMetadata): MethodDecorator {\r\n return function (target: any, propertyKey: string | symbol, descriptor: PropertyDescriptor) {\r\n const routes = Reflect.getMetadata(FUSION_METADATA_KEY, target.constructor) || [];\r\n routes.push({\r\n ...metadata,\r\n handler: propertyKey,\r\n });\r\n Reflect.defineMetadata(FUSION_METADATA_KEY, routes, target.constructor);\r\n return descriptor;\r\n };\r\n}\r\n\r\n/**\r\n * Helper decorators for common HTTP methods\r\n */\r\nexport function FusionGet(path: string = ''): MethodDecorator {\r\n return FusionRoute({ method: 'GET', path });\r\n}\r\n\r\nexport function FusionPost(path: string = ''): MethodDecorator {\r\n return FusionRoute({ method: 'POST', path });\r\n}\r\n\r\nexport function FusionPut(path: string = ''): MethodDecorator {\r\n return FusionRoute({ method: 'PUT', path });\r\n}\r\n\r\nexport function FusionDelete(path: string = ''): MethodDecorator {\r\n return FusionRoute({ method: 'DELETE', path });\r\n}\r\n\r\n/**\r\n * Get Fusion metadata from a controller\r\n */\r\nexport function getFusionMetadata(controller: any): {\r\n controller: any;\r\n routes: any[];\r\n} {\r\n return {\r\n controller: Reflect.getMetadata('fusion:controller', controller),\r\n routes: Reflect.getMetadata(FUSION_METADATA_KEY, controller) || [],\r\n };\r\n}\r\n"],"mappings":";;;;;;AAAA;;;;;;;;;;;;ACGA,OAAO;AASP,IAAMA,sBAAsB;AAMrB,SAASC,iBAAiBC,SAAiB,IAAE;AAChD,SAAO,SAAUC,QAAW;AACxBC,YAAQC,eAAe,qBAAqB;MAAEH;IAAO,GAAGC,MAAAA;AACxD,WAAOA;EACX;AACJ;AALgBF;AAWT,SAASK,YAAYC,UAA6B;AACrD,SAAO,SAAUJ,QAAaK,aAA8BC,YAA8B;AACtF,UAAMC,SAASN,QAAQO,YAAYX,qBAAqBG,OAAO,WAAW,KAAK,CAAA;AAC/EO,WAAOE,KAAK;MACR,GAAGL;MACHM,SAASL;IACb,CAAA;AACAJ,YAAQC,eAAeL,qBAAqBU,QAAQP,OAAO,WAAW;AACtE,WAAOM;EACX;AACJ;AAVgBH;AAeT,SAASQ,UAAUC,OAAe,IAAE;AACvC,SAAOT,YAAY;IAAEU,QAAQ;IAAOD;EAAK,CAAA;AAC7C;AAFgBD;AAIT,SAASG,WAAWF,OAAe,IAAE;AACxC,SAAOT,YAAY;IAAEU,QAAQ;IAAQD;EAAK,CAAA;AAC9C;AAFgBE;AAIT,SAASC,UAAUH,OAAe,IAAE;AACvC,SAAOT,YAAY;IAAEU,QAAQ;IAAOD;EAAK,CAAA;AAC7C;AAFgBG;AAIT,SAASC,aAAaJ,OAAe,IAAE;AAC1C,SAAOT,YAAY;IAAEU,QAAQ;IAAUD;EAAK,CAAA;AAChD;AAFgBI;AAOT,SAASC,kBAAkBC,YAAe;AAI7C,SAAO;IACHA,YAAYjB,QAAQO,YAAY,qBAAqBU,UAAAA;IACrDX,QAAQN,QAAQO,YAAYX,qBAAqBqB,UAAAA,KAAe,CAAA;EACpE;AACJ;AARgBD;","names":["FUSION_METADATA_KEY","FusionController","prefix","target","Reflect","defineMetadata","FusionRoute","metadata","propertyKey","descriptor","routes","getMetadata","push","handler","FusionGet","path","method","FusionPost","FusionPut","FusionDelete","getFusionMetadata","controller"]}
|
package/dist/chunk-VMT3LALB.mjs
DELETED
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
__name
|
|
3
|
-
} from "./chunk-FCEZDH42.mjs";
|
|
4
|
-
|
|
5
|
-
// src/client/fetcher.ts
|
|
6
|
-
var FusionFetcher = class {
|
|
7
|
-
static {
|
|
8
|
-
__name(this, "FusionFetcher");
|
|
9
|
-
}
|
|
10
|
-
baseUrl;
|
|
11
|
-
constructor(baseUrl = "/api") {
|
|
12
|
-
this.baseUrl = baseUrl;
|
|
13
|
-
}
|
|
14
|
-
async request(method, path, body) {
|
|
15
|
-
const headers = {
|
|
16
|
-
"Content-Type": "application/json"
|
|
17
|
-
};
|
|
18
|
-
if (typeof window !== "undefined") {
|
|
19
|
-
const token = localStorage.getItem("fusion_token");
|
|
20
|
-
if (token) headers["Authorization"] = `Bearer ${token}`;
|
|
21
|
-
}
|
|
22
|
-
const response = await fetch(`${this.baseUrl}${path}`, {
|
|
23
|
-
method,
|
|
24
|
-
headers,
|
|
25
|
-
body: body ? JSON.stringify(body) : void 0
|
|
26
|
-
});
|
|
27
|
-
if (!response.ok) {
|
|
28
|
-
throw new Error(`Fusion API Error: ${response.statusText}`);
|
|
29
|
-
}
|
|
30
|
-
return response.json();
|
|
31
|
-
}
|
|
32
|
-
get(path) {
|
|
33
|
-
return this.request("GET", path);
|
|
34
|
-
}
|
|
35
|
-
post(path, body) {
|
|
36
|
-
return this.request("POST", path, body);
|
|
37
|
-
}
|
|
38
|
-
put(path, body) {
|
|
39
|
-
return this.request("PUT", path, body);
|
|
40
|
-
}
|
|
41
|
-
delete(path) {
|
|
42
|
-
return this.request("DELETE", path);
|
|
43
|
-
}
|
|
44
|
-
};
|
|
45
|
-
var apiFetcher = new FusionFetcher();
|
|
46
|
-
|
|
47
|
-
export {
|
|
48
|
-
FusionFetcher,
|
|
49
|
-
apiFetcher
|
|
50
|
-
};
|
|
51
|
-
//# sourceMappingURL=chunk-VMT3LALB.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/client/fetcher.ts"],"sourcesContent":["// packages/api-client/src/fetcher.ts\r\n\r\nexport class FusionFetcher {\r\n private baseUrl: string;\r\n\r\n constructor(baseUrl: string = '/api') {\r\n this.baseUrl = baseUrl;\r\n }\r\n\r\n private async request<T>(method: string, path: string, body?: any): Promise<T> {\r\n const headers: Record<string, string> = {\r\n 'Content-Type': 'application/json',\r\n };\r\n\r\n // Automatically attach Fusion Token if present\r\n if (typeof window !== 'undefined') {\r\n const token = localStorage.getItem('fusion_token');\r\n if (token) headers['Authorization'] = `Bearer ${token}`;\r\n }\r\n\r\n const response = await fetch(`${this.baseUrl}${path}`, {\r\n method,\r\n headers,\r\n body: body ? JSON.stringify(body) : undefined,\r\n });\r\n\r\n if (!response.ok) {\r\n throw new Error(`Fusion API Error: ${response.statusText}`);\r\n }\r\n\r\n return response.json();\r\n }\r\n\r\n get<T>(path: string) { return this.request<T>('GET', path); }\r\n post<T>(path: string, body: any) { return this.request<T>('POST', path, body); }\r\n put<T>(path: string, body: any) { return this.request<T>('PUT', path, body); }\r\n delete<T>(path: string) { return this.request<T>('DELETE', path); }\r\n}\r\n\r\nexport const apiFetcher = new FusionFetcher();\r\n"],"mappings":";;;;;AAEO,IAAMA,gBAAN,MAAMA;EAFb,OAEaA;;;EACDC;EAER,YAAYA,UAAkB,QAAQ;AAClC,SAAKA,UAAUA;EACnB;EAEA,MAAcC,QAAWC,QAAgBC,MAAcC,MAAwB;AAC3E,UAAMC,UAAkC;MACpC,gBAAgB;IACpB;AAGA,QAAI,OAAOC,WAAW,aAAa;AAC/B,YAAMC,QAAQC,aAAaC,QAAQ,cAAA;AACnC,UAAIF,MAAOF,SAAQ,eAAA,IAAmB,UAAUE,KAAAA;IACpD;AAEA,UAAMG,WAAW,MAAMC,MAAM,GAAG,KAAKX,OAAO,GAAGG,IAAAA,IAAQ;MACnDD;MACAG;MACAD,MAAMA,OAAOQ,KAAKC,UAAUT,IAAAA,IAAQU;IACxC,CAAA;AAEA,QAAI,CAACJ,SAASK,IAAI;AACd,YAAM,IAAIC,MAAM,qBAAqBN,SAASO,UAAU,EAAE;IAC9D;AAEA,WAAOP,SAASQ,KAAI;EACxB;EAEAC,IAAOhB,MAAc;AAAE,WAAO,KAAKF,QAAW,OAAOE,IAAAA;EAAO;EAC5DiB,KAAQjB,MAAcC,MAAW;AAAE,WAAO,KAAKH,QAAW,QAAQE,MAAMC,IAAAA;EAAO;EAC/EiB,IAAOlB,MAAcC,MAAW;AAAE,WAAO,KAAKH,QAAW,OAAOE,MAAMC,IAAAA;EAAO;EAC7EkB,OAAUnB,MAAc;AAAE,WAAO,KAAKF,QAAW,UAAUE,IAAAA;EAAO;AACtE;AAEO,IAAMoB,aAAa,IAAIxB,cAAAA;","names":["FusionFetcher","baseUrl","request","method","path","body","headers","window","token","localStorage","getItem","response","fetch","JSON","stringify","undefined","ok","Error","statusText","json","get","post","put","delete","apiFetcher"]}
|
|
@@ -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,IAAKA,WAAAA,0BAAAA,WAAAA;;;;;SAAAA;;AAaL,IAAMC,SAAN,MAAMA;EAbb,OAaaA;;;EACDC;EACAC;EACAC;EAER,YAAYC,UAAyB,CAAC,GAAG;AACrC,SAAKH,QAAQG,QAAQH,SAAK;AAC1B,SAAKC,SAASE,QAAQF,UAAU;AAChC,SAAKC,YAAYC,QAAQD,aAAa;EAC1C;EAEQE,cAAcJ,UAAkBK,MAAqB;AACzD,UAAMH,YAAY,KAAKA,YAAY,KAAI,oBAAII,KAAAA,GAAOC,YAAW,CAAA,MAAQ;AACrE,WAAO,GAAGL,SAAAA,IAAa,KAAKD,MAAM,IAAID,KAAAA,KAAUK,KAAKG,KAAK,GAAA,CAAA;EAC9D;EAEAC,SAASJ,MAAmB;AACxB,QAAI,KAAKL,SAAK,GAAoB;AAC9BU,cAAQC,IAAI,KAAKP,cAAc,SAAA,GAAYC,IAAAA,CAAAA;IAC/C;EACJ;EAEAO,QAAQP,MAAmB;AACvB,QAAI,KAAKL,SAAK,GAAmB;AAC7BU,cAAQC,IAAI,KAAKP,cAAc,QAAA,GAAWC,IAAAA,CAAAA;IAC9C;EACJ;EAEAQ,QAAQR,MAAmB;AACvB,QAAI,KAAKL,SAAK,GAAmB;AAC7BU,cAAQG,KAAK,KAAKT,cAAc,QAAA,GAAWC,IAAAA,CAAAA;IAC/C;EACJ;EAEAS,SAAST,MAAmB;AACxB,QAAI,KAAKL,SAAK,GAAoB;AAC9BU,cAAQI,MAAM,KAAKV,cAAc,SAAA,GAAYC,IAAAA,CAAAA;IACjD;EACJ;EAEAU,WAAWV,MAAmB;AAC1BK,YAAQC,IAAI,KAAKP,cAAc,UAAA,GAAQC,IAAAA,CAAAA;EAC3C;AACJ;AAGO,IAAMW,SAAS,IAAIjB,OAAAA;AAGnB,SAASkB,aAAad,SAAsB;AAC/C,SAAO,IAAIJ,OAAOI,OAAAA;AACtB;AAFgBc;","names":["LogLevel","Logger","level","prefix","timestamp","options","formatMessage","args","Date","toISOString","join","debug","console","log","info","warn","error","success","logger","createLogger"]}
|
package/dist/chunk-W3YRVEFQ.js
DELETED
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
|
-
|
|
3
|
-
var _chunkPZ5AY32Cjs = require('./chunk-PZ5AY32C.js');
|
|
4
|
-
|
|
5
|
-
// src/nest/index.ts
|
|
6
|
-
var nest_exports = {};
|
|
7
|
-
_chunkPZ5AY32Cjs.__export.call(void 0, nest_exports, {
|
|
8
|
-
FusionController: () => FusionController,
|
|
9
|
-
FusionDelete: () => FusionDelete,
|
|
10
|
-
FusionGet: () => FusionGet,
|
|
11
|
-
FusionPost: () => FusionPost,
|
|
12
|
-
FusionPut: () => FusionPut,
|
|
13
|
-
FusionRoute: () => FusionRoute,
|
|
14
|
-
getFusionMetadata: () => getFusionMetadata
|
|
15
|
-
});
|
|
16
|
-
|
|
17
|
-
// src/nest/decorators.ts
|
|
18
|
-
require('reflect-metadata');
|
|
19
|
-
var FUSION_METADATA_KEY = "fusion:routes";
|
|
20
|
-
function FusionController(prefix = "") {
|
|
21
|
-
return function(target) {
|
|
22
|
-
Reflect.defineMetadata("fusion:controller", { prefix }, target);
|
|
23
|
-
return target;
|
|
24
|
-
};
|
|
25
|
-
}
|
|
26
|
-
function FusionRoute(metadata) {
|
|
27
|
-
return function(target, propertyKey, descriptor) {
|
|
28
|
-
const routes = Reflect.getMetadata(FUSION_METADATA_KEY, target.constructor) || [];
|
|
29
|
-
routes.push({
|
|
30
|
-
...metadata,
|
|
31
|
-
handler: propertyKey
|
|
32
|
-
});
|
|
33
|
-
Reflect.defineMetadata(FUSION_METADATA_KEY, routes, target.constructor);
|
|
34
|
-
return descriptor;
|
|
35
|
-
};
|
|
36
|
-
}
|
|
37
|
-
function FusionGet(path = "") {
|
|
38
|
-
return FusionRoute({ method: "GET", path });
|
|
39
|
-
}
|
|
40
|
-
function FusionPost(path = "") {
|
|
41
|
-
return FusionRoute({ method: "POST", path });
|
|
42
|
-
}
|
|
43
|
-
function FusionPut(path = "") {
|
|
44
|
-
return FusionRoute({ method: "PUT", path });
|
|
45
|
-
}
|
|
46
|
-
function FusionDelete(path = "") {
|
|
47
|
-
return FusionRoute({ method: "DELETE", path });
|
|
48
|
-
}
|
|
49
|
-
function getFusionMetadata(controller) {
|
|
50
|
-
return {
|
|
51
|
-
controller: Reflect.getMetadata("fusion:controller", controller),
|
|
52
|
-
routes: Reflect.getMetadata(FUSION_METADATA_KEY, controller) || []
|
|
53
|
-
};
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
exports.FusionController = FusionController; exports.FusionRoute = FusionRoute; exports.FusionGet = FusionGet; exports.FusionPost = FusionPost; exports.FusionPut = FusionPut; exports.FusionDelete = FusionDelete; exports.getFusionMetadata = getFusionMetadata; exports.nest_exports = nest_exports;
|
|
66
|
-
//# sourceMappingURL=chunk-W3YRVEFQ.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["c:\\Users\\ziad\\Desktop\\wexts\\packages\\dist\\chunk-W3YRVEFQ.js"],"names":[],"mappings":"AAAA;AACE;AACF,sDAA4B;AAC5B;AACA;AACA,IAAI,aAAa,EAAE,CAAC,CAAC;AACrB,uCAAQ,YAAa,EAAE;AACvB,EAAE,gBAAgB,EAAE,CAAC,EAAE,GAAG,gBAAgB;AAC1C,EAAE,YAAY,EAAE,CAAC,EAAE,GAAG,YAAY;AAClC,EAAE,SAAS,EAAE,CAAC,EAAE,GAAG,SAAS;AAC5B,EAAE,UAAU,EAAE,CAAC,EAAE,GAAG,UAAU;AAC9B,EAAE,SAAS,EAAE,CAAC,EAAE,GAAG,SAAS;AAC5B,EAAE,WAAW,EAAE,CAAC,EAAE,GAAG,WAAW;AAChC,EAAE,iBAAiB,EAAE,CAAC,EAAE,GAAG;AAC3B,CAAC,CAAC;AACF;AACA;AACA,4BAAyB;AACzB,IAAI,oBAAoB,EAAE,eAAe;AACzC,SAAS,gBAAgB,CAAC,OAAO,EAAE,EAAE,EAAE;AACvC,EAAE,OAAO,QAAQ,CAAC,MAAM,EAAE;AAC1B,IAAI,OAAO,CAAC,cAAc,CAAC,mBAAmB,EAAE,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC;AACnE,IAAI,OAAO,MAAM;AACjB,EAAE,CAAC;AACH;AACA,SAAS,WAAW,CAAC,QAAQ,EAAE;AAC/B,EAAE,OAAO,QAAQ,CAAC,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE;AACnD,IAAI,MAAM,OAAO,EAAE,OAAO,CAAC,WAAW,CAAC,mBAAmB,EAAE,MAAM,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC;AACrF,IAAI,MAAM,CAAC,IAAI,CAAC;AAChB,MAAM,GAAG,QAAQ;AACjB,MAAM,OAAO,EAAE;AACf,IAAI,CAAC,CAAC;AACN,IAAI,OAAO,CAAC,cAAc,CAAC,mBAAmB,EAAE,MAAM,EAAE,MAAM,CAAC,WAAW,CAAC;AAC3E,IAAI,OAAO,UAAU;AACrB,EAAE,CAAC;AACH;AACA,SAAS,SAAS,CAAC,KAAK,EAAE,EAAE,EAAE;AAC9B,EAAE,OAAO,WAAW,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;AAC7C;AACA,SAAS,UAAU,CAAC,KAAK,EAAE,EAAE,EAAE;AAC/B,EAAE,OAAO,WAAW,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;AAC9C;AACA,SAAS,SAAS,CAAC,KAAK,EAAE,EAAE,EAAE;AAC9B,EAAE,OAAO,WAAW,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;AAC7C;AACA,SAAS,YAAY,CAAC,KAAK,EAAE,EAAE,EAAE;AACjC,EAAE,OAAO,WAAW,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;AAChD;AACA,SAAS,iBAAiB,CAAC,UAAU,EAAE;AACvC,EAAE,OAAO;AACT,IAAI,UAAU,EAAE,OAAO,CAAC,WAAW,CAAC,mBAAmB,EAAE,UAAU,CAAC;AACpE,IAAI,MAAM,EAAE,OAAO,CAAC,WAAW,CAAC,mBAAmB,EAAE,UAAU,EAAE,GAAG,CAAC;AACrE,EAAE,CAAC;AACH;AACA;AACA;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,uSAAC","file":"C:\\Users\\ziad\\Desktop\\wexts\\packages\\dist\\chunk-W3YRVEFQ.js","sourcesContent":[null]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["c:\\Users\\ziad\\Desktop\\wexts\\packages\\dist\\chunk-WF65EDRZ.js"],"names":[],"mappings":"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","file":"C:\\Users\\ziad\\Desktop\\wexts\\packages\\dist\\chunk-WF65EDRZ.js","sourcesContent":[null]}
|
package/dist/chunk-WMHVXEYQ.mjs
DELETED
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
__export
|
|
3
|
-
} from "./chunk-CKZ4VSCB.mjs";
|
|
4
|
-
|
|
5
|
-
// src/nest/index.ts
|
|
6
|
-
var nest_exports = {};
|
|
7
|
-
__export(nest_exports, {
|
|
8
|
-
FusionController: () => FusionController,
|
|
9
|
-
FusionDelete: () => FusionDelete,
|
|
10
|
-
FusionGet: () => FusionGet,
|
|
11
|
-
FusionPost: () => FusionPost,
|
|
12
|
-
FusionPut: () => FusionPut,
|
|
13
|
-
FusionRoute: () => FusionRoute,
|
|
14
|
-
getFusionMetadata: () => getFusionMetadata
|
|
15
|
-
});
|
|
16
|
-
|
|
17
|
-
// src/nest/decorators.ts
|
|
18
|
-
import "reflect-metadata";
|
|
19
|
-
var FUSION_METADATA_KEY = "fusion:routes";
|
|
20
|
-
function FusionController(prefix = "") {
|
|
21
|
-
return function(target) {
|
|
22
|
-
Reflect.defineMetadata("fusion:controller", { prefix }, target);
|
|
23
|
-
return target;
|
|
24
|
-
};
|
|
25
|
-
}
|
|
26
|
-
function FusionRoute(metadata) {
|
|
27
|
-
return function(target, propertyKey, descriptor) {
|
|
28
|
-
const routes = Reflect.getMetadata(FUSION_METADATA_KEY, target.constructor) || [];
|
|
29
|
-
routes.push({
|
|
30
|
-
...metadata,
|
|
31
|
-
handler: propertyKey
|
|
32
|
-
});
|
|
33
|
-
Reflect.defineMetadata(FUSION_METADATA_KEY, routes, target.constructor);
|
|
34
|
-
return descriptor;
|
|
35
|
-
};
|
|
36
|
-
}
|
|
37
|
-
function FusionGet(path = "") {
|
|
38
|
-
return FusionRoute({ method: "GET", path });
|
|
39
|
-
}
|
|
40
|
-
function FusionPost(path = "") {
|
|
41
|
-
return FusionRoute({ method: "POST", path });
|
|
42
|
-
}
|
|
43
|
-
function FusionPut(path = "") {
|
|
44
|
-
return FusionRoute({ method: "PUT", path });
|
|
45
|
-
}
|
|
46
|
-
function FusionDelete(path = "") {
|
|
47
|
-
return FusionRoute({ method: "DELETE", path });
|
|
48
|
-
}
|
|
49
|
-
function getFusionMetadata(controller) {
|
|
50
|
-
return {
|
|
51
|
-
controller: Reflect.getMetadata("fusion:controller", controller),
|
|
52
|
-
routes: Reflect.getMetadata(FUSION_METADATA_KEY, controller) || []
|
|
53
|
-
};
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
export {
|
|
57
|
-
FusionController,
|
|
58
|
-
FusionRoute,
|
|
59
|
-
FusionGet,
|
|
60
|
-
FusionPost,
|
|
61
|
-
FusionPut,
|
|
62
|
-
FusionDelete,
|
|
63
|
-
getFusionMetadata,
|
|
64
|
-
nest_exports
|
|
65
|
-
};
|
|
66
|
-
//# sourceMappingURL=chunk-WMHVXEYQ.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/nest/index.ts","../src/nest/decorators.ts"],"sourcesContent":["export * from './decorators';\r\n","// NestJS Integration - Decorators for wexts\r\n// These decorators add metadata for auto API client generation\r\n\r\nimport 'reflect-metadata';\r\n\r\nexport interface FusionRouteMetadata {\r\n method: 'GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH';\r\n path: string;\r\n responseType?: string;\r\n requestType?: string;\r\n}\r\n\r\nconst FUSION_METADATA_KEY = 'fusion:routes';\r\n\r\n/**\r\n * Mark a NestJS controller for Fusion codegen\r\n * Usage: @FusionController('users')\r\n */\r\nexport function FusionController(prefix: string = ''): ClassDecorator {\r\n return function (target: any) {\r\n Reflect.defineMetadata('fusion:controller', { prefix }, target);\r\n return target;\r\n };\r\n}\r\n\r\n/**\r\n * Mark a route for API client generation\r\n * Usage: @FusionRoute({ method: 'GET', path: '/:id' })\r\n */\r\nexport function FusionRoute(metadata: FusionRouteMetadata): MethodDecorator {\r\n return function (target: any, propertyKey: string | symbol, descriptor: PropertyDescriptor) {\r\n const routes = Reflect.getMetadata(FUSION_METADATA_KEY, target.constructor) || [];\r\n routes.push({\r\n ...metadata,\r\n handler: propertyKey,\r\n });\r\n Reflect.defineMetadata(FUSION_METADATA_KEY, routes, target.constructor);\r\n return descriptor;\r\n };\r\n}\r\n\r\n/**\r\n * Helper decorators for common HTTP methods\r\n */\r\nexport function FusionGet(path: string = ''): MethodDecorator {\r\n return FusionRoute({ method: 'GET', path });\r\n}\r\n\r\nexport function FusionPost(path: string = ''): MethodDecorator {\r\n return FusionRoute({ method: 'POST', path });\r\n}\r\n\r\nexport function FusionPut(path: string = ''): MethodDecorator {\r\n return FusionRoute({ method: 'PUT', path });\r\n}\r\n\r\nexport function FusionDelete(path: string = ''): MethodDecorator {\r\n return FusionRoute({ method: 'DELETE', path });\r\n}\r\n\r\n/**\r\n * Get Fusion metadata from a controller\r\n */\r\nexport function getFusionMetadata(controller: any): {\r\n controller: any;\r\n routes: any[];\r\n} {\r\n return {\r\n controller: Reflect.getMetadata('fusion:controller', controller),\r\n routes: Reflect.getMetadata(FUSION_METADATA_KEY, controller) || [],\r\n };\r\n}\r\n"],"mappings":";;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACGA,OAAO;AASP,IAAM,sBAAsB;AAMrB,SAAS,iBAAiB,SAAiB,IAAoB;AAClE,SAAO,SAAU,QAAa;AAC1B,YAAQ,eAAe,qBAAqB,EAAE,OAAO,GAAG,MAAM;AAC9D,WAAO;AAAA,EACX;AACJ;AAMO,SAAS,YAAY,UAAgD;AACxE,SAAO,SAAU,QAAa,aAA8B,YAAgC;AACxF,UAAM,SAAS,QAAQ,YAAY,qBAAqB,OAAO,WAAW,KAAK,CAAC;AAChF,WAAO,KAAK;AAAA,MACR,GAAG;AAAA,MACH,SAAS;AAAA,IACb,CAAC;AACD,YAAQ,eAAe,qBAAqB,QAAQ,OAAO,WAAW;AACtE,WAAO;AAAA,EACX;AACJ;AAKO,SAAS,UAAU,OAAe,IAAqB;AAC1D,SAAO,YAAY,EAAE,QAAQ,OAAO,KAAK,CAAC;AAC9C;AAEO,SAAS,WAAW,OAAe,IAAqB;AAC3D,SAAO,YAAY,EAAE,QAAQ,QAAQ,KAAK,CAAC;AAC/C;AAEO,SAAS,UAAU,OAAe,IAAqB;AAC1D,SAAO,YAAY,EAAE,QAAQ,OAAO,KAAK,CAAC;AAC9C;AAEO,SAAS,aAAa,OAAe,IAAqB;AAC7D,SAAO,YAAY,EAAE,QAAQ,UAAU,KAAK,CAAC;AACjD;AAKO,SAAS,kBAAkB,YAGhC;AACE,SAAO;AAAA,IACH,YAAY,QAAQ,YAAY,qBAAqB,UAAU;AAAA,IAC/D,QAAQ,QAAQ,YAAY,qBAAqB,UAAU,KAAK,CAAC;AAAA,EACrE;AACJ;","names":[]}
|
package/dist/chunk-XVKTIYHY.js
DELETED
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
|
-
|
|
3
|
-
var _chunkXE4OXN2Wjs = require('./chunk-XE4OXN2W.js');
|
|
4
|
-
|
|
5
|
-
// src/client/fetcher.ts
|
|
6
|
-
var FusionFetcher = class {
|
|
7
|
-
static {
|
|
8
|
-
_chunkXE4OXN2Wjs.__name.call(void 0, this, "FusionFetcher");
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
constructor(baseUrl = "/api") {
|
|
12
|
-
this.baseUrl = baseUrl;
|
|
13
|
-
}
|
|
14
|
-
async request(method, path, body) {
|
|
15
|
-
const headers = {
|
|
16
|
-
"Content-Type": "application/json"
|
|
17
|
-
};
|
|
18
|
-
if (typeof window !== "undefined") {
|
|
19
|
-
const token = localStorage.getItem("fusion_token");
|
|
20
|
-
if (token) headers["Authorization"] = `Bearer ${token}`;
|
|
21
|
-
}
|
|
22
|
-
const response = await fetch(`${this.baseUrl}${path}`, {
|
|
23
|
-
method,
|
|
24
|
-
headers,
|
|
25
|
-
body: body ? JSON.stringify(body) : void 0
|
|
26
|
-
});
|
|
27
|
-
if (!response.ok) {
|
|
28
|
-
throw new Error(`Fusion API Error: ${response.statusText}`);
|
|
29
|
-
}
|
|
30
|
-
return response.json();
|
|
31
|
-
}
|
|
32
|
-
get(path) {
|
|
33
|
-
return this.request("GET", path);
|
|
34
|
-
}
|
|
35
|
-
post(path, body) {
|
|
36
|
-
return this.request("POST", path, body);
|
|
37
|
-
}
|
|
38
|
-
put(path, body) {
|
|
39
|
-
return this.request("PUT", path, body);
|
|
40
|
-
}
|
|
41
|
-
delete(path) {
|
|
42
|
-
return this.request("DELETE", path);
|
|
43
|
-
}
|
|
44
|
-
};
|
|
45
|
-
var apiFetcher = new FusionFetcher();
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
exports.FusionFetcher = FusionFetcher; exports.apiFetcher = apiFetcher;
|
|
51
|
-
//# sourceMappingURL=chunk-XVKTIYHY.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["c:\\Users\\ziad\\Desktop\\wexts\\packages\\dist\\chunk-XVKTIYHY.js"],"names":[],"mappings":"AAAA;AACE;AACF,sDAA4B;AAC5B;AACA;AACA,IAAI,cAAc,EAAE,MAAM;AAC1B,EAAE,OAAO;AACT,IAAI,qCAAM,IAAK,EAAE,eAAe,CAAC;AACjC,EAAE;AACF,EAAE;AACF,EAAE,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE;AAChC,IAAI,IAAI,CAAC,QAAQ,EAAE,OAAO;AAC1B,EAAE;AACF,EAAE,MAAM,OAAO,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE;AACpC,IAAI,MAAM,QAAQ,EAAE;AACpB,MAAM,cAAc,EAAE;AACtB,IAAI,CAAC;AACL,IAAI,GAAG,CAAC,OAAO,OAAO,IAAI,WAAW,EAAE;AACvC,MAAM,MAAM,MAAM,EAAE,YAAY,CAAC,OAAO,CAAC,cAAc,CAAC;AACxD,MAAM,GAAG,CAAC,KAAK,EAAE,OAAO,CAAC,eAAe,EAAE,EAAE,CAAC,OAAO,EAAE,KAAK,CAAC,CAAA;AACA,IAAA;AACA,IAAA;AACA,MAAA;AACA,MAAA;AACA,MAAA;AACA,IAAA;AACA,IAAA;AACA,MAAA;AACA,IAAA;AACA,IAAA;AACA,EAAA;AACA,EAAA;AACA,IAAA;AACA,EAAA;AACA,EAAA;AACA,IAAA;AACA,EAAA;AACA,EAAA;AACA,IAAA;AACA,EAAA;AACA,EAAA;AACA,IAAA;AACA,EAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"C:\\Users\\ziad\\Desktop\\wexts\\packages\\dist\\chunk-XVKTIYHY.js","sourcesContent":[null]}
|
package/dist/codegen-MRZDLCYI.js
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
var _chunkFYGXL4V7js = require('./chunk-FYGXL4V7.js');
|
|
6
|
-
require('./chunk-QP2TMRLG.js');
|
|
7
|
-
require('./chunk-PZ5AY32C.js');
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
exports.ClientGenerator = _chunkFYGXL4V7js.ClientGenerator; exports.CodegenWatcher = _chunkFYGXL4V7js.CodegenWatcher; exports.NestJSParser = _chunkFYGXL4V7js.NestJSParser;
|
|
13
|
-
//# sourceMappingURL=codegen-MRZDLCYI.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["c:\\Users\\ziad\\Desktop\\wexts\\packages\\dist\\codegen-MRZDLCYI.js"],"names":[],"mappings":"AAAA;AACE;AACA;AACA;AACF,sDAA4B;AAC5B,+BAA4B;AAC5B,+BAA4B;AAC5B;AACE;AACA;AACA;AACF,2KAAC","file":"C:\\Users\\ziad\\Desktop\\wexts\\packages\\dist\\codegen-MRZDLCYI.js"}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
ClientGenerator,
|
|
3
|
-
CodegenWatcher,
|
|
4
|
-
NestJSParser
|
|
5
|
-
} from "./chunk-NNQFLD7O.mjs";
|
|
6
|
-
import "./chunk-NULGSZFE.mjs";
|
|
7
|
-
import "./chunk-J5LGTIGS.mjs";
|
|
8
|
-
export {
|
|
9
|
-
ClientGenerator,
|
|
10
|
-
CodegenWatcher,
|
|
11
|
-
NestJSParser
|
|
12
|
-
};
|
|
13
|
-
//# sourceMappingURL=codegen-UI5HTMXE.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
FusionDevServer,
|
|
3
|
-
ProcessRunner,
|
|
4
|
-
ProxyServer
|
|
5
|
-
} from "./chunk-HQKTXE7E.mjs";
|
|
6
|
-
import "./chunk-NULGSZFE.mjs";
|
|
7
|
-
import "./chunk-J5LGTIGS.mjs";
|
|
8
|
-
export {
|
|
9
|
-
FusionDevServer,
|
|
10
|
-
ProcessRunner,
|
|
11
|
-
ProxyServer
|
|
12
|
-
};
|
|
13
|
-
//# sourceMappingURL=dev-server-JKRVBWPY.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|