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
package/dist/index.js CHANGED
@@ -1,37 +1,28 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } var _class;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } 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; } var _class;
2
2
 
3
- var _chunk2LJVUMXWjs = require('./chunk-2LJVUMXW.js');
4
-
5
-
6
-
7
- var _chunkO4II6N34js = require('./chunk-O4II6N34.js');
8
-
9
-
10
- var _chunkBG56B4DEjs = require('./chunk-BG56B4DE.js');
3
+ var _chunkHLT3IHJYjs = require('./chunk-HLT3IHJY.js');
11
4
 
12
5
 
13
- var _chunkDNLGCKTTjs = require('./chunk-DNLGCKTT.js');
14
- require('./chunk-7QKLIVRF.js');
15
- require('./chunk-2KAQYLVN.js');
16
6
 
17
7
 
8
+ var _chunk75HBI2XGjs = require('./chunk-75HBI2XG.js');
18
9
 
19
10
 
20
- var _chunk7HNQWJWVjs = require('./chunk-7HNQWJWV.js');
21
11
 
22
12
 
23
13
 
24
14
 
25
15
 
26
- var _chunkWCKSKU3Cjs = require('./chunk-WCKSKU3C.js');
16
+ var _chunkAVMQJWYDjs = require('./chunk-AVMQJWYD.js');
27
17
 
28
18
 
19
+ var _chunk2LJVUMXWjs = require('./chunk-2LJVUMXW.js');
29
20
 
30
21
 
31
22
 
32
23
 
33
24
 
34
- var _chunkAVMQJWYDjs = require('./chunk-AVMQJWYD.js');
25
+ var _chunkWCKSKU3Cjs = require('./chunk-WCKSKU3C.js');
35
26
 
36
27
 
37
28
 
