wexts 4.1.0 → 4.1.5

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 (199) hide show
  1. package/README.md +49 -49
  2. package/bin/wexts.cjs +2 -2
  3. package/package.json +153 -148
  4. package/templates/.dockerignore +43 -43
  5. package/templates/.env.example +17 -17
  6. package/templates/Dockerfile +60 -60
  7. package/templates/Procfile +1 -1
  8. package/templates/README.md +67 -67
  9. package/templates/api-sdk.ts +115 -115
  10. package/templates/docker-compose.yml +34 -34
  11. package/templates/nestjs-api/.env.example +3 -3
  12. package/templates/nestjs-api/README.md +87 -87
  13. package/templates/nestjs-api/nest-cli.json +6 -6
  14. package/templates/nestjs-api/package.json +40 -40
  15. package/templates/nestjs-api/prisma/migrations/20251123205437_init/migration.sql +24 -24
  16. package/templates/nestjs-api/prisma/migrations/migration_lock.toml +3 -3
  17. package/templates/nestjs-api/prisma/schema.prisma +29 -29
  18. package/templates/nestjs-api/src/app.module.ts +17 -17
  19. package/templates/nestjs-api/src/auth/auth.controller.ts +27 -27
  20. package/templates/nestjs-api/src/auth/auth.module.ts +37 -37
  21. package/templates/nestjs-api/src/auth/auth.service.ts +86 -86
  22. package/templates/nestjs-api/src/auth/dto/auth.dto.ts +22 -22
  23. package/templates/nestjs-api/src/auth/guards/jwt-auth.guard.ts +5 -5
  24. package/templates/nestjs-api/src/auth/strategies/jwt.strategy.ts +27 -27
  25. package/templates/nestjs-api/src/main.ts +32 -32
  26. package/templates/nestjs-api/src/prisma/prisma.module.ts +9 -9
  27. package/templates/nestjs-api/src/prisma/prisma.service.ts +14 -14
  28. package/templates/nestjs-api/src/todos/dto/todo.dto.ts +24 -24
  29. package/templates/nestjs-api/src/todos/todos.controller.ts +39 -39
  30. package/templates/nestjs-api/src/todos/todos.module.ts +11 -11
  31. package/templates/nestjs-api/src/todos/todos.service.ts +53 -53
  32. package/templates/nestjs-api/src/users/users.controller.ts +14 -14
  33. package/templates/nestjs-api/src/users/users.module.ts +12 -12
  34. package/templates/nestjs-api/src/users/users.service.ts +19 -19
  35. package/templates/nestjs-api/tsconfig.json +39 -39
  36. package/templates/nextjs-web/README.md +76 -76
  37. package/templates/nextjs-web/app/actions/auth.ts +108 -108
  38. package/templates/nextjs-web/app/dashboard/error.tsx +39 -39
  39. package/templates/nextjs-web/app/dashboard/loading.tsx +14 -14
  40. package/templates/nextjs-web/app/dashboard/page.tsx +5 -5
  41. package/templates/nextjs-web/app/globals.css +93 -93
  42. package/templates/nextjs-web/app/layout.tsx +29 -29
  43. package/templates/nextjs-web/app/login/page.tsx +5 -5
  44. package/templates/nextjs-web/app/page.tsx +28 -28
  45. package/templates/nextjs-web/app/register/page.tsx +5 -5
  46. package/templates/nextjs-web/components/ui/button.tsx +56 -56
  47. package/templates/nextjs-web/components/ui/card.tsx +79 -79
  48. package/templates/nextjs-web/components/ui/input.tsx +25 -25
  49. package/templates/nextjs-web/components/ui/label.tsx +24 -24
  50. package/templates/nextjs-web/features/auth/LoginForm.tsx +140 -140
  51. package/templates/nextjs-web/features/auth/RegisterForm.tsx +159 -159
  52. package/templates/nextjs-web/features/auth/api.ts +35 -35
  53. package/templates/nextjs-web/features/auth/index.ts +3 -3
  54. package/templates/nextjs-web/features/dashboard/DashboardView.tsx +204 -204
  55. package/templates/nextjs-web/features/dashboard/api.ts +9 -9
  56. package/templates/nextjs-web/features/dashboard/components.tsx +74 -74
  57. package/templates/nextjs-web/features/dashboard/index.ts +3 -3
  58. package/templates/nextjs-web/hooks/index.ts +4 -4
  59. package/templates/nextjs-web/lib/api-client.ts +89 -89
  60. package/templates/nextjs-web/lib/api.ts +115 -115
  61. package/templates/nextjs-web/lib/axios-global-config.ts +17 -17
  62. package/templates/nextjs-web/lib/utils.ts +6 -6
  63. package/templates/nextjs-web/lib/wexts-client.ts +4 -4
  64. package/templates/nextjs-web/next-env.d.ts +6 -6
  65. package/templates/nextjs-web/next.config.ts +20 -20
  66. package/templates/nextjs-web/package.json +37 -37
  67. package/templates/nextjs-web/postcss.config.js +6 -6
  68. package/templates/nextjs-web/tailwind.config.ts +69 -69
  69. package/templates/nextjs-web/tsconfig.json +41 -41
  70. package/templates/nixpacks.toml +11 -11
  71. package/templates/root-package.json +31 -31
  72. package/templates/server.ts +66 -66
  73. package/templates/tsconfig.json +30 -30
  74. package/dist/chunk-2KAQYLVN.js +0 -1
  75. package/dist/chunk-2KAQYLVN.js.map +0 -1
  76. package/dist/chunk-2LJVUMXW.js +0 -228
  77. package/dist/chunk-2LJVUMXW.js.map +0 -1
  78. package/dist/chunk-342VRT25.mjs +0 -504
  79. package/dist/chunk-342VRT25.mjs.map +0 -1
  80. package/dist/chunk-7HNQWJWV.js +0 -504
  81. package/dist/chunk-7HNQWJWV.js.map +0 -1
  82. package/dist/chunk-7QKLIVRF.js +0 -94
  83. package/dist/chunk-7QKLIVRF.js.map +0 -1
  84. package/dist/chunk-7SSCNCTW.mjs +0 -137
  85. package/dist/chunk-7SSCNCTW.mjs.map +0 -1
  86. package/dist/chunk-7TLSPR65.mjs +0 -95
  87. package/dist/chunk-7TLSPR65.mjs.map +0 -1
  88. package/dist/chunk-7WULUGLH.mjs +0 -22
  89. package/dist/chunk-7WULUGLH.mjs.map +0 -1
  90. package/dist/chunk-AVMQJWYD.js +0 -95
  91. package/dist/chunk-AVMQJWYD.js.map +0 -1
  92. package/dist/chunk-BG56B4DE.js +0 -106
  93. package/dist/chunk-BG56B4DE.js.map +0 -1
  94. package/dist/chunk-CLM5PNSG.mjs +0 -496
  95. package/dist/chunk-CLM5PNSG.mjs.map +0 -1
  96. package/dist/chunk-DNLGCKTT.js +0 -31
  97. package/dist/chunk-DNLGCKTT.js.map +0 -1
  98. package/dist/chunk-JHOVXH3X.mjs +0 -65
  99. package/dist/chunk-JHOVXH3X.mjs.map +0 -1
  100. package/dist/chunk-MXINIFPC.js +0 -105
  101. package/dist/chunk-MXINIFPC.js.map +0 -1
  102. package/dist/chunk-O4II6N34.js +0 -137
  103. package/dist/chunk-O4II6N34.js.map +0 -1
  104. package/dist/chunk-SE32ZPOZ.js +0 -496
  105. package/dist/chunk-SE32ZPOZ.js.map +0 -1
  106. package/dist/chunk-UAL54DVV.mjs +0 -106
  107. package/dist/chunk-UAL54DVV.mjs.map +0 -1
  108. package/dist/chunk-WCKSKU3C.js +0 -65
  109. package/dist/chunk-WCKSKU3C.js.map +0 -1
  110. package/dist/chunk-WU6FW77M.mjs +0 -105
  111. package/dist/chunk-WU6FW77M.mjs.map +0 -1
  112. package/dist/chunk-XE4OXN2W.js +0 -12
  113. package/dist/chunk-XE4OXN2W.js.map +0 -1
  114. package/dist/chunk-YBM3IJEA.mjs +0 -94
  115. package/dist/chunk-YBM3IJEA.mjs.map +0 -1
  116. package/dist/chunk-YN6WIWNQ.mjs +0 -228
  117. package/dist/chunk-YN6WIWNQ.mjs.map +0 -1
  118. package/dist/chunk-YSLEF5C5.mjs +0 -1
  119. package/dist/chunk-YSLEF5C5.mjs.map +0 -1
  120. package/dist/chunk-ZX7QIN24.mjs +0 -31
  121. package/dist/chunk-ZX7QIN24.mjs.map +0 -1
  122. package/dist/cli/index.d.mts +0 -23
  123. package/dist/cli/index.d.ts +0 -23
  124. package/dist/cli/index.js +0 -716
  125. package/dist/cli/index.js.map +0 -1
  126. package/dist/cli/index.mjs +0 -718
  127. package/dist/cli/index.mjs.map +0 -1
  128. package/dist/client/index.d.mts +0 -21
  129. package/dist/client/index.d.ts +0 -21
  130. package/dist/client/index.js +0 -13
  131. package/dist/client/index.js.map +0 -1
  132. package/dist/client/index.mjs +0 -13
  133. package/dist/client/index.mjs.map +0 -1
  134. package/dist/codegen/index.d.mts +0 -2
  135. package/dist/codegen/index.d.ts +0 -2
  136. package/dist/codegen/index.js +0 -16
  137. package/dist/codegen/index.js.map +0 -1
  138. package/dist/codegen/index.mjs +0 -16
  139. package/dist/codegen/index.mjs.map +0 -1
  140. package/dist/decorators-BT1FFqN0.d.mts +0 -29
  141. package/dist/decorators-DvS58PqC.d.ts +0 -29
  142. package/dist/dev-server/index.d.mts +0 -1
  143. package/dist/dev-server/index.d.ts +0 -1
  144. package/dist/dev-server/index.js +0 -13
  145. package/dist/dev-server/index.js.map +0 -1
  146. package/dist/dev-server/index.mjs +0 -13
  147. package/dist/dev-server/index.mjs.map +0 -1
  148. package/dist/index-7QeQEf37.d.ts +0 -92
  149. package/dist/index-7RvU-jGE.d.mts +0 -66
  150. package/dist/index-7RvU-jGE.d.ts +0 -66
  151. package/dist/index-8nzxy0NN.d.mts +0 -92
  152. package/dist/index-Co5ZsLqq.d.ts +0 -58
  153. package/dist/index-D94W1__r.d.mts +0 -58
  154. package/dist/index-DQmyVp6F.d.mts +0 -27
  155. package/dist/index-KL_1BrQb.d.ts +0 -27
  156. package/dist/index.d.mts +0 -294
  157. package/dist/index.d.ts +0 -294
  158. package/dist/index.js +0 -424
  159. package/dist/index.js.map +0 -1
  160. package/dist/index.mjs +0 -424
  161. package/dist/index.mjs.map +0 -1
  162. package/dist/nest/index.d.mts +0 -3
  163. package/dist/nest/index.d.ts +0 -3
  164. package/dist/nest/index.js +0 -38
  165. package/dist/nest/index.js.map +0 -1
  166. package/dist/nest/index.mjs +0 -38
  167. package/dist/nest/index.mjs.map +0 -1
  168. package/dist/next/index.d.mts +0 -66
  169. package/dist/next/index.d.ts +0 -66
  170. package/dist/next/index.js +0 -289
  171. package/dist/next/index.js.map +0 -1
  172. package/dist/next/index.mjs +0 -251
  173. package/dist/next/index.mjs.map +0 -1
  174. package/dist/rpc/index.d.mts +0 -2
  175. package/dist/rpc/index.d.ts +0 -2
  176. package/dist/rpc/index.js +0 -23
  177. package/dist/rpc/index.js.map +0 -1
  178. package/dist/rpc/index.mjs +0 -23
  179. package/dist/rpc/index.mjs.map +0 -1
  180. package/dist/runtime/index.d.mts +0 -55
  181. package/dist/runtime/index.d.ts +0 -55
  182. package/dist/runtime/index.js +0 -221
  183. package/dist/runtime/index.js.map +0 -1
  184. package/dist/runtime/index.mjs +0 -221
  185. package/dist/runtime/index.mjs.map +0 -1
  186. package/dist/types/index.d.mts +0 -12
  187. package/dist/types/index.d.ts +0 -12
  188. package/dist/types/index.js +0 -2
  189. package/dist/types/index.js.map +0 -1
  190. package/dist/types/index.mjs +0 -3
  191. package/dist/types/index.mjs.map +0 -1
  192. package/dist/types-7d_fC-C3.d.mts +0 -32
  193. package/dist/types-7d_fC-C3.d.ts +0 -32
  194. package/dist/vercel-builder/index.d.mts +0 -58
  195. package/dist/vercel-builder/index.d.ts +0 -58
  196. package/dist/vercel-builder/index.js +0 -330
  197. package/dist/vercel-builder/index.js.map +0 -1
  198. package/dist/vercel-builder/index.mjs +0 -330
  199. package/dist/vercel-builder/index.mjs.map +0 -1
