@gravito/ripple 4.0.0 → 4.0.3

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 (225) hide show
  1. package/README.md +26 -10
  2. package/dist/{ripple/src/OrbitRipple.d.ts → OrbitRipple.d.ts} +1 -0
  3. package/dist/{ripple/src/RippleServer.d.ts → RippleServer.d.ts} +32 -2
  4. package/dist/core/src/Application.d.ts +41 -0
  5. package/dist/core/src/ConfigManager.d.ts +39 -0
  6. package/dist/core/src/Container/RequestScopeManager.d.ts +62 -0
  7. package/dist/core/src/Container/RequestScopeMetrics.d.ts +144 -0
  8. package/dist/core/src/Container.d.ts +45 -0
  9. package/dist/core/src/ErrorHandler.d.ts +3 -0
  10. package/dist/core/src/HookManager.d.ts +104 -165
  11. package/dist/core/src/PlanetCore.d.ts +114 -1
  12. package/dist/core/src/RequestContext.d.ts +97 -0
  13. package/dist/core/src/Router.d.ts +32 -46
  14. package/dist/core/src/ServiceProvider.d.ts +22 -0
  15. package/dist/core/src/adapters/bun/BunContext.d.ts +10 -1
  16. package/dist/core/src/adapters/bun/BunNativeAdapter.d.ts +35 -0
  17. package/dist/core/src/adapters/bun/BunWebSocketHandler.d.ts +48 -0
  18. package/dist/core/src/adapters/bun/RadixRouter.d.ts +1 -0
  19. package/dist/core/src/adapters/bun/index.d.ts +7 -0
  20. package/dist/core/src/binary/BinaryUtils.d.ts +105 -0
  21. package/dist/core/src/binary/index.d.ts +5 -0
  22. package/dist/core/src/cli/queue-commands.d.ts +6 -0
  23. package/dist/core/src/compat/async-local-storage.d.ts +7 -0
  24. package/dist/core/src/compat/crypto.d.ts +6 -0
  25. package/dist/core/src/engine/AOTRouter.d.ts +16 -1
  26. package/dist/core/src/engine/FastContext.d.ts +42 -1
  27. package/dist/core/src/engine/Gravito.d.ts +13 -19
  28. package/dist/core/src/engine/MinimalContext.d.ts +23 -0
  29. package/dist/core/src/engine/analyzer.d.ts +92 -6
  30. package/dist/core/src/engine/types.d.ts +6 -0
  31. package/dist/core/src/error-handling/RequestScopeErrorContext.d.ts +126 -0
  32. package/dist/core/src/events/BackpressureManager.d.ts +215 -0
  33. package/dist/core/src/events/DeadLetterQueue.d.ts +75 -1
  34. package/dist/core/src/events/EventBackend.d.ts +2 -1
  35. package/dist/core/src/events/EventOptions.d.ts +99 -4
  36. package/dist/core/src/events/EventPriorityQueue.d.ts +36 -175
  37. package/dist/core/src/events/FlowControlStrategy.d.ts +109 -0
  38. package/dist/core/src/events/MessageQueueBridge.d.ts +184 -0
  39. package/dist/core/src/events/PriorityEscalationManager.d.ts +82 -0
  40. package/dist/core/src/events/RetryScheduler.d.ts +104 -0
  41. package/dist/core/src/events/WorkerPool.d.ts +98 -0
  42. package/dist/core/src/events/WorkerPoolConfig.d.ts +153 -0
  43. package/dist/core/src/events/WorkerPoolMetrics.d.ts +65 -0
  44. package/dist/core/src/events/aggregation/AggregationWindow.d.ts +77 -0
  45. package/dist/core/src/events/aggregation/DeduplicationManager.d.ts +135 -0
  46. package/dist/core/src/events/aggregation/EventAggregationManager.d.ts +108 -0
  47. package/dist/core/src/events/aggregation/EventBatcher.d.ts +99 -0
  48. package/dist/core/src/events/aggregation/types.d.ts +117 -0
  49. package/dist/core/src/events/index.d.ts +18 -6
  50. package/dist/core/src/events/observability/OTelEventMetrics.d.ts +92 -0
  51. package/dist/core/src/events/observability/StreamWorkerMetrics.d.ts +76 -0
  52. package/dist/core/src/events/observability/index.d.ts +4 -0
  53. package/dist/core/src/events/queue-core.d.ts +77 -0
  54. package/dist/core/src/events/task-executor.d.ts +51 -0
  55. package/dist/core/src/events/types.d.ts +59 -0
  56. package/dist/core/src/ffi/NativeAccelerator.d.ts +62 -0
  57. package/dist/core/src/ffi/NativeHasher.d.ts +139 -0
  58. package/dist/core/src/ffi/cbor-fallback.d.ts +96 -0
  59. package/dist/core/src/ffi/hash-fallback.d.ts +33 -0
  60. package/dist/core/src/ffi/index.d.ts +10 -0
  61. package/dist/core/src/ffi/types.d.ts +135 -0
  62. package/dist/core/src/health/HealthProvider.d.ts +67 -0
  63. package/dist/core/src/helpers/Str.d.ts +15 -0
  64. package/dist/core/src/hooks/ActionManager.d.ts +132 -0
  65. package/dist/core/src/hooks/AsyncDetector.d.ts +84 -0
  66. package/dist/core/src/hooks/FilterManager.d.ts +71 -0
  67. package/dist/core/src/hooks/MigrationWarner.d.ts +24 -0
  68. package/dist/core/src/hooks/dlq-operations.d.ts +60 -0
  69. package/dist/core/src/hooks/types.d.ts +107 -0
  70. package/dist/core/src/http/CookieJar.d.ts +2 -2
  71. package/dist/core/src/http/types.d.ts +43 -3
  72. package/dist/core/src/index.d.ts +504 -15
  73. package/dist/core/src/observability/QueueDashboard.d.ts +136 -0
  74. package/dist/core/src/observability/contracts.d.ts +137 -0
  75. package/dist/core/src/reliability/DeadLetterQueueManager.d.ts +36 -3
  76. package/dist/core/src/runtime/adapter-bun.d.ts +12 -0
  77. package/dist/core/src/runtime/adapter-deno.d.ts +12 -0
  78. package/dist/core/src/runtime/adapter-node.d.ts +12 -0
  79. package/dist/core/src/runtime/adapter-unknown.d.ts +13 -0
  80. package/dist/core/src/runtime/archive.d.ts +17 -0
  81. package/dist/core/src/runtime/compression.d.ts +21 -0
  82. package/dist/core/src/runtime/deep-equals.d.ts +56 -0
  83. package/dist/core/src/runtime/detection.d.ts +22 -0
  84. package/dist/core/src/runtime/escape.d.ts +34 -0
  85. package/dist/core/src/runtime/index.d.ts +44 -0
  86. package/dist/core/src/runtime/markdown.d.ts +44 -0
  87. package/dist/core/src/runtime/types.d.ts +436 -0
  88. package/dist/core/src/runtime-helpers.d.ts +67 -0
  89. package/dist/core/src/runtime.d.ts +10 -118
  90. package/dist/core/src/testing/HttpTester.d.ts +1 -0
  91. package/dist/core/src/transpiler-utils.d.ts +170 -0
  92. package/dist/{ripple/src/engines → engines}/BunEngine.d.ts +11 -0
  93. package/dist/engines/UWebSocketsEngine.d.ts +97 -0
  94. package/dist/engines/WsEngine.d.ts +69 -0
  95. package/dist/{ripple/src/engines → engines}/index.d.ts +4 -0
  96. package/dist/index.js +1 -7139
  97. package/dist/index.js.map +3 -69
  98. package/dist/{ripple/src/serializers → serializers}/ISerializer.d.ts +1 -1
  99. package/dist/{ripple/src/serializers → serializers}/JsonSerializer.d.ts +1 -1
  100. package/dist/{ripple/src/serializers → serializers}/ProtobufSerializer.d.ts +6 -3
  101. package/dist/{ripple/src/types.d.ts → types.d.ts} +11 -0
  102. package/package.json +7 -2
  103. package/dist/atlas/src/DB.d.ts +0 -301
  104. package/dist/atlas/src/OrbitAtlas.d.ts +0 -9
  105. package/dist/atlas/src/config/defineConfig.d.ts +0 -14
  106. package/dist/atlas/src/config/index.d.ts +0 -7
  107. package/dist/atlas/src/config/loadConfig.d.ts +0 -48
  108. package/dist/atlas/src/connection/Connection.d.ts +0 -108
  109. package/dist/atlas/src/connection/ConnectionManager.d.ts +0 -111
  110. package/dist/atlas/src/drivers/BunSQLDriver.d.ts +0 -32
  111. package/dist/atlas/src/drivers/BunSQLPreparedStatement.d.ts +0 -118
  112. package/dist/atlas/src/drivers/MongoDBDriver.d.ts +0 -36
  113. package/dist/atlas/src/drivers/MySQLDriver.d.ts +0 -66
  114. package/dist/atlas/src/drivers/PostgresDriver.d.ts +0 -83
  115. package/dist/atlas/src/drivers/RedisDriver.d.ts +0 -43
  116. package/dist/atlas/src/drivers/SQLiteDriver.d.ts +0 -45
  117. package/dist/atlas/src/drivers/types.d.ts +0 -260
  118. package/dist/atlas/src/errors/index.d.ts +0 -45
  119. package/dist/atlas/src/grammar/Grammar.d.ts +0 -342
  120. package/dist/atlas/src/grammar/MongoGrammar.d.ts +0 -47
  121. package/dist/atlas/src/grammar/MySQLGrammar.d.ts +0 -54
  122. package/dist/atlas/src/grammar/NullGrammar.d.ts +0 -35
  123. package/dist/atlas/src/grammar/PostgresGrammar.d.ts +0 -62
  124. package/dist/atlas/src/grammar/SQLiteGrammar.d.ts +0 -32
  125. package/dist/atlas/src/index.d.ts +0 -67
  126. package/dist/atlas/src/migration/Migration.d.ts +0 -64
  127. package/dist/atlas/src/migration/MigrationRepository.d.ts +0 -65
  128. package/dist/atlas/src/migration/Migrator.d.ts +0 -110
  129. package/dist/atlas/src/migration/index.d.ts +0 -6
  130. package/dist/atlas/src/observability/AtlasMetrics.d.ts +0 -11
  131. package/dist/atlas/src/observability/AtlasObservability.d.ts +0 -15
  132. package/dist/atlas/src/observability/AtlasTracer.d.ts +0 -12
  133. package/dist/atlas/src/observability/index.d.ts +0 -9
  134. package/dist/atlas/src/orm/index.d.ts +0 -5
  135. package/dist/atlas/src/orm/model/DirtyTracker.d.ts +0 -121
  136. package/dist/atlas/src/orm/model/Model.d.ts +0 -449
  137. package/dist/atlas/src/orm/model/ModelRegistry.d.ts +0 -20
  138. package/dist/atlas/src/orm/model/concerns/HasAttributes.d.ts +0 -136
  139. package/dist/atlas/src/orm/model/concerns/HasEvents.d.ts +0 -36
  140. package/dist/atlas/src/orm/model/concerns/HasPersistence.d.ts +0 -87
  141. package/dist/atlas/src/orm/model/concerns/HasRelationships.d.ts +0 -117
  142. package/dist/atlas/src/orm/model/concerns/HasSerialization.d.ts +0 -64
  143. package/dist/atlas/src/orm/model/concerns/applyMixins.d.ts +0 -15
  144. package/dist/atlas/src/orm/model/concerns/index.d.ts +0 -12
  145. package/dist/atlas/src/orm/model/decorators.d.ts +0 -109
  146. package/dist/atlas/src/orm/model/errors.d.ts +0 -52
  147. package/dist/atlas/src/orm/model/index.d.ts +0 -10
  148. package/dist/atlas/src/orm/model/relationships.d.ts +0 -207
  149. package/dist/atlas/src/orm/model/types.d.ts +0 -12
  150. package/dist/atlas/src/orm/schema/SchemaRegistry.d.ts +0 -123
  151. package/dist/atlas/src/orm/schema/SchemaSniffer.d.ts +0 -54
  152. package/dist/atlas/src/orm/schema/index.d.ts +0 -6
  153. package/dist/atlas/src/orm/schema/types.d.ts +0 -85
  154. package/dist/atlas/src/query/Expression.d.ts +0 -60
  155. package/dist/atlas/src/query/NPlusOneDetector.d.ts +0 -10
  156. package/dist/atlas/src/query/QueryBuilder.d.ts +0 -573
  157. package/dist/atlas/src/query/clauses/GroupByClause.d.ts +0 -51
  158. package/dist/atlas/src/query/clauses/HavingClause.d.ts +0 -70
  159. package/dist/atlas/src/query/clauses/JoinClause.d.ts +0 -87
  160. package/dist/atlas/src/query/clauses/LimitClause.d.ts +0 -82
  161. package/dist/atlas/src/query/clauses/OrderByClause.d.ts +0 -69
  162. package/dist/atlas/src/query/clauses/SelectClause.d.ts +0 -71
  163. package/dist/atlas/src/query/clauses/WhereClause.d.ts +0 -167
  164. package/dist/atlas/src/query/clauses/index.d.ts +0 -11
  165. package/dist/atlas/src/schema/Blueprint.d.ts +0 -276
  166. package/dist/atlas/src/schema/ColumnDefinition.d.ts +0 -154
  167. package/dist/atlas/src/schema/ForeignKeyDefinition.d.ts +0 -37
  168. package/dist/atlas/src/schema/Schema.d.ts +0 -131
  169. package/dist/atlas/src/schema/grammars/MySQLSchemaGrammar.d.ts +0 -23
  170. package/dist/atlas/src/schema/grammars/PostgresSchemaGrammar.d.ts +0 -26
  171. package/dist/atlas/src/schema/grammars/SQLiteSchemaGrammar.d.ts +0 -28
  172. package/dist/atlas/src/schema/grammars/SchemaGrammar.d.ts +0 -97
  173. package/dist/atlas/src/schema/grammars/index.d.ts +0 -7
  174. package/dist/atlas/src/schema/index.d.ts +0 -8
  175. package/dist/atlas/src/seed/Factory.d.ts +0 -90
  176. package/dist/atlas/src/seed/Seeder.d.ts +0 -28
  177. package/dist/atlas/src/seed/SeederRunner.d.ts +0 -74
  178. package/dist/atlas/src/seed/index.d.ts +0 -6
  179. package/dist/atlas/src/types/index.d.ts +0 -1100
  180. package/dist/atlas/src/utils/levenshtein.d.ts +0 -9
  181. package/dist/core/src/adapters/PhotonAdapter.d.ts +0 -171
  182. package/dist/core/src/adapters/photon-types.d.ts +0 -73
  183. package/dist/core/src/http/middleware/BodySizeLimit.d.ts +0 -16
  184. package/dist/core/src/http/middleware/Cors.d.ts +0 -24
  185. package/dist/core/src/http/middleware/Csrf.d.ts +0 -23
  186. package/dist/core/src/http/middleware/HeaderTokenGate.d.ts +0 -28
  187. package/dist/core/src/http/middleware/SecurityHeaders.d.ts +0 -29
  188. package/dist/core/src/http/middleware/ThrottleRequests.d.ts +0 -18
  189. package/dist/core/src/instrumentation/index.d.ts +0 -35
  190. package/dist/core/src/instrumentation/opentelemetry.d.ts +0 -178
  191. package/dist/core/src/instrumentation/types.d.ts +0 -182
  192. package/dist/photon/src/index.d.ts +0 -84
  193. package/dist/photon/src/middleware/binary.d.ts +0 -31
  194. package/dist/photon/src/middleware/htmx.d.ts +0 -39
  195. package/dist/photon/src/middleware/ratelimit.d.ts +0 -157
  196. package/dist/photon/src/openapi.d.ts +0 -19
  197. /package/dist/{ripple/src/channels → channels}/Channel.d.ts +0 -0
  198. /package/dist/{ripple/src/channels → channels}/ChannelManager.d.ts +0 -0
  199. /package/dist/{ripple/src/channels → channels}/index.d.ts +0 -0
  200. /package/dist/{ripple/src/drivers → drivers}/LocalDriver.d.ts +0 -0
  201. /package/dist/{ripple/src/drivers → drivers}/NATSDriver.d.ts +0 -0
  202. /package/dist/{ripple/src/drivers → drivers}/RedisDriver.d.ts +0 -0
  203. /package/dist/{ripple/src/drivers → drivers}/index.d.ts +0 -0
  204. /package/dist/{ripple/src/engines → engines}/IRippleEngine.d.ts +0 -0
  205. /package/dist/{ripple/src/errors → errors}/RippleError.d.ts +0 -0
  206. /package/dist/{ripple/src/errors → errors}/index.d.ts +0 -0
  207. /package/dist/{ripple/src/events → events}/BroadcastEvent.d.ts +0 -0
  208. /package/dist/{ripple/src/events → events}/BroadcastManager.d.ts +0 -0
  209. /package/dist/{ripple/src/events → events}/Broadcaster.d.ts +0 -0
  210. /package/dist/{ripple/src/events → events}/index.d.ts +0 -0
  211. /package/dist/{ripple/src/health → health}/HealthChecker.d.ts +0 -0
  212. /package/dist/{ripple/src/health → health}/index.d.ts +0 -0
  213. /package/dist/{ripple/src/index.d.ts → index.d.ts} +0 -0
  214. /package/dist/{ripple/src/logging → logging}/Logger.d.ts +0 -0
  215. /package/dist/{ripple/src/logging → logging}/index.d.ts +0 -0
  216. /package/dist/{ripple/src/middleware → middleware}/InterceptorManager.d.ts +0 -0
  217. /package/dist/{ripple/src/observability → observability}/RippleMetrics.d.ts +0 -0
  218. /package/dist/{ripple/src/reliability → reliability}/AckManager.d.ts +0 -0
  219. /package/dist/{ripple/src/serializers → serializers}/index.d.ts +0 -0
  220. /package/dist/{ripple/src/tracking → tracking}/ConnectionTracker.d.ts +0 -0
  221. /package/dist/{ripple/src/tracking → tracking}/SessionManager.d.ts +0 -0
  222. /package/dist/{ripple/src/tracking → tracking}/index.d.ts +0 -0
  223. /package/dist/{ripple/src/utils → utils}/MessageSerializer.d.ts +0 -0
  224. /package/dist/{ripple/src/utils → utils}/TokenBucket.d.ts +0 -0
  225. /package/dist/{ripple/src/utils → utils}/index.d.ts +0 -0
