wexts 4.1.0 → 4.1.6

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 (113) hide show
  1. package/dist/chunk-27NEYQD2.mjs +222 -0
  2. package/dist/chunk-27NEYQD2.mjs.map +1 -0
  3. package/dist/{chunk-YBM3IJEA.mjs → chunk-5DBFN65W.mjs} +92 -3
  4. package/dist/chunk-5DBFN65W.mjs.map +1 -0
  5. package/dist/{chunk-7HNQWJWV.js → chunk-75HBI2XG.js} +3 -3
  6. package/dist/{chunk-7HNQWJWV.js.map → chunk-75HBI2XG.js.map} +1 -1
  7. package/dist/{chunk-JHOVXH3X.mjs → chunk-C2AG7Q3C.mjs} +2 -2
  8. package/dist/{chunk-7TLSPR65.mjs → chunk-DS5KVVWJ.mjs} +2 -2
  9. package/dist/{chunk-YN6WIWNQ.mjs → chunk-FUPLZMSR.mjs} +3 -3
  10. package/dist/{chunk-7QKLIVRF.js → chunk-HLT3IHJY.js} +92 -3
  11. package/dist/chunk-HLT3IHJY.js.map +1 -0
  12. package/dist/{chunk-7WULUGLH.mjs → chunk-L77ANWWT.mjs} +2 -2
  13. package/dist/{chunk-7WULUGLH.mjs.map → chunk-L77ANWWT.mjs.map} +1 -1
  14. package/dist/chunk-P3Q4I5FD.js +222 -0
  15. package/dist/chunk-P3Q4I5FD.js.map +1 -0
  16. package/dist/{chunk-342VRT25.mjs → chunk-VBIQGUDI.mjs} +6 -6
  17. package/dist/cli/index.js +32 -3
  18. package/dist/cli/index.js.map +1 -1
  19. package/dist/cli/index.mjs +35 -6
  20. package/dist/cli/index.mjs.map +1 -1
  21. package/dist/client/index.d.mts +23 -1
  22. package/dist/client/index.d.ts +23 -1
  23. package/dist/client/index.js +183 -9
  24. package/dist/client/index.js.map +1 -1
  25. package/dist/client/index.mjs +160 -7
  26. package/dist/client/index.mjs.map +1 -1
  27. package/dist/codegen/index.d.mts +2 -2
  28. package/dist/codegen/index.d.ts +2 -2
  29. package/dist/codegen/index.js +3 -3
  30. package/dist/codegen/index.mjs +4 -4
  31. package/dist/decorators-BiQtOHuF.d.ts +60 -0
  32. package/dist/decorators-vBopODtr.d.mts +60 -0
  33. package/dist/dev-server/index.mjs +3 -3
  34. package/dist/errors-D545UvXf.d.mts +37 -0
  35. package/dist/errors-D545UvXf.d.ts +37 -0
  36. package/dist/{index-7QeQEf37.d.ts → index-CJKs4wtN.d.ts} +1 -1
  37. package/dist/index-CUR6CnLk.d.ts +27 -0
  38. package/dist/{index-8nzxy0NN.d.mts → index-h66Vq9dK.d.mts} +1 -1
  39. package/dist/index-tqmYsTUn.d.mts +27 -0
  40. package/dist/index.d.mts +82 -87
  41. package/dist/index.d.ts +82 -87
  42. package/dist/index.js +140 -20
  43. package/dist/index.js.map +1 -1
  44. package/dist/index.mjs +142 -22
  45. package/dist/index.mjs.map +1 -1
  46. package/dist/nest/index.d.mts +2 -3
  47. package/dist/nest/index.d.ts +2 -3
  48. package/dist/nest/index.js +2 -4
  49. package/dist/nest/index.js.map +1 -1
  50. package/dist/nest/index.mjs +3 -5
  51. package/dist/next/index.js +0 -7
  52. package/dist/next/index.js.map +1 -1
  53. package/dist/next/index.mjs.map +1 -1
  54. package/dist/rpc/index.d.mts +32 -2
  55. package/dist/rpc/index.d.ts +32 -2
  56. package/dist/rpc/index.js +18 -22
  57. package/dist/rpc/index.js.map +1 -1
  58. package/dist/rpc/index.mjs +0 -22
  59. package/dist/runtime/index.d.mts +1 -1
  60. package/dist/runtime/index.d.ts +1 -1
  61. package/dist/runtime/index.js +5 -211
  62. package/dist/runtime/index.js.map +1 -1
  63. package/dist/runtime/index.mjs +7 -213
  64. package/dist/runtime/index.mjs.map +1 -1
  65. package/dist/server/index.d.mts +7 -0
  66. package/dist/server/index.d.ts +7 -0
  67. package/dist/server/index.js +58 -0
  68. package/dist/server/index.js.map +1 -0
  69. package/dist/server/index.mjs +58 -0
  70. package/dist/types/index.js +18 -1
  71. package/dist/types/index.js.map +1 -1
  72. package/dist/types/index.mjs +0 -2
  73. package/dist/{types-7d_fC-C3.d.ts → types-CQ_aexOX.d.mts} +1 -1
  74. package/dist/{types-7d_fC-C3.d.mts → types-CQ_aexOX.d.ts} +1 -1
  75. package/dist/vercel-builder/index.mjs +1 -1
  76. package/package.json +6 -1
  77. package/templates/nestjs-api/README.md +1 -1
  78. package/dist/chunk-2KAQYLVN.js +0 -1
  79. package/dist/chunk-2KAQYLVN.js.map +0 -1
  80. package/dist/chunk-7QKLIVRF.js.map +0 -1
  81. package/dist/chunk-7SSCNCTW.mjs +0 -137
  82. package/dist/chunk-7SSCNCTW.mjs.map +0 -1
  83. package/dist/chunk-BG56B4DE.js +0 -106
  84. package/dist/chunk-BG56B4DE.js.map +0 -1
  85. package/dist/chunk-CLM5PNSG.mjs +0 -496
  86. package/dist/chunk-CLM5PNSG.mjs.map +0 -1
  87. package/dist/chunk-DNLGCKTT.js +0 -31
  88. package/dist/chunk-DNLGCKTT.js.map +0 -1
  89. package/dist/chunk-MXINIFPC.js +0 -105
  90. package/dist/chunk-MXINIFPC.js.map +0 -1
  91. package/dist/chunk-O4II6N34.js +0 -137
  92. package/dist/chunk-O4II6N34.js.map +0 -1
  93. package/dist/chunk-SE32ZPOZ.js +0 -496
  94. package/dist/chunk-SE32ZPOZ.js.map +0 -1
  95. package/dist/chunk-UAL54DVV.mjs +0 -106
  96. package/dist/chunk-UAL54DVV.mjs.map +0 -1
  97. package/dist/chunk-WU6FW77M.mjs +0 -105
  98. package/dist/chunk-WU6FW77M.mjs.map +0 -1
  99. package/dist/chunk-YBM3IJEA.mjs.map +0 -1
  100. package/dist/chunk-YSLEF5C5.mjs +0 -1
  101. package/dist/chunk-ZX7QIN24.mjs +0 -31
  102. package/dist/chunk-ZX7QIN24.mjs.map +0 -1
  103. package/dist/decorators-BT1FFqN0.d.mts +0 -29
  104. package/dist/decorators-DvS58PqC.d.ts +0 -29
  105. package/dist/index-Co5ZsLqq.d.ts +0 -58
  106. package/dist/index-D94W1__r.d.mts +0 -58
  107. package/dist/index-DQmyVp6F.d.mts +0 -27
  108. package/dist/index-KL_1BrQb.d.ts +0 -27
  109. /package/dist/{chunk-JHOVXH3X.mjs.map → chunk-C2AG7Q3C.mjs.map} +0 -0
  110. /package/dist/{chunk-7TLSPR65.mjs.map → chunk-DS5KVVWJ.mjs.map} +0 -0
  111. /package/dist/{chunk-YN6WIWNQ.mjs.map → chunk-FUPLZMSR.mjs.map} +0 -0
  112. /package/dist/{chunk-342VRT25.mjs.map → chunk-VBIQGUDI.mjs.map} +0 -0
  113. /package/dist/{chunk-YSLEF5C5.mjs.map → server/index.mjs.map} +0 -0
