wexts 4.1.5 ā 4.1.7
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/dist/chunk-27NEYQD2.mjs +222 -0
- package/dist/chunk-27NEYQD2.mjs.map +1 -0
- package/dist/chunk-2LJVUMXW.js +228 -0
- package/dist/chunk-2LJVUMXW.js.map +1 -0
- package/dist/chunk-5DBFN65W.mjs +183 -0
- package/dist/chunk-5DBFN65W.mjs.map +1 -0
- package/dist/chunk-75HBI2XG.js +504 -0
- package/dist/chunk-75HBI2XG.js.map +1 -0
- package/dist/chunk-AVMQJWYD.js +95 -0
- package/dist/chunk-AVMQJWYD.js.map +1 -0
- package/dist/chunk-C2AG7Q3C.mjs +65 -0
- package/dist/chunk-C2AG7Q3C.mjs.map +1 -0
- package/dist/chunk-DS5KVVWJ.mjs +95 -0
- package/dist/chunk-DS5KVVWJ.mjs.map +1 -0
- package/dist/chunk-FUPLZMSR.mjs +228 -0
- package/dist/chunk-FUPLZMSR.mjs.map +1 -0
- package/dist/chunk-HLT3IHJY.js +183 -0
- package/dist/chunk-HLT3IHJY.js.map +1 -0
- package/dist/chunk-IRRJJ7KL.js +273 -0
- package/dist/chunk-IRRJJ7KL.js.map +1 -0
- package/dist/chunk-L77ANWWT.mjs +22 -0
- package/dist/chunk-L77ANWWT.mjs.map +1 -0
- package/dist/chunk-P3Q4I5FD.js +222 -0
- package/dist/chunk-P3Q4I5FD.js.map +1 -0
- package/dist/chunk-VBIQGUDI.mjs +504 -0
- package/dist/chunk-VBIQGUDI.mjs.map +1 -0
- package/dist/chunk-VJY6PHYF.mjs +273 -0
- package/dist/chunk-VJY6PHYF.mjs.map +1 -0
- package/dist/chunk-WCKSKU3C.js +65 -0
- package/dist/chunk-WCKSKU3C.js.map +1 -0
- package/dist/chunk-XE4OXN2W.js +12 -0
- package/dist/chunk-XE4OXN2W.js.map +1 -0
- package/dist/cli/index.d.mts +23 -0
- package/dist/cli/index.d.ts +23 -0
- package/dist/cli/index.js +634 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/index.mjs +636 -0
- package/dist/cli/index.mjs.map +1 -0
- package/dist/client/index.d.mts +43 -0
- package/dist/client/index.d.ts +43 -0
- package/dist/client/index.js +187 -0
- package/dist/client/index.js.map +1 -0
- package/dist/client/index.mjs +166 -0
- package/dist/client/index.mjs.map +1 -0
- package/dist/codegen/index.d.mts +2 -0
- package/dist/codegen/index.d.ts +2 -0
- package/dist/codegen/index.js +16 -0
- package/dist/codegen/index.js.map +1 -0
- package/dist/codegen/index.mjs +16 -0
- package/dist/codegen/index.mjs.map +1 -0
- package/dist/decorators-BiQtOHuF.d.ts +60 -0
- package/dist/decorators-vBopODtr.d.mts +60 -0
- package/dist/dev-server/index.d.mts +1 -0
- package/dist/dev-server/index.d.ts +1 -0
- package/dist/dev-server/index.js +13 -0
- package/dist/dev-server/index.js.map +1 -0
- package/dist/dev-server/index.mjs +13 -0
- package/dist/dev-server/index.mjs.map +1 -0
- package/dist/errors-D545UvXf.d.mts +37 -0
- package/dist/errors-D545UvXf.d.ts +37 -0
- package/dist/index-7RvU-jGE.d.mts +66 -0
- package/dist/index-7RvU-jGE.d.ts +66 -0
- package/dist/index-BsafLP-a.d.mts +70 -0
- package/dist/index-BsafLP-a.d.ts +70 -0
- package/dist/index-CJKs4wtN.d.ts +92 -0
- package/dist/index-CUR6CnLk.d.ts +27 -0
- package/dist/index-h66Vq9dK.d.mts +92 -0
- package/dist/index-tqmYsTUn.d.mts +27 -0
- package/dist/index.d.mts +289 -0
- package/dist/index.d.ts +289 -0
- package/dist/index.js +544 -0
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +544 -0
- package/dist/index.mjs.map +1 -0
- package/dist/nest/index.d.mts +2 -0
- package/dist/nest/index.d.ts +2 -0
- package/dist/nest/index.js +36 -0
- package/dist/nest/index.js.map +1 -0
- package/dist/nest/index.mjs +36 -0
- package/dist/nest/index.mjs.map +1 -0
- package/dist/next/index.d.mts +66 -0
- package/dist/next/index.d.ts +66 -0
- package/dist/next/index.js +282 -0
- package/dist/next/index.js.map +1 -0
- package/dist/next/index.mjs +251 -0
- package/dist/next/index.mjs.map +1 -0
- package/dist/rpc/index.d.mts +32 -0
- package/dist/rpc/index.d.ts +32 -0
- package/dist/rpc/index.js +19 -0
- package/dist/rpc/index.js.map +1 -0
- package/dist/rpc/index.mjs +1 -0
- package/dist/rpc/index.mjs.map +1 -0
- package/dist/runtime/index.d.mts +55 -0
- package/dist/runtime/index.d.ts +55 -0
- package/dist/runtime/index.js +15 -0
- package/dist/runtime/index.js.map +1 -0
- package/dist/runtime/index.mjs +15 -0
- package/dist/runtime/index.mjs.map +1 -0
- package/dist/server/index.d.mts +7 -0
- package/dist/server/index.d.ts +7 -0
- package/dist/server/index.js +58 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/index.mjs +58 -0
- package/dist/server/index.mjs.map +1 -0
- package/dist/types/index.d.mts +12 -0
- package/dist/types/index.d.ts +12 -0
- package/dist/types/index.js +19 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/index.mjs +1 -0
- package/dist/types/index.mjs.map +1 -0
- package/dist/types-CQ_aexOX.d.mts +32 -0
- package/dist/types-CQ_aexOX.d.ts +32 -0
- package/dist/vercel-builder/index.d.mts +58 -0
- package/dist/vercel-builder/index.d.ts +58 -0
- package/dist/vercel-builder/index.js +330 -0
- package/dist/vercel-builder/index.js.map +1 -0
- package/dist/vercel-builder/index.mjs +330 -0
- package/dist/vercel-builder/index.mjs.map +1 -0
- package/package.json +153 -153
- 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 +19 -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/hello.service.ts +11 -0
- 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 +138 -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
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
var _chunkXE4OXN2Wjs = require('./chunk-XE4OXN2W.js');
|
|
5
|
+
|
|
6
|
+
// src/nest/index.ts
|
|
7
|
+
var nest_exports = {};
|
|
8
|
+
_chunkXE4OXN2Wjs.__export.call(void 0, nest_exports, {
|
|
9
|
+
FusionController: () => FusionController,
|
|
10
|
+
FusionDelete: () => FusionDelete,
|
|
11
|
+
FusionGet: () => FusionGet,
|
|
12
|
+
FusionPost: () => FusionPost,
|
|
13
|
+
FusionPut: () => FusionPut,
|
|
14
|
+
FusionRoute: () => FusionRoute,
|
|
15
|
+
RequireAuth: () => RequireAuth,
|
|
16
|
+
RpcMethod: () => RpcMethod,
|
|
17
|
+
RpcService: () => RpcService,
|
|
18
|
+
WextsRpc: () => WextsRpc,
|
|
19
|
+
WextsRpcService: () => WextsRpcService,
|
|
20
|
+
getFusionMetadata: () => getFusionMetadata,
|
|
21
|
+
getRpcAuthPolicy: () => getRpcAuthPolicy,
|
|
22
|
+
getRuntimeRpcMethodsMetadata: () => getRuntimeRpcMethodsMetadata,
|
|
23
|
+
getRuntimeRpcServiceMetadata: () => getRuntimeRpcServiceMetadata
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
// src/nest/decorators.ts
|
|
27
|
+
require('reflect-metadata');
|
|
28
|
+
var FUSION_METADATA_KEY = "fusion:routes";
|
|
29
|
+
function FusionController(prefix = "") {
|
|
30
|
+
return function(target) {
|
|
31
|
+
Reflect.defineMetadata("fusion:controller", {
|
|
32
|
+
prefix
|
|
33
|
+
}, target);
|
|
34
|
+
return target;
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, FusionController, "FusionController");
|
|
38
|
+
function FusionRoute(metadata) {
|
|
39
|
+
return function(target, propertyKey, descriptor) {
|
|
40
|
+
const routes = Reflect.getMetadata(FUSION_METADATA_KEY, target.constructor) || [];
|
|
41
|
+
routes.push({
|
|
42
|
+
...metadata,
|
|
43
|
+
handler: propertyKey
|
|
44
|
+
});
|
|
45
|
+
Reflect.defineMetadata(FUSION_METADATA_KEY, routes, target.constructor);
|
|
46
|
+
return descriptor;
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, FusionRoute, "FusionRoute");
|
|
50
|
+
function FusionGet(path = "") {
|
|
51
|
+
return FusionRoute({
|
|
52
|
+
method: "GET",
|
|
53
|
+
path
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, FusionGet, "FusionGet");
|
|
57
|
+
function FusionPost(path = "") {
|
|
58
|
+
return FusionRoute({
|
|
59
|
+
method: "POST",
|
|
60
|
+
path
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, FusionPost, "FusionPost");
|
|
64
|
+
function FusionPut(path = "") {
|
|
65
|
+
return FusionRoute({
|
|
66
|
+
method: "PUT",
|
|
67
|
+
path
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, FusionPut, "FusionPut");
|
|
71
|
+
function FusionDelete(path = "") {
|
|
72
|
+
return FusionRoute({
|
|
73
|
+
method: "DELETE",
|
|
74
|
+
path
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, FusionDelete, "FusionDelete");
|
|
78
|
+
function getFusionMetadata(controller) {
|
|
79
|
+
return {
|
|
80
|
+
controller: Reflect.getMetadata("fusion:controller", controller),
|
|
81
|
+
routes: Reflect.getMetadata(FUSION_METADATA_KEY, controller) || []
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, getFusionMetadata, "getFusionMetadata");
|
|
85
|
+
|
|
86
|
+
// src/rpc/decorators.ts
|
|
87
|
+
|
|
88
|
+
var RPC_SERVICE_KEY = "wexts:rpc:service";
|
|
89
|
+
var RPC_METHODS_KEY = "wexts:rpc:methods";
|
|
90
|
+
function RpcService(nameOrOptions) {
|
|
91
|
+
const options = normalizeServiceOptions(nameOrOptions);
|
|
92
|
+
return (target) => {
|
|
93
|
+
Reflect.defineMetadata(RPC_SERVICE_KEY, options, target);
|
|
94
|
+
return target;
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, RpcService, "RpcService");
|
|
98
|
+
function RpcMethod(nameOrOptions) {
|
|
99
|
+
const options = normalizeMethodOptions(nameOrOptions);
|
|
100
|
+
return (target, propertyKey) => {
|
|
101
|
+
const constructor = target.constructor;
|
|
102
|
+
const methods = Reflect.getMetadata(RPC_METHODS_KEY, constructor) || [];
|
|
103
|
+
const nextMethods = methods.filter((method) => method.propertyKey !== propertyKey);
|
|
104
|
+
nextMethods.push({
|
|
105
|
+
propertyKey,
|
|
106
|
+
...options
|
|
107
|
+
});
|
|
108
|
+
Reflect.defineMetadata(RPC_METHODS_KEY, nextMethods, constructor);
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, RpcMethod, "RpcMethod");
|
|
112
|
+
function RequireAuth() {
|
|
113
|
+
return (target, propertyKey) => {
|
|
114
|
+
if (propertyKey) {
|
|
115
|
+
RpcMethod({
|
|
116
|
+
requireAuth: true
|
|
117
|
+
})(target, propertyKey, Object.getOwnPropertyDescriptor(target, propertyKey));
|
|
118
|
+
return;
|
|
119
|
+
}
|
|
120
|
+
const existing = getRuntimeRpcServiceMetadata(target);
|
|
121
|
+
Reflect.defineMetadata(RPC_SERVICE_KEY, {
|
|
122
|
+
...existing,
|
|
123
|
+
requireAuth: true
|
|
124
|
+
}, target);
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, RequireAuth, "RequireAuth");
|
|
128
|
+
function getRuntimeRpcServiceMetadata(target) {
|
|
129
|
+
return Reflect.getMetadata(RPC_SERVICE_KEY, target);
|
|
130
|
+
}
|
|
131
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, getRuntimeRpcServiceMetadata, "getRuntimeRpcServiceMetadata");
|
|
132
|
+
function getRuntimeRpcMethodsMetadata(target) {
|
|
133
|
+
return Reflect.getMetadata(RPC_METHODS_KEY, target) || [];
|
|
134
|
+
}
|
|
135
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, getRuntimeRpcMethodsMetadata, "getRuntimeRpcMethodsMetadata");
|
|
136
|
+
function getRpcAuthPolicy(requireAuth) {
|
|
137
|
+
return requireAuth ? "required" : "public";
|
|
138
|
+
}
|
|
139
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, getRpcAuthPolicy, "getRpcAuthPolicy");
|
|
140
|
+
var WextsRpcService = RpcService;
|
|
141
|
+
var WextsRpc = RpcMethod;
|
|
142
|
+
function normalizeServiceOptions(input) {
|
|
143
|
+
if (typeof input === "string") {
|
|
144
|
+
return {
|
|
145
|
+
name: input,
|
|
146
|
+
requireAuth: false
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
return {
|
|
150
|
+
name: _optionalChain([input, 'optionalAccess', _ => _.name]),
|
|
151
|
+
requireAuth: _nullishCoalesce(_optionalChain([input, 'optionalAccess', _2 => _2.requireAuth]), () => ( true))
|
|
152
|
+
};
|
|
153
|
+
}
|
|
154
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, normalizeServiceOptions, "normalizeServiceOptions");
|
|
155
|
+
function normalizeMethodOptions(input) {
|
|
156
|
+
if (typeof input === "string") {
|
|
157
|
+
return {
|
|
158
|
+
name: input
|
|
159
|
+
};
|
|
160
|
+
}
|
|
161
|
+
return _nullishCoalesce(input, () => ( {}));
|
|
162
|
+
}
|
|
163
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, normalizeMethodOptions, "normalizeMethodOptions");
|
|
164
|
+
|
|
165
|
+
|
|
166
|
+
|
|
167
|
+
|
|
168
|
+
|
|
169
|
+
|
|
170
|
+
|
|
171
|
+
|
|
172
|
+
|
|
173
|
+
|
|
174
|
+
|
|
175
|
+
|
|
176
|
+
|
|
177
|
+
|
|
178
|
+
|
|
179
|
+
|
|
180
|
+
|
|
181
|
+
|
|
182
|
+
exports.FusionController = FusionController; exports.FusionRoute = FusionRoute; exports.FusionGet = FusionGet; exports.FusionPost = FusionPost; exports.FusionPut = FusionPut; exports.FusionDelete = FusionDelete; exports.getFusionMetadata = getFusionMetadata; exports.RpcService = RpcService; exports.RpcMethod = RpcMethod; exports.RequireAuth = RequireAuth; exports.getRuntimeRpcServiceMetadata = getRuntimeRpcServiceMetadata; exports.getRuntimeRpcMethodsMetadata = getRuntimeRpcMethodsMetadata; exports.getRpcAuthPolicy = getRpcAuthPolicy; exports.WextsRpcService = WextsRpcService; exports.WextsRpc = WextsRpc; exports.nest_exports = nest_exports;
|
|
183
|
+
//# sourceMappingURL=chunk-HLT3IHJY.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Volumes/Projects/wexts/packages/dist/chunk-HLT3IHJY.js","../src/nest/index.ts","../src/nest/decorators.ts","../src/rpc/decorators.ts"],"names":["FUSION_METADATA_KEY","FusionController","prefix","target","Reflect","defineMetadata","FusionRoute","metadata","propertyKey","descriptor","routes","getMetadata","push","handler","FusionGet","path","method","FusionPost","FusionPut","FusionDelete","getFusionMetadata","controller","RPC_SERVICE_KEY","RPC_METHODS_KEY","RpcService","nameOrOptions","options","normalizeServiceOptions","RpcMethod","normalizeMethodOptions","constructor","methods","nextMethods","filter","RequireAuth","requireAuth","Object","getOwnPropertyDescriptor","existing","getRuntimeRpcServiceMetadata","getRuntimeRpcMethodsMetadata","getRpcAuthPolicy","WextsRpcService","WextsRpc","input","name"],"mappings":"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","file":"/Volumes/Projects/wexts/packages/dist/chunk-HLT3IHJY.js","sourcesContent":[null,"export * from './decorators';\nexport * from '../rpc/decorators';\n","// NestJS Integration - Decorators for wexts\n// These decorators add metadata for auto API client generation\n\nimport 'reflect-metadata';\n\nexport interface FusionRouteMetadata {\n method: 'GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH';\n path: string;\n responseType?: string;\n requestType?: string;\n}\n\nconst FUSION_METADATA_KEY = 'fusion:routes';\n\n/**\n * Mark a NestJS controller for Fusion codegen\n * Usage: @FusionController('users')\n */\nexport function FusionController(prefix: string = ''): ClassDecorator {\n return function (target: any) {\n Reflect.defineMetadata('fusion:controller', { prefix }, target);\n return target;\n };\n}\n\n/**\n * Mark a route for API client generation\n * Usage: @FusionRoute({ method: 'GET', path: '/:id' })\n */\nexport function FusionRoute(metadata: FusionRouteMetadata): MethodDecorator {\n return function (target: any, propertyKey: string | symbol, descriptor: PropertyDescriptor) {\n const routes = Reflect.getMetadata(FUSION_METADATA_KEY, target.constructor) || [];\n routes.push({\n ...metadata,\n handler: propertyKey,\n });\n Reflect.defineMetadata(FUSION_METADATA_KEY, routes, target.constructor);\n return descriptor;\n };\n}\n\n/**\n * Helper decorators for common HTTP methods\n */\nexport function FusionGet(path: string = ''): MethodDecorator {\n return FusionRoute({ method: 'GET', path });\n}\n\nexport function FusionPost(path: string = ''): MethodDecorator {\n return FusionRoute({ method: 'POST', path });\n}\n\nexport function FusionPut(path: string = ''): MethodDecorator {\n return FusionRoute({ method: 'PUT', path });\n}\n\nexport function FusionDelete(path: string = ''): MethodDecorator {\n return FusionRoute({ method: 'DELETE', path });\n}\n\n/**\n * Get Fusion metadata from a controller\n */\nexport function getFusionMetadata(controller: any): {\n controller: any;\n routes: any[];\n} {\n return {\n controller: Reflect.getMetadata('fusion:controller', controller),\n routes: Reflect.getMetadata(FUSION_METADATA_KEY, controller) || [],\n };\n}\n","import 'reflect-metadata';\nimport type { RpcAuthPolicy } from './types';\n\nconst RPC_SERVICE_KEY = 'wexts:rpc:service';\nconst RPC_METHODS_KEY = 'wexts:rpc:methods';\n\nexport interface RpcServiceOptions {\n name?: string;\n requireAuth?: boolean;\n}\n\nexport interface RpcMethodOptions {\n name?: string;\n requireAuth?: boolean;\n}\n\nexport interface RuntimeRpcServiceMetadata {\n name?: string;\n requireAuth: boolean;\n}\n\nexport interface RuntimeRpcMethodMetadata {\n propertyKey: string | symbol;\n name?: string;\n requireAuth?: boolean;\n}\n\nexport function RpcService(nameOrOptions?: string | RpcServiceOptions): ClassDecorator {\n const options = normalizeServiceOptions(nameOrOptions);\n\n return (target) => {\n Reflect.defineMetadata(RPC_SERVICE_KEY, options, target);\n return target;\n };\n}\n\nexport function RpcMethod(nameOrOptions?: string | RpcMethodOptions): MethodDecorator {\n const options = normalizeMethodOptions(nameOrOptions);\n\n return (target, propertyKey) => {\n const constructor = target.constructor;\n const methods: RuntimeRpcMethodMetadata[] = Reflect.getMetadata(RPC_METHODS_KEY, constructor) || [];\n const nextMethods = methods.filter((method) => method.propertyKey !== propertyKey);\n nextMethods.push({ propertyKey, ...options });\n Reflect.defineMetadata(RPC_METHODS_KEY, nextMethods, constructor);\n };\n}\n\nexport function RequireAuth(): MethodDecorator & ClassDecorator {\n return (target: object, propertyKey?: string | symbol) => {\n if (propertyKey) {\n RpcMethod({ requireAuth: true })(target, propertyKey, Object.getOwnPropertyDescriptor(target, propertyKey)!);\n return;\n }\n\n const existing = getRuntimeRpcServiceMetadata(target as Function);\n Reflect.defineMetadata(RPC_SERVICE_KEY, { ...existing, requireAuth: true }, target);\n };\n}\n\nexport function getRuntimeRpcServiceMetadata(target: Function): RuntimeRpcServiceMetadata | undefined {\n return Reflect.getMetadata(RPC_SERVICE_KEY, target);\n}\n\nexport function getRuntimeRpcMethodsMetadata(target: Function): RuntimeRpcMethodMetadata[] {\n return Reflect.getMetadata(RPC_METHODS_KEY, target) || [];\n}\n\nexport function getRpcAuthPolicy(requireAuth?: boolean): RpcAuthPolicy {\n return requireAuth ? 'required' : 'public';\n}\n\nexport const WextsRpcService = RpcService;\nexport const WextsRpc = RpcMethod;\n\nfunction normalizeServiceOptions(input?: string | RpcServiceOptions): RuntimeRpcServiceMetadata {\n if (typeof input === 'string') {\n return { name: input, requireAuth: false };\n }\n\n return {\n name: input?.name,\n requireAuth: input?.requireAuth ?? true,\n };\n}\n\nfunction normalizeMethodOptions(input?: string | RpcMethodOptions): RpcMethodOptions {\n if (typeof input === 'string') {\n return { name: input };\n }\n\n return input ?? {};\n}\n"]}
|
|
@@ -0,0 +1,273 @@
|
|
|
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 _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; var _class2;
|
|
2
|
+
|
|
3
|
+
var _chunkWCKSKU3Cjs = require('./chunk-WCKSKU3C.js');
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
var _chunkXE4OXN2Wjs = require('./chunk-XE4OXN2W.js');
|
|
8
|
+
|
|
9
|
+
// src/dev-server/index.ts
|
|
10
|
+
var dev_server_exports = {};
|
|
11
|
+
_chunkXE4OXN2Wjs.__export.call(void 0, dev_server_exports, {
|
|
12
|
+
FusionDevServer: () => FusionDevServer,
|
|
13
|
+
ProcessRunner: () => ProcessRunner,
|
|
14
|
+
ProxyServer: () => ProxyServer
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
// src/dev-server/process-runner.ts
|
|
18
|
+
var _child_process = require('child_process');
|
|
19
|
+
var _picocolors = require('picocolors'); var pc = _interopRequireWildcard(_picocolors); var pc2 = _interopRequireWildcard(_picocolors);
|
|
20
|
+
var ProcessRunner = (_class = class {constructor() { _class.prototype.__init.call(this);_class.prototype.__init2.call(this); }
|
|
21
|
+
static {
|
|
22
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, this, "ProcessRunner");
|
|
23
|
+
}
|
|
24
|
+
__init() {this.processes = /* @__PURE__ */ new Map()}
|
|
25
|
+
__init2() {this.colors = {
|
|
26
|
+
cyan: pc.cyan,
|
|
27
|
+
green: pc.green,
|
|
28
|
+
yellow: pc.yellow,
|
|
29
|
+
magenta: pc.magenta,
|
|
30
|
+
blue: pc.blue
|
|
31
|
+
}}
|
|
32
|
+
async run(configs) {
|
|
33
|
+
_chunkWCKSKU3Cjs.logger.info("\u{1F680} Starting development servers...\n");
|
|
34
|
+
for (const config of configs) {
|
|
35
|
+
this.startProcess(config);
|
|
36
|
+
}
|
|
37
|
+
process.on("SIGINT", () => this.stopAll());
|
|
38
|
+
process.on("SIGTERM", () => this.stopAll());
|
|
39
|
+
}
|
|
40
|
+
startProcess(config) {
|
|
41
|
+
const { name, command, args, cwd, color, env } = config;
|
|
42
|
+
const colorFn = this.colors[color];
|
|
43
|
+
const prefix = colorFn(`[${name}]`);
|
|
44
|
+
_chunkWCKSKU3Cjs.logger.info(`${prefix} Starting...`);
|
|
45
|
+
const proc = _child_process.spawn.call(void 0, command, args, {
|
|
46
|
+
cwd,
|
|
47
|
+
stdio: "pipe",
|
|
48
|
+
shell: true,
|
|
49
|
+
env: {
|
|
50
|
+
...process.env,
|
|
51
|
+
...env
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
this.processes.set(name, proc);
|
|
55
|
+
_optionalChain([proc, 'access', _ => _.stdout, 'optionalAccess', _2 => _2.on, 'call', _3 => _3("data", (data) => {
|
|
56
|
+
const lines = data.toString().split("\n").filter((l) => l.trim());
|
|
57
|
+
lines.forEach((line) => {
|
|
58
|
+
console.log(`${prefix} ${line}`);
|
|
59
|
+
});
|
|
60
|
+
})]);
|
|
61
|
+
_optionalChain([proc, 'access', _4 => _4.stderr, 'optionalAccess', _5 => _5.on, 'call', _6 => _6("data", (data) => {
|
|
62
|
+
const lines = data.toString().split("\n").filter((l) => l.trim());
|
|
63
|
+
lines.forEach((line) => {
|
|
64
|
+
console.error(`${prefix} ${pc.red(line)}`);
|
|
65
|
+
});
|
|
66
|
+
})]);
|
|
67
|
+
proc.on("exit", (code) => {
|
|
68
|
+
if (code !== 0 && code !== null) {
|
|
69
|
+
_chunkWCKSKU3Cjs.logger.error(`${prefix} Exited with code ${code}`);
|
|
70
|
+
}
|
|
71
|
+
this.processes.delete(name);
|
|
72
|
+
});
|
|
73
|
+
proc.on("error", (error) => {
|
|
74
|
+
_chunkWCKSKU3Cjs.logger.error(`${prefix} Error:`, error.message);
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
stopAll() {
|
|
78
|
+
_chunkWCKSKU3Cjs.logger.info("\n\u{1F6D1} Stopping all processes...");
|
|
79
|
+
for (const [name, proc] of this.processes.entries()) {
|
|
80
|
+
_chunkWCKSKU3Cjs.logger.info(`Stopping ${name}...`);
|
|
81
|
+
proc.kill("SIGTERM");
|
|
82
|
+
}
|
|
83
|
+
setTimeout(() => {
|
|
84
|
+
process.exit(0);
|
|
85
|
+
}, 1e3);
|
|
86
|
+
}
|
|
87
|
+
isRunning(name) {
|
|
88
|
+
return this.processes.has(name);
|
|
89
|
+
}
|
|
90
|
+
}, _class);
|
|
91
|
+
|
|
92
|
+
// src/dev-server/dev-server.ts
|
|
93
|
+
var _path = require('path'); var path = _interopRequireWildcard(_path);
|
|
94
|
+
var _fs = require('fs'); var fs = _interopRequireWildcard(_fs);
|
|
95
|
+
var DEFAULT_RUNTIME_CONFIG = "./wexts.runtime.js";
|
|
96
|
+
var FusionDevServer = class {
|
|
97
|
+
static {
|
|
98
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, this, "FusionDevServer");
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
constructor() {
|
|
102
|
+
this.processRunner = new ProcessRunner();
|
|
103
|
+
}
|
|
104
|
+
async start(config) {
|
|
105
|
+
const { apiPath, webPath, webPort = 3e3, apiPort = 5050, useProxy = false, rootDir = process.cwd(), runtimeConfigPath = DEFAULT_RUNTIME_CONFIG } = config;
|
|
106
|
+
if (useProxy) {
|
|
107
|
+
throw new Error("The legacy dev proxy is disabled because it conflicts with the Next.js port. Use the production runtime for single-port serving.");
|
|
108
|
+
}
|
|
109
|
+
if (!fs.existsSync(apiPath)) {
|
|
110
|
+
throw new Error(`API path not found: ${apiPath}`);
|
|
111
|
+
}
|
|
112
|
+
if (!fs.existsSync(webPath)) {
|
|
113
|
+
throw new Error(`Web path not found: ${webPath}`);
|
|
114
|
+
}
|
|
115
|
+
const absoluteRuntimeConfigPath = path.isAbsolute(runtimeConfigPath) ? runtimeConfigPath : path.join(path.resolve(rootDir), runtimeConfigPath);
|
|
116
|
+
if (!fs.existsSync(absoluteRuntimeConfigPath)) {
|
|
117
|
+
throw new Error(`Runtime config not found: ${absoluteRuntimeConfigPath}. Create wexts.runtime.js or pass --config.`);
|
|
118
|
+
}
|
|
119
|
+
const processes = this.createProcessConfigs({
|
|
120
|
+
apiPath,
|
|
121
|
+
webPath,
|
|
122
|
+
webPort,
|
|
123
|
+
apiPort,
|
|
124
|
+
rootDir,
|
|
125
|
+
runtimeConfigPath
|
|
126
|
+
});
|
|
127
|
+
await this.processRunner.run(processes);
|
|
128
|
+
_chunkWCKSKU3Cjs.logger.info("\u2554\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2557");
|
|
129
|
+
_chunkWCKSKU3Cjs.logger.info("\u2551 Fusion Development Server Ready \u2551");
|
|
130
|
+
_chunkWCKSKU3Cjs.logger.info("\u255A\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u255D\n");
|
|
131
|
+
_chunkWCKSKU3Cjs.logger.info(`\u{1F310} Web + RPC: http://localhost:${webPort}`);
|
|
132
|
+
_chunkWCKSKU3Cjs.logger.info(`\u{1F50C} API compiler: ${path.resolve(apiPath)}`);
|
|
133
|
+
_chunkWCKSKU3Cjs.logger.info("\n");
|
|
134
|
+
}
|
|
135
|
+
createProcessConfigs(config) {
|
|
136
|
+
const apiPath = path.resolve(config.apiPath);
|
|
137
|
+
const webPath = path.resolve(config.webPath);
|
|
138
|
+
const rootDir = path.resolve(config.rootDir);
|
|
139
|
+
const runtimeConfigPath = path.isAbsolute(config.runtimeConfigPath) ? config.runtimeConfigPath : path.join(rootDir, config.runtimeConfigPath);
|
|
140
|
+
return [
|
|
141
|
+
this.createApiCompilerProcess(apiPath, config.apiPort, rootDir),
|
|
142
|
+
{
|
|
143
|
+
name: "Web",
|
|
144
|
+
command: "pnpm",
|
|
145
|
+
args: [
|
|
146
|
+
"exec",
|
|
147
|
+
"wexts",
|
|
148
|
+
"start",
|
|
149
|
+
"-c",
|
|
150
|
+
runtimeConfigPath,
|
|
151
|
+
"-p",
|
|
152
|
+
config.webPort.toString(),
|
|
153
|
+
"--dev"
|
|
154
|
+
],
|
|
155
|
+
cwd: rootDir,
|
|
156
|
+
color: "green",
|
|
157
|
+
env: {
|
|
158
|
+
NEXT_PUBLIC_API_URL: `http://localhost:${config.apiPort}`,
|
|
159
|
+
WEXTS_WEB_DIR: webPath
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
];
|
|
163
|
+
}
|
|
164
|
+
createApiCompilerProcess(apiPath, apiPort, rootDir) {
|
|
165
|
+
if (fs.existsSync(path.join(apiPath, "package.json"))) {
|
|
166
|
+
return {
|
|
167
|
+
name: "API",
|
|
168
|
+
command: "pnpm",
|
|
169
|
+
args: [
|
|
170
|
+
"run",
|
|
171
|
+
"start:dev"
|
|
172
|
+
],
|
|
173
|
+
cwd: apiPath,
|
|
174
|
+
color: "cyan",
|
|
175
|
+
env: {
|
|
176
|
+
PORT: apiPort.toString()
|
|
177
|
+
}
|
|
178
|
+
};
|
|
179
|
+
}
|
|
180
|
+
return {
|
|
181
|
+
name: "API",
|
|
182
|
+
command: "pnpm",
|
|
183
|
+
args: [
|
|
184
|
+
"exec",
|
|
185
|
+
"tsc",
|
|
186
|
+
"-w",
|
|
187
|
+
"-p",
|
|
188
|
+
path.join(apiPath, "tsconfig.json")
|
|
189
|
+
],
|
|
190
|
+
cwd: rootDir,
|
|
191
|
+
color: "cyan",
|
|
192
|
+
env: {
|
|
193
|
+
PORT: apiPort.toString()
|
|
194
|
+
}
|
|
195
|
+
};
|
|
196
|
+
}
|
|
197
|
+
stop() {
|
|
198
|
+
this.processRunner.stopAll();
|
|
199
|
+
}
|
|
200
|
+
};
|
|
201
|
+
|
|
202
|
+
// src/dev-server/proxy.ts
|
|
203
|
+
var _http = require('http'); var _http2 = _interopRequireDefault(_http);
|
|
204
|
+
var _httpproxy = require('http-proxy'); var _httpproxy2 = _interopRequireDefault(_httpproxy);
|
|
205
|
+
|
|
206
|
+
var ProxyServer = (_class2 = class {constructor() { _class2.prototype.__init3.call(this);_class2.prototype.__init4.call(this); }
|
|
207
|
+
static {
|
|
208
|
+
_chunkXE4OXN2Wjs.__name.call(void 0, this, "ProxyServer");
|
|
209
|
+
}
|
|
210
|
+
__init3() {this.server = null}
|
|
211
|
+
__init4() {this.proxy = null}
|
|
212
|
+
async start(config) {
|
|
213
|
+
const { port, apiTarget, apiPrefix } = config;
|
|
214
|
+
this.proxy = _httpproxy2.default.createProxyServer({
|
|
215
|
+
target: apiTarget,
|
|
216
|
+
changeOrigin: true,
|
|
217
|
+
ws: true
|
|
218
|
+
});
|
|
219
|
+
this.proxy.on("error", (err, req, res) => {
|
|
220
|
+
_chunkWCKSKU3Cjs.logger.error("Proxy error:", err.message);
|
|
221
|
+
if (res && "headersSent" in res && !res.headersSent) {
|
|
222
|
+
res.writeHead(502, {
|
|
223
|
+
"Content-Type": "text/plain"
|
|
224
|
+
});
|
|
225
|
+
res.end("Bad Gateway - API server unavailable");
|
|
226
|
+
}
|
|
227
|
+
});
|
|
228
|
+
this.server = _http2.default.createServer((req, res) => {
|
|
229
|
+
if (_optionalChain([req, 'access', _7 => _7.url, 'optionalAccess', _8 => _8.startsWith, 'call', _9 => _9(apiPrefix)])) {
|
|
230
|
+
const newUrl = req.url.substring(apiPrefix.length) || "/";
|
|
231
|
+
req.url = newUrl;
|
|
232
|
+
_chunkWCKSKU3Cjs.logger.info(pc2.gray(`\u2192 ${req.method} ${apiPrefix}${newUrl}`));
|
|
233
|
+
this.proxy.web(req, res);
|
|
234
|
+
} else {
|
|
235
|
+
res.writeHead(404);
|
|
236
|
+
res.end("Not Found");
|
|
237
|
+
}
|
|
238
|
+
});
|
|
239
|
+
this.server.on("upgrade", (req, socket, head) => {
|
|
240
|
+
if (_optionalChain([req, 'access', _10 => _10.url, 'optionalAccess', _11 => _11.startsWith, 'call', _12 => _12(apiPrefix)])) {
|
|
241
|
+
const newUrl = req.url.substring(apiPrefix.length) || "/";
|
|
242
|
+
req.url = newUrl;
|
|
243
|
+
this.proxy.ws(req, socket, head);
|
|
244
|
+
}
|
|
245
|
+
});
|
|
246
|
+
return new Promise((resolve2) => {
|
|
247
|
+
this.server.listen(port, () => {
|
|
248
|
+
_chunkWCKSKU3Cjs.logger.success(`\u2705 Proxy server running on port ${port}`);
|
|
249
|
+
_chunkWCKSKU3Cjs.logger.info(` Forwarding ${pc2.cyan(apiPrefix + "/*")} \u2192 ${pc2.cyan(apiTarget)}
|
|
250
|
+
`);
|
|
251
|
+
resolve2();
|
|
252
|
+
});
|
|
253
|
+
});
|
|
254
|
+
}
|
|
255
|
+
stop() {
|
|
256
|
+
if (this.server) {
|
|
257
|
+
this.server.close();
|
|
258
|
+
this.server = null;
|
|
259
|
+
}
|
|
260
|
+
if (this.proxy) {
|
|
261
|
+
this.proxy.close();
|
|
262
|
+
this.proxy = null;
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
}, _class2);
|
|
266
|
+
|
|
267
|
+
|
|
268
|
+
|
|
269
|
+
|
|
270
|
+
|
|
271
|
+
|
|
272
|
+
exports.ProcessRunner = ProcessRunner; exports.FusionDevServer = FusionDevServer; exports.ProxyServer = ProxyServer; exports.dev_server_exports = dev_server_exports;
|
|
273
|
+
//# sourceMappingURL=chunk-IRRJJ7KL.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Volumes/Projects/wexts/packages/dist/chunk-IRRJJ7KL.js","../src/dev-server/index.ts","../src/dev-server/process-runner.ts","../src/dev-server/dev-server.ts","../src/dev-server/proxy.ts"],"names":["ProcessRunner","processes","Map","colors","cyan","green","yellow","magenta","blue","run","configs","logger","info","config","startProcess","process","on","stopAll","name","command","args","cwd","color","env","colorFn","prefix","spawn","lines","forEach","log","error","code","exit","path","fs","DEFAULT_RUNTIME_CONFIG","FusionDevServer","processRunner","apiPath","useProxy","Error","existsSync","absoluteRuntimeConfigPath","webPath","webPort","apiPort","rootDir","runtimeConfigPath","createProcessConfigs","createApiCompilerProcess","NEXT_PUBLIC_API_URL","WEXTS_WEB_DIR","join","httpProxy","pc","ProxyServer","port","apiTarget","changeOrigin","writeHead","server","url","newUrl","proxy","Promise","success","resolve","close"],"mappings":"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","file":"/Volumes/Projects/wexts/packages/dist/chunk-IRRJJ7KL.js","sourcesContent":[null,"export * from './dev-server';\nexport * from './process-runner';\nexport * from './proxy';\n","import { spawn, ChildProcess } from 'child_process';\nimport { logger } from '../core/logger';\nimport * as pc from 'picocolors';\n\nexport interface ProcessConfig {\n name: string;\n command: string;\n args: string[];\n cwd: string;\n color: 'cyan' | 'green' | 'yellow' | 'magenta' | 'blue';\n env?: Record<string, string>;\n}\n\n/**\n * Run multiple processes concurrently with colored output\n */\nexport class ProcessRunner {\n private processes: Map<string, ChildProcess> = new Map();\n private colors = {\n cyan: pc.cyan,\n green: pc.green,\n yellow: pc.yellow,\n magenta: pc.magenta,\n blue: pc.blue,\n };\n\n async run(configs: ProcessConfig[]): Promise<void> {\n logger.info('š Starting development servers...\\n');\n\n for (const config of configs) {\n this.startProcess(config);\n }\n\n // Handle graceful shutdown\n process.on('SIGINT', () => this.stopAll());\n process.on('SIGTERM', () => this.stopAll());\n }\n\n private startProcess(config: ProcessConfig): void {\n const { name, command, args, cwd, color, env } = config;\n\n const colorFn = this.colors[color];\n const prefix = colorFn(`[${name}]`);\n\n logger.info(`${prefix} Starting...`);\n\n const proc = spawn(command, args, {\n cwd,\n stdio: 'pipe',\n shell: true,\n env: { ...process.env, ...env },\n });\n\n this.processes.set(name, proc);\n\n // Handle stdout\n proc.stdout?.on('data', (data) => {\n const lines = data.toString().split('\\n').filter((l: string) => l.trim());\n lines.forEach((line: string) => {\n console.log(`${prefix} ${line}`);\n });\n });\n\n // Handle stderr\n proc.stderr?.on('data', (data) => {\n const lines = data.toString().split('\\n').filter((l: string) => l.trim());\n lines.forEach((line: string) => {\n console.error(`${prefix} ${pc.red(line)}`);\n });\n });\n\n // Handle exit\n proc.on('exit', (code) => {\n if (code !== 0 && code !== null) {\n logger.error(`${prefix} Exited with code ${code}`);\n }\n this.processes.delete(name);\n });\n\n // Handle errors\n proc.on('error', (error) => {\n logger.error(`${prefix} Error:`, error.message);\n });\n }\n\n stopAll(): void {\n logger.info('\\nš Stopping all processes...');\n\n for (const [name, proc] of this.processes.entries()) {\n logger.info(`Stopping ${name}...`);\n proc.kill('SIGTERM');\n }\n\n setTimeout(() => {\n process.exit(0);\n }, 1000);\n }\n\n isRunning(name: string): boolean {\n return this.processes.has(name);\n }\n}\n","import { ProcessRunner, ProcessConfig } from './process-runner';\nimport { logger } from '../core/logger';\nimport * as path from 'path';\nimport * as fs from 'fs';\n\nexport interface DevServerConfig {\n apiPath: string;\n webPath: string;\n webPort?: number;\n apiPort?: number;\n useProxy?: boolean;\n rootDir?: string;\n runtimeConfigPath?: string;\n}\n\nconst DEFAULT_RUNTIME_CONFIG = './wexts.runtime.js';\n\n/**\n * Unified development server for Fusion projects\n */\nexport class FusionDevServer {\n private processRunner: ProcessRunner;\n\n constructor() {\n this.processRunner = new ProcessRunner();\n }\n\n async start(config: DevServerConfig): Promise<void> {\n const {\n apiPath,\n webPath,\n webPort = 3000,\n apiPort = 5050,\n useProxy = false,\n rootDir = process.cwd(),\n runtimeConfigPath = DEFAULT_RUNTIME_CONFIG,\n } = config;\n\n if (useProxy) {\n throw new Error('The legacy dev proxy is disabled because it conflicts with the Next.js port. Use the production runtime for single-port serving.');\n }\n\n // Validate paths\n if (!fs.existsSync(apiPath)) {\n throw new Error(`API path not found: ${apiPath}`);\n }\n if (!fs.existsSync(webPath)) {\n throw new Error(`Web path not found: ${webPath}`);\n }\n\n const absoluteRuntimeConfigPath = path.isAbsolute(runtimeConfigPath)\n ? runtimeConfigPath\n : path.join(path.resolve(rootDir), runtimeConfigPath);\n if (!fs.existsSync(absoluteRuntimeConfigPath)) {\n throw new Error(`Runtime config not found: ${absoluteRuntimeConfigPath}. Create wexts.runtime.js or pass --config.`);\n }\n\n const processes = this.createProcessConfigs({\n apiPath,\n webPath,\n webPort,\n apiPort,\n rootDir,\n runtimeConfigPath,\n });\n\n // Start processes\n await this.processRunner.run(processes);\n\n // Log info\n logger.info('āāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāā');\n logger.info('ā Fusion Development Server Ready ā');\n logger.info('āāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāā\\n');\n logger.info(`š Web + RPC: http://localhost:${webPort}`);\n logger.info(`š API compiler: ${path.resolve(apiPath)}`);\n logger.info('\\n');\n }\n\n createProcessConfigs(config: Required<Pick<DevServerConfig, 'apiPath' | 'webPath' | 'webPort' | 'apiPort' | 'rootDir' | 'runtimeConfigPath'>>): ProcessConfig[] {\n const apiPath = path.resolve(config.apiPath);\n const webPath = path.resolve(config.webPath);\n const rootDir = path.resolve(config.rootDir);\n const runtimeConfigPath = path.isAbsolute(config.runtimeConfigPath)\n ? config.runtimeConfigPath\n : path.join(rootDir, config.runtimeConfigPath);\n\n return [\n this.createApiCompilerProcess(apiPath, config.apiPort, rootDir),\n {\n name: 'Web',\n command: 'pnpm',\n args: ['exec', 'wexts', 'start', '-c', runtimeConfigPath, '-p', config.webPort.toString(), '--dev'],\n cwd: rootDir,\n color: 'green',\n env: {\n NEXT_PUBLIC_API_URL: `http://localhost:${config.apiPort}`,\n WEXTS_WEB_DIR: webPath,\n },\n },\n ];\n }\n\n private createApiCompilerProcess(apiPath: string, apiPort: number, rootDir: string): ProcessConfig {\n if (fs.existsSync(path.join(apiPath, 'package.json'))) {\n return {\n name: 'API',\n command: 'pnpm',\n args: ['run', 'start:dev'],\n cwd: apiPath,\n color: 'cyan',\n env: {\n PORT: apiPort.toString(),\n },\n };\n }\n\n return {\n name: 'API',\n command: 'pnpm',\n args: ['exec', 'tsc', '-w', '-p', path.join(apiPath, 'tsconfig.json')],\n cwd: rootDir,\n color: 'cyan',\n env: {\n PORT: apiPort.toString(),\n },\n };\n }\n\n stop(): void {\n this.processRunner.stopAll();\n }\n}\n","import http from 'http';\nimport httpProxy from 'http-proxy';\nimport { logger } from '../core/logger';\nimport * as pc from 'picocolors';\n\nexport interface ProxyConfig {\n port: number;\n apiTarget: string;\n apiPrefix: string;\n}\n\n/**\n * Proxy server to forward API requests from Next.js to NestJS\n */\nexport class ProxyServer {\n private server: http.Server | null = null;\n private proxy: httpProxy | null = null;\n\n async start(config: ProxyConfig): Promise<void> {\n const { port, apiTarget, apiPrefix } = config;\n\n this.proxy = httpProxy.createProxyServer({\n target: apiTarget,\n changeOrigin: true,\n ws: true, // WebSocket support\n });\n\n // Handle proxy errors\n this.proxy.on('error', (err, req, res) => {\n logger.error('Proxy error:', err.message);\n if (res && 'headersSent' in res && !(res as any).headersSent) {\n (res as http.ServerResponse).writeHead(502, { 'Content-Type': 'text/plain' });\n (res as http.ServerResponse).end('Bad Gateway - API server unavailable');\n }\n });\n\n this.server = http.createServer((req, res) => {\n // Check if request is for API\n if (req.url?.startsWith(apiPrefix)) {\n // Remove prefix before forwarding\n const newUrl = req.url.substring(apiPrefix.length) || '/';\n req.url = newUrl;\n\n logger.info(pc.gray(`ā ${req.method} ${apiPrefix}${newUrl}`));\n this.proxy!.web(req, res);\n } else {\n // Not an API request - should not happen\n res.writeHead(404);\n res.end('Not Found');\n }\n });\n\n // Handle WebSocket upgrade\n this.server.on('upgrade', (req, socket, head) => {\n if (req.url?.startsWith(apiPrefix)) {\n const newUrl = req.url.substring(apiPrefix.length) || '/';\n req.url = newUrl;\n this.proxy!.ws(req, socket, head);\n }\n });\n\n return new Promise((resolve) => {\n this.server!.listen(port, () => {\n logger.success(`ā
Proxy server running on port ${port}`);\n logger.info(` Forwarding ${pc.cyan(apiPrefix + '/*')} ā ${pc.cyan(apiTarget)}\\n`);\n resolve();\n });\n });\n }\n\n stop(): void {\n if (this.server) {\n this.server.close();\n this.server = null;\n }\n if (this.proxy) {\n this.proxy.close();\n this.proxy = null;\n }\n }\n}\n"]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
|
+
var __export = (target, all) => {
|
|
4
|
+
for (var name in all)
|
|
5
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
6
|
+
};
|
|
7
|
+
|
|
8
|
+
// ../node_modules/.pnpm/tsup@8.5.1_@swc+core@1.15.33_jiti@1.21.7_postcss@8.5.12_typescript@5.9.3/node_modules/tsup/assets/esm_shims.js
|
|
9
|
+
import path from "path";
|
|
10
|
+
import { fileURLToPath } from "url";
|
|
11
|
+
var getFilename = /* @__PURE__ */ __name(() => fileURLToPath(import.meta.url), "getFilename");
|
|
12
|
+
var getDirname = /* @__PURE__ */ __name(() => path.dirname(getFilename()), "getDirname");
|
|
13
|
+
var __dirname = /* @__PURE__ */ getDirname();
|
|
14
|
+
var __filename = /* @__PURE__ */ getFilename();
|
|
15
|
+
|
|
16
|
+
export {
|
|
17
|
+
__name,
|
|
18
|
+
__export,
|
|
19
|
+
__dirname,
|
|
20
|
+
__filename
|
|
21
|
+
};
|
|
22
|
+
//# sourceMappingURL=chunk-L77ANWWT.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../node_modules/.pnpm/tsup@8.5.1_@swc+core@1.15.33_jiti@1.21.7_postcss@8.5.12_typescript@5.9.3/node_modules/tsup/assets/esm_shims.js"],"sourcesContent":["// Shim globals in esm bundle\nimport path from 'node:path'\nimport { fileURLToPath } from 'node:url'\n\nconst getFilename = () => fileURLToPath(import.meta.url)\nconst getDirname = () => path.dirname(getFilename())\n\nexport const __dirname = /* @__PURE__ */ getDirname()\nexport const __filename = /* @__PURE__ */ getFilename()\n"],"mappings":";;;;;;;;AACA,OAAOA,UAAU;AACjB,SAASC,qBAAqB;AAE9B,IAAMC,cAAc,6BAAMC,cAAc,YAAYC,GAAG,GAAnC;AACpB,IAAMC,aAAa,6BAAMC,KAAKC,QAAQL,YAAAA,CAAAA,GAAnB;AAEZ,IAAMM,YAA4BH,2BAAAA;AAClC,IAAMI,aAA6BP,4BAAAA;","names":["path","fileURLToPath","getFilename","fileURLToPath","url","getDirname","path","dirname","__dirname","__filename"]}
|