@@ -0,0 +1,170 @@
1
+ /**
2
+ * @fileoverview Transpiler 工具庫 - AST 層級代碼分析
3
+ *
4
+ * 使用 Bun.Transpiler API 進行精確的 handler 函式分析,
5
+ * 相比傳統字串匹配,精確度從 ~85% 提升至 ~99%。
6
+ *
7
+ * 核心策略:
8
+ * 1. 使用 transformSync() 標準化代碼格式(統一縮排、引號等)
9
+ * 2. 對轉換後的代碼使用精確的正規表達式匹配 member expression
10
+ * 3. 區分 API 呼叫(.req.header())與變數名稱(const header = ...)
11
+ * 4. 支援解構賦值模式(const { header } = ctx.req)
12
+ * 5. 快取 Transpiler 實例(性能提升 5.9x)+ LRU 快取結果(額外 128x)
13
+ *
14
+ * @module @gravito/core/transpiler-utils
15
+ * @since 3.1.0
16
+ */
17
+ /**
18
+ * TranspilerCache - 管理 Bun.Transpiler 實例與結果快取
19
+ *
20
+ * 避免重複建立 Transpiler(每次建立約需 40µs),
21
+ * 並快取 transformSync 結果(重用快取比每次 transform 快 128x)。
22
+ *
23
+ * @example
24
+ * ```typescript
25
+ * const cache = TranspilerCache.getInstance()
26
+ * const transformed = cache.transform(handlerSource)
27
+ * ```
28
+ */
29
+ export declare class TranspilerCache {
30
+ private static instance;
31
+ /** 共享的 Bun.Transpiler 實例(避免重複建立) */
32
+ private readonly transpiler;
33
+ /** LRU 快取:原始代碼 → 轉換結果 */
34
+ private readonly cache;
35
+ /** 快取大小上限 */
36
+ private readonly maxSize;
37
+ /** 快取 TTL(毫秒),預設 5 分鐘 */
38
+ private readonly ttlMs;
39
+ private constructor();
40
+ /**
41
+ * 取得單例實例
42
+ * 確保全程只建立一個 Transpiler 實例
43
+ */
44
+ static getInstance(): TranspilerCache;
45
+ /**
46
+ * 重置單例(主要用於測試)
47
+ */
48
+ static resetInstance(): void;
49
+ /**
50
+ * 轉換代碼並快取結果
51
+ *
52
+ * 先嘗試從快取取得,若未命中則呼叫 transformSync 並儲存結果。
53
+ * 快取已滿時淘汰最舊的條目(近似 LRU)。
54
+ *
55
+ * 處理兩個 Bun.Transpiler 邊緣案例:
56
+ * 1. 箭頭函式表達式:`async (ctx) => ...` → transformSync 返回空字串
57
+ * 解法:包裝成 `const __fn = <source>` 後再轉換
58
+ * 2. 匿名函式表達式:`function(ctx) {...}` → transformSync 拋出 Parse error
59
+ * 解法:同樣包裝後轉換
60
+ *
61
+ * @param source - 原始 handler 函式字串
62
+ * @returns 轉換後的標準化代碼,若完全失敗則回傳 null
63
+ */
64
+ transform(source: string): string | null;
65
+ /**
66
+ * 實際執行 transformSync,處理箭頭函式和匿名函式的邊緣案例
67
+ *
68
+ * @param source - 原始代碼字串
69
+ * @returns 轉換後的代碼,或失敗時回傳 null
70
+ */
71
+ private doTransform;
72
+ /**
73
+ * 將代碼包裝成賦值語句後再 transform
74
+ *
75
+ * 用於處理無法直接 transform 的函式表達式。
76
+ * 包裝格式:`const __fn = <source>`
77
+ *
78
+ * @param source - 原始函式字串
79
+ * @returns 包裝後的轉換結果,或失敗時回傳 null
80
+ */
81
+ private transformWrapped;
82
+ /**
83
+ * 取得目前快取大小
84
+ */
85
+ get size(): number;
86
+ /**
87
+ * 清除所有快取條目
88
+ */
89
+ clear(): void;
90
+ }
91
+ /**
92
+ * Transpiler 分析的返回結果
93
+ * 與 HandlerAnalysis 介面對應
94
+ */
95
+ export interface TranspilerAnalysisResult {
96
+ usesHeaders: boolean;
97
+ usesQuery: boolean;
98
+ usesBody: boolean;
99
+ usesParams: boolean;
100
+ isAsync: boolean;
101
+ }
102
+ /**
103
+ * 使用 Bun.Transpiler 進行精確的 handler 靜態分析
104
+ *
105
+ * 相比字串匹配,此函式能正確區分:
106
+ * - API 呼叫(`ctx.req.header(name)`)vs 變數名稱(`const header = '...'`)
107
+ * - 解構賦值(`const { header } = ctx.req`)
108
+ * - Minified 代碼(transformSync 先標準化)
109
+ * - 箭頭函式與匿名函式(包裝策略處理 Bun.Transpiler 邊緣案例)
110
+ *
111
+ * 若 Transpiler 轉換失敗,會自動 fallback 到字串匹配模式。
112
+ *
113
+ * ## isAsync 特殊處理
114
+ *
115
+ * `isAsync` 直接從原始碼偵測 `async` 關鍵字,而不是從 transformSync 結果:
116
+ * - 箭頭函式 `async (ctx) => ...` 的 transformSync 返回空字串
117
+ * - `async` 關鍵字本身不存在假陽性問題
118
+ *
119
+ * @param source - handler 函式的字串表示(通常來自 handler.toString())
120
+ * @returns 分析結果,或在 fallback 模式下的近似結果
121
+ *
122
+ * @example
123
+ * ```typescript
124
+ * const handler = async (ctx) => {
125
+ * const name = ctx.req.query('name')
126
+ * return ctx.json({ name })
127
+ * }
128
+ * const result = analyzeHandlerWithTranspiler(handler.toString())
129
+ * // result.usesQuery === true
130
+ * // result.usesHeaders === false(即使有 'header' 字串,也不會誤判)
131
+ * // result.isAsync === true(即使是箭頭函式也能正確偵測)
132
+ * ```
133
+ */
134
+ export declare function analyzeHandlerWithTranspiler(source: string): TranspilerAnalysisResult;
135
+ /**
136
+ * 測試 handler 源代碼是否存取特定的 req 成員屬性
137
+ *
138
+ * 工具函式,方便在 Gravito.ts 等地方進行特定屬性的快速檢測。
139
+ *
140
+ * @param source - handler 函式的字串表示
141
+ * @param property - 要測試的屬性名稱(如 'header', 'query', 'body')
142
+ * @returns 若該屬性被存取則回傳 true
143
+ *
144
+ * @example
145
+ * ```typescript
146
+ * const src = handler.toString()
147
+ * if (hasReqMemberAccess(src, 'header')) {
148
+ * // handler 存取了 header
149
+ * }
150
+ * ```
151
+ */
152
+ export declare function hasReqMemberAccess(source: string, property: string): boolean;
153
+ /**
154
+ * 判斷 handler 是否為非同步函式
155
+ *
156
+ * 直接從原始碼偵測 `async` 關鍵字,不依賴 transformSync 結果,
157
+ * 因為箭頭函式的 transformSync 返回空字串。
158
+ * `async` 關鍵字本身不存在假陽性問題。
159
+ *
160
+ * @param source - handler 函式的字串表示
161
+ * @returns 若為 async 函式則回傳 true
162
+ */
163
+ export declare function isAsyncHandler(source: string): boolean;
164
+ /**
165
+ * 預熱 Transpiler 快取
166
+ *
167
+ * 在應用啟動時呼叫,觸發 Transpiler 實例建立,
168
+ * 避免第一個請求時的冷啟動延遲。
169
+ */
170
+ export declare function warmupTranspilerCache(): void;
@@ -95,4 +95,15 @@ export declare class BunEngine implements IRippleEngine {
95
95
  * Useful for advanced use cases.
96
96
  */
97
97
  getServer(): Server<ClientData> | undefined;
98
+ /**
99
+ * 獲取 WebSocket 路由 handlers(供 BunNativeAdapter.registerWebSocketRoute 使用)
100
+ *
101
+ * @returns WebSocket handler 物件(包含 open、message、close、drain)
102
+ */
103
+ getWebSocketConfig(): {
104
+ open: (ws: any) => void;
105
+ message: (ws: any, data: any) => void;
106
+ close: (ws: any, code: number, reason: string) => void;
107
+ drain: (_ws: any) => void;
108
+ };
98
109
  }