@@ -1,105 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } async function _asyncNullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return await rhsFn(); } } 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; }
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.status} ${response.statusText}`);
29
- }
30
- if (response.status === 204) {
31
- return void 0;
32
- }
33
- return response.json();
34
- }
35
- get(path) {
36
- return this.request("GET", path);
37
- }
38
- post(path, body) {
39
- return this.request("POST", path, body);
40
- }
41
- put(path, body) {
42
- return this.request("PUT", path, body);
43
- }
44
- delete(path) {
45
- return this.request("DELETE", path);
46
- }
47
- };
48
- var apiFetcher = new FusionFetcher();
49
- function createWextsRpcClient(manifest, options = {}) {
50
- const services = new Set((_nullishCoalesce(_optionalChain([manifest, 'optionalAccess', _ => _.services]), () => ( []))).map((service) => service.name));
51
- const methodMap = /* @__PURE__ */ new Map();
52
- for (const service of _nullishCoalesce(_optionalChain([manifest, 'optionalAccess', _2 => _2.services]), () => ( []))) {
53
- methodMap.set(service.name, new Set(service.methods.map((method) => method.name)));
54
- }
55
- const createServiceProxy = /* @__PURE__ */ _chunkXE4OXN2Wjs.__name.call(void 0, (serviceName) => new Proxy({}, {
56
- get(_target, methodName) {
57
- if (typeof methodName !== "string") return void 0;
58
- if (methodName === "then") return void 0;
59
- const knownMethods = methodMap.get(serviceName);
60
- if (knownMethods && !knownMethods.has(methodName)) {
61
- throw new Error(`Wexts RPC method not found: ${serviceName}.${methodName}`);
62
- }
63
- return (...args) => invokeRpc(serviceName, methodName, args, options);
64
- }
65
- }), "createServiceProxy");
66
- return new Proxy({}, {
67
- get(_target, serviceName) {
68
- if (typeof serviceName !== "string") return void 0;
69
- if (serviceName === "then") return void 0;
70
- if (services.size > 0 && !services.has(serviceName)) {
71
- throw new Error(`Wexts RPC service not found: ${serviceName}`);
72
- }
73
- return createServiceProxy(serviceName);
74
- }
75
- });
76
- }
77
- _chunkXE4OXN2Wjs.__name.call(void 0, createWextsRpcClient, "createWextsRpcClient");
78
- async function invokeRpc(serviceName, methodName, args, options) {
79
- const fetchImpl = _nullishCoalesce(options.fetch, () => ( fetch));
80
- const baseUrl = _nullishCoalesce(options.baseUrl, () => ( "/rpc"));
81
- const headers = {
82
- "Content-Type": "application/json",
83
- ...await _asyncNullishCoalesce(await _optionalChain([options, 'access', _3 => _3.getHeaders, 'optionalCall', _4 => _4()]), async () => ( {}))
84
- };
85
- const response = await fetchImpl(`${baseUrl}/${encodeURIComponent(serviceName)}/${encodeURIComponent(methodName)}`, {
86
- method: "POST",
87
- headers,
88
- body: JSON.stringify({
89
- args
90
- })
91
- });
92
- if (!response.ok) {
93
- throw new Error(`Wexts RPC Error: ${response.status} ${response.statusText}`);
94
- }
95
- const payload = await response.json();
96
- return payload.data;
97
- }
98
- _chunkXE4OXN2Wjs.__name.call(void 0, invokeRpc, "invokeRpc");
99
-
100
-
101
-
102
-
103
-
104
- exports.FusionFetcher = FusionFetcher; exports.apiFetcher = apiFetcher; exports.createWextsRpcClient = createWextsRpcClient;
105
- //# sourceMappingURL=chunk-MXINIFPC.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Volumes/Projects/wexts/packages/dist/chunk-MXINIFPC.js","../src/client/fetcher.ts"],"names":["FusionFetcher","baseUrl","request","method","path","body","headers","window","token","localStorage","getItem","undefined","service","Map","serviceName","methodName","createWextsRpcClient","options","fetch","encodeURIComponent","args","response","data","invokeRpc"],"mappings":"AAAA;AACE;AACF,sDAA4B;AAC5B;AACA;ACFO,IAAMA,cAAAA,EAAN,MAAMA;ADIb,ECJA,OAAaA;ADKb,IAAI,qCAAM,IAAK,EAAE,eAAe,CAAC;AACjC,EAAE;AACF,ECNYC;ADOZ,ECLI,WAAA,CAAYA,QAAAA,EAAkB,MAAA,EAAQ;AAClC,IAAA,IAAA,CAAKA,QAAAA,EAAUA,OAAAA;ADMvB,ECLI;ADMJ,ECJI,MAAcC,OAAAA,CAAWC,MAAAA,EAAgBC,IAAAA,EAAcC,IAAAA,EAAwB;AAC3E,IAAA,MAAMC,QAAAA,EAAkC;ADKhD,MCJY,cAAA,EAAgB;ADK5B,ICJQ,CAAA;AAGA,IAAA,GAAA,CAAI,OAAOC,OAAAA,IAAW,WAAA,EAAa;AAC/B,MAAA,MAAMC,MAAAA,EAAQC,YAAAA,CAAaC,OAAAA,CAAQ,cAAA,CAAA;AACnC,MAAA,GAAA,CAAIF,KAAAA,EAAOF,OAAAA,CAAQ,eAAA,EAAA,EAAmB,CAAA,OAAA,EAAUE,KAAAA,CAAAA,CAAAA;AACpD,IAAA;AAEmD,IAAA;AAC/CL,MAAAA;AACAG,MAAAA;AACoCK,MAAAA;AACxC,IAAA;AAEkB,IAAA;AACsC,MAAA;AACxD,IAAA;AAE6B,IAAA;AAClBA,MAAAA;AACX,IAAA;AAEoB,IAAA;AACxB,EAAA;AAEqB,EAAA;AAAgCP,IAAAA;AAAO,EAAA;AAC3B,EAAA;AAAuCC,IAAAA;AAAO,EAAA;AAC/C,EAAA;AAAsCA,IAAAA;AAAO,EAAA;AACrD,EAAA;AAAmCD,IAAAA;AAAO,EAAA;AACtE;AAE8BJ;AAYS;AAEsBY,EAAAA;AACnCC,EAAAA;AAE0B,EAAA;AACY,IAAA;AAC5D,EAAA;AAE4BC,EAAAA;AACD,IAAA;AACwBH,MAAAA;AACTA,MAAAA;AAECG,MAAAA;AACgB,MAAA;AACAA,QAAAA;AACnD,MAAA;AAEsDC,MAAAA;AAC1D,IAAA;AAXuB,EAAA;AAcN,EAAA;AACO,IAAA;AACwBJ,MAAAA;AACTA,MAAAA;AACkB,MAAA;AACDG,QAAAA;AACpD,MAAA;AAE0BA,MAAAA;AAC9B,IAAA;AACJ,EAAA;AACJ;AApCgBE;AA0CZC;AAEmCC,EAAAA;AACA,EAAA;AACnB,EAAA;AACI,IAAA;AACqB,IAAA;AACzC,EAAA;AAC+CC,EAAAA;AACnC,IAAA;AACRb,IAAAA;AACqB,IAAA;AAAEc,MAAAA;AAAK,IAAA;AAChC,EAAA;AAEkB,EAAA;AACyCC,IAAAA;AAC3D,EAAA;AAEmC,EAAA;AACpBC,EAAAA;AACnB;AAxBeC;ADO6C;AACA;AACA;AACA;AACA;AACA","file":"/Volumes/Projects/wexts/packages/dist/chunk-MXINIFPC.js","sourcesContent":[null,"import type { RpcManifest, RpcInvocationResponse } from '../rpc/types';\n\nexport class FusionFetcher {\n private baseUrl: string;\n\n constructor(baseUrl: string = '/api') {\n this.baseUrl = baseUrl;\n }\n\n private async request<T>(method: string, path: string, body?: any): Promise<T> {\n const headers: Record<string, string> = {\n 'Content-Type': 'application/json',\n };\n\n // Automatically attach Fusion Token if present\n if (typeof window !== 'undefined') {\n const token = localStorage.getItem('fusion_token');\n if (token) headers['Authorization'] = `Bearer ${token}`;\n }\n\n const response = await fetch(`${this.baseUrl}${path}`, {\n method,\n headers,\n body: body ? JSON.stringify(body) : undefined,\n });\n\n if (!response.ok) {\n throw new Error(`Fusion API Error: ${response.status} ${response.statusText}`);\n }\n\n if (response.status === 204) {\n return undefined as T;\n }\n\n return response.json();\n }\n\n get<T>(path: string) { return this.request<T>('GET', path); }\n post<T>(path: string, body: any) { return this.request<T>('POST', path, body); }\n put<T>(path: string, body: any) { return this.request<T>('PUT', path, body); }\n delete<T>(path: string) { return this.request<T>('DELETE', path); }\n}\n\nexport const apiFetcher = new FusionFetcher();\n\nexport interface WextsRpcClientOptions {\n baseUrl?: string;\n fetch?: typeof fetch;\n getHeaders?: () => Record<string, string> | Promise<Record<string, string>>;\n}\n\nexport type WextsRpcClient = Record<string, Record<string, (...args: unknown[]) => Promise<unknown>>>;\n\nexport function createWextsRpcClient(\n manifest: Pick<RpcManifest, 'services'> | undefined,\n options: WextsRpcClientOptions = {}\n): WextsRpcClient {\n const services = new Set((manifest?.services ?? []).map((service) => service.name));\n const methodMap = new Map<string, Set<string>>();\n\n for (const service of manifest?.services ?? []) {\n methodMap.set(service.name, new Set(service.methods.map((method) => method.name)));\n }\n\n const createServiceProxy = (serviceName: string) => new Proxy({}, {\n get(_target, methodName) {\n if (typeof methodName !== 'string') return undefined;\n if (methodName === 'then') return undefined;\n\n const knownMethods = methodMap.get(serviceName);\n if (knownMethods && !knownMethods.has(methodName)) {\n throw new Error(`Wexts RPC method not found: ${serviceName}.${methodName}`);\n }\n\n return (...args: unknown[]) => invokeRpc(serviceName, methodName, args, options);\n },\n }) as Record<string, (...args: unknown[]) => Promise<unknown>>;\n\n return new Proxy({}, {\n get(_target, serviceName) {\n if (typeof serviceName !== 'string') return undefined;\n if (serviceName === 'then') return undefined;\n if (services.size > 0 && !services.has(serviceName)) {\n throw new Error(`Wexts RPC service not found: ${serviceName}`);\n }\n\n return createServiceProxy(serviceName);\n },\n }) as WextsRpcClient;\n}\n\nasync function invokeRpc(\n serviceName: string,\n methodName: string,\n args: unknown[],\n options: WextsRpcClientOptions\n): Promise<unknown> {\n const fetchImpl = options.fetch ?? fetch;\n const baseUrl = options.baseUrl ?? '/rpc';\n const headers = {\n 'Content-Type': 'application/json',\n ...(await options.getHeaders?.() ?? {}),\n };\n const response = await fetchImpl(`${baseUrl}/${encodeURIComponent(serviceName)}/${encodeURIComponent(methodName)}`, {\n method: 'POST',\n headers,\n body: JSON.stringify({ args }),\n });\n\n if (!response.ok) {\n throw new Error(`Wexts RPC Error: ${response.status} ${response.statusText}`);\n }\n\n const payload = await response.json() as RpcInvocationResponse;\n return payload.data;\n}\n"]}
@@ -1,137 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } async function _asyncNullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return await rhsFn(); } } 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; }
2
-
3
- var _chunkAVMQJWYDjs = require('./chunk-AVMQJWYD.js');
4
-
5
-
6
- var _chunkXE4OXN2Wjs = require('./chunk-XE4OXN2W.js');
7
-
8
- // src/client/fetcher.ts
9
- var FusionFetcher = class {
10
- static {
11
- _chunkXE4OXN2Wjs.__name.call(void 0, this, "FusionFetcher");
12
- }
13
-
14
- constructor(baseUrl = "/api") {
15
- this.baseUrl = baseUrl;
16
- }
17
- async request(method, path, body) {
18
- const headers = {
19
- "Content-Type": "application/json"
20
- };
21
- if (typeof window !== "undefined") {
22
- const token = localStorage.getItem("fusion_token");
23
- if (token) headers["Authorization"] = `Bearer ${token}`;
24
- }
25
- const response = await fetch(`${this.baseUrl}${path}`, {
26
- method,
27
- headers,
28
- body: body ? JSON.stringify(body) : void 0
29
- });
30
- if (!response.ok) {
31
- throw new (0, _chunkAVMQJWYDjs.WextsRpcError)({
32
- code: "WEXTS_API_REQUEST_FAILED",
33
- message: `Fusion API Error: ${response.status} ${response.statusText}`,
34
- suggestedFix: "Check the API route, server logs, and authentication headers.",
35
- docsSlug: "troubleshooting"
36
- });
37
- }
38
- if (response.status === 204) {
39
- return void 0;
40
- }
41
- return response.json();
42
- }
43
- get(path) {
44
- return this.request("GET", path);
45
- }
46
- post(path, body) {
47
- return this.request("POST", path, body);
48
- }
49
- put(path, body) {
50
- return this.request("PUT", path, body);
51
- }
52
- delete(path) {
53
- return this.request("DELETE", path);
54
- }
55
- };
56
- var apiFetcher = new FusionFetcher();
57
- function createWextsRpcClient(manifest, options = {}) {
58
- const hasManifest = Boolean(manifest);
59
- const services = new Set((_nullishCoalesce(_optionalChain([manifest, 'optionalAccess', _ => _.services]), () => ( []))).map((service) => service.name));
60
- const methodMap = /* @__PURE__ */ new Map();
61
- for (const service of _nullishCoalesce(_optionalChain([manifest, 'optionalAccess', _2 => _2.services]), () => ( []))) {
62
- methodMap.set(service.name, new Set(service.methods.map((method) => method.name)));
63
- }
64
- const createServiceProxy = /* @__PURE__ */ _chunkXE4OXN2Wjs.__name.call(void 0, (serviceName) => new Proxy({}, {
65
- get(_target, methodName) {
66
- if (typeof methodName !== "string") return void 0;
67
- if (methodName === "then") return void 0;
68
- const knownMethods = methodMap.get(serviceName);
69
- if (knownMethods && !knownMethods.has(methodName)) {
70
- throw new (0, _chunkAVMQJWYDjs.WextsRpcError)({
71
- code: "WEXTS_RPC_METHOD_NOT_FOUND",
72
- message: `Wexts RPC method not found: ${serviceName}.${methodName}`,
73
- suggestedFix: "Run `wexts generate` and verify the method is decorated with @RpcMethod().",
74
- docsSlug: "rpc"
75
- });
76
- }
77
- return (...args) => invokeRpc(serviceName, methodName, args, options);
78
- }
79
- }), "createServiceProxy");
80
- return new Proxy({}, {
81
- get(_target, serviceName) {
82
- if (typeof serviceName !== "string") return void 0;
83
- if (serviceName === "then") return void 0;
84
- if (!hasManifest) {
85
- throw new (0, _chunkAVMQJWYDjs.WextsRpcError)({
86
- code: "WEXTS_RPC_MANIFEST_MISSING",
87
- message: "Wexts RPC manifest is missing.",
88
- suggestedFix: "Run `wexts generate` and import the generated client/provider instead of creating an empty client.",
89
- docsSlug: "codegen"
90
- });
91
- }
92
- if (!services.has(serviceName)) {
93
- throw new (0, _chunkAVMQJWYDjs.WextsRpcError)({
94
- code: "WEXTS_RPC_SERVICE_NOT_FOUND",
95
- message: `Wexts RPC service not found: ${serviceName}`,
96
- suggestedFix: "Run `wexts generate` and verify the service is decorated with @RpcService().",
97
- docsSlug: "rpc"
98
- });
99
- }
100
- return createServiceProxy(serviceName);
101
- }
102
- });
103
- }
104
- _chunkXE4OXN2Wjs.__name.call(void 0, createWextsRpcClient, "createWextsRpcClient");
105
- async function invokeRpc(serviceName, methodName, args, options) {
106
- const fetchImpl = _nullishCoalesce(options.fetch, () => ( fetch));
107
- const baseUrl = _nullishCoalesce(options.baseUrl, () => ( "/rpc"));
108
- const headers = {
109
- "Content-Type": "application/json",
110
- ...await _asyncNullishCoalesce(await _optionalChain([options, 'access', _3 => _3.getHeaders, 'optionalCall', _4 => _4()]), async () => ( {}))
111
- };
112
- const response = await fetchImpl(`${baseUrl}/${encodeURIComponent(serviceName)}/${encodeURIComponent(methodName)}`, {
113
- method: "POST",
114
- headers,
115
- body: JSON.stringify({
116
- args
117
- })
118
- });
119
- if (!response.ok) {
120
- throw new (0, _chunkAVMQJWYDjs.WextsRpcError)({
121
- code: "WEXTS_RPC_REQUEST_FAILED",
122
- message: `Wexts RPC Error: ${response.status} ${response.statusText}`,
123
- suggestedFix: "Check the RPC route, service policy, and server logs.",
124
- docsSlug: "troubleshooting"
125
- });
126
- }
127
- const payload = await response.json();
128
- return payload.data;
129
- }
130
- _chunkXE4OXN2Wjs.__name.call(void 0, invokeRpc, "invokeRpc");
131
-
132
-
133
-
134
-
135
-
136
- exports.FusionFetcher = FusionFetcher; exports.apiFetcher = apiFetcher; exports.createWextsRpcClient = createWextsRpcClient;
137
- //# sourceMappingURL=chunk-O4II6N34.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Volumes/Projects/wexts/packages/dist/chunk-O4II6N34.js","../src/client/fetcher.ts"],"names":["FusionFetcher","baseUrl","request","method","path","body","headers","window","token","localStorage","getItem","undefined","response","manifest","service","Map","serviceName","methodName","createWextsRpcClient","options","fetch","encodeURIComponent","args","data","invokeRpc"],"mappings":"AAAA;AACE;AACF,sDAA4B;AAC5B;AACE;AACF,sDAA4B;AAC5B;AACA;ACJO,IAAMA,cAAAA,EAAN,MAAMA;ADMb,ECRA,OAEaA;ADOb,IAAI,qCAAM,IAAK,EAAE,eAAe,CAAC;AACjC,EAAE;AACF,ECRYC;ADSZ,ECPI,WAAA,CAAYA,QAAAA,EAAkB,MAAA,EAAQ;AAClC,IAAA,IAAA,CAAKA,QAAAA,EAAUA,OAAAA;ADQvB,ECPI;ADQJ,ECNI,MAAcC,OAAAA,CAAWC,MAAAA,EAAgBC,IAAAA,EAAcC,IAAAA,EAAwB;AAC3E,IAAA,MAAMC,QAAAA,EAAkC;ADOhD,MCNY,cAAA,EAAgB;ADO5B,ICNQ,CAAA;AAGA,IAAA,GAAA,CAAI,OAAOC,OAAAA,IAAW,WAAA,EAAa;AAC/B,MAAA,MAAMC,MAAAA,EAAQC,YAAAA,CAAaC,OAAAA,CAAQ,cAAA,CAAA;AACnC,MAAA,GAAA,CAAIF,KAAAA,EAAOF,OAAAA,CAAQ,eAAA,EAAA,EAAmB,CAAA,OAAA,EAAUE,KAAAA,CAAAA,CAAAA;AACpD,IAAA;AAEmD,IAAA;AAC/CL,MAAAA;AACAG,MAAAA;AACoCK,MAAAA;AACxC,IAAA;AAEkB,IAAA;AACU,MAAA;AACd,QAAA;AAC2CC,QAAAA;AACnC,QAAA;AACJ,QAAA;AACd,MAAA;AACJ,IAAA;AAE6B,IAAA;AAClBD,MAAAA;AACX,IAAA;AAEoB,IAAA;AACxB,EAAA;AAEqB,EAAA;AAAgCP,IAAAA;AAAO,EAAA;AAC3B,EAAA;AAAuCC,IAAAA;AAAO,EAAA;AAC/C,EAAA;AAAsCA,IAAAA;AAAO,EAAA;AACrD,EAAA;AAAmCD,IAAAA;AAAO,EAAA;AACtE;AAE8BJ;AAYS;AAEPa,EAAAA;AAC6BC,EAAAA;AACnCC,EAAAA;AAE0B,EAAA;AACY,IAAA;AAC5D,EAAA;AAE4BC,EAAAA;AACD,IAAA;AACwBL,MAAAA;AACTA,MAAAA;AAECK,MAAAA;AACgB,MAAA;AACvB,QAAA;AACd,UAAA;AACkCA,UAAAA;AAC1B,UAAA;AACJ,UAAA;AACd,QAAA;AACJ,MAAA;AAEsDC,MAAAA;AAC1D,IAAA;AAhBuB,EAAA;AAmBN,EAAA;AACO,IAAA;AACwBN,MAAAA;AACTA,MAAAA;AACjB,MAAA;AACU,QAAA;AACd,UAAA;AACG,UAAA;AACK,UAAA;AACJ,UAAA;AACd,QAAA;AACJ,MAAA;AACgC,MAAA;AACJ,QAAA;AACd,UAAA;AACmCK,UAAAA;AAC3B,UAAA;AACJ,UAAA;AACd,QAAA;AACJ,MAAA;AAE0BA,MAAAA;AAC9B,IAAA;AACJ,EAAA;AACJ;AAvDgBE;AA6DZC;AAEmCC,EAAAA;AACA,EAAA;AACnB,EAAA;AACI,IAAA;AACqB,IAAA;AACzC,EAAA;AAC+CC,EAAAA;AACnC,IAAA;AACRf,IAAAA;AACqB,IAAA;AAAEgB,MAAAA;AAAK,IAAA;AAChC,EAAA;AAEkB,EAAA;AACU,IAAA;AACd,MAAA;AAC0CV,MAAAA;AAClC,MAAA;AACJ,MAAA;AACd,IAAA;AACJ,EAAA;AAEmC,EAAA;AACpBW,EAAAA;AACnB;AA7BeC;ADc6C;AACA;AACA;AACA;AACA;AACA","file":"/Volumes/Projects/wexts/packages/dist/chunk-O4II6N34.js","sourcesContent":[null,"import type { RpcManifest, RpcInvocationResponse } from '../rpc/types';\nimport { WextsRpcError } from '../errors';\n\nexport class FusionFetcher {\n private baseUrl: string;\n\n constructor(baseUrl: string = '/api') {\n this.baseUrl = baseUrl;\n }\n\n private async request<T>(method: string, path: string, body?: any): Promise<T> {\n const headers: Record<string, string> = {\n 'Content-Type': 'application/json',\n };\n\n // Automatically attach Fusion Token if present\n if (typeof window !== 'undefined') {\n const token = localStorage.getItem('fusion_token');\n if (token) headers['Authorization'] = `Bearer ${token}`;\n }\n\n const response = await fetch(`${this.baseUrl}${path}`, {\n method,\n headers,\n body: body ? JSON.stringify(body) : undefined,\n });\n\n if (!response.ok) {\n throw new WextsRpcError({\n code: 'WEXTS_API_REQUEST_FAILED',\n message: `Fusion API Error: ${response.status} ${response.statusText}`,\n suggestedFix: 'Check the API route, server logs, and authentication headers.',\n docsSlug: 'troubleshooting',\n });\n }\n\n if (response.status === 204) {\n return undefined as T;\n }\n\n return response.json();\n }\n\n get<T>(path: string) { return this.request<T>('GET', path); }\n post<T>(path: string, body: any) { return this.request<T>('POST', path, body); }\n put<T>(path: string, body: any) { return this.request<T>('PUT', path, body); }\n delete<T>(path: string) { return this.request<T>('DELETE', path); }\n}\n\nexport const apiFetcher = new FusionFetcher();\n\nexport interface WextsRpcClientOptions {\n baseUrl?: string;\n fetch?: typeof fetch;\n getHeaders?: () => Record<string, string> | Promise<Record<string, string>>;\n}\n\nexport type WextsRpcClient = Record<string, Record<string, (...args: unknown[]) => Promise<unknown>>>;\n\nexport function createWextsRpcClient(\n manifest: Pick<RpcManifest, 'services'> | undefined,\n options: WextsRpcClientOptions = {}\n): WextsRpcClient {\n const hasManifest = Boolean(manifest);\n const services = new Set((manifest?.services ?? []).map((service) => service.name));\n const methodMap = new Map<string, Set<string>>();\n\n for (const service of manifest?.services ?? []) {\n methodMap.set(service.name, new Set(service.methods.map((method) => method.name)));\n }\n\n const createServiceProxy = (serviceName: string) => new Proxy({}, {\n get(_target, methodName) {\n if (typeof methodName !== 'string') return undefined;\n if (methodName === 'then') return undefined;\n\n const knownMethods = methodMap.get(serviceName);\n if (knownMethods && !knownMethods.has(methodName)) {\n throw new WextsRpcError({\n code: 'WEXTS_RPC_METHOD_NOT_FOUND',\n message: `Wexts RPC method not found: ${serviceName}.${methodName}`,\n suggestedFix: 'Run `wexts generate` and verify the method is decorated with @RpcMethod().',\n docsSlug: 'rpc',\n });\n }\n\n return (...args: unknown[]) => invokeRpc(serviceName, methodName, args, options);\n },\n }) as Record<string, (...args: unknown[]) => Promise<unknown>>;\n\n return new Proxy({}, {\n get(_target, serviceName) {\n if (typeof serviceName !== 'string') return undefined;\n if (serviceName === 'then') return undefined;\n if (!hasManifest) {\n throw new WextsRpcError({\n code: 'WEXTS_RPC_MANIFEST_MISSING',\n message: 'Wexts RPC manifest is missing.',\n suggestedFix: 'Run `wexts generate` and import the generated client/provider instead of creating an empty client.',\n docsSlug: 'codegen',\n });\n }\n if (!services.has(serviceName)) {\n throw new WextsRpcError({\n code: 'WEXTS_RPC_SERVICE_NOT_FOUND',\n message: `Wexts RPC service not found: ${serviceName}`,\n suggestedFix: 'Run `wexts generate` and verify the service is decorated with @RpcService().',\n docsSlug: 'rpc',\n });\n }\n\n return createServiceProxy(serviceName);\n },\n }) as WextsRpcClient;\n}\n\nasync function invokeRpc(\n serviceName: string,\n methodName: string,\n args: unknown[],\n options: WextsRpcClientOptions\n): Promise<unknown> {\n const fetchImpl = options.fetch ?? fetch;\n const baseUrl = options.baseUrl ?? '/rpc';\n const headers = {\n 'Content-Type': 'application/json',\n ...(await options.getHeaders?.() ?? {}),\n };\n const response = await fetchImpl(`${baseUrl}/${encodeURIComponent(serviceName)}/${encodeURIComponent(methodName)}`, {\n method: 'POST',\n headers,\n body: JSON.stringify({ args }),\n });\n\n if (!response.ok) {\n throw new WextsRpcError({\n code: 'WEXTS_RPC_REQUEST_FAILED',\n message: `Wexts RPC Error: ${response.status} ${response.statusText}`,\n suggestedFix: 'Check the RPC route, service policy, and server logs.',\n docsSlug: 'troubleshooting',\n });\n }\n\n const payload = await response.json() as RpcInvocationResponse;\n return payload.data;\n}\n"]}