wexts 4.1.0 → 4.1.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (199) hide show
  1. package/README.md +49 -49
  2. package/bin/wexts.cjs +2 -2
  3. package/package.json +153 -148
  4. package/templates/.dockerignore +43 -43
  5. package/templates/.env.example +17 -17
  6. package/templates/Dockerfile +60 -60
  7. package/templates/Procfile +1 -1
  8. package/templates/README.md +67 -67
  9. package/templates/api-sdk.ts +115 -115
  10. package/templates/docker-compose.yml +34 -34
  11. package/templates/nestjs-api/.env.example +3 -3
  12. package/templates/nestjs-api/README.md +87 -87
  13. package/templates/nestjs-api/nest-cli.json +6 -6
  14. package/templates/nestjs-api/package.json +40 -40
  15. package/templates/nestjs-api/prisma/migrations/20251123205437_init/migration.sql +24 -24
  16. package/templates/nestjs-api/prisma/migrations/migration_lock.toml +3 -3
  17. package/templates/nestjs-api/prisma/schema.prisma +29 -29
  18. package/templates/nestjs-api/src/app.module.ts +17 -17
  19. package/templates/nestjs-api/src/auth/auth.controller.ts +27 -27
  20. package/templates/nestjs-api/src/auth/auth.module.ts +37 -37
  21. package/templates/nestjs-api/src/auth/auth.service.ts +86 -86
  22. package/templates/nestjs-api/src/auth/dto/auth.dto.ts +22 -22
  23. package/templates/nestjs-api/src/auth/guards/jwt-auth.guard.ts +5 -5
  24. package/templates/nestjs-api/src/auth/strategies/jwt.strategy.ts +27 -27
  25. package/templates/nestjs-api/src/main.ts +32 -32
  26. package/templates/nestjs-api/src/prisma/prisma.module.ts +9 -9
  27. package/templates/nestjs-api/src/prisma/prisma.service.ts +14 -14
  28. package/templates/nestjs-api/src/todos/dto/todo.dto.ts +24 -24
  29. package/templates/nestjs-api/src/todos/todos.controller.ts +39 -39
  30. package/templates/nestjs-api/src/todos/todos.module.ts +11 -11
  31. package/templates/nestjs-api/src/todos/todos.service.ts +53 -53
  32. package/templates/nestjs-api/src/users/users.controller.ts +14 -14
  33. package/templates/nestjs-api/src/users/users.module.ts +12 -12
  34. package/templates/nestjs-api/src/users/users.service.ts +19 -19
  35. package/templates/nestjs-api/tsconfig.json +39 -39
  36. package/templates/nextjs-web/README.md +76 -76
  37. package/templates/nextjs-web/app/actions/auth.ts +108 -108
  38. package/templates/nextjs-web/app/dashboard/error.tsx +39 -39
  39. package/templates/nextjs-web/app/dashboard/loading.tsx +14 -14
  40. package/templates/nextjs-web/app/dashboard/page.tsx +5 -5
  41. package/templates/nextjs-web/app/globals.css +93 -93
  42. package/templates/nextjs-web/app/layout.tsx +29 -29
  43. package/templates/nextjs-web/app/login/page.tsx +5 -5
  44. package/templates/nextjs-web/app/page.tsx +28 -28
  45. package/templates/nextjs-web/app/register/page.tsx +5 -5
  46. package/templates/nextjs-web/components/ui/button.tsx +56 -56
  47. package/templates/nextjs-web/components/ui/card.tsx +79 -79
  48. package/templates/nextjs-web/components/ui/input.tsx +25 -25
  49. package/templates/nextjs-web/components/ui/label.tsx +24 -24
  50. package/templates/nextjs-web/features/auth/LoginForm.tsx +140 -140
  51. package/templates/nextjs-web/features/auth/RegisterForm.tsx +159 -159
  52. package/templates/nextjs-web/features/auth/api.ts +35 -35
  53. package/templates/nextjs-web/features/auth/index.ts +3 -3
  54. package/templates/nextjs-web/features/dashboard/DashboardView.tsx +204 -204
  55. package/templates/nextjs-web/features/dashboard/api.ts +9 -9
  56. package/templates/nextjs-web/features/dashboard/components.tsx +74 -74
  57. package/templates/nextjs-web/features/dashboard/index.ts +3 -3
  58. package/templates/nextjs-web/hooks/index.ts +4 -4
  59. package/templates/nextjs-web/lib/api-client.ts +89 -89
  60. package/templates/nextjs-web/lib/api.ts +115 -115
  61. package/templates/nextjs-web/lib/axios-global-config.ts +17 -17
  62. package/templates/nextjs-web/lib/utils.ts +6 -6
  63. package/templates/nextjs-web/lib/wexts-client.ts +4 -4
  64. package/templates/nextjs-web/next-env.d.ts +6 -6
  65. package/templates/nextjs-web/next.config.ts +20 -20
  66. package/templates/nextjs-web/package.json +37 -37
  67. package/templates/nextjs-web/postcss.config.js +6 -6
  68. package/templates/nextjs-web/tailwind.config.ts +69 -69
  69. package/templates/nextjs-web/tsconfig.json +41 -41
  70. package/templates/nixpacks.toml +11 -11
  71. package/templates/root-package.json +31 -31
  72. package/templates/server.ts +66 -66
  73. package/templates/tsconfig.json +30 -30
  74. package/dist/chunk-2KAQYLVN.js +0 -1
  75. package/dist/chunk-2KAQYLVN.js.map +0 -1
  76. package/dist/chunk-2LJVUMXW.js +0 -228
  77. package/dist/chunk-2LJVUMXW.js.map +0 -1
  78. package/dist/chunk-342VRT25.mjs +0 -504
  79. package/dist/chunk-342VRT25.mjs.map +0 -1
  80. package/dist/chunk-7HNQWJWV.js +0 -504
  81. package/dist/chunk-7HNQWJWV.js.map +0 -1
  82. package/dist/chunk-7QKLIVRF.js +0 -94
  83. package/dist/chunk-7QKLIVRF.js.map +0 -1
  84. package/dist/chunk-7SSCNCTW.mjs +0 -137
  85. package/dist/chunk-7SSCNCTW.mjs.map +0 -1
  86. package/dist/chunk-7TLSPR65.mjs +0 -95
  87. package/dist/chunk-7TLSPR65.mjs.map +0 -1
  88. package/dist/chunk-7WULUGLH.mjs +0 -22
  89. package/dist/chunk-7WULUGLH.mjs.map +0 -1
  90. package/dist/chunk-AVMQJWYD.js +0 -95
  91. package/dist/chunk-AVMQJWYD.js.map +0 -1
  92. package/dist/chunk-BG56B4DE.js +0 -106
  93. package/dist/chunk-BG56B4DE.js.map +0 -1
  94. package/dist/chunk-CLM5PNSG.mjs +0 -496
  95. package/dist/chunk-CLM5PNSG.mjs.map +0 -1
  96. package/dist/chunk-DNLGCKTT.js +0 -31
  97. package/dist/chunk-DNLGCKTT.js.map +0 -1
  98. package/dist/chunk-JHOVXH3X.mjs +0 -65
  99. package/dist/chunk-JHOVXH3X.mjs.map +0 -1
  100. package/dist/chunk-MXINIFPC.js +0 -105
  101. package/dist/chunk-MXINIFPC.js.map +0 -1
  102. package/dist/chunk-O4II6N34.js +0 -137
  103. package/dist/chunk-O4II6N34.js.map +0 -1
  104. package/dist/chunk-SE32ZPOZ.js +0 -496
  105. package/dist/chunk-SE32ZPOZ.js.map +0 -1
  106. package/dist/chunk-UAL54DVV.mjs +0 -106
  107. package/dist/chunk-UAL54DVV.mjs.map +0 -1
  108. package/dist/chunk-WCKSKU3C.js +0 -65
  109. package/dist/chunk-WCKSKU3C.js.map +0 -1
  110. package/dist/chunk-WU6FW77M.mjs +0 -105
  111. package/dist/chunk-WU6FW77M.mjs.map +0 -1
  112. package/dist/chunk-XE4OXN2W.js +0 -12
  113. package/dist/chunk-XE4OXN2W.js.map +0 -1
  114. package/dist/chunk-YBM3IJEA.mjs +0 -94
  115. package/dist/chunk-YBM3IJEA.mjs.map +0 -1
  116. package/dist/chunk-YN6WIWNQ.mjs +0 -228
  117. package/dist/chunk-YN6WIWNQ.mjs.map +0 -1
  118. package/dist/chunk-YSLEF5C5.mjs +0 -1
  119. package/dist/chunk-YSLEF5C5.mjs.map +0 -1
  120. package/dist/chunk-ZX7QIN24.mjs +0 -31
  121. package/dist/chunk-ZX7QIN24.mjs.map +0 -1
  122. package/dist/cli/index.d.mts +0 -23
  123. package/dist/cli/index.d.ts +0 -23
  124. package/dist/cli/index.js +0 -716
  125. package/dist/cli/index.js.map +0 -1
  126. package/dist/cli/index.mjs +0 -718
  127. package/dist/cli/index.mjs.map +0 -1
  128. package/dist/client/index.d.mts +0 -21
  129. package/dist/client/index.d.ts +0 -21
  130. package/dist/client/index.js +0 -13
  131. package/dist/client/index.js.map +0 -1
  132. package/dist/client/index.mjs +0 -13
  133. package/dist/client/index.mjs.map +0 -1
  134. package/dist/codegen/index.d.mts +0 -2
  135. package/dist/codegen/index.d.ts +0 -2
  136. package/dist/codegen/index.js +0 -16
  137. package/dist/codegen/index.js.map +0 -1
  138. package/dist/codegen/index.mjs +0 -16
  139. package/dist/codegen/index.mjs.map +0 -1
  140. package/dist/decorators-BT1FFqN0.d.mts +0 -29
  141. package/dist/decorators-DvS58PqC.d.ts +0 -29
  142. package/dist/dev-server/index.d.mts +0 -1
  143. package/dist/dev-server/index.d.ts +0 -1
  144. package/dist/dev-server/index.js +0 -13
  145. package/dist/dev-server/index.js.map +0 -1
  146. package/dist/dev-server/index.mjs +0 -13
  147. package/dist/dev-server/index.mjs.map +0 -1
  148. package/dist/index-7QeQEf37.d.ts +0 -92
  149. package/dist/index-7RvU-jGE.d.mts +0 -66
  150. package/dist/index-7RvU-jGE.d.ts +0 -66
  151. package/dist/index-8nzxy0NN.d.mts +0 -92
  152. package/dist/index-Co5ZsLqq.d.ts +0 -58
  153. package/dist/index-D94W1__r.d.mts +0 -58
  154. package/dist/index-DQmyVp6F.d.mts +0 -27
  155. package/dist/index-KL_1BrQb.d.ts +0 -27
  156. package/dist/index.d.mts +0 -294
  157. package/dist/index.d.ts +0 -294
  158. package/dist/index.js +0 -424
  159. package/dist/index.js.map +0 -1
  160. package/dist/index.mjs +0 -424
  161. package/dist/index.mjs.map +0 -1
  162. package/dist/nest/index.d.mts +0 -3
  163. package/dist/nest/index.d.ts +0 -3
  164. package/dist/nest/index.js +0 -38
  165. package/dist/nest/index.js.map +0 -1
  166. package/dist/nest/index.mjs +0 -38
  167. package/dist/nest/index.mjs.map +0 -1
  168. package/dist/next/index.d.mts +0 -66
  169. package/dist/next/index.d.ts +0 -66
  170. package/dist/next/index.js +0 -289
  171. package/dist/next/index.js.map +0 -1
  172. package/dist/next/index.mjs +0 -251
  173. package/dist/next/index.mjs.map +0 -1
  174. package/dist/rpc/index.d.mts +0 -2
  175. package/dist/rpc/index.d.ts +0 -2
  176. package/dist/rpc/index.js +0 -23
  177. package/dist/rpc/index.js.map +0 -1
  178. package/dist/rpc/index.mjs +0 -23
  179. package/dist/rpc/index.mjs.map +0 -1
  180. package/dist/runtime/index.d.mts +0 -55
  181. package/dist/runtime/index.d.ts +0 -55
  182. package/dist/runtime/index.js +0 -221
  183. package/dist/runtime/index.js.map +0 -1
  184. package/dist/runtime/index.mjs +0 -221
  185. package/dist/runtime/index.mjs.map +0 -1
  186. package/dist/types/index.d.mts +0 -12
  187. package/dist/types/index.d.ts +0 -12
  188. package/dist/types/index.js +0 -2
  189. package/dist/types/index.js.map +0 -1
  190. package/dist/types/index.mjs +0 -3
  191. package/dist/types/index.mjs.map +0 -1
  192. package/dist/types-7d_fC-C3.d.mts +0 -32
  193. package/dist/types-7d_fC-C3.d.ts +0 -32
  194. package/dist/vercel-builder/index.d.mts +0 -58
  195. package/dist/vercel-builder/index.d.ts +0 -58
  196. package/dist/vercel-builder/index.js +0 -330
  197. package/dist/vercel-builder/index.js.map +0 -1
  198. package/dist/vercel-builder/index.mjs +0 -330
  199. package/dist/vercel-builder/index.mjs.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/next/provider.tsx","../../src/errors.ts","../../src/client/fetcher.ts","../../src/next/useAuth.ts"],"sourcesContent":["'use client';\n\nimport React, { createContext, useContext, ReactNode } from 'react';\nimport { createWextsRpcClient, FusionFetcher, WextsRpcClient } from '../client/fetcher';\n\ninterface FusionContextType {\n client: FusionFetcher;\n wexts: WextsRpcClient;\n}\n\nconst FusionContext = createContext<FusionContextType | null>(null);\n\nexport interface FusionProviderProps {\n children: ReactNode;\n baseUrl?: string;\n rpcBaseUrl?: string;\n rpcClient?: object;\n}\n\n/**\n * FusionProvider - Provides API client to React components\n * Usage:\n * ```tsx\n * <FusionProvider baseUrl=\"/api\">\n * <App />\n * </FusionProvider>\n * ```\n */\nexport function FusionProvider({ children, baseUrl = '/api', rpcBaseUrl = '/rpc', rpcClient }: FusionProviderProps) {\n const client = React.useMemo(() => new FusionFetcher(baseUrl), [baseUrl]);\n const wexts = React.useMemo(\n () => (rpcClient as WextsRpcClient | undefined) ?? createWextsRpcClient(undefined, { baseUrl: rpcBaseUrl }),\n [rpcBaseUrl, rpcClient]\n );\n\n return (\n <FusionContext.Provider value={{ client, wexts }}>\n {children}\n </FusionContext.Provider>\n );\n}\n\n/**\n * useFusion hook - Access API client in components\n * Usage:\n * ```tsx\n * const { client } = useFusion();\n * const data = await client.get('/users');\n * ```\n */\nexport function useFusion(): FusionContextType {\n const context = useContext(FusionContext);\n if (!context) {\n throw new Error('useFusion must be used within FusionProvider');\n }\n return context;\n}\n\nexport function useWexts<TClient = WextsRpcClient>(): TClient {\n const context = useFusion();\n return context.wexts as TClient;\n}\n","export interface WextsErrorOptions {\n code: string;\n message: string;\n cause?: unknown;\n suggestedFix?: string;\n docsSlug?: string;\n}\n\nexport class WextsError extends Error {\n readonly code: string;\n readonly suggestedFix?: string;\n readonly docsSlug?: string;\n\n constructor(options: WextsErrorOptions) {\n super(options.message, options.cause === undefined ? undefined : { cause: options.cause });\n this.name = 'WextsError';\n this.code = options.code;\n this.suggestedFix = options.suggestedFix;\n this.docsSlug = options.docsSlug;\n }\n\n get docsUrl(): string | undefined {\n return this.docsSlug ? `https://github.com/ziadmustafa1/wexts/blob/main/docs/${this.docsSlug}.md` : undefined;\n }\n}\n\nexport class WextsRpcError extends WextsError {\n constructor(options: Omit<WextsErrorOptions, 'code'> & { code?: string }) {\n super({ code: options.code ?? 'WEXTS_RPC_ERROR', ...options });\n this.name = 'WextsRpcError';\n }\n}\n\nexport class WextsCodegenError extends WextsError {\n constructor(options: Omit<WextsErrorOptions, 'code'> & { code?: string }) {\n super({ code: options.code ?? 'WEXTS_CODEGEN_ERROR', ...options });\n this.name = 'WextsCodegenError';\n }\n}\n\nexport class WextsRuntimeError extends WextsError {\n constructor(options: Omit<WextsErrorOptions, 'code'> & { code?: string }) {\n super({ code: options.code ?? 'WEXTS_RUNTIME_ERROR', ...options });\n this.name = 'WextsRuntimeError';\n }\n}\n\nexport class WextsSecurityError extends WextsError {\n constructor(options: Omit<WextsErrorOptions, 'code'> & { code?: string }) {\n super({ code: options.code ?? 'WEXTS_SECURITY_ERROR', ...options });\n this.name = 'WextsSecurityError';\n }\n}\n\nexport function formatWextsError(error: unknown): string {\n if (!(error instanceof WextsError)) {\n return error instanceof Error ? error.message : String(error);\n }\n\n const lines = [`${error.code}: ${error.message}`];\n if (error.suggestedFix) lines.push(`Suggested fix: ${error.suggestedFix}`);\n if (error.docsUrl) lines.push(`Docs: ${error.docsUrl}`);\n return lines.join('\\n');\n}\n","import type { RpcManifest, RpcInvocationResponse } from '../rpc/types';\nimport { WextsRpcError } from '../errors';\n\nexport class FusionFetcher {\n private baseUrl: string;\n\n constructor(baseUrl: string = '/api') {\n this.baseUrl = baseUrl;\n }\n\n private async request<T>(method: string, path: string, body?: any): Promise<T> {\n const headers: Record<string, string> = {\n 'Content-Type': 'application/json',\n };\n\n // Automatically attach Fusion Token if present\n if (typeof window !== 'undefined') {\n const token = localStorage.getItem('fusion_token');\n if (token) headers['Authorization'] = `Bearer ${token}`;\n }\n\n const response = await fetch(`${this.baseUrl}${path}`, {\n method,\n headers,\n body: body ? JSON.stringify(body) : undefined,\n });\n\n if (!response.ok) {\n throw new WextsRpcError({\n code: 'WEXTS_API_REQUEST_FAILED',\n message: `Fusion API Error: ${response.status} ${response.statusText}`,\n suggestedFix: 'Check the API route, server logs, and authentication headers.',\n docsSlug: 'troubleshooting',\n });\n }\n\n if (response.status === 204) {\n return undefined as T;\n }\n\n return response.json();\n }\n\n get<T>(path: string) { return this.request<T>('GET', path); }\n post<T>(path: string, body: any) { return this.request<T>('POST', path, body); }\n put<T>(path: string, body: any) { return this.request<T>('PUT', path, body); }\n delete<T>(path: string) { return this.request<T>('DELETE', path); }\n}\n\nexport const apiFetcher = new FusionFetcher();\n\nexport interface WextsRpcClientOptions {\n baseUrl?: string;\n fetch?: typeof fetch;\n getHeaders?: () => Record<string, string> | Promise<Record<string, string>>;\n}\n\nexport type WextsRpcClient = Record<string, Record<string, (...args: unknown[]) => Promise<unknown>>>;\n\nexport function createWextsRpcClient(\n manifest: Pick<RpcManifest, 'services'> | undefined,\n options: WextsRpcClientOptions = {}\n): WextsRpcClient {\n const hasManifest = Boolean(manifest);\n const services = new Set((manifest?.services ?? []).map((service) => service.name));\n const methodMap = new Map<string, Set<string>>();\n\n for (const service of manifest?.services ?? []) {\n methodMap.set(service.name, new Set(service.methods.map((method) => method.name)));\n }\n\n const createServiceProxy = (serviceName: string) => new Proxy({}, {\n get(_target, methodName) {\n if (typeof methodName !== 'string') return undefined;\n if (methodName === 'then') return undefined;\n\n const knownMethods = methodMap.get(serviceName);\n if (knownMethods && !knownMethods.has(methodName)) {\n throw new WextsRpcError({\n code: 'WEXTS_RPC_METHOD_NOT_FOUND',\n message: `Wexts RPC method not found: ${serviceName}.${methodName}`,\n suggestedFix: 'Run `wexts generate` and verify the method is decorated with @RpcMethod().',\n docsSlug: 'rpc',\n });\n }\n\n return (...args: unknown[]) => invokeRpc(serviceName, methodName, args, options);\n },\n }) as Record<string, (...args: unknown[]) => Promise<unknown>>;\n\n return new Proxy({}, {\n get(_target, serviceName) {\n if (typeof serviceName !== 'string') return undefined;\n if (serviceName === 'then') return undefined;\n if (!hasManifest) {\n throw new WextsRpcError({\n code: 'WEXTS_RPC_MANIFEST_MISSING',\n message: 'Wexts RPC manifest is missing.',\n suggestedFix: 'Run `wexts generate` and import the generated client/provider instead of creating an empty client.',\n docsSlug: 'codegen',\n });\n }\n if (!services.has(serviceName)) {\n throw new WextsRpcError({\n code: 'WEXTS_RPC_SERVICE_NOT_FOUND',\n message: `Wexts RPC service not found: ${serviceName}`,\n suggestedFix: 'Run `wexts generate` and verify the service is decorated with @RpcService().',\n docsSlug: 'rpc',\n });\n }\n\n return createServiceProxy(serviceName);\n },\n }) as WextsRpcClient;\n}\n\nasync function invokeRpc(\n serviceName: string,\n methodName: string,\n args: unknown[],\n options: WextsRpcClientOptions\n): Promise<unknown> {\n const fetchImpl = options.fetch ?? fetch;\n const baseUrl = options.baseUrl ?? '/rpc';\n const headers = {\n 'Content-Type': 'application/json',\n ...(await options.getHeaders?.() ?? {}),\n };\n const response = await fetchImpl(`${baseUrl}/${encodeURIComponent(serviceName)}/${encodeURIComponent(methodName)}`, {\n method: 'POST',\n headers,\n body: JSON.stringify({ args }),\n });\n\n if (!response.ok) {\n throw new WextsRpcError({\n code: 'WEXTS_RPC_REQUEST_FAILED',\n message: `Wexts RPC Error: ${response.status} ${response.statusText}`,\n suggestedFix: 'Check the RPC route, service policy, and server logs.',\n docsSlug: 'troubleshooting',\n });\n }\n\n const payload = await response.json() as RpcInvocationResponse;\n return payload.data;\n}\n","'use client';\n\nimport { useState, useEffect } from 'react';\nimport { useFusion } from './provider';\n\nexport interface AuthUser {\n id: string;\n email: string;\n name?: string;\n}\n\nexport interface UseAuthReturn {\n user: AuthUser | null;\n loading: boolean;\n login: (email: string, password: string) => Promise<void>;\n logout: () => Promise<void>;\n isAuthenticated: boolean;\n}\n\n/**\n * useAuth hook - Authentication state management\n * Usage:\n * ```tsx\n * const { user, login, logout, isAuthenticated } = useAuth();\n * ```\n */\nexport function useAuth(): UseAuthReturn {\n const { client } = useFusion();\n const [user, setUser] = useState<AuthUser | null>(null);\n const [loading, setLoading] = useState(true);\n\n useEffect(() => {\n // Check for existing session\n const token = localStorage.getItem('fusion_token');\n if (token) {\n // Validate token and load user\n loadUser();\n } else {\n setLoading(false);\n }\n }, []);\n\n const loadUser = async () => {\n try {\n const userData = await client.get<AuthUser>('/auth/me');\n setUser(userData);\n } catch (error) {\n localStorage.removeItem('fusion_token');\n } finally {\n setLoading(false);\n }\n };\n\n const login = async (email: string, password: string) => {\n const response = await client.post<{ token: string; user: AuthUser }>('/auth/login', {\n email,\n password,\n });\n localStorage.setItem('fusion_token', response.token);\n setUser(response.user);\n };\n\n const logout = async () => {\n localStorage.removeItem('fusion_token');\n setUser(null);\n };\n\n return {\n user,\n loading,\n login,\n logout,\n isAuthenticated: !!user,\n };\n}\n"],"mappings":"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","names":["React","createContext","useContext","WextsError","Error","code","suggestedFix","docsSlug","options","message","cause","undefined","name","docsUrl","WextsRpcError","FusionFetcher","baseUrl","request","method","path","body","headers","window","token","localStorage","getItem","response","fetch","JSON","stringify","undefined","ok","WextsRpcError","code","message","status","statusText","suggestedFix","docsSlug","json","get","post","put","delete","apiFetcher","createWextsRpcClient","manifest","options","hasManifest","Boolean","services","Set","map","service","name","methodMap","Map","set","methods","createServiceProxy","serviceName","Proxy","_target","methodName","knownMethods","has","args","invokeRpc","fetchImpl","getHeaders","encodeURIComponent","payload","data","FusionContext","createContext","FusionProvider","children","baseUrl","rpcBaseUrl","rpcClient","client","React","useMemo","FusionFetcher","wexts","createWextsRpcClient","undefined","Provider","value","useFusion","context","useContext","Error","useWexts","useState","useEffect","useAuth","client","useFusion","user","setUser","useState","loading","setLoading","useEffect","token","localStorage","getItem","loadUser","userData","get","error","removeItem","login","email","password","response","post","setItem","logout","isAuthenticated"]}
@@ -1,2 +0,0 @@
1
- export { R as RequireAuth, a as RpcMethod, b as RpcMethodOptions, c as RpcService, d as RpcServiceOptions, e as RuntimeRpcMethodMetadata, f as RuntimeRpcServiceMetadata, W as WextsRpc, g as WextsRpcService, h as getRpcAuthPolicy, i as getRuntimeRpcMethodsMetadata, j as getRuntimeRpcServiceMetadata } from '../decorators-BT1FFqN0.mjs';
2
- export { R as RpcAuthPolicy, a as RpcInvocationRequest, b as RpcInvocationResponse, c as RpcManifest, d as RpcMethodManifest, e as RpcParameterManifest, f as RpcServiceManifest } from '../types-7d_fC-C3.mjs';
@@ -1,2 +0,0 @@
1
- export { R as RequireAuth, a as RpcMethod, b as RpcMethodOptions, c as RpcService, d as RpcServiceOptions, e as RuntimeRpcMethodMetadata, f as RuntimeRpcServiceMetadata, W as WextsRpc, g as WextsRpcService, h as getRpcAuthPolicy, i as getRuntimeRpcMethodsMetadata, j as getRuntimeRpcServiceMetadata } from '../decorators-DvS58PqC.js';
2
- export { R as RpcAuthPolicy, a as RpcInvocationRequest, b as RpcInvocationResponse, c as RpcManifest, d as RpcMethodManifest, e as RpcParameterManifest, f as RpcServiceManifest } from '../types-7d_fC-C3.js';
package/dist/rpc/index.js DELETED
@@ -1,23 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});require('../chunk-DNLGCKTT.js');
2
-
3
-
4
-
5
-
6
-
7
-
8
-
9
-
10
-
11
- var _chunk7QKLIVRFjs = require('../chunk-7QKLIVRF.js');
12
- require('../chunk-XE4OXN2W.js');
13
-
14
-
15
-
16
-
17
-
18
-
19
-
20
-
21
-
22
- exports.RequireAuth = _chunk7QKLIVRFjs.RequireAuth; exports.RpcMethod = _chunk7QKLIVRFjs.RpcMethod; exports.RpcService = _chunk7QKLIVRFjs.RpcService; exports.WextsRpc = _chunk7QKLIVRFjs.WextsRpc; exports.WextsRpcService = _chunk7QKLIVRFjs.WextsRpcService; exports.getRpcAuthPolicy = _chunk7QKLIVRFjs.getRpcAuthPolicy; exports.getRuntimeRpcMethodsMetadata = _chunk7QKLIVRFjs.getRuntimeRpcMethodsMetadata; exports.getRuntimeRpcServiceMetadata = _chunk7QKLIVRFjs.getRuntimeRpcServiceMetadata;
23
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Volumes/Projects/wexts/packages/dist/rpc/index.js"],"names":[],"mappings":"AAAA,yGAA6B;AAC7B;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,uDAA6B;AAC7B,gCAA6B;AAC7B;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,yeAAC","file":"/Volumes/Projects/wexts/packages/dist/rpc/index.js"}
@@ -1,23 +0,0 @@
1
- import "../chunk-ZX7QIN24.mjs";
2
- import {
3
- RequireAuth,
4
- RpcMethod,
5
- RpcService,
6
- WextsRpc,
7
- WextsRpcService,
8
- getRpcAuthPolicy,
9
- getRuntimeRpcMethodsMetadata,
10
- getRuntimeRpcServiceMetadata
11
- } from "../chunk-YBM3IJEA.mjs";
12
- import "../chunk-7WULUGLH.mjs";
13
- export {
14
- RequireAuth,
15
- RpcMethod,
16
- RpcService,
17
- WextsRpc,
18
- WextsRpcService,
19
- getRpcAuthPolicy,
20
- getRuntimeRpcMethodsMetadata,
21
- getRuntimeRpcServiceMetadata
22
- };
23
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -1,55 +0,0 @@
1
- import { FastifyRequest, FastifyInstance, FastifyServerOptions } from 'fastify';
2
- import { c as RpcManifest, f as RpcServiceManifest } from '../types-7d_fC-C3.mjs';
3
- import { WextsShieldConfig } from '@wexts/security';
4
- import { IncomingMessage, ServerResponse } from 'http';
5
-
6
- type RpcServiceInstances = Record<string, Record<string, (...args: unknown[]) => unknown | Promise<unknown>>>;
7
- interface RegisterRpcRoutesOptions {
8
- manifest: RpcManifest;
9
- services: RpcServiceInstances;
10
- authorize?: (request: FastifyRequest, service: RpcServiceManifest, methodName: string) => boolean | Promise<boolean>;
11
- }
12
- declare function registerRpcRoutes(fastify: FastifyInstance, options: RegisterRpcRoutesOptions): Promise<void>;
13
-
14
- interface WextsRuntimeConfig {
15
- rootDir?: string;
16
- port?: number;
17
- host?: string;
18
- dev?: boolean;
19
- nextDir?: string;
20
- nestAppModule?: unknown;
21
- nestAppModulePath?: string;
22
- rpcManifest?: RpcManifest;
23
- rpcManifestPath?: string;
24
- rpcServices?: RpcServiceInstances;
25
- security?: WextsShieldConfig;
26
- logger?: FastifyServerOptions['logger'];
27
- }
28
- interface WextsRuntimeServer {
29
- fastify: FastifyInstance;
30
- start: () => Promise<void>;
31
- close: () => Promise<void>;
32
- }
33
- declare function createWextsRuntimeServer(config?: WextsRuntimeConfig): Promise<WextsRuntimeServer>;
34
- declare function startWextsRuntime(config?: WextsRuntimeConfig): Promise<WextsRuntimeServer>;
35
-
36
- /**
37
- * Vercel / serverless handler adapter for the Wexts runtime.
38
- *
39
- * Creates a standard Node.js (req, res) handler that delegates to the
40
- * Fastify-backed Wexts runtime **without** calling fastify.listen().
41
- *
42
- * Usage:
43
- * const handler = await createWextsHandler({ ... });
44
- * export default handler; // Vercel function entry
45
- */
46
-
47
- type WextsHandler = (req: IncomingMessage, res: ServerResponse) => void;
48
- /**
49
- * Build a serverless-compatible handler from the Wexts runtime.
50
- * The returned function accepts Node http (req, res) and passes them
51
- * into the Fastify instance without ever calling listen().
52
- */
53
- declare function createWextsHandler(config?: WextsRuntimeConfig): Promise<WextsHandler>;
54
-
55
- export { type RegisterRpcRoutesOptions, type RpcServiceInstances, type WextsHandler, type WextsRuntimeConfig, type WextsRuntimeServer, createWextsHandler, createWextsRuntimeServer, registerRpcRoutes, startWextsRuntime };
@@ -1,55 +0,0 @@
1
- import { FastifyRequest, FastifyInstance, FastifyServerOptions } from 'fastify';
2
- import { c as RpcManifest, f as RpcServiceManifest } from '../types-7d_fC-C3.js';
3
- import { WextsShieldConfig } from '@wexts/security';
4
- import { IncomingMessage, ServerResponse } from 'http';
5
-
6
- type RpcServiceInstances = Record<string, Record<string, (...args: unknown[]) => unknown | Promise<unknown>>>;
7
- interface RegisterRpcRoutesOptions {
8
- manifest: RpcManifest;
9
- services: RpcServiceInstances;
10
- authorize?: (request: FastifyRequest, service: RpcServiceManifest, methodName: string) => boolean | Promise<boolean>;
11
- }
12
- declare function registerRpcRoutes(fastify: FastifyInstance, options: RegisterRpcRoutesOptions): Promise<void>;
13
-
14
- interface WextsRuntimeConfig {
15
- rootDir?: string;
16
- port?: number;
17
- host?: string;
18
- dev?: boolean;
19
- nextDir?: string;
20
- nestAppModule?: unknown;
21
- nestAppModulePath?: string;
22
- rpcManifest?: RpcManifest;
23
- rpcManifestPath?: string;
24
- rpcServices?: RpcServiceInstances;
25
- security?: WextsShieldConfig;
26
- logger?: FastifyServerOptions['logger'];
27
- }
28
- interface WextsRuntimeServer {
29
- fastify: FastifyInstance;
30
- start: () => Promise<void>;
31
- close: () => Promise<void>;
32
- }
33
- declare function createWextsRuntimeServer(config?: WextsRuntimeConfig): Promise<WextsRuntimeServer>;
34
- declare function startWextsRuntime(config?: WextsRuntimeConfig): Promise<WextsRuntimeServer>;
35
-
36
- /**
37
- * Vercel / serverless handler adapter for the Wexts runtime.
38
- *
39
- * Creates a standard Node.js (req, res) handler that delegates to the
40
- * Fastify-backed Wexts runtime **without** calling fastify.listen().
41
- *
42
- * Usage:
43
- * const handler = await createWextsHandler({ ... });
44
- * export default handler; // Vercel function entry
45
- */
46
-
47
- type WextsHandler = (req: IncomingMessage, res: ServerResponse) => void;
48
- /**
49
- * Build a serverless-compatible handler from the Wexts runtime.
50
- * The returned function accepts Node http (req, res) and passes them
51
- * into the Fastify instance without ever calling listen().
52
- */
53
- declare function createWextsHandler(config?: WextsRuntimeConfig): Promise<WextsHandler>;
54
-
55
- export { type RegisterRpcRoutesOptions, type RpcServiceInstances, type WextsHandler, type WextsRuntimeConfig, type WextsRuntimeServer, createWextsHandler, createWextsRuntimeServer, registerRpcRoutes, startWextsRuntime };
@@ -1,221 +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 _chunkAVMQJWYDjs = require('../chunk-AVMQJWYD.js');
4
-
5
-
6
- var _chunkXE4OXN2Wjs = require('../chunk-XE4OXN2W.js');
7
-
8
- // src/runtime/rpc-router.ts
9
- async function registerRpcRoutes(fastify, options) {
10
- const serviceMap = new Map(options.manifest.services.map((service) => [
11
- service.name,
12
- service
13
- ]));
14
- fastify.post("/rpc/:service/:method", async (request, reply) => {
15
- const service = serviceMap.get(request.params.service);
16
- if (!service) {
17
- reply.status(404);
18
- return {
19
- error: "WEXTS_RPC_SERVICE_NOT_FOUND"
20
- };
21
- }
22
- const method = service.methods.find((candidate) => candidate.name === request.params.method);
23
- if (!method) {
24
- reply.status(404);
25
- return {
26
- error: "WEXTS_RPC_METHOD_NOT_FOUND"
27
- };
28
- }
29
- if (method.requireAuth || service.requireAuth) {
30
- const authorized = await _optionalChain([options, 'access', _ => _.authorize, 'optionalCall', _2 => _2(request, service, method.name)]);
31
- if (!authorized) {
32
- reply.status(401);
33
- return {
34
- error: "WEXTS_RPC_AUTH_REQUIRED"
35
- };
36
- }
37
- }
38
- const instance = options.services[service.name];
39
- const handler = _optionalChain([instance, 'optionalAccess', _3 => _3[method.handlerName]]);
40
- if (!handler) {
41
- reply.status(500);
42
- return {
43
- error: "WEXTS_RPC_HANDLER_NOT_BOUND"
44
- };
45
- }
46
- const args = Array.isArray(_optionalChain([request, 'access', _4 => _4.body, 'optionalAccess', _5 => _5.args])) ? request.body.args : [];
47
- const data = await handler.apply(instance, args);
48
- return {
49
- data
50
- };
51
- });
52
- }
53
- _chunkXE4OXN2Wjs.__name.call(void 0, registerRpcRoutes, "registerRpcRoutes");
54
-
55
- // src/runtime/server.ts
56
- var _fs = require('fs'); var fs = _interopRequireWildcard(_fs);
57
- var _path = require('path'); var path = _interopRequireWildcard(_path);
58
- var _fastify = require('fastify'); var _fastify2 = _interopRequireDefault(_fastify);
59
- var _security = require('@wexts/security');
60
- async function createWextsRuntimeServer(config = {}) {
61
- const rootDir = path.resolve(_nullishCoalesce(config.rootDir, () => ( process.cwd())));
62
- const fastify = _fastify2.default.call(void 0, {
63
- logger: _nullishCoalesce(config.logger, () => ( true)),
64
- bodyLimit: _nullishCoalesce(_optionalChain([config, 'access', _6 => _6.security, 'optionalAccess', _7 => _7.bodyLimitBytes]), () => ( 1048576)),
65
- requestTimeout: _nullishCoalesce(_optionalChain([config, 'access', _8 => _8.security, 'optionalAccess', _9 => _9.requestTimeoutMs]), () => ( 3e4))
66
- });
67
- const manifest = _nullishCoalesce(config.rpcManifest, () => ( loadJson(rootDir, config.rpcManifestPath)));
68
- const routePolicies = [
69
- ..._nullishCoalesce(_optionalChain([config, 'access', _10 => _10.security, 'optionalAccess', _11 => _11.routePolicies]), () => ( [])),
70
- ...rpcPoliciesFromManifest(manifest)
71
- ];
72
- await _security.registerWextsShield.call(void 0, fastify, {
73
- ...config.security,
74
- routePolicies
75
- });
76
- fastify.get("/health", async () => ({
77
- ok: true,
78
- runtime: "wexts"
79
- }));
80
- fastify.get("/api/health", async () => ({
81
- ok: true,
82
- runtime: "wexts",
83
- scope: "api"
84
- }));
85
- if (manifest && config.rpcServices) {
86
- await registerRpcRoutes(fastify, {
87
- manifest,
88
- services: config.rpcServices,
89
- authorize: /* @__PURE__ */ _chunkXE4OXN2Wjs.__name.call(void 0, (request) => Boolean(request.headers.authorization || request.headers.cookie), "authorize")
90
- });
91
- }
92
- if (config.nestAppModule || config.nestAppModulePath) {
93
- await mountNest(fastify, rootDir, config);
94
- }
95
- if (config.nextDir) {
96
- await mountNext(fastify, rootDir, config);
97
- }
98
- const start = /* @__PURE__ */ _chunkXE4OXN2Wjs.__name.call(void 0, async () => {
99
- await fastify.listen({
100
- port: _nullishCoalesce(config.port, () => ( Number(_nullishCoalesce(process.env.PORT, () => ( 3e3))))),
101
- host: _nullishCoalesce(config.host, () => ( "0.0.0.0"))
102
- });
103
- }, "start");
104
- const close = /* @__PURE__ */ _chunkXE4OXN2Wjs.__name.call(void 0, async () => {
105
- await fastify.close();
106
- }, "close");
107
- registerShutdown(close);
108
- return {
109
- fastify,
110
- start,
111
- close
112
- };
113
- }
114
- _chunkXE4OXN2Wjs.__name.call(void 0, createWextsRuntimeServer, "createWextsRuntimeServer");
115
- async function startWextsRuntime(config = {}) {
116
- const server = await createWextsRuntimeServer(config);
117
- await server.start();
118
- return server;
119
- }
120
- _chunkXE4OXN2Wjs.__name.call(void 0, startWextsRuntime, "startWextsRuntime");
121
- function rpcPoliciesFromManifest(manifest) {
122
- if (!manifest) return [];
123
- return manifest.services.flatMap((service) => service.methods.map((method) => ({
124
- path: `/rpc/${service.name}/${method.name}`,
125
- methods: [
126
- "POST"
127
- ],
128
- mode: service.requireAuth || method.requireAuth ? "requireAuth" : "public"
129
- })));
130
- }
131
- _chunkXE4OXN2Wjs.__name.call(void 0, rpcPoliciesFromManifest, "rpcPoliciesFromManifest");
132
- function loadJson(rootDir, filePath) {
133
- if (!filePath) return void 0;
134
- const absolutePath = path.isAbsolute(filePath) ? filePath : path.join(rootDir, filePath);
135
- if (!fs.existsSync(absolutePath)) return void 0;
136
- return JSON.parse(fs.readFileSync(absolutePath, "utf8"));
137
- }
138
- _chunkXE4OXN2Wjs.__name.call(void 0, loadJson, "loadJson");
139
- async function mountNest(fastify, rootDir, config) {
140
- const [{ NestFactory }, { FastifyAdapter }] = await Promise.all([
141
- Promise.resolve().then(() => _interopRequireWildcard(require("@nestjs/core"))),
142
- Promise.resolve().then(() => _interopRequireWildcard(require("@nestjs/platform-fastify")))
143
- ]);
144
- const AppModule = await _asyncNullishCoalesce(config.nestAppModule, async () => ( await importModule(rootDir, config.nestAppModulePath)));
145
- const moduleValue = _nullishCoalesce(AppModule.AppModule, () => ( AppModule));
146
- const nestApp = await NestFactory.create(moduleValue, new FastifyAdapter(fastify), {
147
- logger: config.dev ? [
148
- "log",
149
- "error",
150
- "warn"
151
- ] : [
152
- "error",
153
- "warn"
154
- ]
155
- });
156
- nestApp.setGlobalPrefix("api");
157
- await nestApp.init();
158
- }
159
- _chunkXE4OXN2Wjs.__name.call(void 0, mountNest, "mountNest");
160
- async function mountNext(fastify, rootDir, config) {
161
- const nextModule = await Promise.resolve().then(() => _interopRequireWildcard(require("next")));
162
- const next = nextModule.default;
163
- if (!next) {
164
- throw new (0, _chunkAVMQJWYDjs.WextsRuntimeError)({
165
- code: "WEXTS_RUNTIME_NEXT_MISSING",
166
- message: "Next.js could not be loaded. Install next or omit nextDir.",
167
- suggestedFix: "Install `next` in the application or remove `nextDir` from wexts.runtime.js.",
168
- docsSlug: "runtime"
169
- });
170
- }
171
- const nextApp = next({
172
- dev: _nullishCoalesce(config.dev, () => ( process.env.NODE_ENV !== "production")),
173
- dir: path.isAbsolute(config.nextDir) ? config.nextDir : path.join(rootDir, config.nextDir)
174
- });
175
- await nextApp.prepare();
176
- const handler = nextApp.getRequestHandler();
177
- fastify.all("/*", async (request, reply) => {
178
- await handler(request.raw, reply.raw);
179
- reply.hijack();
180
- });
181
- }
182
- _chunkXE4OXN2Wjs.__name.call(void 0, mountNext, "mountNext");
183
- async function importModule(rootDir, modulePath) {
184
- const absolutePath = path.isAbsolute(modulePath) ? modulePath : path.join(rootDir, modulePath);
185
- return Promise.resolve().then(() => _interopRequireWildcard(require(pathToFileUrl(absolutePath))));
186
- }
187
- _chunkXE4OXN2Wjs.__name.call(void 0, importModule, "importModule");
188
- function pathToFileUrl(filePath) {
189
- return `file://${filePath}`;
190
- }
191
- _chunkXE4OXN2Wjs.__name.call(void 0, pathToFileUrl, "pathToFileUrl");
192
- function registerShutdown(close) {
193
- const handler = /* @__PURE__ */ _chunkXE4OXN2Wjs.__name.call(void 0, async () => {
194
- await close();
195
- process.exit(0);
196
- }, "handler");
197
- process.once("SIGINT", handler);
198
- process.once("SIGTERM", handler);
199
- }
200
- _chunkXE4OXN2Wjs.__name.call(void 0, registerShutdown, "registerShutdown");
201
-
202
- // src/runtime/vercel-handler.ts
203
- async function createWextsHandler(config = {}) {
204
- const server = await createWextsRuntimeServer({
205
- ...config,
206
- // Serverless does not use long-lived logging
207
- logger: _nullishCoalesce(config.logger, () => ( false))
208
- });
209
- await server.fastify.ready();
210
- return (req, res) => {
211
- server.fastify.server.emit("request", req, res);
212
- };
213
- }
214
- _chunkXE4OXN2Wjs.__name.call(void 0, createWextsHandler, "createWextsHandler");
215
-
216
-
217
-
218
-
219
-
220
- exports.createWextsHandler = createWextsHandler; exports.createWextsRuntimeServer = createWextsRuntimeServer; exports.registerRpcRoutes = registerRpcRoutes; exports.startWextsRuntime = startWextsRuntime;
221
- //# 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';\nimport { WextsRuntimeError } from '../errors';\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 WextsRuntimeError({\n code: 'WEXTS_RUNTIME_NEXT_MISSING',\n message: 'Next.js could not be loaded. Install next or omit nextDir.',\n suggestedFix: 'Install `next` in the application or remove `nextDir` from wexts.runtime.js.',\n docsSlug: 'runtime',\n });\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"]}