@@ -0,0 +1,97 @@
1
+ /**
2
+ * @fileoverview uWebSockets.js engine implementation for Node.js
3
+ *
4
+ * Wraps uWebSockets.js API to implement the IRippleEngine interface.
5
+ * This engine provides high performance on Node.js, close to Bun's native performance.
6
+ *
7
+ * @module @gravito/ripple/engines
8
+ * @since 5.0.0
9
+ */
10
+ import type { ClientData } from '../types';
11
+ import type { IRippleEngine, RippleSocket } from './IRippleEngine';
12
+ interface WebSocket {
13
+ send(message: string | ArrayBuffer, isBinary?: boolean, compress?: boolean): number;
14
+ close(): void;
15
+ getBufferedAmount(): number;
16
+ subscribe(topic: string): void;
17
+ unsubscribe(topic: string): void;
18
+ publish(topic: string, message: string | ArrayBuffer, isBinary?: boolean, compress?: boolean): boolean;
19
+ getUserData(): ClientData;
20
+ }
21
+ /**
22
+ * Wrapper around uWebSockets.js WebSocket to implement RippleSocket interface.
23
+ *
24
+ * This is a zero-overhead wrapper that delegates all operations to the uWebSockets.js
25
+ * WebSocket object.
26
+ */
27
+ export declare class UWebSocketsRippleSocket implements RippleSocket {
28
+ private ws;
29
+ constructor(ws: WebSocket);
30
+ get id(): string;
31
+ get data(): ClientData;
32
+ send(data: string | Uint8Array, compress?: boolean): void;
33
+ close(_code?: number, _reason?: string): void;
34
+ getBufferedAmount(): number;
35
+ subscribe(topic: string): void;
36
+ unsubscribe(topic: string): void;
37
+ publish(topic: string, data: string | Uint8Array): void;
38
+ get raw(): WebSocket;
39
+ }
40
+ /**
41
+ * Configuration for uWebSocketsEngine.
42
+ */
43
+ export interface UWebSocketsEngineConfig {
44
+ /** Port to listen on */
45
+ port?: number;
46
+ /** Hostname to bind to */
47
+ hostname?: string;
48
+ /** TLS configuration */
49
+ tls?: {
50
+ cert: string;
51
+ key: string;
52
+ };
53
+ /** Compression mode (0 = disabled, 1 = shared, 3 = dedicated 3KB) */
54
+ compression?: number;
55
+ /** Maximum payload length in bytes (default: 16MB) */
56
+ maxPayloadLength?: number;
57
+ /** Idle timeout in seconds (default: 120) */
58
+ idleTimeout?: number;
59
+ /** Maximum backpressure in bytes (default: 1MB) */
60
+ maxBackpressure?: number;
61
+ /** Development mode (enables verbose logging) */
62
+ development?: boolean;
63
+ }
64
+ /**
65
+ * uWebSockets.js engine for Node.js.
66
+ *
67
+ * Leverages uWebSockets.js high-performance WebSocket implementation with native pub/sub support.
68
+ * This engine provides excellent performance on Node.js (~90% of Bun's performance).
69
+ */
70
+ export declare class UWebSocketsEngine implements IRippleEngine {
71
+ private config;
72
+ readonly name = "node-uws";
73
+ private app?;
74
+ private uws?;
75
+ private connectionHandler?;
76
+ private disconnectionHandler?;
77
+ private messageHandler?;
78
+ private sockets;
79
+ private listenSocket?;
80
+ constructor(config?: UWebSocketsEngineConfig);
81
+ onConnection(handler: (socket: RippleSocket) => void): void;
82
+ onDisconnection(handler: (socket: RippleSocket, code: number, reason: string) => void): void;
83
+ onMessage(handler: (socket: RippleSocket, message: string | Uint8Array) => void): void;
84
+ listen(port: number): Promise<void>;
85
+ close(): Promise<void>;
86
+ broadcast(topic: string, data: string | Uint8Array, excludeSocketId?: string): void;
87
+ getConnectedSockets(): RippleSocket[];
88
+ getSocket(id: string): RippleSocket | undefined;
89
+ /**
90
+ * Upgrade an HTTP request to WebSocket.
91
+ *
92
+ * Note: This method is not used in the engine-based architecture.
93
+ * uWebSockets.js handles upgrades internally via the ws() route.
94
+ */
95
+ upgrade(_req: Request, _data?: Record<string, unknown>): boolean;
96
+ }
97
+ export {};
@@ -0,0 +1,69 @@
1
+ /**
2
+ * @fileoverview Node.js ws engine implementation
3
+ *
4
+ * Wraps the 'ws' library to implement the IRippleEngine interface.
5
+ * Implements in-memory pub/sub since the ws library does not support it natively.
6
+ *
7
+ * @module @gravito/ripple/engines
8
+ * @since 5.0.0
9
+ */
10
+ import { type WebSocket } from 'ws';
11
+ import type { ClientData } from '../types';
12
+ import type { IRippleEngine, RippleSocket } from './IRippleEngine';
13
+ /**
14
+ * Wrapper around 'ws' WebSocket to implement RippleSocket interface.
15
+ */
16
+ export declare class WsRippleSocket implements RippleSocket {
17
+ private ws;
18
+ private clientData;
19
+ private engine;
20
+ constructor(ws: WebSocket, clientData: ClientData, engine: WsEngine);
21
+ get id(): string;
22
+ get data(): ClientData;
23
+ send(data: string | Uint8Array, compress?: boolean): void;
24
+ close(code?: number, reason?: string): void;
25
+ getBufferedAmount(): number;
26
+ subscribe(topic: string): void;
27
+ unsubscribe(topic: string): void;
28
+ publish(topic: string, data: string | Uint8Array): void;
29
+ get raw(): WebSocket;
30
+ }
31
+ /**
32
+ * Configuration for WsEngine.
33
+ */
34
+ export interface WsEngineConfig {
35
+ /** Port to listen on */
36
+ port?: number;
37
+ /** Hostname to bind to */
38
+ hostname?: string;
39
+ /** Development mode */
40
+ development?: boolean;
41
+ /** WebSocket path */
42
+ path?: string;
43
+ }
44
+ /**
45
+ * Node.js ws engine.
46
+ *
47
+ * Uses the popular 'ws' library. Provides standard compatibility but
48
+ * uses application-layer pub/sub.
49
+ */
50
+ export declare class WsEngine implements IRippleEngine {
51
+ private config;
52
+ readonly name = "node-ws";
53
+ private wss?;
54
+ private connectionHandler?;
55
+ private disconnectionHandler?;
56
+ private messageHandler?;
57
+ private sockets;
58
+ private subscriptions;
59
+ constructor(config?: WsEngineConfig);
60
+ onConnection(handler: (socket: RippleSocket) => void): void;
61
+ onDisconnection(handler: (socket: RippleSocket, code: number, reason: string) => void): void;
62
+ onMessage(handler: (socket: RippleSocket, message: string | Uint8Array) => void): void;
63
+ listen(port: number): Promise<void>;
64
+ close(): Promise<void>;
65
+ subscribe(socketId: string, topic: string): void;
66
+ unsubscribe(socketId: string, topic: string): void;
67
+ private cleanupSocket;
68
+ broadcast(topic: string, data: string | Uint8Array, excludeSocketId?: string): void;
69
+ }
@@ -9,3 +9,7 @@
9
9
  export type { BunEngineConfig } from './BunEngine';
10
10
  export { BunEngine, BunRippleSocket } from './BunEngine';
11
11
  export type { EngineFactory, IRippleEngine, RippleSocket } from './IRippleEngine';
12
+ export type { UWebSocketsEngineConfig } from './UWebSocketsEngine';
13
+ export { UWebSocketsEngine, UWebSocketsRippleSocket } from './UWebSocketsEngine';
14
+ export type { WsEngineConfig } from './WsEngine';
15
+ export { WsEngine, WsRippleSocket } from './WsEngine';