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.
Files changed (189) hide show
  1. package/README.md +49 -49
  2. package/bin/wexts.cjs +2 -2
  3. package/package.json +153 -148
  4. package/templates/.dockerignore +43 -43
  5. package/templates/.env.example +17 -17
  6. package/templates/Dockerfile +60 -60
  7. package/templates/Procfile +1 -1
  8. package/templates/README.md +67 -67
  9. package/templates/api-sdk.ts +115 -115
  10. package/templates/docker-compose.yml +34 -34
  11. package/templates/nestjs-api/.env.example +3 -3
  12. package/templates/nestjs-api/README.md +87 -87
  13. package/templates/nestjs-api/nest-cli.json +6 -6
  14. package/templates/nestjs-api/package.json +40 -40
  15. package/templates/nestjs-api/prisma/migrations/20251123205437_init/migration.sql +24 -24
  16. package/templates/nestjs-api/prisma/migrations/migration_lock.toml +3 -3
  17. package/templates/nestjs-api/prisma/schema.prisma +29 -29
  18. package/templates/nestjs-api/src/app.module.ts +17 -17
  19. package/templates/nestjs-api/src/auth/auth.controller.ts +27 -27
  20. package/templates/nestjs-api/src/auth/auth.module.ts +37 -37
  21. package/templates/nestjs-api/src/auth/auth.service.ts +86 -86
  22. package/templates/nestjs-api/src/auth/dto/auth.dto.ts +22 -22
  23. package/templates/nestjs-api/src/auth/guards/jwt-auth.guard.ts +5 -5
  24. package/templates/nestjs-api/src/auth/strategies/jwt.strategy.ts +27 -27
  25. package/templates/nestjs-api/src/main.ts +32 -32
  26. package/templates/nestjs-api/src/prisma/prisma.module.ts +9 -9
  27. package/templates/nestjs-api/src/prisma/prisma.service.ts +14 -14
  28. package/templates/nestjs-api/src/todos/dto/todo.dto.ts +24 -24
  29. package/templates/nestjs-api/src/todos/todos.controller.ts +39 -39
  30. package/templates/nestjs-api/src/todos/todos.module.ts +11 -11
  31. package/templates/nestjs-api/src/todos/todos.service.ts +53 -53
  32. package/templates/nestjs-api/src/users/users.controller.ts +14 -14
  33. package/templates/nestjs-api/src/users/users.module.ts +12 -12
  34. package/templates/nestjs-api/src/users/users.service.ts +19 -19
  35. package/templates/nestjs-api/tsconfig.json +39 -39
  36. package/templates/nextjs-web/README.md +76 -76
  37. package/templates/nextjs-web/app/actions/auth.ts +108 -108
  38. package/templates/nextjs-web/app/dashboard/error.tsx +39 -39
  39. package/templates/nextjs-web/app/dashboard/loading.tsx +14 -14
  40. package/templates/nextjs-web/app/dashboard/page.tsx +5 -5
  41. package/templates/nextjs-web/app/globals.css +93 -93
  42. package/templates/nextjs-web/app/layout.tsx +29 -29
  43. package/templates/nextjs-web/app/login/page.tsx +5 -5
  44. package/templates/nextjs-web/app/page.tsx +28 -28
  45. package/templates/nextjs-web/app/register/page.tsx +5 -5
  46. package/templates/nextjs-web/components/ui/button.tsx +56 -56
  47. package/templates/nextjs-web/components/ui/card.tsx +79 -79
  48. package/templates/nextjs-web/components/ui/input.tsx +25 -25
  49. package/templates/nextjs-web/components/ui/label.tsx +24 -24
  50. package/templates/nextjs-web/features/auth/LoginForm.tsx +140 -140
  51. package/templates/nextjs-web/features/auth/RegisterForm.tsx +159 -159
  52. package/templates/nextjs-web/features/auth/api.ts +35 -35
  53. package/templates/nextjs-web/features/auth/index.ts +3 -3
  54. package/templates/nextjs-web/features/dashboard/DashboardView.tsx +204 -204
  55. package/templates/nextjs-web/features/dashboard/api.ts +9 -9
  56. package/templates/nextjs-web/features/dashboard/components.tsx +74 -74
  57. package/templates/nextjs-web/features/dashboard/index.ts +3 -3
  58. package/templates/nextjs-web/hooks/index.ts +4 -4
  59. package/templates/nextjs-web/lib/api-client.ts +89 -89
  60. package/templates/nextjs-web/lib/api.ts +115 -115
  61. package/templates/nextjs-web/lib/axios-global-config.ts +17 -17
  62. package/templates/nextjs-web/lib/utils.ts +6 -6
  63. package/templates/nextjs-web/lib/wexts-client.ts +4 -4
  64. package/templates/nextjs-web/next-env.d.ts +6 -6
  65. package/templates/nextjs-web/next.config.ts +20 -20
  66. package/templates/nextjs-web/package.json +37 -37
  67. package/templates/nextjs-web/postcss.config.js +6 -6
  68. package/templates/nextjs-web/tailwind.config.ts +69 -69
  69. package/templates/nextjs-web/tsconfig.json +41 -41
  70. package/templates/nixpacks.toml +11 -11
  71. package/templates/root-package.json +31 -31
  72. package/templates/server.ts +66 -66
  73. package/templates/tsconfig.json +30 -30
  74. package/dist/chunk-2KAQYLVN.js +0 -1
  75. package/dist/chunk-2KAQYLVN.js.map +0 -1
  76. package/dist/chunk-2LJVUMXW.js +0 -228
  77. package/dist/chunk-2LJVUMXW.js.map +0 -1
  78. package/dist/chunk-7QKLIVRF.js +0 -94
  79. package/dist/chunk-7QKLIVRF.js.map +0 -1
  80. package/dist/chunk-7WULUGLH.mjs +0 -22
  81. package/dist/chunk-7WULUGLH.mjs.map +0 -1
  82. package/dist/chunk-BG56B4DE.js +0 -106
  83. package/dist/chunk-BG56B4DE.js.map +0 -1
  84. package/dist/chunk-CLM5PNSG.mjs +0 -496
  85. package/dist/chunk-CLM5PNSG.mjs.map +0 -1
  86. package/dist/chunk-DNLGCKTT.js +0 -31
  87. package/dist/chunk-DNLGCKTT.js.map +0 -1
  88. package/dist/chunk-JHOVXH3X.mjs +0 -65
  89. package/dist/chunk-JHOVXH3X.mjs.map +0 -1
  90. package/dist/chunk-MXINIFPC.js +0 -105
  91. package/dist/chunk-MXINIFPC.js.map +0 -1
  92. package/dist/chunk-SE32ZPOZ.js +0 -496
  93. package/dist/chunk-SE32ZPOZ.js.map +0 -1
  94. package/dist/chunk-UAL54DVV.mjs +0 -106
  95. package/dist/chunk-UAL54DVV.mjs.map +0 -1
  96. package/dist/chunk-WCKSKU3C.js +0 -65
  97. package/dist/chunk-WCKSKU3C.js.map +0 -1
  98. package/dist/chunk-WU6FW77M.mjs +0 -105
  99. package/dist/chunk-WU6FW77M.mjs.map +0 -1
  100. package/dist/chunk-XE4OXN2W.js +0 -12
  101. package/dist/chunk-XE4OXN2W.js.map +0 -1
  102. package/dist/chunk-YBM3IJEA.mjs +0 -94
  103. package/dist/chunk-YBM3IJEA.mjs.map +0 -1
  104. package/dist/chunk-YN6WIWNQ.mjs +0 -228
  105. package/dist/chunk-YN6WIWNQ.mjs.map +0 -1
  106. package/dist/chunk-YSLEF5C5.mjs +0 -1
  107. package/dist/chunk-YSLEF5C5.mjs.map +0 -1
  108. package/dist/chunk-ZX7QIN24.mjs +0 -31
  109. package/dist/chunk-ZX7QIN24.mjs.map +0 -1
  110. package/dist/cli/index.d.mts +0 -11
  111. package/dist/cli/index.d.ts +0 -11
  112. package/dist/cli/index.js +0 -332
  113. package/dist/cli/index.js.map +0 -1
  114. package/dist/cli/index.mjs +0 -334
  115. package/dist/cli/index.mjs.map +0 -1
  116. package/dist/client/index.d.mts +0 -21
  117. package/dist/client/index.d.ts +0 -21
  118. package/dist/client/index.js +0 -12
  119. package/dist/client/index.js.map +0 -1
  120. package/dist/client/index.mjs +0 -12
  121. package/dist/client/index.mjs.map +0 -1
  122. package/dist/codegen/index.d.mts +0 -2
  123. package/dist/codegen/index.d.ts +0 -2
  124. package/dist/codegen/index.js +0 -15
  125. package/dist/codegen/index.js.map +0 -1
  126. package/dist/codegen/index.mjs +0 -15
  127. package/dist/codegen/index.mjs.map +0 -1
  128. package/dist/decorators-BT1FFqN0.d.mts +0 -29
  129. package/dist/decorators-DvS58PqC.d.ts +0 -29
  130. package/dist/dev-server/index.d.mts +0 -1
  131. package/dist/dev-server/index.d.ts +0 -1
  132. package/dist/dev-server/index.js +0 -13
  133. package/dist/dev-server/index.js.map +0 -1
  134. package/dist/dev-server/index.mjs +0 -13
  135. package/dist/dev-server/index.mjs.map +0 -1
  136. package/dist/index-7QeQEf37.d.ts +0 -92
  137. package/dist/index-7RvU-jGE.d.mts +0 -66
  138. package/dist/index-7RvU-jGE.d.ts +0 -66
  139. package/dist/index-8nzxy0NN.d.mts +0 -92
  140. package/dist/index-Co5ZsLqq.d.ts +0 -58
  141. package/dist/index-D94W1__r.d.mts +0 -58
  142. package/dist/index-DQmyVp6F.d.mts +0 -27
  143. package/dist/index-KL_1BrQb.d.ts +0 -27
  144. package/dist/index.d.mts +0 -258
  145. package/dist/index.d.ts +0 -258
  146. package/dist/index.js +0 -410
  147. package/dist/index.js.map +0 -1
  148. package/dist/index.mjs +0 -410
  149. package/dist/index.mjs.map +0 -1
  150. package/dist/nest/index.d.mts +0 -3
  151. package/dist/nest/index.d.ts +0 -3
  152. package/dist/nest/index.js +0 -38
  153. package/dist/nest/index.js.map +0 -1
  154. package/dist/nest/index.mjs +0 -38
  155. package/dist/nest/index.mjs.map +0 -1
  156. package/dist/next/index.d.mts +0 -66
  157. package/dist/next/index.d.ts +0 -66
  158. package/dist/next/index.js +0 -226
  159. package/dist/next/index.js.map +0 -1
  160. package/dist/next/index.mjs +0 -188
  161. package/dist/next/index.mjs.map +0 -1
  162. package/dist/rpc/index.d.mts +0 -2
  163. package/dist/rpc/index.d.ts +0 -2
  164. package/dist/rpc/index.js +0 -23
  165. package/dist/rpc/index.js.map +0 -1
  166. package/dist/rpc/index.mjs +0 -23
  167. package/dist/rpc/index.mjs.map +0 -1
  168. package/dist/runtime/index.d.mts +0 -55
  169. package/dist/runtime/index.d.ts +0 -55
  170. package/dist/runtime/index.js +0 -213
  171. package/dist/runtime/index.js.map +0 -1
  172. package/dist/runtime/index.mjs +0 -213
  173. package/dist/runtime/index.mjs.map +0 -1
  174. package/dist/types/index.d.mts +0 -12
  175. package/dist/types/index.d.ts +0 -12
  176. package/dist/types/index.js +0 -2
  177. package/dist/types/index.js.map +0 -1
  178. package/dist/types/index.mjs +0 -3
  179. package/dist/types/index.mjs.map +0 -1
  180. package/dist/types-7d_fC-C3.d.mts +0 -32
  181. package/dist/types-7d_fC-C3.d.ts +0 -32
  182. package/dist/vercel-builder/index.d.mts +0 -58
  183. package/dist/vercel-builder/index.d.ts +0 -58
  184. package/dist/vercel-builder/index.js +0 -330
  185. package/dist/vercel-builder/index.js.map +0 -1
  186. package/dist/vercel-builder/index.mjs +0 -330
  187. package/dist/vercel-builder/index.mjs.map +0 -1
  188. package/templates/nestjs-api/package-lock.json +0 -5623
  189. package/templates/nextjs-web/package-lock.json +0 -3254
