wexts 4.0.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.
- package/README.md +49 -49
- package/bin/wexts.cjs +2 -2
- package/package.json +153 -148
- package/templates/.dockerignore +43 -43
- package/templates/.env.example +17 -17
- package/templates/Dockerfile +60 -60
- package/templates/Procfile +1 -1
- package/templates/README.md +67 -67
- package/templates/api-sdk.ts +115 -115
- package/templates/docker-compose.yml +34 -34
- package/templates/nestjs-api/.env.example +3 -3
- package/templates/nestjs-api/README.md +87 -87
- package/templates/nestjs-api/nest-cli.json +6 -6
- package/templates/nestjs-api/package.json +40 -40
- package/templates/nestjs-api/prisma/migrations/20251123205437_init/migration.sql +24 -24
- package/templates/nestjs-api/prisma/migrations/migration_lock.toml +3 -3
- package/templates/nestjs-api/prisma/schema.prisma +29 -29
- package/templates/nestjs-api/src/app.module.ts +17 -17
- package/templates/nestjs-api/src/auth/auth.controller.ts +27 -27
- package/templates/nestjs-api/src/auth/auth.module.ts +37 -37
- package/templates/nestjs-api/src/auth/auth.service.ts +86 -86
- package/templates/nestjs-api/src/auth/dto/auth.dto.ts +22 -22
- package/templates/nestjs-api/src/auth/guards/jwt-auth.guard.ts +5 -5
- package/templates/nestjs-api/src/auth/strategies/jwt.strategy.ts +27 -27
- package/templates/nestjs-api/src/main.ts +32 -32
- package/templates/nestjs-api/src/prisma/prisma.module.ts +9 -9
- package/templates/nestjs-api/src/prisma/prisma.service.ts +14 -14
- package/templates/nestjs-api/src/todos/dto/todo.dto.ts +24 -24
- package/templates/nestjs-api/src/todos/todos.controller.ts +39 -39
- package/templates/nestjs-api/src/todos/todos.module.ts +11 -11
- package/templates/nestjs-api/src/todos/todos.service.ts +53 -53
- package/templates/nestjs-api/src/users/users.controller.ts +14 -14
- package/templates/nestjs-api/src/users/users.module.ts +12 -12
- package/templates/nestjs-api/src/users/users.service.ts +19 -19
- package/templates/nestjs-api/tsconfig.json +39 -39
- package/templates/nextjs-web/README.md +76 -76
- package/templates/nextjs-web/app/actions/auth.ts +108 -108
- package/templates/nextjs-web/app/dashboard/error.tsx +39 -39
- package/templates/nextjs-web/app/dashboard/loading.tsx +14 -14
- package/templates/nextjs-web/app/dashboard/page.tsx +5 -5
- package/templates/nextjs-web/app/globals.css +93 -93
- package/templates/nextjs-web/app/layout.tsx +29 -29
- package/templates/nextjs-web/app/login/page.tsx +5 -5
- package/templates/nextjs-web/app/page.tsx +28 -28
- package/templates/nextjs-web/app/register/page.tsx +5 -5
- package/templates/nextjs-web/components/ui/button.tsx +56 -56
- package/templates/nextjs-web/components/ui/card.tsx +79 -79
- package/templates/nextjs-web/components/ui/input.tsx +25 -25
- package/templates/nextjs-web/components/ui/label.tsx +24 -24
- package/templates/nextjs-web/features/auth/LoginForm.tsx +140 -140
- package/templates/nextjs-web/features/auth/RegisterForm.tsx +159 -159
- package/templates/nextjs-web/features/auth/api.ts +35 -35
- package/templates/nextjs-web/features/auth/index.ts +3 -3
- package/templates/nextjs-web/features/dashboard/DashboardView.tsx +204 -204
- package/templates/nextjs-web/features/dashboard/api.ts +9 -9
- package/templates/nextjs-web/features/dashboard/components.tsx +74 -74
- package/templates/nextjs-web/features/dashboard/index.ts +3 -3
- package/templates/nextjs-web/hooks/index.ts +4 -4
- package/templates/nextjs-web/lib/api-client.ts +89 -89
- package/templates/nextjs-web/lib/api.ts +115 -115
- package/templates/nextjs-web/lib/axios-global-config.ts +17 -17
- package/templates/nextjs-web/lib/utils.ts +6 -6
- package/templates/nextjs-web/lib/wexts-client.ts +4 -4
- package/templates/nextjs-web/next-env.d.ts +6 -6
- package/templates/nextjs-web/next.config.ts +20 -20
- package/templates/nextjs-web/package.json +37 -37
- package/templates/nextjs-web/postcss.config.js +6 -6
- package/templates/nextjs-web/tailwind.config.ts +69 -69
- package/templates/nextjs-web/tsconfig.json +41 -41
- package/templates/nixpacks.toml +11 -11
- package/templates/root-package.json +31 -31
- package/templates/server.ts +66 -66
- package/templates/tsconfig.json +30 -30
- package/dist/chunk-2KAQYLVN.js +0 -1
- package/dist/chunk-2KAQYLVN.js.map +0 -1
- package/dist/chunk-2LJVUMXW.js +0 -228
- package/dist/chunk-2LJVUMXW.js.map +0 -1
- package/dist/chunk-7QKLIVRF.js +0 -94
- package/dist/chunk-7QKLIVRF.js.map +0 -1
- package/dist/chunk-7WULUGLH.mjs +0 -22
- package/dist/chunk-7WULUGLH.mjs.map +0 -1
- package/dist/chunk-BG56B4DE.js +0 -106
- package/dist/chunk-BG56B4DE.js.map +0 -1
- package/dist/chunk-CLM5PNSG.mjs +0 -496
- package/dist/chunk-CLM5PNSG.mjs.map +0 -1
- package/dist/chunk-DNLGCKTT.js +0 -31
- package/dist/chunk-DNLGCKTT.js.map +0 -1
- package/dist/chunk-JHOVXH3X.mjs +0 -65
- package/dist/chunk-JHOVXH3X.mjs.map +0 -1
- package/dist/chunk-MXINIFPC.js +0 -105
- package/dist/chunk-MXINIFPC.js.map +0 -1
- package/dist/chunk-SE32ZPOZ.js +0 -496
- package/dist/chunk-SE32ZPOZ.js.map +0 -1
- package/dist/chunk-UAL54DVV.mjs +0 -106
- package/dist/chunk-UAL54DVV.mjs.map +0 -1
- package/dist/chunk-WCKSKU3C.js +0 -65
- package/dist/chunk-WCKSKU3C.js.map +0 -1
- package/dist/chunk-WU6FW77M.mjs +0 -105
- package/dist/chunk-WU6FW77M.mjs.map +0 -1
- package/dist/chunk-XE4OXN2W.js +0 -12
- package/dist/chunk-XE4OXN2W.js.map +0 -1
- package/dist/chunk-YBM3IJEA.mjs +0 -94
- package/dist/chunk-YBM3IJEA.mjs.map +0 -1
- package/dist/chunk-YN6WIWNQ.mjs +0 -228
- package/dist/chunk-YN6WIWNQ.mjs.map +0 -1
- package/dist/chunk-YSLEF5C5.mjs +0 -1
- package/dist/chunk-YSLEF5C5.mjs.map +0 -1
- package/dist/chunk-ZX7QIN24.mjs +0 -31
- package/dist/chunk-ZX7QIN24.mjs.map +0 -1
- package/dist/cli/index.d.mts +0 -11
- package/dist/cli/index.d.ts +0 -11
- package/dist/cli/index.js +0 -332
- package/dist/cli/index.js.map +0 -1
- package/dist/cli/index.mjs +0 -334
- package/dist/cli/index.mjs.map +0 -1
- package/dist/client/index.d.mts +0 -21
- package/dist/client/index.d.ts +0 -21
- package/dist/client/index.js +0 -12
- package/dist/client/index.js.map +0 -1
- package/dist/client/index.mjs +0 -12
- package/dist/client/index.mjs.map +0 -1
- package/dist/codegen/index.d.mts +0 -2
- package/dist/codegen/index.d.ts +0 -2
- package/dist/codegen/index.js +0 -15
- package/dist/codegen/index.js.map +0 -1
- package/dist/codegen/index.mjs +0 -15
- package/dist/codegen/index.mjs.map +0 -1
- package/dist/decorators-BT1FFqN0.d.mts +0 -29
- package/dist/decorators-DvS58PqC.d.ts +0 -29
- package/dist/dev-server/index.d.mts +0 -1
- package/dist/dev-server/index.d.ts +0 -1
- package/dist/dev-server/index.js +0 -13
- package/dist/dev-server/index.js.map +0 -1
- package/dist/dev-server/index.mjs +0 -13
- package/dist/dev-server/index.mjs.map +0 -1
- package/dist/index-7QeQEf37.d.ts +0 -92
- package/dist/index-7RvU-jGE.d.mts +0 -66
- package/dist/index-7RvU-jGE.d.ts +0 -66
- package/dist/index-8nzxy0NN.d.mts +0 -92
- package/dist/index-Co5ZsLqq.d.ts +0 -58
- package/dist/index-D94W1__r.d.mts +0 -58
- package/dist/index-DQmyVp6F.d.mts +0 -27
- package/dist/index-KL_1BrQb.d.ts +0 -27
- package/dist/index.d.mts +0 -258
- package/dist/index.d.ts +0 -258
- package/dist/index.js +0 -410
- package/dist/index.js.map +0 -1
- package/dist/index.mjs +0 -410
- package/dist/index.mjs.map +0 -1
- package/dist/nest/index.d.mts +0 -3
- package/dist/nest/index.d.ts +0 -3
- package/dist/nest/index.js +0 -38
- package/dist/nest/index.js.map +0 -1
- package/dist/nest/index.mjs +0 -38
- package/dist/nest/index.mjs.map +0 -1
- package/dist/next/index.d.mts +0 -66
- package/dist/next/index.d.ts +0 -66
- package/dist/next/index.js +0 -226
- package/dist/next/index.js.map +0 -1
- package/dist/next/index.mjs +0 -188
- package/dist/next/index.mjs.map +0 -1
- package/dist/rpc/index.d.mts +0 -2
- package/dist/rpc/index.d.ts +0 -2
- package/dist/rpc/index.js +0 -23
- package/dist/rpc/index.js.map +0 -1
- package/dist/rpc/index.mjs +0 -23
- package/dist/rpc/index.mjs.map +0 -1
- package/dist/runtime/index.d.mts +0 -55
- package/dist/runtime/index.d.ts +0 -55
- package/dist/runtime/index.js +0 -213
- package/dist/runtime/index.js.map +0 -1
- package/dist/runtime/index.mjs +0 -213
- package/dist/runtime/index.mjs.map +0 -1
- package/dist/types/index.d.mts +0 -12
- package/dist/types/index.d.ts +0 -12
- package/dist/types/index.js +0 -2
- package/dist/types/index.js.map +0 -1
- package/dist/types/index.mjs +0 -3
- package/dist/types/index.mjs.map +0 -1
- package/dist/types-7d_fC-C3.d.mts +0 -32
- package/dist/types-7d_fC-C3.d.ts +0 -32
- package/dist/vercel-builder/index.d.mts +0 -58
- package/dist/vercel-builder/index.d.ts +0 -58
- package/dist/vercel-builder/index.js +0 -330
- package/dist/vercel-builder/index.js.map +0 -1
- package/dist/vercel-builder/index.mjs +0 -330
- package/dist/vercel-builder/index.mjs.map +0 -1
- package/templates/nestjs-api/package-lock.json +0 -5623
- package/templates/nextjs-web/package-lock.json +0 -3254
package/dist/index.mjs
DELETED
|
@@ -1,410 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
dev_server_exports
|
|
3
|
-
} from "./chunk-YN6WIWNQ.mjs";
|
|
4
|
-
import {
|
|
5
|
-
FusionFetcher,
|
|
6
|
-
createWextsRpcClient
|
|
7
|
-
} from "./chunk-WU6FW77M.mjs";
|
|
8
|
-
import {
|
|
9
|
-
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";
|
|
16
|
-
import {
|
|
17
|
-
FileSystem,
|
|
18
|
-
codegen_exports,
|
|
19
|
-
filesystem
|
|
20
|
-
} from "./chunk-CLM5PNSG.mjs";
|
|
21
|
-
import {
|
|
22
|
-
LogLevel,
|
|
23
|
-
Logger,
|
|
24
|
-
createLogger,
|
|
25
|
-
logger
|
|
26
|
-
} from "./chunk-JHOVXH3X.mjs";
|
|
27
|
-
import {
|
|
28
|
-
__export,
|
|
29
|
-
__name
|
|
30
|
-
} from "./chunk-7WULUGLH.mjs";
|
|
31
|
-
|
|
32
|
-
// src/core/index.ts
|
|
33
|
-
var core_exports = {};
|
|
34
|
-
__export(core_exports, {
|
|
35
|
-
APIError: () => APIError,
|
|
36
|
-
ConfigError: () => ConfigError,
|
|
37
|
-
ConfigLoader: () => ConfigLoader,
|
|
38
|
-
FileSystem: () => FileSystem,
|
|
39
|
-
FusionError: () => FusionError,
|
|
40
|
-
LogLevel: () => LogLevel,
|
|
41
|
-
Logger: () => Logger,
|
|
42
|
-
ProcessManager: () => ProcessManager,
|
|
43
|
-
ValidationError: () => ValidationError,
|
|
44
|
-
config: () => config,
|
|
45
|
-
createLogger: () => createLogger,
|
|
46
|
-
filesystem: () => filesystem,
|
|
47
|
-
load: () => load,
|
|
48
|
-
logger: () => logger
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
// src/core/config.ts
|
|
52
|
-
import * as fs from "fs";
|
|
53
|
-
import * as path from "path";
|
|
54
|
-
var ConfigLoader = class {
|
|
55
|
-
static {
|
|
56
|
-
__name(this, "ConfigLoader");
|
|
57
|
-
}
|
|
58
|
-
config = /* @__PURE__ */ new Map();
|
|
59
|
-
configDir;
|
|
60
|
-
constructor(configDir = process.cwd()) {
|
|
61
|
-
this.configDir = configDir;
|
|
62
|
-
}
|
|
63
|
-
/**
|
|
64
|
-
* Load configuration from file or environment
|
|
65
|
-
*/
|
|
66
|
-
load(key, defaultValue) {
|
|
67
|
-
if (this.config.has(key)) {
|
|
68
|
-
return this.config.get(key);
|
|
69
|
-
}
|
|
70
|
-
const envKey = `FUSION_${key.toUpperCase()}`;
|
|
71
|
-
if (process.env[envKey]) {
|
|
72
|
-
const value = this.parseEnvValue(process.env[envKey]);
|
|
73
|
-
this.config.set(key, value);
|
|
74
|
-
return value;
|
|
75
|
-
}
|
|
76
|
-
const configPath = path.join(this.configDir, "fusion.config.json");
|
|
77
|
-
if (fs.existsSync(configPath)) {
|
|
78
|
-
try {
|
|
79
|
-
const fileConfig = JSON.parse(fs.readFileSync(configPath, "utf-8"));
|
|
80
|
-
if (fileConfig[key] !== void 0) {
|
|
81
|
-
this.config.set(key, fileConfig[key]);
|
|
82
|
-
return fileConfig[key];
|
|
83
|
-
}
|
|
84
|
-
} catch (error) {
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
return defaultValue;
|
|
88
|
-
}
|
|
89
|
-
/**
|
|
90
|
-
* Set configuration value
|
|
91
|
-
*/
|
|
92
|
-
set(key, value) {
|
|
93
|
-
this.config.set(key, value);
|
|
94
|
-
}
|
|
95
|
-
/**
|
|
96
|
-
* Get all configuration
|
|
97
|
-
*/
|
|
98
|
-
getAll() {
|
|
99
|
-
return Object.fromEntries(this.config);
|
|
100
|
-
}
|
|
101
|
-
/**
|
|
102
|
-
* Parse environment value (handles JSON strings)
|
|
103
|
-
*/
|
|
104
|
-
parseEnvValue(value) {
|
|
105
|
-
try {
|
|
106
|
-
return JSON.parse(value);
|
|
107
|
-
} catch {
|
|
108
|
-
return value;
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
};
|
|
112
|
-
var config = new ConfigLoader();
|
|
113
|
-
function load(key, defaultValue) {
|
|
114
|
-
return config.load(key, defaultValue);
|
|
115
|
-
}
|
|
116
|
-
__name(load, "load");
|
|
117
|
-
|
|
118
|
-
// src/core/process-manager.ts
|
|
119
|
-
var ProcessManager = class {
|
|
120
|
-
static {
|
|
121
|
-
__name(this, "ProcessManager");
|
|
122
|
-
}
|
|
123
|
-
/**
|
|
124
|
-
* Setup process error handlers
|
|
125
|
-
*/
|
|
126
|
-
static initialize() {
|
|
127
|
-
process.on("uncaughtException", (error) => {
|
|
128
|
-
console.error("[Fusion] Uncaught Exception:", error);
|
|
129
|
-
process.exit(1);
|
|
130
|
-
});
|
|
131
|
-
process.on("unhandledRejection", (reason, promise) => {
|
|
132
|
-
console.error("[Fusion] Unhandled Rejection at:", promise, "reason:", reason);
|
|
133
|
-
});
|
|
134
|
-
process.on("SIGTERM", () => {
|
|
135
|
-
console.log("[Fusion] SIGTERM received, shutting down gracefully");
|
|
136
|
-
process.exit(0);
|
|
137
|
-
});
|
|
138
|
-
process.on("SIGINT", () => {
|
|
139
|
-
console.log("[Fusion] SIGINT received, shutting down gracefully");
|
|
140
|
-
process.exit(0);
|
|
141
|
-
});
|
|
142
|
-
}
|
|
143
|
-
/**
|
|
144
|
-
* Graceful shutdown helper
|
|
145
|
-
*/
|
|
146
|
-
static async shutdown(cleanup) {
|
|
147
|
-
try {
|
|
148
|
-
await cleanup();
|
|
149
|
-
process.exit(0);
|
|
150
|
-
} catch (error) {
|
|
151
|
-
console.error("[Fusion] Error during shutdown:", error);
|
|
152
|
-
process.exit(1);
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
};
|
|
156
|
-
|
|
157
|
-
// src/core/errors.ts
|
|
158
|
-
var FusionError = class extends Error {
|
|
159
|
-
static {
|
|
160
|
-
__name(this, "FusionError");
|
|
161
|
-
}
|
|
162
|
-
code;
|
|
163
|
-
constructor(message, code) {
|
|
164
|
-
super(message), this.code = code;
|
|
165
|
-
this.name = "FusionError";
|
|
166
|
-
}
|
|
167
|
-
};
|
|
168
|
-
var ConfigError = class extends FusionError {
|
|
169
|
-
static {
|
|
170
|
-
__name(this, "ConfigError");
|
|
171
|
-
}
|
|
172
|
-
constructor(message) {
|
|
173
|
-
super(message, "CONFIG_ERROR");
|
|
174
|
-
this.name = "ConfigError";
|
|
175
|
-
}
|
|
176
|
-
};
|
|
177
|
-
var ValidationError = class extends FusionError {
|
|
178
|
-
static {
|
|
179
|
-
__name(this, "ValidationError");
|
|
180
|
-
}
|
|
181
|
-
constructor(message) {
|
|
182
|
-
super(message, "VALIDATION_ERROR");
|
|
183
|
-
this.name = "ValidationError";
|
|
184
|
-
}
|
|
185
|
-
};
|
|
186
|
-
var APIError = class extends FusionError {
|
|
187
|
-
static {
|
|
188
|
-
__name(this, "APIError");
|
|
189
|
-
}
|
|
190
|
-
statusCode;
|
|
191
|
-
constructor(message, statusCode) {
|
|
192
|
-
super(message, "API_ERROR"), this.statusCode = statusCode;
|
|
193
|
-
this.name = "APIError";
|
|
194
|
-
}
|
|
195
|
-
};
|
|
196
|
-
|
|
197
|
-
// src/config/index.ts
|
|
198
|
-
var config_exports = {};
|
|
199
|
-
__export(config_exports, {
|
|
200
|
-
loader: () => loader
|
|
201
|
-
});
|
|
202
|
-
|
|
203
|
-
// src/config/loader.ts
|
|
204
|
-
var loader = {
|
|
205
|
-
load: /* @__PURE__ */ __name(() => ({}), "load")
|
|
206
|
-
};
|
|
207
|
-
|
|
208
|
-
// src/insight/index.ts
|
|
209
|
-
var insight_exports = {};
|
|
210
|
-
__export(insight_exports, {
|
|
211
|
-
server: () => server
|
|
212
|
-
});
|
|
213
|
-
|
|
214
|
-
// src/insight/server.ts
|
|
215
|
-
var server = {
|
|
216
|
-
start: /* @__PURE__ */ __name(() => console.log("Insight server started"), "start")
|
|
217
|
-
};
|
|
218
|
-
|
|
219
|
-
// src/create-fusion/index.ts
|
|
220
|
-
var create_fusion_exports = {};
|
|
221
|
-
__export(create_fusion_exports, {
|
|
222
|
-
ProjectScaffolder: () => ProjectScaffolder
|
|
223
|
-
});
|
|
224
|
-
|
|
225
|
-
// src/create-fusion/scaffold.ts
|
|
226
|
-
import { mkdir, writeFile } from "fs/promises";
|
|
227
|
-
import { join as join2 } from "path";
|
|
228
|
-
var ProjectScaffolder = class {
|
|
229
|
-
static {
|
|
230
|
-
__name(this, "ProjectScaffolder");
|
|
231
|
-
}
|
|
232
|
-
async scaffold(options) {
|
|
233
|
-
const { projectName, template } = options;
|
|
234
|
-
const projectPath = join2(process.cwd(), projectName);
|
|
235
|
-
logger.info(`Creating project at: ${projectPath}`);
|
|
236
|
-
await mkdir(projectPath, {
|
|
237
|
-
recursive: true
|
|
238
|
-
});
|
|
239
|
-
if (template === "monorepo") {
|
|
240
|
-
await this.createMonorepo(projectPath, projectName);
|
|
241
|
-
} else if (template === "api") {
|
|
242
|
-
await this.createNestJSApp(projectPath, projectName);
|
|
243
|
-
} else if (template === "web") {
|
|
244
|
-
await this.createNextJSApp(projectPath, projectName);
|
|
245
|
-
}
|
|
246
|
-
logger.success(`Project ${projectName} created successfully!`);
|
|
247
|
-
logger.info(`
|
|
248
|
-
Next steps:`);
|
|
249
|
-
logger.info(` cd ${projectName}`);
|
|
250
|
-
logger.info(` wexts dev`);
|
|
251
|
-
}
|
|
252
|
-
async createMonorepo(projectPath, projectName) {
|
|
253
|
-
await mkdir(join2(projectPath, "apps", "api"), {
|
|
254
|
-
recursive: true
|
|
255
|
-
});
|
|
256
|
-
await mkdir(join2(projectPath, "apps", "web"), {
|
|
257
|
-
recursive: true
|
|
258
|
-
});
|
|
259
|
-
await mkdir(join2(projectPath, "packages", "types"), {
|
|
260
|
-
recursive: true
|
|
261
|
-
});
|
|
262
|
-
await mkdir(join2(projectPath, "packages", "api-client"), {
|
|
263
|
-
recursive: true
|
|
264
|
-
});
|
|
265
|
-
const packageJson = {
|
|
266
|
-
name: projectName,
|
|
267
|
-
version: "0.0.1",
|
|
268
|
-
private: true,
|
|
269
|
-
workspaces: [
|
|
270
|
-
"apps/*",
|
|
271
|
-
"packages/*"
|
|
272
|
-
],
|
|
273
|
-
scripts: {
|
|
274
|
-
dev: "wexts dev",
|
|
275
|
-
build: "wexts build"
|
|
276
|
-
},
|
|
277
|
-
devDependencies: {
|
|
278
|
-
"wexts": "^3.0.3"
|
|
279
|
-
}
|
|
280
|
-
};
|
|
281
|
-
await writeFile(join2(projectPath, "package.json"), JSON.stringify(packageJson, null, 2));
|
|
282
|
-
const readme = `# ${projectName}
|
|
283
|
-
|
|
284
|
-
Created with the deprecated ProjectScaffolder compatibility API.
|
|
285
|
-
|
|
286
|
-
Use examples/hello-rpc as the canonical Wexts reference.
|
|
287
|
-
|
|
288
|
-
## Getting Started
|
|
289
|
-
|
|
290
|
-
\`\`\`bash
|
|
291
|
-
wexts dev
|
|
292
|
-
\`\`\`
|
|
293
|
-
`;
|
|
294
|
-
await writeFile(join2(projectPath, "README.md"), readme);
|
|
295
|
-
}
|
|
296
|
-
async createNestJSApp(projectPath, projectName) {
|
|
297
|
-
await writeFile(join2(projectPath, "README.md"), `# ${projectName}
|
|
298
|
-
|
|
299
|
-
Standalone API scaffolding through ProjectScaffolder is deprecated. Use examples/hello-rpc or wexts create for the canonical path.
|
|
300
|
-
`);
|
|
301
|
-
}
|
|
302
|
-
async createNextJSApp(projectPath, projectName) {
|
|
303
|
-
await writeFile(join2(projectPath, "README.md"), `# ${projectName}
|
|
304
|
-
|
|
305
|
-
Standalone web scaffolding through ProjectScaffolder is deprecated. Use examples/hello-rpc or wexts create for the canonical path.
|
|
306
|
-
`);
|
|
307
|
-
}
|
|
308
|
-
};
|
|
309
|
-
|
|
310
|
-
// src/next/index.ts
|
|
311
|
-
var next_exports = {};
|
|
312
|
-
__export(next_exports, {
|
|
313
|
-
FusionProvider: () => FusionProvider,
|
|
314
|
-
useAuth: () => useAuth,
|
|
315
|
-
useFusion: () => useFusion,
|
|
316
|
-
useWexts: () => useWexts
|
|
317
|
-
});
|
|
318
|
-
|
|
319
|
-
// src/next/provider.tsx
|
|
320
|
-
import React, { createContext, useContext } from "react";
|
|
321
|
-
var FusionContext = /* @__PURE__ */ createContext(null);
|
|
322
|
-
function FusionProvider({ children, baseUrl = "/api", rpcBaseUrl = "/rpc", rpcClient }) {
|
|
323
|
-
const client = React.useMemo(() => new FusionFetcher(baseUrl), [
|
|
324
|
-
baseUrl
|
|
325
|
-
]);
|
|
326
|
-
const wexts = React.useMemo(() => rpcClient ?? createWextsRpcClient(void 0, {
|
|
327
|
-
baseUrl: rpcBaseUrl
|
|
328
|
-
}), [
|
|
329
|
-
rpcBaseUrl,
|
|
330
|
-
rpcClient
|
|
331
|
-
]);
|
|
332
|
-
return /* @__PURE__ */ React.createElement(FusionContext.Provider, {
|
|
333
|
-
value: {
|
|
334
|
-
client,
|
|
335
|
-
wexts
|
|
336
|
-
}
|
|
337
|
-
}, children);
|
|
338
|
-
}
|
|
339
|
-
__name(FusionProvider, "FusionProvider");
|
|
340
|
-
function useFusion() {
|
|
341
|
-
const context = useContext(FusionContext);
|
|
342
|
-
if (!context) {
|
|
343
|
-
throw new Error("useFusion must be used within FusionProvider");
|
|
344
|
-
}
|
|
345
|
-
return context;
|
|
346
|
-
}
|
|
347
|
-
__name(useFusion, "useFusion");
|
|
348
|
-
function useWexts() {
|
|
349
|
-
const context = useFusion();
|
|
350
|
-
return context.wexts;
|
|
351
|
-
}
|
|
352
|
-
__name(useWexts, "useWexts");
|
|
353
|
-
|
|
354
|
-
// src/next/useAuth.ts
|
|
355
|
-
import { useState, useEffect } from "react";
|
|
356
|
-
function useAuth() {
|
|
357
|
-
const { client } = useFusion();
|
|
358
|
-
const [user, setUser] = useState(null);
|
|
359
|
-
const [loading, setLoading] = useState(true);
|
|
360
|
-
useEffect(() => {
|
|
361
|
-
const token = localStorage.getItem("fusion_token");
|
|
362
|
-
if (token) {
|
|
363
|
-
loadUser();
|
|
364
|
-
} else {
|
|
365
|
-
setLoading(false);
|
|
366
|
-
}
|
|
367
|
-
}, []);
|
|
368
|
-
const loadUser = /* @__PURE__ */ __name(async () => {
|
|
369
|
-
try {
|
|
370
|
-
const userData = await client.get("/auth/me");
|
|
371
|
-
setUser(userData);
|
|
372
|
-
} catch (error) {
|
|
373
|
-
localStorage.removeItem("fusion_token");
|
|
374
|
-
} finally {
|
|
375
|
-
setLoading(false);
|
|
376
|
-
}
|
|
377
|
-
}, "loadUser");
|
|
378
|
-
const login = /* @__PURE__ */ __name(async (email, password) => {
|
|
379
|
-
const response = await client.post("/auth/login", {
|
|
380
|
-
email,
|
|
381
|
-
password
|
|
382
|
-
});
|
|
383
|
-
localStorage.setItem("fusion_token", response.token);
|
|
384
|
-
setUser(response.user);
|
|
385
|
-
}, "login");
|
|
386
|
-
const logout = /* @__PURE__ */ __name(async () => {
|
|
387
|
-
localStorage.removeItem("fusion_token");
|
|
388
|
-
setUser(null);
|
|
389
|
-
}, "logout");
|
|
390
|
-
return {
|
|
391
|
-
user,
|
|
392
|
-
loading,
|
|
393
|
-
login,
|
|
394
|
-
logout,
|
|
395
|
-
isAuthenticated: !!user
|
|
396
|
-
};
|
|
397
|
-
}
|
|
398
|
-
__name(useAuth, "useAuth");
|
|
399
|
-
export {
|
|
400
|
-
codegen_exports as Codegen,
|
|
401
|
-
config_exports as Config,
|
|
402
|
-
core_exports as Core,
|
|
403
|
-
create_fusion_exports as CreateFusion,
|
|
404
|
-
dev_server_exports as DevServer,
|
|
405
|
-
insight_exports as Insight,
|
|
406
|
-
nest_exports as Nest,
|
|
407
|
-
next_exports as Next,
|
|
408
|
-
rpc_exports as Rpc
|
|
409
|
-
};
|
|
410
|
-
//# sourceMappingURL=index.mjs.map
|
package/dist/index.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../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"],"sourcesContent":["// 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': '^3.0.3',\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"],"mappings":"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","names":["fs","path","ConfigLoader","config","Map","configDir","process","cwd","load","key","defaultValue","has","get","envKey","toUpperCase","env","value","parseEnvValue","set","configPath","join","existsSync","fileConfig","JSON","parse","readFileSync","undefined","error","getAll","Object","fromEntries","ProcessManager","initialize","process","on","error","console","exit","reason","promise","log","shutdown","cleanup","FusionError","Error","message","code","name","ConfigError","ValidationError","APIError","statusCode","loader","load","server","start","console","log","mkdir","writeFile","join","ProjectScaffolder","scaffold","options","projectName","template","projectPath","join","process","cwd","logger","info","mkdir","recursive","createMonorepo","createNestJSApp","createNextJSApp","success","packageJson","name","version","private","workspaces","scripts","dev","build","devDependencies","writeFile","JSON","stringify","readme","React","createContext","useContext","FusionContext","createContext","FusionProvider","children","baseUrl","rpcBaseUrl","rpcClient","client","React","useMemo","FusionFetcher","wexts","createWextsRpcClient","undefined","Provider","value","useFusion","context","useContext","Error","useWexts","useState","useEffect","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"]}
|
package/dist/nest/index.d.mts
DELETED
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
export { F as FusionController, a as FusionDelete, b as FusionGet, c as FusionPost, d as FusionPut, e as FusionRoute, f as FusionRouteMetadata, g as getFusionMetadata } from '../index-D94W1__r.mjs';
|
|
2
|
-
export { R as RequireAuth, a as RpcMethod, b as RpcMethodOptions, c as RpcService, d as RpcServiceOptions, e as RuntimeRpcMethodMetadata, f as RuntimeRpcServiceMetadata, W as WextsRpc, g as WextsRpcService, h as getRpcAuthPolicy, i as getRuntimeRpcMethodsMetadata, j as getRuntimeRpcServiceMetadata } from '../decorators-BT1FFqN0.mjs';
|
|
3
|
-
import '../types-7d_fC-C3.mjs';
|
package/dist/nest/index.d.ts
DELETED
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
export { F as FusionController, a as FusionDelete, b as FusionGet, c as FusionPost, d as FusionPut, e as FusionRoute, f as FusionRouteMetadata, g as getFusionMetadata } from '../index-Co5ZsLqq.js';
|
|
2
|
-
export { R as RequireAuth, a as RpcMethod, b as RpcMethodOptions, c as RpcService, d as RpcServiceOptions, e as RuntimeRpcMethodMetadata, f as RuntimeRpcServiceMetadata, W as WextsRpc, g as WextsRpcService, h as getRpcAuthPolicy, i as getRuntimeRpcMethodsMetadata, j as getRuntimeRpcServiceMetadata } from '../decorators-DvS58PqC.js';
|
|
3
|
-
import '../types-7d_fC-C3.js';
|
package/dist/nest/index.js
DELETED
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
var _chunkBG56B4DEjs = require('../chunk-BG56B4DE.js');
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
var _chunk7QKLIVRFjs = require('../chunk-7QKLIVRF.js');
|
|
20
|
-
require('../chunk-XE4OXN2W.js');
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
exports.FusionController = _chunkBG56B4DEjs.FusionController; exports.FusionDelete = _chunkBG56B4DEjs.FusionDelete; exports.FusionGet = _chunkBG56B4DEjs.FusionGet; exports.FusionPost = _chunkBG56B4DEjs.FusionPost; exports.FusionPut = _chunkBG56B4DEjs.FusionPut; exports.FusionRoute = _chunkBG56B4DEjs.FusionRoute; exports.RequireAuth = _chunk7QKLIVRFjs.RequireAuth; exports.RpcMethod = _chunk7QKLIVRFjs.RpcMethod; exports.RpcService = _chunk7QKLIVRFjs.RpcService; exports.WextsRpc = _chunk7QKLIVRFjs.WextsRpc; exports.WextsRpcService = _chunk7QKLIVRFjs.WextsRpcService; exports.getFusionMetadata = _chunkBG56B4DEjs.getFusionMetadata; exports.getRpcAuthPolicy = _chunk7QKLIVRFjs.getRpcAuthPolicy; exports.getRuntimeRpcMethodsMetadata = _chunk7QKLIVRFjs.getRuntimeRpcMethodsMetadata; exports.getRuntimeRpcServiceMetadata = _chunk7QKLIVRFjs.getRuntimeRpcServiceMetadata;
|
|
38
|
-
//# sourceMappingURL=index.js.map
|
package/dist/nest/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["/Volumes/Projects/wexts/packages/dist/nest/index.js"],"names":[],"mappings":"AAAA;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACF,uDAA6B;AAC7B;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,uDAA6B;AAC7B,gCAA6B;AAC7B;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,m2BAAC","file":"/Volumes/Projects/wexts/packages/dist/nest/index.js"}
|
package/dist/nest/index.mjs
DELETED
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
FusionController,
|
|
3
|
-
FusionDelete,
|
|
4
|
-
FusionGet,
|
|
5
|
-
FusionPost,
|
|
6
|
-
FusionPut,
|
|
7
|
-
FusionRoute,
|
|
8
|
-
getFusionMetadata
|
|
9
|
-
} from "../chunk-UAL54DVV.mjs";
|
|
10
|
-
import {
|
|
11
|
-
RequireAuth,
|
|
12
|
-
RpcMethod,
|
|
13
|
-
RpcService,
|
|
14
|
-
WextsRpc,
|
|
15
|
-
WextsRpcService,
|
|
16
|
-
getRpcAuthPolicy,
|
|
17
|
-
getRuntimeRpcMethodsMetadata,
|
|
18
|
-
getRuntimeRpcServiceMetadata
|
|
19
|
-
} from "../chunk-YBM3IJEA.mjs";
|
|
20
|
-
import "../chunk-7WULUGLH.mjs";
|
|
21
|
-
export {
|
|
22
|
-
FusionController,
|
|
23
|
-
FusionDelete,
|
|
24
|
-
FusionGet,
|
|
25
|
-
FusionPost,
|
|
26
|
-
FusionPut,
|
|
27
|
-
FusionRoute,
|
|
28
|
-
RequireAuth,
|
|
29
|
-
RpcMethod,
|
|
30
|
-
RpcService,
|
|
31
|
-
WextsRpc,
|
|
32
|
-
WextsRpcService,
|
|
33
|
-
getFusionMetadata,
|
|
34
|
-
getRpcAuthPolicy,
|
|
35
|
-
getRuntimeRpcMethodsMetadata,
|
|
36
|
-
getRuntimeRpcServiceMetadata
|
|
37
|
-
};
|
|
38
|
-
//# sourceMappingURL=index.mjs.map
|
package/dist/nest/index.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
package/dist/next/index.d.mts
DELETED
|
@@ -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 };
|
package/dist/next/index.d.ts
DELETED
|
@@ -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 };
|