@@ -43,7 +34,7 @@ _chunkXE4OXN2Wjs.__export.call(void 0, core_exports, {
43
34
  APIError: () => APIError,
44
35
  ConfigError: () => ConfigError,
45
36
  ConfigLoader: () => ConfigLoader,
46
- FileSystem: () => _chunk7HNQWJWVjs.FileSystem,
37
+ FileSystem: () => _chunk75HBI2XGjs.FileSystem,
47
38
  FusionError: () => FusionError,
48
39
  LogLevel: () => _chunkWCKSKU3Cjs.LogLevel,
49
40
  Logger: () => _chunkWCKSKU3Cjs.Logger,
@@ -51,7 +42,7 @@ _chunkXE4OXN2Wjs.__export.call(void 0, core_exports, {
51
42
  ValidationError: () => ValidationError,
52
43
  config: () => config,
53
44
  createLogger: () => _chunkWCKSKU3Cjs.createLogger,
54
- filesystem: () => _chunk7HNQWJWVjs.filesystem,
45
+ filesystem: () => _chunk75HBI2XGjs.filesystem,
55
46
  load: () => load,
56
47
  logger: () => _chunkWCKSKU3Cjs.logger
57
48
  });
@@ -326,12 +317,138 @@ _chunkXE4OXN2Wjs.__export.call(void 0, next_exports, {
326
317
 
327
318
  // src/next/provider.tsx
328
319
  var _react = require('react'); var _react2 = _interopRequireDefault(_react);
320
+
321
+ // src/client/fetcher.ts
322
+ var FusionFetcher = class {
323
+ static {
324
+ _chunkXE4OXN2Wjs.__name.call(void 0, this, "FusionFetcher");
325
+ }
326
+
327
+ constructor(baseUrl = "/api") {
328
+ this.baseUrl = baseUrl;
329
+ }
330
+ async request(method, path2, body) {
331
+ const headers = {
332
+ "Content-Type": "application/json"
333
+ };
334
+ if (typeof window !== "undefined") {
335
+ const token = localStorage.getItem("fusion_token");
336
+ if (token) headers["Authorization"] = `Bearer ${token}`;
337
+ }
338
+ const response = await fetch(`${this.baseUrl}${path2}`, {
339
+ method,
340
+ headers,
341
+ body: body ? JSON.stringify(body) : void 0
342
+ });
343
+ if (!response.ok) {
344
+ throw new (0, _chunkAVMQJWYDjs.WextsRpcError)({
345
+ code: "WEXTS_API_REQUEST_FAILED",
346
+ message: `Fusion API Error: ${response.status} ${response.statusText}`,
347
+ suggestedFix: "Check the API route, server logs, and authentication headers.",
348
+ docsSlug: "troubleshooting"
349
+ });
350
+ }
351
+ if (response.status === 204) {
352
+ return void 0;
353
+ }
354
+ return response.json();
355
+ }
356
+ get(path2) {
357
+ return this.request("GET", path2);
358
+ }
359
+ post(path2, body) {
360
+ return this.request("POST", path2, body);
361
+ }
362
+ put(path2, body) {
363
+ return this.request("PUT", path2, body);
364
+ }
365
+ delete(path2) {
366
+ return this.request("DELETE", path2);
367
+ }
368
+ };
369
+ var apiFetcher = new FusionFetcher();
370
+ function createWextsRpcClient(manifest, options = {}) {
371
+ const hasManifest = Boolean(manifest);
372
+ const services = new Set((_nullishCoalesce(_optionalChain([manifest, 'optionalAccess', _ => _.services]), () => ( []))).map((service) => service.name));
373
+ const methodMap = /* @__PURE__ */ new Map();
374
+ for (const service of _nullishCoalesce(_optionalChain([manifest, 'optionalAccess', _2 => _2.services]), () => ( []))) {
375
+ methodMap.set(service.name, new Set(service.methods.map((method) => method.name)));
376
+ }
377
+ const createServiceProxy = /* @__PURE__ */ _chunkXE4OXN2Wjs.__name.call(void 0, (serviceName) => new Proxy({}, {
378
+ get(_target, methodName) {
379
+ if (typeof methodName !== "string") return void 0;
380
+ if (methodName === "then") return void 0;
381
+ const knownMethods = methodMap.get(serviceName);
382
+ if (knownMethods && !knownMethods.has(methodName)) {
383
+ throw new (0, _chunkAVMQJWYDjs.WextsRpcError)({
384
+ code: "WEXTS_RPC_METHOD_NOT_FOUND",
385
+ message: `Wexts RPC method not found: ${serviceName}.${methodName}`,
386
+ suggestedFix: "Run `wexts generate` and verify the method is decorated with @RpcMethod().",
387
+ docsSlug: "rpc"
388
+ });
389
+ }
390
+ return (...args) => invokeRpc(serviceName, methodName, args, options);
391
+ }
392
+ }), "createServiceProxy");
393
+ return new Proxy({}, {
394
+ get(_target, serviceName) {
395
+ if (typeof serviceName !== "string") return void 0;
396
+ if (serviceName === "then") return void 0;
397
+ if (!hasManifest) {
398
+ throw new (0, _chunkAVMQJWYDjs.WextsRpcError)({
399
+ code: "WEXTS_RPC_MANIFEST_MISSING",
400
+ message: "Wexts RPC manifest is missing.",
401
+ suggestedFix: "Run `wexts generate` and import the generated client/provider instead of creating an empty client.",
402
+ docsSlug: "codegen"
403
+ });
404
+ }
405
+ if (!services.has(serviceName)) {
406
+ throw new (0, _chunkAVMQJWYDjs.WextsRpcError)({
407
+ code: "WEXTS_RPC_SERVICE_NOT_FOUND",
408
+ message: `Wexts RPC service not found: ${serviceName}`,
409
+ suggestedFix: "Run `wexts generate` and verify the service is decorated with @RpcService().",
410
+ docsSlug: "rpc"
411
+ });
412
+ }
413
+ return createServiceProxy(serviceName);
414
+ }
415
+ });
416
+ }
417
+ _chunkXE4OXN2Wjs.__name.call(void 0, createWextsRpcClient, "createWextsRpcClient");
418
+ async function invokeRpc(serviceName, methodName, args, options) {
419
+ const fetchImpl = _nullishCoalesce(options.fetch, () => ( fetch));
420
+ const baseUrl = _nullishCoalesce(options.baseUrl, () => ( "/rpc"));
421
+ const headers = {
422
+ "Content-Type": "application/json",
423
+ ...await _asyncNullishCoalesce(await _optionalChain([options, 'access', _3 => _3.getHeaders, 'optionalCall', _4 => _4()]), async () => ( {}))
424
+ };
425
+ const response = await fetchImpl(`${baseUrl}/${encodeURIComponent(serviceName)}/${encodeURIComponent(methodName)}`, {
426
+ method: "POST",
427
+ headers,
428
+ body: JSON.stringify({
429
+ args
430
+ })
431
+ });
432
+ if (!response.ok) {
433
+ throw new (0, _chunkAVMQJWYDjs.WextsRpcError)({
434
+ code: "WEXTS_RPC_REQUEST_FAILED",
435
+ message: `Wexts RPC Error: ${response.status} ${response.statusText}`,
436
+ suggestedFix: "Check the RPC route, service policy, and server logs.",
437
+ docsSlug: "troubleshooting"
438
+ });
439
+ }
440
+ const payload = await response.json();
441
+ return payload.data;
442
+ }
443
+ _chunkXE4OXN2Wjs.__name.call(void 0, invokeRpc, "invokeRpc");
444
+
445
+ // src/next/provider.tsx
329
446
  var FusionContext = /* @__PURE__ */ _react.createContext.call(void 0, null);
330
447
  function FusionProvider({ children, baseUrl = "/api", rpcBaseUrl = "/rpc", rpcClient }) {
331
- const client = _react2.default.useMemo(() => new (0, _chunkO4II6N34js.FusionFetcher)(baseUrl), [
448
+ const client = _react2.default.useMemo(() => new FusionFetcher(baseUrl), [
332
449
  baseUrl
333
450
  ]);
334
- const wexts = _react2.default.useMemo(() => _nullishCoalesce(rpcClient, () => ( _chunkO4II6N34js.createWextsRpcClient.call(void 0, void 0, {
451
+ const wexts = _react2.default.useMemo(() => _nullishCoalesce(rpcClient, () => ( createWextsRpcClient(void 0, {
335
452
  baseUrl: rpcBaseUrl
336
453
  }))), [
337
454
  rpcBaseUrl,
@@ -405,6 +522,9 @@ function useAuth() {
405
522
  }
406
523
  _chunkXE4OXN2Wjs.__name.call(void 0, useAuth, "useAuth");
407
524
 
525
+ // src/rpc/index.ts
526
+ var rpc_exports = {};
527
+
408
528
 
409
529
 
410
530
 
@@ -420,5 +540,5 @@ _chunkXE4OXN2Wjs.__name.call(void 0, useAuth, "useAuth");
420
540
 
421
541
 
422
542
 
423
- exports.Codegen = _chunk7HNQWJWVjs.codegen_exports; exports.Config = config_exports; exports.Core = core_exports; exports.CreateFusion = create_fusion_exports; exports.DevServer = _chunk2LJVUMXWjs.dev_server_exports; exports.Insight = insight_exports; exports.Nest = _chunkBG56B4DEjs.nest_exports; exports.Next = next_exports; exports.Rpc = _chunkDNLGCKTTjs.rpc_exports; exports.WextsCodegenError = _chunkAVMQJWYDjs.WextsCodegenError; exports.WextsError = _chunkAVMQJWYDjs.WextsError; exports.WextsRpcError = _chunkAVMQJWYDjs.WextsRpcError; exports.WextsRuntimeError = _chunkAVMQJWYDjs.WextsRuntimeError; exports.WextsSecurityError = _chunkAVMQJWYDjs.WextsSecurityError; exports.formatWextsError = _chunkAVMQJWYDjs.formatWextsError;
543
+ exports.Codegen = _chunk75HBI2XGjs.codegen_exports; exports.Config = config_exports; exports.Core = core_exports; exports.CreateFusion = create_fusion_exports; exports.DevServer = _chunk2LJVUMXWjs.dev_server_exports; exports.Insight = insight_exports; exports.Nest = _chunkHLT3IHJYjs.nest_exports; exports.Next = next_exports; exports.Rpc = rpc_exports; exports.WextsCodegenError = _chunkAVMQJWYDjs.WextsCodegenError; exports.WextsError = _chunkAVMQJWYDjs.WextsError; exports.WextsRpcError = _chunkAVMQJWYDjs.WextsRpcError; exports.WextsRuntimeError = _chunkAVMQJWYDjs.WextsRuntimeError; exports.WextsSecurityError = _chunkAVMQJWYDjs.WextsSecurityError; exports.formatWextsError = _chunkAVMQJWYDjs.formatWextsError;
424
544
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["/Volumes/Projects/wexts/packages/dist/index.js","../src/core/index.ts","../src/core/config.ts","../src/core/process-manager.ts","../src/core/errors.ts","../src/config/index.ts","../src/config/loader.ts","../src/insight/index.ts","../src/insight/server.ts","../src/create-fusion/index.ts","../src/create-fusion/scaffold.ts","../src/next/index.ts","../src/next/provider.tsx","../src/next/useAuth.ts"],"names":["ConfigLoader","config","Map","configDir","process","cwd","load","key","defaultValue","has","get","envKey","toUpperCase","env","value","readFileSync","ProcessManager","error","promise","cleanup","Error","code","FusionError","statusCode","log","ProjectScaffolder","options","projectName","projectPath","useContext","createContext","FusionFetcher","baseUrl","rpcClient","rpcBaseUrl","FusionContext","client","wexts","children","FusionProvider","useFusion","context","useWexts","useAuth","loadUser","userData","email","password","response","user","loading","login","logout"],"mappings":"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","file":"/Volumes/Projects/wexts/packages/dist/index.js","sourcesContent":[null,"// Core exports placeholder\nexport * from './config';\nexport * from './logger';\nexport * from './filesystem';\nexport * from './process-manager';\nexport * from './errors';\n","import * as fs from 'fs';\nimport * as path from 'path';\n\nexport interface FusionConfig {\n [key: string]: any;\n}\n\nexport class ConfigLoader {\n private config: Map<string, any> = new Map();\n private configDir: string;\n\n constructor(configDir: string = process.cwd()) {\n this.configDir = configDir;\n }\n\n /**\n * Load configuration from file or environment\n */\n load(key: string, defaultValue?: any): any {\n if (this.config.has(key)) {\n return this.config.get(key);\n }\n\n // Try to load from environment variable\n const envKey = `FUSION_${key.toUpperCase()}`;\n if (process.env[envKey]) {\n const value = this.parseEnvValue(process.env[envKey]!);\n this.config.set(key, value);\n return value;\n }\n\n // Try to load from config file\n const configPath = path.join(this.configDir, 'fusion.config.json');\n if (fs.existsSync(configPath)) {\n try {\n const fileConfig = JSON.parse(fs.readFileSync(configPath, 'utf-8'));\n if (fileConfig[key] !== undefined) {\n this.config.set(key, fileConfig[key]);\n return fileConfig[key];\n }\n } catch (error) {\n // Silently fail and use default\n }\n }\n\n return defaultValue;\n }\n\n /**\n * Set configuration value\n */\n set(key: string, value: any): void {\n this.config.set(key, value);\n }\n\n /**\n * Get all configuration\n */\n getAll(): FusionConfig {\n return Object.fromEntries(this.config);\n }\n\n /**\n * Parse environment value (handles JSON strings)\n */\n private parseEnvValue(value: string): any {\n try {\n return JSON.parse(value);\n } catch {\n return value;\n }\n }\n}\n\n// Export singleton instance\nexport const config = new ConfigLoader();\n\n// Helper function for backward compatibility\nexport function load(key: string, defaultValue?: any): any {\n return config.load(key, defaultValue);\n}\n","export class ProcessManager {\n /**\n * Setup process error handlers\n */\n static initialize(): void {\n process.on('uncaughtException', (error) => {\n console.error('[Fusion] Uncaught Exception:', error);\n process.exit(1);\n });\n\n process.on('unhandledRejection', (reason, promise) => {\n console.error('[Fusion] Unhandled Rejection at:', promise, 'reason:', reason);\n });\n\n process.on('SIGTERM', () => {\n console.log('[Fusion] SIGTERM received, shutting down gracefully');\n process.exit(0);\n });\n\n process.on('SIGINT', () => {\n console.log('[Fusion] SIGINT received, shutting down gracefully');\n process.exit(0);\n });\n }\n\n /**\n * Graceful shutdown helper\n */\n static async shutdown(cleanup: () => Promise<void>): Promise<void> {\n try {\n await cleanup();\n process.exit(0);\n } catch (error) {\n console.error('[Fusion] Error during shutdown:', error);\n process.exit(1);\n }\n }\n}\n","export class FusionError extends Error {\n constructor(message: string, public code?: string) {\n super(message);\n this.name = 'FusionError';\n }\n}\n\nexport class ConfigError extends FusionError {\n constructor(message: string) {\n super(message, 'CONFIG_ERROR');\n this.name = 'ConfigError';\n }\n}\n\nexport class ValidationError extends FusionError {\n constructor(message: string) {\n super(message, 'VALIDATION_ERROR');\n this.name = 'ValidationError';\n }\n}\n\nexport class APIError extends FusionError {\n constructor(message: string, public statusCode?: number) {\n super(message, 'API_ERROR');\n this.name = 'APIError';\n }\n}\n","// Config exports placeholder\nexport * from './loader';\n","export const loader = {\n load: () => ({}),\n};\n","// Insight exports placeholder\nexport * from './server';\n","export const server = {\n start: () => console.log('Insight server started'),\n};\n","export * from './scaffold';\n","import { mkdir, writeFile } from 'fs/promises';\nimport { join } from 'path';\nimport { logger } from '../core/logger';\n\nexport interface ScaffoldOptions {\n projectName: string;\n template: 'monorepo' | 'api' | 'web';\n packageManager?: 'npm' | 'pnpm' | 'yarn';\n}\n\n/**\n * @deprecated Use the `wexts create` CLI and `examples/hello-rpc` canonical scaffold instead.\n */\nexport class ProjectScaffolder {\n async scaffold(options: ScaffoldOptions): Promise<void> {\n const { projectName, template } = options;\n const projectPath = join(process.cwd(), projectName);\n\n logger.info(`Creating project at: ${projectPath}`);\n\n // Create base directory\n await mkdir(projectPath, { recursive: true });\n\n if (template === 'monorepo') {\n await this.createMonorepo(projectPath, projectName);\n } else if (template === 'api') {\n await this.createNestJSApp(projectPath, projectName);\n } else if (template === 'web') {\n await this.createNextJSApp(projectPath, projectName);\n }\n\n logger.success(`Project ${projectName} created successfully!`);\n logger.info(`\\nNext steps:`);\n logger.info(` cd ${projectName}`);\n logger.info(` wexts dev`);\n }\n\n private async createMonorepo(projectPath: string, projectName: string): Promise<void> {\n // Create directory structure\n await mkdir(join(projectPath, 'apps', 'api'), { recursive: true });\n await mkdir(join(projectPath, 'apps', 'web'), { recursive: true });\n await mkdir(join(projectPath, 'packages', 'types'), { recursive: true });\n await mkdir(join(projectPath, 'packages', 'api-client'), { recursive: true });\n\n // Create root package.json\n const packageJson = {\n name: projectName,\n version: '0.0.1',\n private: true,\n workspaces: ['apps/*', 'packages/*'],\n scripts: {\n dev: 'wexts dev',\n build: 'wexts build',\n },\n devDependencies: {\n 'wexts': '^4.0.0',\n },\n };\n\n await writeFile(\n join(projectPath, 'package.json'),\n JSON.stringify(packageJson, null, 2)\n );\n\n // Create README\n const readme = `# ${projectName}\\n\\nCreated with the deprecated ProjectScaffolder compatibility API.\\n\\nUse examples/hello-rpc as the canonical Wexts reference.\\n\\n## Getting Started\\n\\n\\`\\`\\`bash\\nwexts dev\\n\\`\\`\\`\\n`;\n await writeFile(join(projectPath, 'README.md'), readme);\n }\n\n private async createNestJSApp(projectPath: string, projectName: string): Promise<void> {\n await writeFile(\n join(projectPath, 'README.md'),\n `# ${projectName}\\n\\nStandalone API scaffolding through ProjectScaffolder is deprecated. Use examples/hello-rpc or wexts create for the canonical path.\\n`\n );\n }\n\n private async createNextJSApp(projectPath: string, projectName: string): Promise<void> {\n await writeFile(\n join(projectPath, 'README.md'),\n `# ${projectName}\\n\\nStandalone web scaffolding through ProjectScaffolder is deprecated. Use examples/hello-rpc or wexts create for the canonical path.\\n`\n );\n }\n}\n","export * from './provider';\nexport * from './useAuth';\n","'use client';\n\nimport React, { createContext, useContext, ReactNode } from 'react';\nimport { createWextsRpcClient, FusionFetcher, WextsRpcClient } from '../client/fetcher';\n\ninterface FusionContextType {\n client: FusionFetcher;\n wexts: WextsRpcClient;\n}\n\nconst FusionContext = createContext<FusionContextType | null>(null);\n\nexport interface FusionProviderProps {\n children: ReactNode;\n baseUrl?: string;\n rpcBaseUrl?: string;\n rpcClient?: object;\n}\n\n/**\n * FusionProvider - Provides API client to React components\n * Usage:\n * ```tsx\n * <FusionProvider baseUrl=\"/api\">\n * <App />\n * </FusionProvider>\n * ```\n */\nexport function FusionProvider({ children, baseUrl = '/api', rpcBaseUrl = '/rpc', rpcClient }: FusionProviderProps) {\n const client = React.useMemo(() => new FusionFetcher(baseUrl), [baseUrl]);\n const wexts = React.useMemo(\n () => (rpcClient as WextsRpcClient | undefined) ?? createWextsRpcClient(undefined, { baseUrl: rpcBaseUrl }),\n [rpcBaseUrl, rpcClient]\n );\n\n return (\n <FusionContext.Provider value={{ client, wexts }}>\n {children}\n </FusionContext.Provider>\n );\n}\n\n/**\n * useFusion hook - Access API client in components\n * Usage:\n * ```tsx\n * const { client } = useFusion();\n * const data = await client.get('/users');\n * ```\n */\nexport function useFusion(): FusionContextType {\n const context = useContext(FusionContext);\n if (!context) {\n throw new Error('useFusion must be used within FusionProvider');\n }\n return context;\n}\n\nexport function useWexts<TClient = WextsRpcClient>(): TClient {\n const context = useFusion();\n return context.wexts as TClient;\n}\n","'use client';\n\nimport { useState, useEffect } from 'react';\nimport { useFusion } from './provider';\n\nexport interface AuthUser {\n id: string;\n email: string;\n name?: string;\n}\n\nexport interface UseAuthReturn {\n user: AuthUser | null;\n loading: boolean;\n login: (email: string, password: string) => Promise<void>;\n logout: () => Promise<void>;\n isAuthenticated: boolean;\n}\n\n/**\n * useAuth hook - Authentication state management\n * Usage:\n * ```tsx\n * const { user, login, logout, isAuthenticated } = useAuth();\n * ```\n */\nexport function useAuth(): UseAuthReturn {\n const { client } = useFusion();\n const [user, setUser] = useState<AuthUser | null>(null);\n const [loading, setLoading] = useState(true);\n\n useEffect(() => {\n // Check for existing session\n const token = localStorage.getItem('fusion_token');\n if (token) {\n // Validate token and load user\n loadUser();\n } else {\n setLoading(false);\n }\n }, []);\n\n const loadUser = async () => {\n try {\n const userData = await client.get<AuthUser>('/auth/me');\n setUser(userData);\n } catch (error) {\n localStorage.removeItem('fusion_token');\n } finally {\n setLoading(false);\n }\n };\n\n const login = async (email: string, password: string) => {\n const response = await client.post<{ token: string; user: AuthUser }>('/auth/login', {\n email,\n password,\n });\n localStorage.setItem('fusion_token', response.token);\n setUser(response.user);\n };\n\n const logout = async () => {\n localStorage.removeItem('fusion_token');\n setUser(null);\n };\n\n return {\n user,\n loading,\n login,\n logout,\n isAuthenticated: !!user,\n };\n}\n"]}
1
+ {"version":3,"sources":["/Volumes/Projects/wexts/packages/dist/index.js","../src/core/index.ts","../src/core/config.ts","../src/core/process-manager.ts","../src/core/errors.ts","../src/config/index.ts","../src/config/loader.ts","../src/insight/index.ts","../src/insight/server.ts","../src/create-fusion/index.ts","../src/create-fusion/scaffold.ts","../src/next/index.ts","../src/next/provider.tsx","../src/client/fetcher.ts","../src/next/useAuth.ts","../src/rpc/index.ts"],"names":["ConfigLoader","config","Map","configDir","process","cwd","load","key","defaultValue","has","get","envKey","toUpperCase","env","value","readFileSync","ProcessManager","error","promise","cleanup","Error","code","FusionError","statusCode","log","ProjectScaffolder","options","projectName","projectPath","useContext","FusionFetcher","baseUrl","method","headers","undefined","status","path","body","manifest","services","service","serviceName","methodName","createWextsRpcClient","fetch","args","data","invokeRpc","createContext","rpcClient","rpcBaseUrl","FusionContext","client","wexts","children","FusionProvider","useFusion","context","useWexts","useAuth","loadUser","userData","email","password","response","user","loading","login","logout"],"mappings":"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","file":"/Volumes/Projects/wexts/packages/dist/index.js","sourcesContent":[null,"// Core exports placeholder\nexport * from './config';\nexport * from './logger';\nexport * from './filesystem';\nexport * from './process-manager';\nexport * from './errors';\n","import * as fs from 'fs';\nimport * as path from 'path';\n\nexport interface FusionConfig {\n [key: string]: any;\n}\n\nexport class ConfigLoader {\n private config: Map<string, any> = new Map();\n private configDir: string;\n\n constructor(configDir: string = process.cwd()) {\n this.configDir = configDir;\n }\n\n /**\n * Load configuration from file or environment\n */\n load(key: string, defaultValue?: any): any {\n if (this.config.has(key)) {\n return this.config.get(key);\n }\n\n // Try to load from environment variable\n const envKey = `FUSION_${key.toUpperCase()}`;\n if (process.env[envKey]) {\n const value = this.parseEnvValue(process.env[envKey]!);\n this.config.set(key, value);\n return value;\n }\n\n // Try to load from config file\n const configPath = path.join(this.configDir, 'fusion.config.json');\n if (fs.existsSync(configPath)) {\n try {\n const fileConfig = JSON.parse(fs.readFileSync(configPath, 'utf-8'));\n if (fileConfig[key] !== undefined) {\n this.config.set(key, fileConfig[key]);\n return fileConfig[key];\n }\n } catch (error) {\n // Silently fail and use default\n }\n }\n\n return defaultValue;\n }\n\n /**\n * Set configuration value\n */\n set(key: string, value: any): void {\n this.config.set(key, value);\n }\n\n /**\n * Get all configuration\n */\n getAll(): FusionConfig {\n return Object.fromEntries(this.config);\n }\n\n /**\n * Parse environment value (handles JSON strings)\n */\n private parseEnvValue(value: string): any {\n try {\n return JSON.parse(value);\n } catch {\n return value;\n }\n }\n}\n\n// Export singleton instance\nexport const config = new ConfigLoader();\n\n// Helper function for backward compatibility\nexport function load(key: string, defaultValue?: any): any {\n return config.load(key, defaultValue);\n}\n","export class ProcessManager {\n /**\n * Setup process error handlers\n */\n static initialize(): void {\n process.on('uncaughtException', (error) => {\n console.error('[Fusion] Uncaught Exception:', error);\n process.exit(1);\n });\n\n process.on('unhandledRejection', (reason, promise) => {\n console.error('[Fusion] Unhandled Rejection at:', promise, 'reason:', reason);\n });\n\n process.on('SIGTERM', () => {\n console.log('[Fusion] SIGTERM received, shutting down gracefully');\n process.exit(0);\n });\n\n process.on('SIGINT', () => {\n console.log('[Fusion] SIGINT received, shutting down gracefully');\n process.exit(0);\n });\n }\n\n /**\n * Graceful shutdown helper\n */\n static async shutdown(cleanup: () => Promise<void>): Promise<void> {\n try {\n await cleanup();\n process.exit(0);\n } catch (error) {\n console.error('[Fusion] Error during shutdown:', error);\n process.exit(1);\n }\n }\n}\n","export class FusionError extends Error {\n constructor(message: string, public code?: string) {\n super(message);\n this.name = 'FusionError';\n }\n}\n\nexport class ConfigError extends FusionError {\n constructor(message: string) {\n super(message, 'CONFIG_ERROR');\n this.name = 'ConfigError';\n }\n}\n\nexport class ValidationError extends FusionError {\n constructor(message: string) {\n super(message, 'VALIDATION_ERROR');\n this.name = 'ValidationError';\n }\n}\n\nexport class APIError extends FusionError {\n constructor(message: string, public statusCode?: number) {\n super(message, 'API_ERROR');\n this.name = 'APIError';\n }\n}\n","// Config exports placeholder\nexport * from './loader';\n","export const loader = {\n load: () => ({}),\n};\n","// Insight exports placeholder\nexport * from './server';\n","export const server = {\n start: () => console.log('Insight server started'),\n};\n","export * from './scaffold';\n","import { mkdir, writeFile } from 'fs/promises';\nimport { join } from 'path';\nimport { logger } from '../core/logger';\n\nexport interface ScaffoldOptions {\n projectName: string;\n template: 'monorepo' | 'api' | 'web';\n packageManager?: 'npm' | 'pnpm' | 'yarn';\n}\n\n/**\n * @deprecated Use the `wexts create` CLI and `examples/hello-rpc` canonical scaffold instead.\n */\nexport class ProjectScaffolder {\n async scaffold(options: ScaffoldOptions): Promise<void> {\n const { projectName, template } = options;\n const projectPath = join(process.cwd(), projectName);\n\n logger.info(`Creating project at: ${projectPath}`);\n\n // Create base directory\n await mkdir(projectPath, { recursive: true });\n\n if (template === 'monorepo') {\n await this.createMonorepo(projectPath, projectName);\n } else if (template === 'api') {\n await this.createNestJSApp(projectPath, projectName);\n } else if (template === 'web') {\n await this.createNextJSApp(projectPath, projectName);\n }\n\n logger.success(`Project ${projectName} created successfully!`);\n logger.info(`\\nNext steps:`);\n logger.info(` cd ${projectName}`);\n logger.info(` wexts dev`);\n }\n\n private async createMonorepo(projectPath: string, projectName: string): Promise<void> {\n // Create directory structure\n await mkdir(join(projectPath, 'apps', 'api'), { recursive: true });\n await mkdir(join(projectPath, 'apps', 'web'), { recursive: true });\n await mkdir(join(projectPath, 'packages', 'types'), { recursive: true });\n await mkdir(join(projectPath, 'packages', 'api-client'), { recursive: true });\n\n // Create root package.json\n const packageJson = {\n name: projectName,\n version: '0.0.1',\n private: true,\n workspaces: ['apps/*', 'packages/*'],\n scripts: {\n dev: 'wexts dev',\n build: 'wexts build',\n },\n devDependencies: {\n 'wexts': '^4.0.0',\n },\n };\n\n await writeFile(\n join(projectPath, 'package.json'),\n JSON.stringify(packageJson, null, 2)\n );\n\n // Create README\n const readme = `# ${projectName}\\n\\nCreated with the deprecated ProjectScaffolder compatibility API.\\n\\nUse examples/hello-rpc as the canonical Wexts reference.\\n\\n## Getting Started\\n\\n\\`\\`\\`bash\\nwexts dev\\n\\`\\`\\`\\n`;\n await writeFile(join(projectPath, 'README.md'), readme);\n }\n\n private async createNestJSApp(projectPath: string, projectName: string): Promise<void> {\n await writeFile(\n join(projectPath, 'README.md'),\n `# ${projectName}\\n\\nStandalone API scaffolding through ProjectScaffolder is deprecated. Use examples/hello-rpc or wexts create for the canonical path.\\n`\n );\n }\n\n private async createNextJSApp(projectPath: string, projectName: string): Promise<void> {\n await writeFile(\n join(projectPath, 'README.md'),\n `# ${projectName}\\n\\nStandalone web scaffolding through ProjectScaffolder is deprecated. Use examples/hello-rpc or wexts create for the canonical path.\\n`\n );\n }\n}\n","export * from './provider';\nexport * from './useAuth';\n","'use client';\n\nimport React, { createContext, useContext, ReactNode } from 'react';\nimport { createWextsRpcClient, FusionFetcher, WextsRpcClient } from '../client/fetcher';\n\ninterface FusionContextType {\n client: FusionFetcher;\n wexts: WextsRpcClient;\n}\n\nconst FusionContext = createContext<FusionContextType | null>(null);\n\nexport interface FusionProviderProps {\n children: ReactNode;\n baseUrl?: string;\n rpcBaseUrl?: string;\n rpcClient?: object;\n}\n\n/**\n * FusionProvider - Provides API client to React components\n * Usage:\n * ```tsx\n * <FusionProvider baseUrl=\"/api\">\n * <App />\n * </FusionProvider>\n * ```\n */\nexport function FusionProvider({ children, baseUrl = '/api', rpcBaseUrl = '/rpc', rpcClient }: FusionProviderProps) {\n const client = React.useMemo(() => new FusionFetcher(baseUrl), [baseUrl]);\n const wexts = React.useMemo(\n () => (rpcClient as WextsRpcClient | undefined) ?? createWextsRpcClient(undefined, { baseUrl: rpcBaseUrl }),\n [rpcBaseUrl, rpcClient]\n );\n\n return (\n <FusionContext.Provider value={{ client, wexts }}>\n {children}\n </FusionContext.Provider>\n );\n}\n\n/**\n * useFusion hook - Access API client in components\n * Usage:\n * ```tsx\n * const { client } = useFusion();\n * const data = await client.get('/users');\n * ```\n */\nexport function useFusion(): FusionContextType {\n const context = useContext(FusionContext);\n if (!context) {\n throw new Error('useFusion must be used within FusionProvider');\n }\n return context;\n}\n\nexport function useWexts<TClient = WextsRpcClient>(): TClient {\n const context = useFusion();\n return context.wexts as TClient;\n}\n","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","'use client';\n\nimport { useState, useEffect } from 'react';\nimport { useFusion } from './provider';\n\nexport interface AuthUser {\n id: string;\n email: string;\n name?: string;\n}\n\nexport interface UseAuthReturn {\n user: AuthUser | null;\n loading: boolean;\n login: (email: string, password: string) => Promise<void>;\n logout: () => Promise<void>;\n isAuthenticated: boolean;\n}\n\n/**\n * useAuth hook - Authentication state management\n * Usage:\n * ```tsx\n * const { user, login, logout, isAuthenticated } = useAuth();\n * ```\n */\nexport function useAuth(): UseAuthReturn {\n const { client } = useFusion();\n const [user, setUser] = useState<AuthUser | null>(null);\n const [loading, setLoading] = useState(true);\n\n useEffect(() => {\n // Check for existing session\n const token = localStorage.getItem('fusion_token');\n if (token) {\n // Validate token and load user\n loadUser();\n } else {\n setLoading(false);\n }\n }, []);\n\n const loadUser = async () => {\n try {\n const userData = await client.get<AuthUser>('/auth/me');\n setUser(userData);\n } catch (error) {\n localStorage.removeItem('fusion_token');\n } finally {\n setLoading(false);\n }\n };\n\n const login = async (email: string, password: string) => {\n const response = await client.post<{ token: string; user: AuthUser }>('/auth/login', {\n email,\n password,\n });\n localStorage.setItem('fusion_token', response.token);\n setUser(response.user);\n };\n\n const logout = async () => {\n localStorage.removeItem('fusion_token');\n setUser(null);\n };\n\n return {\n user,\n loading,\n login,\n logout,\n isAuthenticated: !!user,\n };\n}\n","export * from './types';\n"]}
package/dist/index.mjs CHANGED
@@ -1,29 +1,11 @@
1
- import {
2
- dev_server_exports
3
- } from "./chunk-YN6WIWNQ.mjs";
4
- import {
5
- FusionFetcher,
6
- createWextsRpcClient
7
- } from "./chunk-7SSCNCTW.mjs";
8
1
  import {
9
2
  nest_exports
10
- } from "./chunk-UAL54DVV.mjs";
11
- import {
12
- rpc_exports
13
- } from "./chunk-ZX7QIN24.mjs";
14
- import "./chunk-YBM3IJEA.mjs";
15
- import "./chunk-YSLEF5C5.mjs";
3
+ } from "./chunk-5DBFN65W.mjs";
16
4
  import {
17
5
  FileSystem,
18
6
  codegen_exports,
19
7
  filesystem
20
- } from "./chunk-342VRT25.mjs";
21
- import {
22
- LogLevel,
23
- Logger,
24
- createLogger,
25
- logger
26
- } from "./chunk-JHOVXH3X.mjs";
8
+ } from "./chunk-VBIQGUDI.mjs";
27
9
  import {
28
10
  WextsCodegenError,
29
11
  WextsError,
@@ -31,11 +13,20 @@ import {
31
13
  WextsRuntimeError,
32
14
  WextsSecurityError,
33
15
  formatWextsError
34
- } from "./chunk-7TLSPR65.mjs";
16
+ } from "./chunk-DS5KVVWJ.mjs";
17
+ import {
18
+ dev_server_exports
19
+ } from "./chunk-FUPLZMSR.mjs";
20
+ import {
21
+ LogLevel,
22
+ Logger,
23
+ createLogger,
24
+ logger
25
+ } from "./chunk-C2AG7Q3C.mjs";
35
26
  import {
36
27
  __export,
37
28
  __name
38
- } from "./chunk-7WULUGLH.mjs";
29
+ } from "./chunk-L77ANWWT.mjs";
39
30
 
40
31
  // src/core/index.ts
41
32
  var core_exports = {};
@@ -326,6 +317,132 @@ __export(next_exports, {
326
317
 
327
318
  // src/next/provider.tsx
328
319
  import React, { createContext, useContext } from "react";
320
+
321
+ // src/client/fetcher.ts
322
+ var FusionFetcher = class {
323
+ static {
324
+ __name(this, "FusionFetcher");
325
+ }
326
+ baseUrl;
327
+ constructor(baseUrl = "/api") {
328
+ this.baseUrl = baseUrl;
329
+ }
330
+ async request(method, path2, body) {
331
+ const headers = {
332
+ "Content-Type": "application/json"
333
+ };
334
+ if (typeof window !== "undefined") {
335
+ const token = localStorage.getItem("fusion_token");
336
+ if (token) headers["Authorization"] = `Bearer ${token}`;
337
+ }
338
+ const response = await fetch(`${this.baseUrl}${path2}`, {
339
+ method,
340
+ headers,
341
+ body: body ? JSON.stringify(body) : void 0
342
+ });
343
+ if (!response.ok) {
344
+ throw new WextsRpcError({
345
+ code: "WEXTS_API_REQUEST_FAILED",
346
+ message: `Fusion API Error: ${response.status} ${response.statusText}`,
347
+ suggestedFix: "Check the API route, server logs, and authentication headers.",
348
+ docsSlug: "troubleshooting"
349
+ });
350
+ }
351
+ if (response.status === 204) {
352
+ return void 0;
353
+ }
354
+ return response.json();
355
+ }
356
+ get(path2) {
357
+ return this.request("GET", path2);
358
+ }
359
+ post(path2, body) {
360
+ return this.request("POST", path2, body);
361
+ }
362
+ put(path2, body) {
363
+ return this.request("PUT", path2, body);
364
+ }
365
+ delete(path2) {
366
+ return this.request("DELETE", path2);
367
+ }
368
+ };
369
+ var apiFetcher = new FusionFetcher();
370
+ function createWextsRpcClient(manifest, options = {}) {
371
+ const hasManifest = Boolean(manifest);
372
+ const services = new Set((manifest?.services ?? []).map((service) => service.name));
373
+ const methodMap = /* @__PURE__ */ new Map();
374
+ for (const service of manifest?.services ?? []) {
375
+ methodMap.set(service.name, new Set(service.methods.map((method) => method.name)));
376
+ }
377
+ const createServiceProxy = /* @__PURE__ */ __name((serviceName) => new Proxy({}, {
378
+ get(_target, methodName) {
379
+ if (typeof methodName !== "string") return void 0;
380
+ if (methodName === "then") return void 0;
381
+ const knownMethods = methodMap.get(serviceName);
382
+ if (knownMethods && !knownMethods.has(methodName)) {
383
+ throw new WextsRpcError({
384
+ code: "WEXTS_RPC_METHOD_NOT_FOUND",
385
+ message: `Wexts RPC method not found: ${serviceName}.${methodName}`,
386
+ suggestedFix: "Run `wexts generate` and verify the method is decorated with @RpcMethod().",
387
+ docsSlug: "rpc"
388
+ });
389
+ }
390
+ return (...args) => invokeRpc(serviceName, methodName, args, options);
391
+ }
392
+ }), "createServiceProxy");
393
+ return new Proxy({}, {
394
+ get(_target, serviceName) {
395
+ if (typeof serviceName !== "string") return void 0;
396
+ if (serviceName === "then") return void 0;
397
+ if (!hasManifest) {
398
+ throw new WextsRpcError({
399
+ code: "WEXTS_RPC_MANIFEST_MISSING",
400
+ message: "Wexts RPC manifest is missing.",
401
+ suggestedFix: "Run `wexts generate` and import the generated client/provider instead of creating an empty client.",
402
+ docsSlug: "codegen"
403
+ });
404
+ }
405
+ if (!services.has(serviceName)) {
406
+ throw new WextsRpcError({
407
+ code: "WEXTS_RPC_SERVICE_NOT_FOUND",
408
+ message: `Wexts RPC service not found: ${serviceName}`,
409
+ suggestedFix: "Run `wexts generate` and verify the service is decorated with @RpcService().",
410
+ docsSlug: "rpc"
411
+ });
412
+ }
413
+ return createServiceProxy(serviceName);
414
+ }
415
+ });
416
+ }
417
+ __name(createWextsRpcClient, "createWextsRpcClient");
418
+ async function invokeRpc(serviceName, methodName, args, options) {
419
+ const fetchImpl = options.fetch ?? fetch;
420
+ const baseUrl = options.baseUrl ?? "/rpc";
421
+ const headers = {
422
+ "Content-Type": "application/json",
423
+ ...await options.getHeaders?.() ?? {}
424
+ };
425
+ const response = await fetchImpl(`${baseUrl}/${encodeURIComponent(serviceName)}/${encodeURIComponent(methodName)}`, {
426
+ method: "POST",
427
+ headers,
428
+ body: JSON.stringify({
429
+ args
430
+ })
431
+ });
432
+ if (!response.ok) {
433
+ throw new WextsRpcError({
434
+ code: "WEXTS_RPC_REQUEST_FAILED",
435
+ message: `Wexts RPC Error: ${response.status} ${response.statusText}`,
436
+ suggestedFix: "Check the RPC route, service policy, and server logs.",
437
+ docsSlug: "troubleshooting"
438
+ });
439
+ }
440
+ const payload = await response.json();
441
+ return payload.data;
442
+ }
443
+ __name(invokeRpc, "invokeRpc");
444
+
445
+ // src/next/provider.tsx
329
446
  var FusionContext = /* @__PURE__ */ createContext(null);
330
447
  function FusionProvider({ children, baseUrl = "/api", rpcBaseUrl = "/rpc", rpcClient }) {
331
448
  const client = React.useMemo(() => new FusionFetcher(baseUrl), [
@@ -404,6 +521,9 @@ function useAuth() {
404
521
  };
405
522
  }
406
523
  __name(useAuth, "useAuth");
524
+
525
+ // src/rpc/index.ts
526
+ var rpc_exports = {};
407
527
  export {
408
528
  codegen_exports as Codegen,
409
529
  config_exports as Config,