@@ -1,66 +0,0 @@
1
- import React, { ReactNode } from 'react';
2
-
3
- declare class FusionFetcher {
4
- private baseUrl;
5
- constructor(baseUrl?: string);
6
- private request;
7
- get<T>(path: string): Promise<T>;
8
- post<T>(path: string, body: any): Promise<T>;
9
- put<T>(path: string, body: any): Promise<T>;
10
- delete<T>(path: string): Promise<T>;
11
- }
12
- type WextsRpcClient = Record<string, Record<string, (...args: unknown[]) => Promise<unknown>>>;
13
-
14
- interface FusionContextType {
15
- client: FusionFetcher;
16
- wexts: WextsRpcClient;
17
- }
18
- interface FusionProviderProps {
19
- children: ReactNode;
20
- baseUrl?: string;
21
- rpcBaseUrl?: string;
22
- rpcClient?: object;
23
- }
24
- /**
25
- * FusionProvider - Provides API client to React components
26
- * Usage:
27
- * ```tsx
28
- * <FusionProvider baseUrl="/api">
29
- * <App />
30
- * </FusionProvider>
31
- * ```
32
- */
33
- declare function FusionProvider({ children, baseUrl, rpcBaseUrl, rpcClient }: FusionProviderProps): React.JSX.Element;
34
- /**
35
- * useFusion hook - Access API client in components
36
- * Usage:
37
- * ```tsx
38
- * const { client } = useFusion();
39
- * const data = await client.get('/users');
40
- * ```
41
- */
42
- declare function useFusion(): FusionContextType;
43
- declare function useWexts<TClient = WextsRpcClient>(): TClient;
44
-
45
- interface AuthUser {
46
- id: string;
47
- email: string;
48
- name?: string;
49
- }
50
- interface UseAuthReturn {
51
- user: AuthUser | null;
52
- loading: boolean;
53
- login: (email: string, password: string) => Promise<void>;
54
- logout: () => Promise<void>;
55
- isAuthenticated: boolean;
56
- }
57
- /**
58
- * useAuth hook - Authentication state management
59
- * Usage:
60
- * ```tsx
61
- * const { user, login, logout, isAuthenticated } = useAuth();
62
- * ```
63
- */
64
- declare function useAuth(): UseAuthReturn;
65
-
66
- export { type AuthUser, FusionProvider, type FusionProviderProps, type UseAuthReturn, useAuth, useFusion, useWexts };
@@ -1,289 +0,0 @@
1
- "use client";
2
- "use strict";
3
- var __create = Object.create;
4
- var __defProp = Object.defineProperty;
5
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
- var __getOwnPropNames = Object.getOwnPropertyNames;
7
- var __getProtoOf = Object.getPrototypeOf;
8
- var __hasOwnProp = Object.prototype.hasOwnProperty;
9
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
10
- var __export = (target, all) => {
11
- for (var name in all)
12
- __defProp(target, name, { get: all[name], enumerable: true });
13
- };
14
- var __copyProps = (to, from, except, desc) => {
15
- if (from && typeof from === "object" || typeof from === "function") {
16
- for (let key of __getOwnPropNames(from))
17
- if (!__hasOwnProp.call(to, key) && key !== except)
18
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
19
- }
20
- return to;
21
- };
22
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
23
- // If the importer is in node compatibility mode or this is not an ESM
24
- // file that has been converted to a CommonJS file using a Babel-
25
- // compatible transform (i.e. "__esModule" has not been set), then set
26
- // "default" to the CommonJS "module.exports" for node compatibility.
27
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
28
- mod
29
- ));
30
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
31
-
32
- // src/next/index.ts
33
- var next_exports = {};
34
- __export(next_exports, {
35
- FusionProvider: () => FusionProvider,
36
- useAuth: () => useAuth,
37
- useFusion: () => useFusion,
38
- useWexts: () => useWexts
39
- });
40
- module.exports = __toCommonJS(next_exports);
41
-
42
- // src/next/provider.tsx
43
- var import_react = __toESM(require("react"));
44
-
45
- // src/errors.ts
46
- var WextsError = class extends Error {
47
- static {
48
- __name(this, "WextsError");
49
- }
50
- code;
51
- suggestedFix;
52
- docsSlug;
53
- constructor(options) {
54
- super(options.message, options.cause === void 0 ? void 0 : {
55
- cause: options.cause
56
- });
57
- this.name = "WextsError";
58
- this.code = options.code;
59
- this.suggestedFix = options.suggestedFix;
60
- this.docsSlug = options.docsSlug;
61
- }
62
- get docsUrl() {
63
- return this.docsSlug ? `https://github.com/ziadmustafa1/wexts/blob/main/docs/${this.docsSlug}.md` : void 0;
64
- }
65
- };
66
- var WextsRpcError = class extends WextsError {
67
- static {
68
- __name(this, "WextsRpcError");
69
- }
70
- constructor(options) {
71
- super({
72
- code: options.code ?? "WEXTS_RPC_ERROR",
73
- ...options
74
- });
75
- this.name = "WextsRpcError";
76
- }
77
- };
78
-
79
- // src/client/fetcher.ts
80
- var FusionFetcher = class {
81
- static {
82
- __name(this, "FusionFetcher");
83
- }
84
- baseUrl;
85
- constructor(baseUrl = "/api") {
86
- this.baseUrl = baseUrl;
87
- }
88
- async request(method, path, body) {
89
- const headers = {
90
- "Content-Type": "application/json"
91
- };
92
- if (typeof window !== "undefined") {
93
- const token = localStorage.getItem("fusion_token");
94
- if (token) headers["Authorization"] = `Bearer ${token}`;
95
- }
96
- const response = await fetch(`${this.baseUrl}${path}`, {
97
- method,
98
- headers,
99
- body: body ? JSON.stringify(body) : void 0
100
- });
101
- if (!response.ok) {
102
- throw new WextsRpcError({
103
- code: "WEXTS_API_REQUEST_FAILED",
104
- message: `Fusion API Error: ${response.status} ${response.statusText}`,
105
- suggestedFix: "Check the API route, server logs, and authentication headers.",
106
- docsSlug: "troubleshooting"
107
- });
108
- }
109
- if (response.status === 204) {
110
- return void 0;
111
- }
112
- return response.json();
113
- }
114
- get(path) {
115
- return this.request("GET", path);
116
- }
117
- post(path, body) {
118
- return this.request("POST", path, body);
119
- }
120
- put(path, body) {
121
- return this.request("PUT", path, body);
122
- }
123
- delete(path) {
124
- return this.request("DELETE", path);
125
- }
126
- };
127
- var apiFetcher = new FusionFetcher();
128
- function createWextsRpcClient(manifest, options = {}) {
129
- const hasManifest = Boolean(manifest);
130
- const services = new Set((manifest?.services ?? []).map((service) => service.name));
131
- const methodMap = /* @__PURE__ */ new Map();
132
- for (const service of manifest?.services ?? []) {
133
- methodMap.set(service.name, new Set(service.methods.map((method) => method.name)));
134
- }
135
- const createServiceProxy = /* @__PURE__ */ __name((serviceName) => new Proxy({}, {
136
- get(_target, methodName) {
137
- if (typeof methodName !== "string") return void 0;
138
- if (methodName === "then") return void 0;
139
- const knownMethods = methodMap.get(serviceName);
140
- if (knownMethods && !knownMethods.has(methodName)) {
141
- throw new WextsRpcError({
142
- code: "WEXTS_RPC_METHOD_NOT_FOUND",
143
- message: `Wexts RPC method not found: ${serviceName}.${methodName}`,
144
- suggestedFix: "Run `wexts generate` and verify the method is decorated with @RpcMethod().",
145
- docsSlug: "rpc"
146
- });
147
- }
148
- return (...args) => invokeRpc(serviceName, methodName, args, options);
149
- }
150
- }), "createServiceProxy");
151
- return new Proxy({}, {
152
- get(_target, serviceName) {
153
- if (typeof serviceName !== "string") return void 0;
154
- if (serviceName === "then") return void 0;
155
- if (!hasManifest) {
156
- throw new WextsRpcError({
157
- code: "WEXTS_RPC_MANIFEST_MISSING",
158
- message: "Wexts RPC manifest is missing.",
159
- suggestedFix: "Run `wexts generate` and import the generated client/provider instead of creating an empty client.",
160
- docsSlug: "codegen"
161
- });
162
- }
163
- if (!services.has(serviceName)) {
164
- throw new WextsRpcError({
165
- code: "WEXTS_RPC_SERVICE_NOT_FOUND",
166
- message: `Wexts RPC service not found: ${serviceName}`,
167
- suggestedFix: "Run `wexts generate` and verify the service is decorated with @RpcService().",
168
- docsSlug: "rpc"
169
- });
170
- }
171
- return createServiceProxy(serviceName);
172
- }
173
- });
174
- }
175
- __name(createWextsRpcClient, "createWextsRpcClient");
176
- async function invokeRpc(serviceName, methodName, args, options) {
177
- const fetchImpl = options.fetch ?? fetch;
178
- const baseUrl = options.baseUrl ?? "/rpc";
179
- const headers = {
180
- "Content-Type": "application/json",
181
- ...await options.getHeaders?.() ?? {}
182
- };
183
- const response = await fetchImpl(`${baseUrl}/${encodeURIComponent(serviceName)}/${encodeURIComponent(methodName)}`, {
184
- method: "POST",
185
- headers,
186
- body: JSON.stringify({
187
- args
188
- })
189
- });
190
- if (!response.ok) {
191
- throw new WextsRpcError({
192
- code: "WEXTS_RPC_REQUEST_FAILED",
193
- message: `Wexts RPC Error: ${response.status} ${response.statusText}`,
194
- suggestedFix: "Check the RPC route, service policy, and server logs.",
195
- docsSlug: "troubleshooting"
196
- });
197
- }
198
- const payload = await response.json();
199
- return payload.data;
200
- }
201
- __name(invokeRpc, "invokeRpc");
202
-
203
- // src/next/provider.tsx
204
- var FusionContext = /* @__PURE__ */ (0, import_react.createContext)(null);
205
- function FusionProvider({ children, baseUrl = "/api", rpcBaseUrl = "/rpc", rpcClient }) {
206
- const client = import_react.default.useMemo(() => new FusionFetcher(baseUrl), [
207
- baseUrl
208
- ]);
209
- const wexts = import_react.default.useMemo(() => rpcClient ?? createWextsRpcClient(void 0, {
210
- baseUrl: rpcBaseUrl
211
- }), [
212
- rpcBaseUrl,
213
- rpcClient
214
- ]);
215
- return /* @__PURE__ */ import_react.default.createElement(FusionContext.Provider, {
216
- value: {
217
- client,
218
- wexts
219
- }
220
- }, children);
221
- }
222
- __name(FusionProvider, "FusionProvider");
223
- function useFusion() {
224
- const context = (0, import_react.useContext)(FusionContext);
225
- if (!context) {
226
- throw new Error("useFusion must be used within FusionProvider");
227
- }
228
- return context;
229
- }
230
- __name(useFusion, "useFusion");
231
- function useWexts() {
232
- const context = useFusion();
233
- return context.wexts;
234
- }
235
- __name(useWexts, "useWexts");
236
-
237
- // src/next/useAuth.ts
238
- var import_react2 = require("react");
239
- function useAuth() {
240
- const { client } = useFusion();
241
- const [user, setUser] = (0, import_react2.useState)(null);
242
- const [loading, setLoading] = (0, import_react2.useState)(true);
243
- (0, import_react2.useEffect)(() => {
244
- const token = localStorage.getItem("fusion_token");
245
- if (token) {
246
- loadUser();
247
- } else {
248
- setLoading(false);
249
- }
250
- }, []);
251
- const loadUser = /* @__PURE__ */ __name(async () => {
252
- try {
253
- const userData = await client.get("/auth/me");
254
- setUser(userData);
255
- } catch (error) {
256
- localStorage.removeItem("fusion_token");
257
- } finally {
258
- setLoading(false);
259
- }
260
- }, "loadUser");
261
- const login = /* @__PURE__ */ __name(async (email, password) => {
262
- const response = await client.post("/auth/login", {
263
- email,
264
- password
265
- });
266
- localStorage.setItem("fusion_token", response.token);
267
- setUser(response.user);
268
- }, "login");
269
- const logout = /* @__PURE__ */ __name(async () => {
270
- localStorage.removeItem("fusion_token");
271
- setUser(null);
272
- }, "logout");
273
- return {
274
- user,
275
- loading,
276
- login,
277
- logout,
278
- isAuthenticated: !!user
279
- };
280
- }
281
- __name(useAuth, "useAuth");
282
- // Annotate the CommonJS export names for ESM import in node:
283
- 0 && (module.exports = {
284
- FusionProvider,
285
- useAuth,
286
- useFusion,
287
- useWexts
288
- });
289
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/next/index.ts","../../src/next/provider.tsx","../../src/errors.ts","../../src/client/fetcher.ts","../../src/next/useAuth.ts"],"sourcesContent":["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","export interface WextsErrorOptions {\n code: string;\n message: string;\n cause?: unknown;\n suggestedFix?: string;\n docsSlug?: string;\n}\n\nexport class WextsError extends Error {\n readonly code: string;\n readonly suggestedFix?: string;\n readonly docsSlug?: string;\n\n constructor(options: WextsErrorOptions) {\n super(options.message, options.cause === undefined ? undefined : { cause: options.cause });\n this.name = 'WextsError';\n this.code = options.code;\n this.suggestedFix = options.suggestedFix;\n this.docsSlug = options.docsSlug;\n }\n\n get docsUrl(): string | undefined {\n return this.docsSlug ? `https://github.com/ziadmustafa1/wexts/blob/main/docs/${this.docsSlug}.md` : undefined;\n }\n}\n\nexport class WextsRpcError extends WextsError {\n constructor(options: Omit<WextsErrorOptions, 'code'> & { code?: string }) {\n super({ code: options.code ?? 'WEXTS_RPC_ERROR', ...options });\n this.name = 'WextsRpcError';\n }\n}\n\nexport class WextsCodegenError extends WextsError {\n constructor(options: Omit<WextsErrorOptions, 'code'> & { code?: string }) {\n super({ code: options.code ?? 'WEXTS_CODEGEN_ERROR', ...options });\n this.name = 'WextsCodegenError';\n }\n}\n\nexport class WextsRuntimeError extends WextsError {\n constructor(options: Omit<WextsErrorOptions, 'code'> & { code?: string }) {\n super({ code: options.code ?? 'WEXTS_RUNTIME_ERROR', ...options });\n this.name = 'WextsRuntimeError';\n }\n}\n\nexport class WextsSecurityError extends WextsError {\n constructor(options: Omit<WextsErrorOptions, 'code'> & { code?: string }) {\n super({ code: options.code ?? 'WEXTS_SECURITY_ERROR', ...options });\n this.name = 'WextsSecurityError';\n }\n}\n\nexport function formatWextsError(error: unknown): string {\n if (!(error instanceof WextsError)) {\n return error instanceof Error ? error.message : String(error);\n }\n\n const lines = [`${error.code}: ${error.message}`];\n if (error.suggestedFix) lines.push(`Suggested fix: ${error.suggestedFix}`);\n if (error.docsUrl) lines.push(`Docs: ${error.docsUrl}`);\n return lines.join('\\n');\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"],"mappings":"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","names":["WextsError","Error","code","suggestedFix","docsSlug","options","message","cause","undefined","name","docsUrl","WextsRpcError","FusionFetcher","baseUrl","request","method","path","body","headers","window","token","localStorage","getItem","response","fetch","JSON","stringify","undefined","ok","WextsRpcError","code","message","status","statusText","suggestedFix","docsSlug","json","get","post","put","delete","apiFetcher","createWextsRpcClient","manifest","options","hasManifest","Boolean","services","Set","map","service","name","methodMap","Map","set","methods","createServiceProxy","serviceName","Proxy","_target","methodName","knownMethods","has","args","invokeRpc","fetchImpl","getHeaders","encodeURIComponent","payload","data","FusionContext","createContext","FusionProvider","children","baseUrl","rpcBaseUrl","rpcClient","client","React","useMemo","FusionFetcher","wexts","createWextsRpcClient","undefined","Provider","value","useFusion","context","useContext","Error","useWexts","import_react","useAuth","client","useFusion","user","setUser","useState","loading","setLoading","useEffect","token","localStorage","getItem","loadUser","userData","get","error","removeItem","login","email","password","response","post","setItem","logout","isAuthenticated"]}
@@ -1,251 +0,0 @@
1
- "use client";
2
- var __defProp = Object.defineProperty;
3
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
4
-
5
- // src/next/provider.tsx
6
- import React, { createContext, useContext } from "react";
7
-
8
- // src/errors.ts
9
- var WextsError = class extends Error {
10
- static {
11
- __name(this, "WextsError");
12
- }
13
- code;
14
- suggestedFix;
15
- docsSlug;
16
- constructor(options) {
17
- super(options.message, options.cause === void 0 ? void 0 : {
18
- cause: options.cause
19
- });
20
- this.name = "WextsError";
21
- this.code = options.code;
22
- this.suggestedFix = options.suggestedFix;
23
- this.docsSlug = options.docsSlug;
24
- }
25
- get docsUrl() {
26
- return this.docsSlug ? `https://github.com/ziadmustafa1/wexts/blob/main/docs/${this.docsSlug}.md` : void 0;
27
- }
28
- };
29
- var WextsRpcError = class extends WextsError {
30
- static {
31
- __name(this, "WextsRpcError");
32
- }
33
- constructor(options) {
34
- super({
35
- code: options.code ?? "WEXTS_RPC_ERROR",
36
- ...options
37
- });
38
- this.name = "WextsRpcError";
39
- }
40
- };
41
-
42
- // src/client/fetcher.ts
43
- var FusionFetcher = class {
44
- static {
45
- __name(this, "FusionFetcher");
46
- }
47
- baseUrl;
48
- constructor(baseUrl = "/api") {
49
- this.baseUrl = baseUrl;
50
- }
51
- async request(method, path, body) {
52
- const headers = {
53
- "Content-Type": "application/json"
54
- };
55
- if (typeof window !== "undefined") {
56
- const token = localStorage.getItem("fusion_token");
57
- if (token) headers["Authorization"] = `Bearer ${token}`;
58
- }
59
- const response = await fetch(`${this.baseUrl}${path}`, {
60
- method,
61
- headers,
62
- body: body ? JSON.stringify(body) : void 0
63
- });
64
- if (!response.ok) {
65
- throw new WextsRpcError({
66
- code: "WEXTS_API_REQUEST_FAILED",
67
- message: `Fusion API Error: ${response.status} ${response.statusText}`,
68
- suggestedFix: "Check the API route, server logs, and authentication headers.",
69
- docsSlug: "troubleshooting"
70
- });
71
- }
72
- if (response.status === 204) {
73
- return void 0;
74
- }
75
- return response.json();
76
- }
77
- get(path) {
78
- return this.request("GET", path);
79
- }
80
- post(path, body) {
81
- return this.request("POST", path, body);
82
- }
83
- put(path, body) {
84
- return this.request("PUT", path, body);
85
- }
86
- delete(path) {
87
- return this.request("DELETE", path);
88
- }
89
- };
90
- var apiFetcher = new FusionFetcher();
91
- function createWextsRpcClient(manifest, options = {}) {
92
- const hasManifest = Boolean(manifest);
93
- const services = new Set((manifest?.services ?? []).map((service) => service.name));
94
- const methodMap = /* @__PURE__ */ new Map();
95
- for (const service of manifest?.services ?? []) {
96
- methodMap.set(service.name, new Set(service.methods.map((method) => method.name)));
97
- }
98
- const createServiceProxy = /* @__PURE__ */ __name((serviceName) => new Proxy({}, {
99
- get(_target, methodName) {
100
- if (typeof methodName !== "string") return void 0;
101
- if (methodName === "then") return void 0;
102
- const knownMethods = methodMap.get(serviceName);
103
- if (knownMethods && !knownMethods.has(methodName)) {
104
- throw new WextsRpcError({
105
- code: "WEXTS_RPC_METHOD_NOT_FOUND",
106
- message: `Wexts RPC method not found: ${serviceName}.${methodName}`,
107
- suggestedFix: "Run `wexts generate` and verify the method is decorated with @RpcMethod().",
108
- docsSlug: "rpc"
109
- });
110
- }
111
- return (...args) => invokeRpc(serviceName, methodName, args, options);
112
- }
113
- }), "createServiceProxy");
114
- return new Proxy({}, {
115
- get(_target, serviceName) {
116
- if (typeof serviceName !== "string") return void 0;
117
- if (serviceName === "then") return void 0;
118
- if (!hasManifest) {
119
- throw new WextsRpcError({
120
- code: "WEXTS_RPC_MANIFEST_MISSING",
121
- message: "Wexts RPC manifest is missing.",
122
- suggestedFix: "Run `wexts generate` and import the generated client/provider instead of creating an empty client.",
123
- docsSlug: "codegen"
124
- });
125
- }
126
- if (!services.has(serviceName)) {
127
- throw new WextsRpcError({
128
- code: "WEXTS_RPC_SERVICE_NOT_FOUND",
129
- message: `Wexts RPC service not found: ${serviceName}`,
130
- suggestedFix: "Run `wexts generate` and verify the service is decorated with @RpcService().",
131
- docsSlug: "rpc"
132
- });
133
- }
134
- return createServiceProxy(serviceName);
135
- }
136
- });
137
- }
138
- __name(createWextsRpcClient, "createWextsRpcClient");
139
- async function invokeRpc(serviceName, methodName, args, options) {
140
- const fetchImpl = options.fetch ?? fetch;
141
- const baseUrl = options.baseUrl ?? "/rpc";
142
- const headers = {
143
- "Content-Type": "application/json",
144
- ...await options.getHeaders?.() ?? {}
145
- };
146
- const response = await fetchImpl(`${baseUrl}/${encodeURIComponent(serviceName)}/${encodeURIComponent(methodName)}`, {
147
- method: "POST",
148
- headers,
149
- body: JSON.stringify({
150
- args
151
- })
152
- });
153
- if (!response.ok) {
154
- throw new WextsRpcError({
155
- code: "WEXTS_RPC_REQUEST_FAILED",
156
- message: `Wexts RPC Error: ${response.status} ${response.statusText}`,
157
- suggestedFix: "Check the RPC route, service policy, and server logs.",
158
- docsSlug: "troubleshooting"
159
- });
160
- }
161
- const payload = await response.json();
162
- return payload.data;
163
- }
164
- __name(invokeRpc, "invokeRpc");
165
-
166
- // src/next/provider.tsx
167
- var FusionContext = /* @__PURE__ */ createContext(null);
168
- function FusionProvider({ children, baseUrl = "/api", rpcBaseUrl = "/rpc", rpcClient }) {
169
- const client = React.useMemo(() => new FusionFetcher(baseUrl), [
170
- baseUrl
171
- ]);
172
- const wexts = React.useMemo(() => rpcClient ?? createWextsRpcClient(void 0, {
173
- baseUrl: rpcBaseUrl
174
- }), [
175
- rpcBaseUrl,
176
- rpcClient
177
- ]);
178
- return /* @__PURE__ */ React.createElement(FusionContext.Provider, {
179
- value: {
180
- client,
181
- wexts
182
- }
183
- }, children);
184
- }
185
- __name(FusionProvider, "FusionProvider");
186
- function useFusion() {
187
- const context = useContext(FusionContext);
188
- if (!context) {
189
- throw new Error("useFusion must be used within FusionProvider");
190
- }
191
- return context;
192
- }
193
- __name(useFusion, "useFusion");
194
- function useWexts() {
195
- const context = useFusion();
196
- return context.wexts;
197
- }
198
- __name(useWexts, "useWexts");
199
-
200
- // src/next/useAuth.ts
201
- import { useState, useEffect } from "react";
202
- function useAuth() {
203
- const { client } = useFusion();
204
- const [user, setUser] = useState(null);
205
- const [loading, setLoading] = useState(true);
206
- useEffect(() => {
207
- const token = localStorage.getItem("fusion_token");
208
- if (token) {
209
- loadUser();
210
- } else {
211
- setLoading(false);
212
- }
213
- }, []);
214
- const loadUser = /* @__PURE__ */ __name(async () => {
215
- try {
216
- const userData = await client.get("/auth/me");
217
- setUser(userData);
218
- } catch (error) {
219
- localStorage.removeItem("fusion_token");
220
- } finally {
221
- setLoading(false);
222
- }
223
- }, "loadUser");
224
- const login = /* @__PURE__ */ __name(async (email, password) => {
225
- const response = await client.post("/auth/login", {
226
- email,
227
- password
228
- });
229
- localStorage.setItem("fusion_token", response.token);
230
- setUser(response.user);
231
- }, "login");
232
- const logout = /* @__PURE__ */ __name(async () => {
233
- localStorage.removeItem("fusion_token");
234
- setUser(null);
235
- }, "logout");
236
- return {
237
- user,
238
- loading,
239
- login,
240
- logout,
241
- isAuthenticated: !!user
242
- };
243
- }
244
- __name(useAuth, "useAuth");
245
- export {
246
- FusionProvider,
247
- useAuth,
248
- useFusion,
249
- useWexts
250
- };
251
- //# sourceMappingURL=index.mjs.map