@@ -1,213 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } async function _asyncNullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return await rhsFn(); } } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
2
-
3
- var _chunkXE4OXN2Wjs = require('../chunk-XE4OXN2W.js');
4
-
5
- // src/runtime/rpc-router.ts
6
- async function registerRpcRoutes(fastify, options) {
7
- const serviceMap = new Map(options.manifest.services.map((service) => [
8
- service.name,
9
- service
10
- ]));
11
- fastify.post("/rpc/:service/:method", async (request, reply) => {
12
- const service = serviceMap.get(request.params.service);
13
- if (!service) {
14
- reply.status(404);
15
- return {
16
- error: "WEXTS_RPC_SERVICE_NOT_FOUND"
17
- };
18
- }
19
- const method = service.methods.find((candidate) => candidate.name === request.params.method);
20
- if (!method) {
21
- reply.status(404);
22
- return {
23
- error: "WEXTS_RPC_METHOD_NOT_FOUND"
24
- };
25
- }
26
- if (method.requireAuth || service.requireAuth) {
27
- const authorized = await _optionalChain([options, 'access', _ => _.authorize, 'optionalCall', _2 => _2(request, service, method.name)]);
28
- if (!authorized) {
29
- reply.status(401);
30
- return {
31
- error: "WEXTS_RPC_AUTH_REQUIRED"
32
- };
33
- }
34
- }
35
- const instance = options.services[service.name];
36
- const handler = _optionalChain([instance, 'optionalAccess', _3 => _3[method.handlerName]]);
37
- if (!handler) {
38
- reply.status(500);
39
- return {
40
- error: "WEXTS_RPC_HANDLER_NOT_BOUND"
41
- };
42
- }
43
- const args = Array.isArray(_optionalChain([request, 'access', _4 => _4.body, 'optionalAccess', _5 => _5.args])) ? request.body.args : [];
44
- const data = await handler.apply(instance, args);
45
- return {
46
- data
47
- };
48
- });
49
- }
50
- _chunkXE4OXN2Wjs.__name.call(void 0, registerRpcRoutes, "registerRpcRoutes");
51
-
52
- // src/runtime/server.ts
53
- var _fs = require('fs'); var fs = _interopRequireWildcard(_fs);
54
- var _path = require('path'); var path = _interopRequireWildcard(_path);
55
- var _fastify = require('fastify'); var _fastify2 = _interopRequireDefault(_fastify);
56
- var _security = require('@wexts/security');
57
- async function createWextsRuntimeServer(config = {}) {
58
- const rootDir = path.resolve(_nullishCoalesce(config.rootDir, () => ( process.cwd())));
59
- const fastify = _fastify2.default.call(void 0, {
60
- logger: _nullishCoalesce(config.logger, () => ( true)),
61
- bodyLimit: _nullishCoalesce(_optionalChain([config, 'access', _6 => _6.security, 'optionalAccess', _7 => _7.bodyLimitBytes]), () => ( 1048576)),
62
- requestTimeout: _nullishCoalesce(_optionalChain([config, 'access', _8 => _8.security, 'optionalAccess', _9 => _9.requestTimeoutMs]), () => ( 3e4))
63
- });
64
- const manifest = _nullishCoalesce(config.rpcManifest, () => ( loadJson(rootDir, config.rpcManifestPath)));
65
- const routePolicies = [
66
- ..._nullishCoalesce(_optionalChain([config, 'access', _10 => _10.security, 'optionalAccess', _11 => _11.routePolicies]), () => ( [])),
67
- ...rpcPoliciesFromManifest(manifest)
68
- ];
69
- await _security.registerWextsShield.call(void 0, fastify, {
70
- ...config.security,
71
- routePolicies
72
- });
73
- fastify.get("/health", async () => ({
74
- ok: true,
75
- runtime: "wexts"
76
- }));
77
- fastify.get("/api/health", async () => ({
78
- ok: true,
79
- runtime: "wexts",
80
- scope: "api"
81
- }));
82
- if (manifest && config.rpcServices) {
83
- await registerRpcRoutes(fastify, {
84
- manifest,
85
- services: config.rpcServices,
86
- authorize: /* @__PURE__ */ _chunkXE4OXN2Wjs.__name.call(void 0, (request) => Boolean(request.headers.authorization || request.headers.cookie), "authorize")
87
- });
88
- }
89
- if (config.nestAppModule || config.nestAppModulePath) {
90
- await mountNest(fastify, rootDir, config);
91
- }
92
- if (config.nextDir) {
93
- await mountNext(fastify, rootDir, config);
94
- }
95
- const start = /* @__PURE__ */ _chunkXE4OXN2Wjs.__name.call(void 0, async () => {
96
- await fastify.listen({
97
- port: _nullishCoalesce(config.port, () => ( Number(_nullishCoalesce(process.env.PORT, () => ( 3e3))))),
98
- host: _nullishCoalesce(config.host, () => ( "0.0.0.0"))
99
- });
100
- }, "start");
101
- const close = /* @__PURE__ */ _chunkXE4OXN2Wjs.__name.call(void 0, async () => {
102
- await fastify.close();
103
- }, "close");
104
- registerShutdown(close);
105
- return {
106
- fastify,
107
- start,
108
- close
109
- };
110
- }
111
- _chunkXE4OXN2Wjs.__name.call(void 0, createWextsRuntimeServer, "createWextsRuntimeServer");
112
- async function startWextsRuntime(config = {}) {
113
- const server = await createWextsRuntimeServer(config);
114
- await server.start();
115
- return server;
116
- }
117
- _chunkXE4OXN2Wjs.__name.call(void 0, startWextsRuntime, "startWextsRuntime");
118
- function rpcPoliciesFromManifest(manifest) {
119
- if (!manifest) return [];
120
- return manifest.services.flatMap((service) => service.methods.map((method) => ({
121
- path: `/rpc/${service.name}/${method.name}`,
122
- methods: [
123
- "POST"
124
- ],
125
- mode: service.requireAuth || method.requireAuth ? "requireAuth" : "public"
126
- })));
127
- }
128
- _chunkXE4OXN2Wjs.__name.call(void 0, rpcPoliciesFromManifest, "rpcPoliciesFromManifest");
129
- function loadJson(rootDir, filePath) {
130
- if (!filePath) return void 0;
131
- const absolutePath = path.isAbsolute(filePath) ? filePath : path.join(rootDir, filePath);
132
- if (!fs.existsSync(absolutePath)) return void 0;
133
- return JSON.parse(fs.readFileSync(absolutePath, "utf8"));
134
- }
135
- _chunkXE4OXN2Wjs.__name.call(void 0, loadJson, "loadJson");
136
- async function mountNest(fastify, rootDir, config) {
137
- const [{ NestFactory }, { FastifyAdapter }] = await Promise.all([
138
- Promise.resolve().then(() => _interopRequireWildcard(require("@nestjs/core"))),
139
- Promise.resolve().then(() => _interopRequireWildcard(require("@nestjs/platform-fastify")))
140
- ]);
141
- const AppModule = await _asyncNullishCoalesce(config.nestAppModule, async () => ( await importModule(rootDir, config.nestAppModulePath)));
142
- const moduleValue = _nullishCoalesce(AppModule.AppModule, () => ( AppModule));
143
- const nestApp = await NestFactory.create(moduleValue, new FastifyAdapter(fastify), {
144
- logger: config.dev ? [
145
- "log",
146
- "error",
147
- "warn"
148
- ] : [
149
- "error",
150
- "warn"
151
- ]
152
- });
153
- nestApp.setGlobalPrefix("api");
154
- await nestApp.init();
155
- }
156
- _chunkXE4OXN2Wjs.__name.call(void 0, mountNest, "mountNest");
157
- async function mountNext(fastify, rootDir, config) {
158
- const nextModule = await Promise.resolve().then(() => _interopRequireWildcard(require("next")));
159
- const next = nextModule.default;
160
- if (!next) {
161
- throw new Error("Next.js could not be loaded. Install next or omit nextDir.");
162
- }
163
- const nextApp = next({
164
- dev: _nullishCoalesce(config.dev, () => ( process.env.NODE_ENV !== "production")),
165
- dir: path.isAbsolute(config.nextDir) ? config.nextDir : path.join(rootDir, config.nextDir)
166
- });
167
- await nextApp.prepare();
168
- const handler = nextApp.getRequestHandler();
169
- fastify.all("/*", async (request, reply) => {
170
- await handler(request.raw, reply.raw);
171
- reply.hijack();
172
- });
173
- }
174
- _chunkXE4OXN2Wjs.__name.call(void 0, mountNext, "mountNext");
175
- async function importModule(rootDir, modulePath) {
176
- const absolutePath = path.isAbsolute(modulePath) ? modulePath : path.join(rootDir, modulePath);
177
- return Promise.resolve().then(() => _interopRequireWildcard(require(pathToFileUrl(absolutePath))));
178
- }
179
- _chunkXE4OXN2Wjs.__name.call(void 0, importModule, "importModule");
180
- function pathToFileUrl(filePath) {
181
- return `file://${filePath}`;
182
- }
183
- _chunkXE4OXN2Wjs.__name.call(void 0, pathToFileUrl, "pathToFileUrl");
184
- function registerShutdown(close) {
185
- const handler = /* @__PURE__ */ _chunkXE4OXN2Wjs.__name.call(void 0, async () => {
186
- await close();
187
- process.exit(0);
188
- }, "handler");
189
- process.once("SIGINT", handler);
190
- process.once("SIGTERM", handler);
191
- }
192
- _chunkXE4OXN2Wjs.__name.call(void 0, registerShutdown, "registerShutdown");
193
-
194
- // src/runtime/vercel-handler.ts
195
- async function createWextsHandler(config = {}) {
196
- const server = await createWextsRuntimeServer({
197
- ...config,
198
- // Serverless does not use long-lived logging
199
- logger: _nullishCoalesce(config.logger, () => ( false))
200
- });
201
- await server.fastify.ready();
202
- return (req, res) => {
203
- server.fastify.server.emit("request", req, res);
204
- };
205
- }
206
- _chunkXE4OXN2Wjs.__name.call(void 0, createWextsHandler, "createWextsHandler");
207
-
208
-
209
-
210
-
211
-
212
- exports.createWextsHandler = createWextsHandler; exports.createWextsRuntimeServer = createWextsRuntimeServer; exports.registerRpcRoutes = registerRpcRoutes; exports.startWextsRuntime = startWextsRuntime;
213
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Volumes/Projects/wexts/packages/dist/runtime/index.js","../../src/runtime/rpc-router.ts","../../src/runtime/server.ts","../../src/runtime/vercel-handler.ts"],"names":["registerRpcRoutes","fastify","options","serviceMap","Map","manifest","services","map","service","name","post","request","reply","get","params","status","error","method","methods","find","candidate","requireAuth","authorized","authorize","instance","handler","handlerName","args","Array","isArray","body","data","apply","createWextsRuntimeServer","config","rootDir","resolve","process","cwd","Fastify","logger","bodyLimit","security","bodyLimitBytes","requestTimeout","requestTimeoutMs","rpcManifest","loadJson","rpcManifestPath","routePolicies","rpcPoliciesFromManifest","registerWextsShield","ok","runtime","scope","rpcServices","Boolean","headers","authorization","cookie","nestAppModule","nestAppModulePath","mountNest","nextDir","mountNext","start","listen","port","Number","env","PORT","host","close","registerShutdown","startWextsRuntime","server","flatMap","path","undefined","filePath","absolutePath","AppModule","moduleValue","default","NODE_ENV","modulePath","importModule","pathToFileUrl","res","req","createWextsHandler"],"mappings":"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","file":"/Volumes/Projects/wexts/packages/dist/runtime/index.js","sourcesContent":[null,"import type { FastifyInstance, FastifyReply, FastifyRequest } from 'fastify';\nimport type { RpcManifest, RpcServiceManifest } from '../rpc/types';\n\nexport type RpcServiceInstances = Record<string, Record<string, (...args: unknown[]) => unknown | Promise<unknown>>>;\n\nexport interface RegisterRpcRoutesOptions {\n manifest: RpcManifest;\n services: RpcServiceInstances;\n authorize?: (request: FastifyRequest, service: RpcServiceManifest, methodName: string) => boolean | Promise<boolean>;\n}\n\nexport async function registerRpcRoutes(fastify: FastifyInstance, options: RegisterRpcRoutesOptions): Promise<void> {\n const serviceMap = new Map(options.manifest.services.map((service) => [service.name, service]));\n\n fastify.post('/rpc/:service/:method', async (request: FastifyRequest<{\n Params: { service: string; method: string };\n Body: { args?: unknown[] };\n }>, reply: FastifyReply) => {\n const service = serviceMap.get(request.params.service);\n if (!service) {\n reply.status(404);\n return { error: 'WEXTS_RPC_SERVICE_NOT_FOUND' };\n }\n\n const method = service.methods.find((candidate) => candidate.name === request.params.method);\n if (!method) {\n reply.status(404);\n return { error: 'WEXTS_RPC_METHOD_NOT_FOUND' };\n }\n\n if (method.requireAuth || service.requireAuth) {\n const authorized = await options.authorize?.(request, service, method.name);\n if (!authorized) {\n reply.status(401);\n return { error: 'WEXTS_RPC_AUTH_REQUIRED' };\n }\n }\n\n const instance = options.services[service.name];\n const handler = instance?.[method.handlerName];\n if (!handler) {\n reply.status(500);\n return { error: 'WEXTS_RPC_HANDLER_NOT_BOUND' };\n }\n\n const args = Array.isArray(request.body?.args) ? request.body.args : [];\n const data = await handler.apply(instance, args);\n return { data };\n });\n}\n","import * as fs from 'fs';\nimport * as path from 'path';\nimport Fastify, { FastifyInstance, FastifyServerOptions } from 'fastify';\nimport { registerWextsShield, type WextsShieldConfig, type WextsShieldRoutePolicy } from '@wexts/security';\nimport type { RpcManifest } from '../rpc/types';\nimport { registerRpcRoutes, type RpcServiceInstances } from './rpc-router';\n\nexport interface WextsRuntimeConfig {\n rootDir?: string;\n port?: number;\n host?: string;\n dev?: boolean;\n nextDir?: string;\n nestAppModule?: unknown;\n nestAppModulePath?: string;\n rpcManifest?: RpcManifest;\n rpcManifestPath?: string;\n rpcServices?: RpcServiceInstances;\n security?: WextsShieldConfig;\n logger?: FastifyServerOptions['logger'];\n}\n\nexport interface WextsRuntimeServer {\n fastify: FastifyInstance;\n start: () => Promise<void>;\n close: () => Promise<void>;\n}\n\nexport async function createWextsRuntimeServer(config: WextsRuntimeConfig = {}): Promise<WextsRuntimeServer> {\n const rootDir = path.resolve(config.rootDir ?? process.cwd());\n const fastify = Fastify({\n logger: config.logger ?? true,\n bodyLimit: config.security?.bodyLimitBytes ?? 1_048_576,\n requestTimeout: config.security?.requestTimeoutMs ?? 30_000,\n });\n\n const manifest = config.rpcManifest ?? loadJson<RpcManifest>(rootDir, config.rpcManifestPath);\n const routePolicies = [\n ...(config.security?.routePolicies ?? []),\n ...rpcPoliciesFromManifest(manifest),\n ];\n\n await registerWextsShield(fastify, {\n ...config.security,\n routePolicies,\n });\n\n fastify.get('/health', async () => ({\n ok: true,\n runtime: 'wexts',\n }));\n\n fastify.get('/api/health', async () => ({\n ok: true,\n runtime: 'wexts',\n scope: 'api',\n }));\n\n if (manifest && config.rpcServices) {\n await registerRpcRoutes(fastify, {\n manifest,\n services: config.rpcServices,\n authorize: (request) => Boolean(request.headers.authorization || request.headers.cookie),\n });\n }\n\n if (config.nestAppModule || config.nestAppModulePath) {\n await mountNest(fastify, rootDir, config);\n }\n\n if (config.nextDir) {\n await mountNext(fastify, rootDir, config);\n }\n\n const start = async () => {\n await fastify.listen({\n port: config.port ?? Number(process.env.PORT ?? 3000),\n host: config.host ?? '0.0.0.0',\n });\n };\n\n const close = async () => {\n await fastify.close();\n };\n\n registerShutdown(close);\n\n return {\n fastify,\n start,\n close,\n };\n}\n\nexport async function startWextsRuntime(config: WextsRuntimeConfig = {}): Promise<WextsRuntimeServer> {\n const server = await createWextsRuntimeServer(config);\n await server.start();\n return server;\n}\n\nfunction rpcPoliciesFromManifest(manifest?: RpcManifest): WextsShieldRoutePolicy[] {\n if (!manifest) return [];\n\n return manifest.services.flatMap((service) => service.methods.map((method) => ({\n path: `/rpc/${service.name}/${method.name}`,\n methods: ['POST'],\n mode: service.requireAuth || method.requireAuth ? 'requireAuth' : 'public',\n })));\n}\n\nfunction loadJson<T>(rootDir: string, filePath?: string): T | undefined {\n if (!filePath) return undefined;\n\n const absolutePath = path.isAbsolute(filePath) ? filePath : path.join(rootDir, filePath);\n if (!fs.existsSync(absolutePath)) return undefined;\n return JSON.parse(fs.readFileSync(absolutePath, 'utf8')) as T;\n}\n\nasync function mountNest(fastify: FastifyInstance, rootDir: string, config: WextsRuntimeConfig): Promise<void> {\n const [{ NestFactory }, { FastifyAdapter }] = await Promise.all([\n import('@nestjs/core'),\n import('@nestjs/platform-fastify'),\n ]);\n const AppModule = config.nestAppModule ?? await importModule(rootDir, config.nestAppModulePath!);\n const moduleValue = (AppModule as { AppModule?: unknown }).AppModule ?? AppModule;\n const nestApp = await NestFactory.create(moduleValue as never, new FastifyAdapter(fastify as never), {\n logger: config.dev ? ['log', 'error', 'warn'] : ['error', 'warn'],\n });\n nestApp.setGlobalPrefix('api');\n await nestApp.init();\n}\n\nasync function mountNext(fastify: FastifyInstance, rootDir: string, config: WextsRuntimeConfig): Promise<void> {\n const nextModule = await import('next') as unknown as { default?: (options: unknown) => { prepare: () => Promise<void>; getRequestHandler: () => (req: unknown, res: unknown) => Promise<void> } };\n const next = nextModule.default;\n if (!next) {\n throw new Error('Next.js could not be loaded. Install next or omit nextDir.');\n }\n const nextApp = next({\n dev: config.dev ?? process.env.NODE_ENV !== 'production',\n dir: path.isAbsolute(config.nextDir!) ? config.nextDir : path.join(rootDir, config.nextDir!),\n });\n await nextApp.prepare();\n const handler = nextApp.getRequestHandler();\n\n fastify.all('/*', async (request, reply) => {\n await handler(request.raw, reply.raw);\n reply.hijack();\n });\n}\n\nasync function importModule(rootDir: string, modulePath: string): Promise<unknown> {\n const absolutePath = path.isAbsolute(modulePath) ? modulePath : path.join(rootDir, modulePath);\n return import(pathToFileUrl(absolutePath));\n}\n\nfunction pathToFileUrl(filePath: string): string {\n return `file://${filePath}`;\n}\n\nfunction registerShutdown(close: () => Promise<void>): void {\n const handler = async () => {\n await close();\n process.exit(0);\n };\n\n process.once('SIGINT', handler);\n process.once('SIGTERM', handler);\n}\n","/**\n * Vercel / serverless handler adapter for the Wexts runtime.\n *\n * Creates a standard Node.js (req, res) handler that delegates to the\n * Fastify-backed Wexts runtime **without** calling fastify.listen().\n *\n * Usage:\n * const handler = await createWextsHandler({ ... });\n * export default handler; // Vercel function entry\n */\n\nimport type { IncomingMessage, ServerResponse } from 'http';\nimport type { WextsRuntimeConfig } from './server';\nimport { createWextsRuntimeServer } from './server';\n\nexport type WextsHandler = (req: IncomingMessage, res: ServerResponse) => void;\n\n/**\n * Build a serverless-compatible handler from the Wexts runtime.\n * The returned function accepts Node http (req, res) and passes them\n * into the Fastify instance without ever calling listen().\n */\nexport async function createWextsHandler(\n config: WextsRuntimeConfig = {},\n): Promise<WextsHandler> {\n const server = await createWextsRuntimeServer({\n ...config,\n // Serverless does not use long-lived logging\n logger: config.logger ?? false,\n });\n\n // Fastify exposes a raw Node handler via server.server (the http.Server)\n // But we need to call .ready() first so all plugins are loaded.\n await server.fastify.ready();\n\n return (req: IncomingMessage, res: ServerResponse) => {\n server.fastify.server.emit('request', req, res);\n };\n}\n"]}
@@ -1,213 +0,0 @@
1
- import {
2
- __name
3
- } from "../chunk-7WULUGLH.mjs";
4
-
5
- // src/runtime/rpc-router.ts
6
- async function registerRpcRoutes(fastify, options) {
7
- const serviceMap = new Map(options.manifest.services.map((service) => [
8
- service.name,
9
- service
10
- ]));
11
- fastify.post("/rpc/:service/:method", async (request, reply) => {
12
- const service = serviceMap.get(request.params.service);
13
- if (!service) {
14
- reply.status(404);
15
- return {
16
- error: "WEXTS_RPC_SERVICE_NOT_FOUND"
17
- };
18
- }
19
- const method = service.methods.find((candidate) => candidate.name === request.params.method);
20
- if (!method) {
21
- reply.status(404);
22
- return {
23
- error: "WEXTS_RPC_METHOD_NOT_FOUND"
24
- };
25
- }
26
- if (method.requireAuth || service.requireAuth) {
27
- const authorized = await options.authorize?.(request, service, method.name);
28
- if (!authorized) {
29
- reply.status(401);
30
- return {
31
- error: "WEXTS_RPC_AUTH_REQUIRED"
32
- };
33
- }
34
- }
35
- const instance = options.services[service.name];
36
- const handler = instance?.[method.handlerName];
37
- if (!handler) {
38
- reply.status(500);
39
- return {
40
- error: "WEXTS_RPC_HANDLER_NOT_BOUND"
41
- };
42
- }
43
- const args = Array.isArray(request.body?.args) ? request.body.args : [];
44
- const data = await handler.apply(instance, args);
45
- return {
46
- data
47
- };
48
- });
49
- }
50
- __name(registerRpcRoutes, "registerRpcRoutes");
51
-
52
- // src/runtime/server.ts
53
- import * as fs from "fs";
54
- import * as path from "path";
55
- import Fastify from "fastify";
56
- import { registerWextsShield } from "@wexts/security";
57
- async function createWextsRuntimeServer(config = {}) {
58
- const rootDir = path.resolve(config.rootDir ?? process.cwd());
59
- const fastify = Fastify({
60
- logger: config.logger ?? true,
61
- bodyLimit: config.security?.bodyLimitBytes ?? 1048576,
62
- requestTimeout: config.security?.requestTimeoutMs ?? 3e4
63
- });
64
- const manifest = config.rpcManifest ?? loadJson(rootDir, config.rpcManifestPath);
65
- const routePolicies = [
66
- ...config.security?.routePolicies ?? [],
67
- ...rpcPoliciesFromManifest(manifest)
68
- ];
69
- await registerWextsShield(fastify, {
70
- ...config.security,
71
- routePolicies
72
- });
73
- fastify.get("/health", async () => ({
74
- ok: true,
75
- runtime: "wexts"
76
- }));
77
- fastify.get("/api/health", async () => ({
78
- ok: true,
79
- runtime: "wexts",
80
- scope: "api"
81
- }));
82
- if (manifest && config.rpcServices) {
83
- await registerRpcRoutes(fastify, {
84
- manifest,
85
- services: config.rpcServices,
86
- authorize: /* @__PURE__ */ __name((request) => Boolean(request.headers.authorization || request.headers.cookie), "authorize")
87
- });
88
- }
89
- if (config.nestAppModule || config.nestAppModulePath) {
90
- await mountNest(fastify, rootDir, config);
91
- }
92
- if (config.nextDir) {
93
- await mountNext(fastify, rootDir, config);
94
- }
95
- const start = /* @__PURE__ */ __name(async () => {
96
- await fastify.listen({
97
- port: config.port ?? Number(process.env.PORT ?? 3e3),
98
- host: config.host ?? "0.0.0.0"
99
- });
100
- }, "start");
101
- const close = /* @__PURE__ */ __name(async () => {
102
- await fastify.close();
103
- }, "close");
104
- registerShutdown(close);
105
- return {
106
- fastify,
107
- start,
108
- close
109
- };
110
- }
111
- __name(createWextsRuntimeServer, "createWextsRuntimeServer");
112
- async function startWextsRuntime(config = {}) {
113
- const server = await createWextsRuntimeServer(config);
114
- await server.start();
115
- return server;
116
- }
117
- __name(startWextsRuntime, "startWextsRuntime");
118
- function rpcPoliciesFromManifest(manifest) {
119
- if (!manifest) return [];
120
- return manifest.services.flatMap((service) => service.methods.map((method) => ({
121
- path: `/rpc/${service.name}/${method.name}`,
122
- methods: [
123
- "POST"
124
- ],
125
- mode: service.requireAuth || method.requireAuth ? "requireAuth" : "public"
126
- })));
127
- }
128
- __name(rpcPoliciesFromManifest, "rpcPoliciesFromManifest");
129
- function loadJson(rootDir, filePath) {
130
- if (!filePath) return void 0;
131
- const absolutePath = path.isAbsolute(filePath) ? filePath : path.join(rootDir, filePath);
132
- if (!fs.existsSync(absolutePath)) return void 0;
133
- return JSON.parse(fs.readFileSync(absolutePath, "utf8"));
134
- }
135
- __name(loadJson, "loadJson");
136
- async function mountNest(fastify, rootDir, config) {
137
- const [{ NestFactory }, { FastifyAdapter }] = await Promise.all([
138
- import("@nestjs/core"),
139
- import("@nestjs/platform-fastify")
140
- ]);
141
- const AppModule = config.nestAppModule ?? await importModule(rootDir, config.nestAppModulePath);
142
- const moduleValue = AppModule.AppModule ?? AppModule;
143
- const nestApp = await NestFactory.create(moduleValue, new FastifyAdapter(fastify), {
144
- logger: config.dev ? [
145
- "log",
146
- "error",
147
- "warn"
148
- ] : [
149
- "error",
150
- "warn"
151
- ]
152
- });
153
- nestApp.setGlobalPrefix("api");
154
- await nestApp.init();
155
- }
156
- __name(mountNest, "mountNest");
157
- async function mountNext(fastify, rootDir, config) {
158
- const nextModule = await import("next");
159
- const next = nextModule.default;
160
- if (!next) {
161
- throw new Error("Next.js could not be loaded. Install next or omit nextDir.");
162
- }
163
- const nextApp = next({
164
- dev: config.dev ?? process.env.NODE_ENV !== "production",
165
- dir: path.isAbsolute(config.nextDir) ? config.nextDir : path.join(rootDir, config.nextDir)
166
- });
167
- await nextApp.prepare();
168
- const handler = nextApp.getRequestHandler();
169
- fastify.all("/*", async (request, reply) => {
170
- await handler(request.raw, reply.raw);
171
- reply.hijack();
172
- });
173
- }
174
- __name(mountNext, "mountNext");
175
- async function importModule(rootDir, modulePath) {
176
- const absolutePath = path.isAbsolute(modulePath) ? modulePath : path.join(rootDir, modulePath);
177
- return import(pathToFileUrl(absolutePath));
178
- }
179
- __name(importModule, "importModule");
180
- function pathToFileUrl(filePath) {
181
- return `file://${filePath}`;
182
- }
183
- __name(pathToFileUrl, "pathToFileUrl");
184
- function registerShutdown(close) {
185
- const handler = /* @__PURE__ */ __name(async () => {
186
- await close();
187
- process.exit(0);
188
- }, "handler");
189
- process.once("SIGINT", handler);
190
- process.once("SIGTERM", handler);
191
- }
192
- __name(registerShutdown, "registerShutdown");
193
-
194
- // src/runtime/vercel-handler.ts
195
- async function createWextsHandler(config = {}) {
196
- const server = await createWextsRuntimeServer({
197
- ...config,
198
- // Serverless does not use long-lived logging
199
- logger: config.logger ?? false
200
- });
201
- await server.fastify.ready();
202
- return (req, res) => {
203
- server.fastify.server.emit("request", req, res);
204
- };
205
- }
206
- __name(createWextsHandler, "createWextsHandler");
207
- export {
208
- createWextsHandler,
209
- createWextsRuntimeServer,
210
- registerRpcRoutes,
211
- startWextsRuntime
212
- };
213
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/runtime/rpc-router.ts","../../src/runtime/server.ts","../../src/runtime/vercel-handler.ts"],"sourcesContent":["import type { FastifyInstance, FastifyReply, FastifyRequest } from 'fastify';\nimport type { RpcManifest, RpcServiceManifest } from '../rpc/types';\n\nexport type RpcServiceInstances = Record<string, Record<string, (...args: unknown[]) => unknown | Promise<unknown>>>;\n\nexport interface RegisterRpcRoutesOptions {\n manifest: RpcManifest;\n services: RpcServiceInstances;\n authorize?: (request: FastifyRequest, service: RpcServiceManifest, methodName: string) => boolean | Promise<boolean>;\n}\n\nexport async function registerRpcRoutes(fastify: FastifyInstance, options: RegisterRpcRoutesOptions): Promise<void> {\n const serviceMap = new Map(options.manifest.services.map((service) => [service.name, service]));\n\n fastify.post('/rpc/:service/:method', async (request: FastifyRequest<{\n Params: { service: string; method: string };\n Body: { args?: unknown[] };\n }>, reply: FastifyReply) => {\n const service = serviceMap.get(request.params.service);\n if (!service) {\n reply.status(404);\n return { error: 'WEXTS_RPC_SERVICE_NOT_FOUND' };\n }\n\n const method = service.methods.find((candidate) => candidate.name === request.params.method);\n if (!method) {\n reply.status(404);\n return { error: 'WEXTS_RPC_METHOD_NOT_FOUND' };\n }\n\n if (method.requireAuth || service.requireAuth) {\n const authorized = await options.authorize?.(request, service, method.name);\n if (!authorized) {\n reply.status(401);\n return { error: 'WEXTS_RPC_AUTH_REQUIRED' };\n }\n }\n\n const instance = options.services[service.name];\n const handler = instance?.[method.handlerName];\n if (!handler) {\n reply.status(500);\n return { error: 'WEXTS_RPC_HANDLER_NOT_BOUND' };\n }\n\n const args = Array.isArray(request.body?.args) ? request.body.args : [];\n const data = await handler.apply(instance, args);\n return { data };\n });\n}\n","import * as fs from 'fs';\nimport * as path from 'path';\nimport Fastify, { FastifyInstance, FastifyServerOptions } from 'fastify';\nimport { registerWextsShield, type WextsShieldConfig, type WextsShieldRoutePolicy } from '@wexts/security';\nimport type { RpcManifest } from '../rpc/types';\nimport { registerRpcRoutes, type RpcServiceInstances } from './rpc-router';\n\nexport interface WextsRuntimeConfig {\n rootDir?: string;\n port?: number;\n host?: string;\n dev?: boolean;\n nextDir?: string;\n nestAppModule?: unknown;\n nestAppModulePath?: string;\n rpcManifest?: RpcManifest;\n rpcManifestPath?: string;\n rpcServices?: RpcServiceInstances;\n security?: WextsShieldConfig;\n logger?: FastifyServerOptions['logger'];\n}\n\nexport interface WextsRuntimeServer {\n fastify: FastifyInstance;\n start: () => Promise<void>;\n close: () => Promise<void>;\n}\n\nexport async function createWextsRuntimeServer(config: WextsRuntimeConfig = {}): Promise<WextsRuntimeServer> {\n const rootDir = path.resolve(config.rootDir ?? process.cwd());\n const fastify = Fastify({\n logger: config.logger ?? true,\n bodyLimit: config.security?.bodyLimitBytes ?? 1_048_576,\n requestTimeout: config.security?.requestTimeoutMs ?? 30_000,\n });\n\n const manifest = config.rpcManifest ?? loadJson<RpcManifest>(rootDir, config.rpcManifestPath);\n const routePolicies = [\n ...(config.security?.routePolicies ?? []),\n ...rpcPoliciesFromManifest(manifest),\n ];\n\n await registerWextsShield(fastify, {\n ...config.security,\n routePolicies,\n });\n\n fastify.get('/health', async () => ({\n ok: true,\n runtime: 'wexts',\n }));\n\n fastify.get('/api/health', async () => ({\n ok: true,\n runtime: 'wexts',\n scope: 'api',\n }));\n\n if (manifest && config.rpcServices) {\n await registerRpcRoutes(fastify, {\n manifest,\n services: config.rpcServices,\n authorize: (request) => Boolean(request.headers.authorization || request.headers.cookie),\n });\n }\n\n if (config.nestAppModule || config.nestAppModulePath) {\n await mountNest(fastify, rootDir, config);\n }\n\n if (config.nextDir) {\n await mountNext(fastify, rootDir, config);\n }\n\n const start = async () => {\n await fastify.listen({\n port: config.port ?? Number(process.env.PORT ?? 3000),\n host: config.host ?? '0.0.0.0',\n });\n };\n\n const close = async () => {\n await fastify.close();\n };\n\n registerShutdown(close);\n\n return {\n fastify,\n start,\n close,\n };\n}\n\nexport async function startWextsRuntime(config: WextsRuntimeConfig = {}): Promise<WextsRuntimeServer> {\n const server = await createWextsRuntimeServer(config);\n await server.start();\n return server;\n}\n\nfunction rpcPoliciesFromManifest(manifest?: RpcManifest): WextsShieldRoutePolicy[] {\n if (!manifest) return [];\n\n return manifest.services.flatMap((service) => service.methods.map((method) => ({\n path: `/rpc/${service.name}/${method.name}`,\n methods: ['POST'],\n mode: service.requireAuth || method.requireAuth ? 'requireAuth' : 'public',\n })));\n}\n\nfunction loadJson<T>(rootDir: string, filePath?: string): T | undefined {\n if (!filePath) return undefined;\n\n const absolutePath = path.isAbsolute(filePath) ? filePath : path.join(rootDir, filePath);\n if (!fs.existsSync(absolutePath)) return undefined;\n return JSON.parse(fs.readFileSync(absolutePath, 'utf8')) as T;\n}\n\nasync function mountNest(fastify: FastifyInstance, rootDir: string, config: WextsRuntimeConfig): Promise<void> {\n const [{ NestFactory }, { FastifyAdapter }] = await Promise.all([\n import('@nestjs/core'),\n import('@nestjs/platform-fastify'),\n ]);\n const AppModule = config.nestAppModule ?? await importModule(rootDir, config.nestAppModulePath!);\n const moduleValue = (AppModule as { AppModule?: unknown }).AppModule ?? AppModule;\n const nestApp = await NestFactory.create(moduleValue as never, new FastifyAdapter(fastify as never), {\n logger: config.dev ? ['log', 'error', 'warn'] : ['error', 'warn'],\n });\n nestApp.setGlobalPrefix('api');\n await nestApp.init();\n}\n\nasync function mountNext(fastify: FastifyInstance, rootDir: string, config: WextsRuntimeConfig): Promise<void> {\n const nextModule = await import('next') as unknown as { default?: (options: unknown) => { prepare: () => Promise<void>; getRequestHandler: () => (req: unknown, res: unknown) => Promise<void> } };\n const next = nextModule.default;\n if (!next) {\n throw new Error('Next.js could not be loaded. Install next or omit nextDir.');\n }\n const nextApp = next({\n dev: config.dev ?? process.env.NODE_ENV !== 'production',\n dir: path.isAbsolute(config.nextDir!) ? config.nextDir : path.join(rootDir, config.nextDir!),\n });\n await nextApp.prepare();\n const handler = nextApp.getRequestHandler();\n\n fastify.all('/*', async (request, reply) => {\n await handler(request.raw, reply.raw);\n reply.hijack();\n });\n}\n\nasync function importModule(rootDir: string, modulePath: string): Promise<unknown> {\n const absolutePath = path.isAbsolute(modulePath) ? modulePath : path.join(rootDir, modulePath);\n return import(pathToFileUrl(absolutePath));\n}\n\nfunction pathToFileUrl(filePath: string): string {\n return `file://${filePath}`;\n}\n\nfunction registerShutdown(close: () => Promise<void>): void {\n const handler = async () => {\n await close();\n process.exit(0);\n };\n\n process.once('SIGINT', handler);\n process.once('SIGTERM', handler);\n}\n","/**\n * Vercel / serverless handler adapter for the Wexts runtime.\n *\n * Creates a standard Node.js (req, res) handler that delegates to the\n * Fastify-backed Wexts runtime **without** calling fastify.listen().\n *\n * Usage:\n * const handler = await createWextsHandler({ ... });\n * export default handler; // Vercel function entry\n */\n\nimport type { IncomingMessage, ServerResponse } from 'http';\nimport type { WextsRuntimeConfig } from './server';\nimport { createWextsRuntimeServer } from './server';\n\nexport type WextsHandler = (req: IncomingMessage, res: ServerResponse) => void;\n\n/**\n * Build a serverless-compatible handler from the Wexts runtime.\n * The returned function accepts Node http (req, res) and passes them\n * into the Fastify instance without ever calling listen().\n */\nexport async function createWextsHandler(\n config: WextsRuntimeConfig = {},\n): Promise<WextsHandler> {\n const server = await createWextsRuntimeServer({\n ...config,\n // Serverless does not use long-lived logging\n logger: config.logger ?? false,\n });\n\n // Fastify exposes a raw Node handler via server.server (the http.Server)\n // But we need to call .ready() first so all plugins are loaded.\n await server.fastify.ready();\n\n return (req: IncomingMessage, res: ServerResponse) => {\n server.fastify.server.emit('request', req, res);\n };\n}\n"],"mappings":"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","names":["registerRpcRoutes","fastify","options","serviceMap","Map","manifest","services","map","service","name","post","request","reply","get","params","status","error","method","methods","find","candidate","requireAuth","authorized","authorize","instance","handler","handlerName","args","Array","isArray","body","data","apply","fs","path","Fastify","registerWextsShield","createWextsRuntimeServer","config","rootDir","resolve","process","cwd","fastify","Fastify","logger","bodyLimit","security","bodyLimitBytes","requestTimeout","requestTimeoutMs","manifest","rpcManifest","loadJson","rpcManifestPath","routePolicies","rpcPoliciesFromManifest","registerWextsShield","get","ok","runtime","scope","rpcServices","registerRpcRoutes","services","authorize","request","Boolean","headers","authorization","cookie","nestAppModule","nestAppModulePath","mountNest","nextDir","mountNext","start","listen","port","Number","env","PORT","host","close","registerShutdown","startWextsRuntime","server","flatMap","service","methods","map","method","path","name","mode","requireAuth","filePath","undefined","absolutePath","isAbsolute","join","existsSync","JSON","parse","readFileSync","NestFactory","FastifyAdapter","Promise","all","AppModule","importModule","moduleValue","nestApp","create","dev","setGlobalPrefix","init","nextModule","next","default","Error","nextApp","NODE_ENV","dir","prepare","handler","getRequestHandler","reply","raw","hijack","modulePath","pathToFileUrl","exit","once","createWextsHandler","config","server","createWextsRuntimeServer","logger","fastify","ready","req","res","emit"]}
@@ -1,12 +0,0 @@
1
- interface User {
2
- id: string;
3
- email: string;
4
- name?: string;
5
- }
6
- interface Todo {
7
- id: string;
8
- title: string;
9
- completed: boolean;
10
- }
11
-
12
- export type { Todo, User };
@@ -1,12 +0,0 @@
1
- interface User {
2
- id: string;
3
- email: string;
4
- name?: string;
5
- }
6
- interface Todo {
7
- id: string;
8
- title: string;
9
- completed: boolean;
10
- }
11
-
12
- export type { Todo, User };
@@ -1,2 +0,0 @@
1
- "use strict";require('../chunk-2KAQYLVN.js');
2
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Volumes/Projects/wexts/packages/dist/types/index.js"],"names":[],"mappings":"AAAA,6CAA6B","file":"/Volumes/Projects/wexts/packages/dist/types/index.js"}
@@ -1,3 +0,0 @@
1
- import "../chunk-YSLEF5C5.mjs";
2
- import "../chunk-7WULUGLH.mjs";
3
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -1,32 +0,0 @@
1
- type RpcAuthPolicy = 'public' | 'required';
2
- interface RpcParameterManifest {
3
- name: string;
4
- type: string;
5
- optional: boolean;
6
- }
7
- interface RpcMethodManifest {
8
- name: string;
9
- handlerName: string;
10
- requireAuth: boolean;
11
- parameters: RpcParameterManifest[];
12
- returnType: string;
13
- }
14
- interface RpcServiceManifest {
15
- name: string;
16
- className: string;
17
- importPath: string;
18
- requireAuth: boolean;
19
- methods: RpcMethodManifest[];
20
- }
21
- interface RpcManifest {
22
- schemaVersion: 1;
23
- services: RpcServiceManifest[];
24
- }
25
- interface RpcInvocationRequest {
26
- args: unknown[];
27
- }
28
- interface RpcInvocationResponse<T = unknown> {
29
- data: T;
30
- }
31
-
32
- export type { RpcAuthPolicy as R, RpcInvocationRequest as a, RpcInvocationResponse as b, RpcManifest as c, RpcMethodManifest as d, RpcParameterManifest as e, RpcServiceManifest as f };
@@ -1,32 +0,0 @@
1
- type RpcAuthPolicy = 'public' | 'required';
2
- interface RpcParameterManifest {
3
- name: string;
4
- type: string;
5
- optional: boolean;
6
- }
7
- interface RpcMethodManifest {
8
- name: string;
9
- handlerName: string;
10
- requireAuth: boolean;
11
- parameters: RpcParameterManifest[];
12
- returnType: string;
13
- }
14
- interface RpcServiceManifest {
15
- name: string;
16
- className: string;
17
- importPath: string;
18
- requireAuth: boolean;
19
- methods: RpcMethodManifest[];
20
- }
21
- interface RpcManifest {
22
- schemaVersion: 1;
23
- services: RpcServiceManifest[];
24
- }
25
- interface RpcInvocationRequest {
26
- args: unknown[];
27
- }
28
- interface RpcInvocationResponse<T = unknown> {
29
- data: T;
30
- }
31
-
32
- export type { RpcAuthPolicy as R, RpcInvocationRequest as a, RpcInvocationResponse as b, RpcManifest as c, RpcMethodManifest as d, RpcParameterManifest as e, RpcServiceManifest as f };