@gravito/ripple 4.0.1 → 5.0.0

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 (226) 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 -1
  4. package/dist/core/src/Application.d.ts +41 -0
  5. package/dist/core/src/HookManager.d.ts +33 -189
  6. package/dist/core/src/PlanetCore.d.ts +31 -1
  7. package/dist/core/src/Router.d.ts +32 -46
  8. package/dist/core/src/adapters/bun/BunContext.d.ts +6 -1
  9. package/dist/core/src/adapters/bun/BunNativeAdapter.d.ts +35 -0
  10. package/dist/core/src/adapters/bun/BunWebSocketHandler.d.ts +48 -0
  11. package/dist/core/src/adapters/bun/RadixRouter.d.ts +1 -0
  12. package/dist/core/src/adapters/bun/index.d.ts +7 -0
  13. package/dist/core/src/binary/BinaryUtils.d.ts +105 -0
  14. package/dist/core/src/binary/index.d.ts +5 -0
  15. package/dist/core/src/compat/async-local-storage.d.ts +7 -0
  16. package/dist/core/src/compat/crypto.d.ts +6 -0
  17. package/dist/core/src/engine/AOTRouter.d.ts +10 -0
  18. package/dist/core/src/engine/FastContext.d.ts +19 -1
  19. package/dist/core/src/engine/Gravito.d.ts +13 -18
  20. package/dist/core/src/engine/MinimalContext.d.ts +2 -0
  21. package/dist/core/src/engine/analyzer.d.ts +92 -6
  22. package/dist/core/src/engine/types.d.ts +3 -0
  23. package/dist/core/src/events/CircuitBreaker.d.ts +12 -0
  24. package/dist/core/src/events/EventPriorityQueue.d.ts +18 -256
  25. package/dist/core/src/events/index.d.ts +12 -11
  26. package/dist/core/src/events/queue-core.d.ts +77 -0
  27. package/dist/core/src/events/task-executor.d.ts +51 -0
  28. package/dist/core/src/exceptions/AuthException.d.ts +10 -0
  29. package/dist/core/src/exceptions/AuthenticationException.d.ts +2 -2
  30. package/dist/core/src/exceptions/AuthorizationException.d.ts +2 -2
  31. package/dist/core/src/exceptions/CacheException.d.ts +9 -0
  32. package/dist/core/src/exceptions/CircularDependencyException.d.ts +2 -1
  33. package/dist/core/src/exceptions/ConfigurationException.d.ts +9 -0
  34. package/dist/core/src/exceptions/DatabaseException.d.ts +9 -0
  35. package/dist/core/src/exceptions/DomainException.d.ts +9 -0
  36. package/dist/core/src/exceptions/InfrastructureException.d.ts +17 -0
  37. package/dist/core/src/exceptions/QueueException.d.ts +9 -0
  38. package/dist/core/src/exceptions/StorageException.d.ts +9 -0
  39. package/dist/core/src/exceptions/StreamException.d.ts +9 -0
  40. package/dist/core/src/exceptions/SystemException.d.ts +9 -0
  41. package/dist/core/src/exceptions/ValidationException.d.ts +2 -2
  42. package/dist/core/src/exceptions/index.d.ts +10 -0
  43. package/dist/core/src/ffi/NativeAccelerator.d.ts +62 -0
  44. package/dist/core/src/ffi/NativeHasher.d.ts +139 -0
  45. package/dist/core/src/ffi/cbor-fallback.d.ts +96 -0
  46. package/dist/core/src/ffi/hash-fallback.d.ts +33 -0
  47. package/dist/core/src/ffi/index.d.ts +10 -0
  48. package/dist/core/src/ffi/types.d.ts +135 -0
  49. package/dist/core/src/helpers/Str.d.ts +15 -0
  50. package/dist/core/src/hooks/ActionManager.d.ts +132 -0
  51. package/dist/core/src/hooks/AsyncDetector.d.ts +84 -0
  52. package/dist/core/src/hooks/FilterManager.d.ts +71 -0
  53. package/dist/core/src/hooks/MigrationWarner.d.ts +24 -0
  54. package/dist/core/src/hooks/dlq-operations.d.ts +60 -0
  55. package/dist/core/src/hooks/types.d.ts +107 -0
  56. package/dist/core/src/http/CookieJar.d.ts +2 -2
  57. package/dist/core/src/http/types.d.ts +24 -3
  58. package/dist/core/src/index.d.ts +491 -14
  59. package/dist/core/src/observability/contracts.d.ts +137 -0
  60. package/dist/core/src/reliability/DeadLetterQueueManager.d.ts +2 -3
  61. package/dist/core/src/runtime/adapter-bun.d.ts +12 -0
  62. package/dist/core/src/runtime/adapter-deno.d.ts +12 -0
  63. package/dist/core/src/runtime/adapter-node.d.ts +12 -0
  64. package/dist/core/src/runtime/adapter-unknown.d.ts +13 -0
  65. package/dist/core/src/runtime/archive.d.ts +17 -0
  66. package/dist/core/src/runtime/compression.d.ts +21 -0
  67. package/dist/core/src/runtime/deep-equals.d.ts +56 -0
  68. package/dist/core/src/runtime/detection.d.ts +22 -0
  69. package/dist/core/src/runtime/escape.d.ts +34 -0
  70. package/dist/core/src/runtime/index.d.ts +44 -0
  71. package/dist/core/src/runtime/markdown.d.ts +44 -0
  72. package/dist/core/src/runtime/types.d.ts +436 -0
  73. package/dist/core/src/runtime-helpers.d.ts +67 -0
  74. package/dist/core/src/runtime.d.ts +10 -118
  75. package/dist/core/src/testing/HttpTester.d.ts +1 -0
  76. package/dist/core/src/transpiler-utils.d.ts +170 -0
  77. package/dist/{ripple/src/engines → engines}/BunEngine.d.ts +11 -0
  78. package/dist/errors/RippleError.d.ts +66 -0
  79. package/dist/index.js +1 -7502
  80. package/dist/index.js.map +3 -71
  81. package/package.json +6 -2
  82. package/dist/atlas/src/DB.d.ts +0 -348
  83. package/dist/atlas/src/OrbitAtlas.d.ts +0 -9
  84. package/dist/atlas/src/config/defineConfig.d.ts +0 -14
  85. package/dist/atlas/src/config/index.d.ts +0 -7
  86. package/dist/atlas/src/config/loadConfig.d.ts +0 -41
  87. package/dist/atlas/src/connection/Connection.d.ts +0 -112
  88. package/dist/atlas/src/connection/ConnectionManager.d.ts +0 -180
  89. package/dist/atlas/src/connection/ReplicaConnectionPool.d.ts +0 -54
  90. package/dist/atlas/src/drivers/BunSQLDriver.d.ts +0 -32
  91. package/dist/atlas/src/drivers/BunSQLPreparedStatement.d.ts +0 -118
  92. package/dist/atlas/src/drivers/MongoDBDriver.d.ts +0 -36
  93. package/dist/atlas/src/drivers/MySQLDriver.d.ts +0 -79
  94. package/dist/atlas/src/drivers/PostgresDriver.d.ts +0 -96
  95. package/dist/atlas/src/drivers/RedisDriver.d.ts +0 -43
  96. package/dist/atlas/src/drivers/SQLiteDriver.d.ts +0 -45
  97. package/dist/atlas/src/drivers/types.d.ts +0 -260
  98. package/dist/atlas/src/errors/index.d.ts +0 -45
  99. package/dist/atlas/src/grammar/Grammar.d.ts +0 -342
  100. package/dist/atlas/src/grammar/MongoGrammar.d.ts +0 -47
  101. package/dist/atlas/src/grammar/MySQLGrammar.d.ts +0 -54
  102. package/dist/atlas/src/grammar/NullGrammar.d.ts +0 -35
  103. package/dist/atlas/src/grammar/PostgresGrammar.d.ts +0 -62
  104. package/dist/atlas/src/grammar/SQLiteGrammar.d.ts +0 -32
  105. package/dist/atlas/src/index.d.ts +0 -79
  106. package/dist/atlas/src/migration/Migration.d.ts +0 -64
  107. package/dist/atlas/src/migration/MigrationRepository.d.ts +0 -65
  108. package/dist/atlas/src/migration/Migrator.d.ts +0 -110
  109. package/dist/atlas/src/migration/index.d.ts +0 -6
  110. package/dist/atlas/src/observability/AtlasMetrics.d.ts +0 -33
  111. package/dist/atlas/src/observability/AtlasObservability.d.ts +0 -15
  112. package/dist/atlas/src/observability/AtlasTracer.d.ts +0 -12
  113. package/dist/atlas/src/observability/index.d.ts +0 -9
  114. package/dist/atlas/src/orm/Repository.d.ts +0 -247
  115. package/dist/atlas/src/orm/index.d.ts +0 -6
  116. package/dist/atlas/src/orm/model/DirtyTracker.d.ts +0 -121
  117. package/dist/atlas/src/orm/model/Model.d.ts +0 -458
  118. package/dist/atlas/src/orm/model/ModelRegistry.d.ts +0 -20
  119. package/dist/atlas/src/orm/model/concerns/HasAttributes.d.ts +0 -150
  120. package/dist/atlas/src/orm/model/concerns/HasEvents.d.ts +0 -36
  121. package/dist/atlas/src/orm/model/concerns/HasPersistence.d.ts +0 -92
  122. package/dist/atlas/src/orm/model/concerns/HasRelationships.d.ts +0 -117
  123. package/dist/atlas/src/orm/model/concerns/HasSerialization.d.ts +0 -64
  124. package/dist/atlas/src/orm/model/concerns/applyMixins.d.ts +0 -15
  125. package/dist/atlas/src/orm/model/concerns/index.d.ts +0 -12
  126. package/dist/atlas/src/orm/model/decorators.d.ts +0 -138
  127. package/dist/atlas/src/orm/model/errors.d.ts +0 -52
  128. package/dist/atlas/src/orm/model/index.d.ts +0 -10
  129. package/dist/atlas/src/orm/model/relationships.d.ts +0 -207
  130. package/dist/atlas/src/orm/model/types.d.ts +0 -12
  131. package/dist/atlas/src/orm/schema/SchemaRegistry.d.ts +0 -124
  132. package/dist/atlas/src/orm/schema/SchemaSniffer.d.ts +0 -54
  133. package/dist/atlas/src/orm/schema/index.d.ts +0 -6
  134. package/dist/atlas/src/orm/schema/types.d.ts +0 -85
  135. package/dist/atlas/src/pool/AdaptivePoolManager.d.ts +0 -98
  136. package/dist/atlas/src/pool/PoolHealthChecker.d.ts +0 -91
  137. package/dist/atlas/src/pool/PoolStrategy.d.ts +0 -129
  138. package/dist/atlas/src/pool/PoolWarmer.d.ts +0 -92
  139. package/dist/atlas/src/query/Expression.d.ts +0 -60
  140. package/dist/atlas/src/query/NPlusOneDetector.d.ts +0 -10
  141. package/dist/atlas/src/query/QueryBuilder.d.ts +0 -643
  142. package/dist/atlas/src/query/RelationshipResolver.d.ts +0 -23
  143. package/dist/atlas/src/query/clauses/GroupByClause.d.ts +0 -51
  144. package/dist/atlas/src/query/clauses/HavingClause.d.ts +0 -70
  145. package/dist/atlas/src/query/clauses/JoinClause.d.ts +0 -87
  146. package/dist/atlas/src/query/clauses/LimitClause.d.ts +0 -82
  147. package/dist/atlas/src/query/clauses/OrderByClause.d.ts +0 -69
  148. package/dist/atlas/src/query/clauses/SelectClause.d.ts +0 -71
  149. package/dist/atlas/src/query/clauses/WhereClause.d.ts +0 -167
  150. package/dist/atlas/src/query/clauses/index.d.ts +0 -11
  151. package/dist/atlas/src/schema/Blueprint.d.ts +0 -276
  152. package/dist/atlas/src/schema/ColumnDefinition.d.ts +0 -154
  153. package/dist/atlas/src/schema/ForeignKeyDefinition.d.ts +0 -37
  154. package/dist/atlas/src/schema/MigrationGenerator.d.ts +0 -45
  155. package/dist/atlas/src/schema/Schema.d.ts +0 -131
  156. package/dist/atlas/src/schema/SchemaDiff.d.ts +0 -73
  157. package/dist/atlas/src/schema/TypeGenerator.d.ts +0 -57
  158. package/dist/atlas/src/schema/TypeWriter.d.ts +0 -42
  159. package/dist/atlas/src/schema/grammars/MySQLSchemaGrammar.d.ts +0 -23
  160. package/dist/atlas/src/schema/grammars/PostgresSchemaGrammar.d.ts +0 -26
  161. package/dist/atlas/src/schema/grammars/SQLiteSchemaGrammar.d.ts +0 -28
  162. package/dist/atlas/src/schema/grammars/SchemaGrammar.d.ts +0 -97
  163. package/dist/atlas/src/schema/grammars/index.d.ts +0 -7
  164. package/dist/atlas/src/schema/index.d.ts +0 -8
  165. package/dist/atlas/src/seed/Factory.d.ts +0 -90
  166. package/dist/atlas/src/seed/Seeder.d.ts +0 -28
  167. package/dist/atlas/src/seed/SeederRunner.d.ts +0 -74
  168. package/dist/atlas/src/seed/index.d.ts +0 -6
  169. package/dist/atlas/src/sharding/ShardingManager.d.ts +0 -59
  170. package/dist/atlas/src/types/index.d.ts +0 -1182
  171. package/dist/atlas/src/utils/CursorEncoding.d.ts +0 -63
  172. package/dist/atlas/src/utils/levenshtein.d.ts +0 -9
  173. package/dist/core/src/adapters/PhotonAdapter.d.ts +0 -175
  174. package/dist/core/src/adapters/photon-types.d.ts +0 -73
  175. package/dist/core/src/http/middleware/BodySizeLimit.d.ts +0 -16
  176. package/dist/core/src/http/middleware/Cors.d.ts +0 -24
  177. package/dist/core/src/http/middleware/Csrf.d.ts +0 -23
  178. package/dist/core/src/http/middleware/HeaderTokenGate.d.ts +0 -28
  179. package/dist/core/src/http/middleware/SecurityHeaders.d.ts +0 -29
  180. package/dist/core/src/http/middleware/ThrottleRequests.d.ts +0 -18
  181. package/dist/core/src/instrumentation/index.d.ts +0 -35
  182. package/dist/core/src/instrumentation/opentelemetry.d.ts +0 -178
  183. package/dist/core/src/instrumentation/types.d.ts +0 -182
  184. package/dist/core/src/observability/Metrics.d.ts +0 -244
  185. package/dist/photon/src/index.d.ts +0 -89
  186. package/dist/photon/src/middleware/binary.d.ts +0 -31
  187. package/dist/photon/src/middleware/htmx.d.ts +0 -39
  188. package/dist/photon/src/middleware/ratelimit-redis.d.ts +0 -50
  189. package/dist/photon/src/middleware/ratelimit.d.ts +0 -161
  190. package/dist/photon/src/openapi.d.ts +0 -19
  191. package/dist/ripple/src/errors/RippleError.d.ts +0 -48
  192. /package/dist/{ripple/src/channels → channels}/Channel.d.ts +0 -0
  193. /package/dist/{ripple/src/channels → channels}/ChannelManager.d.ts +0 -0
  194. /package/dist/{ripple/src/channels → channels}/index.d.ts +0 -0
  195. /package/dist/{ripple/src/drivers → drivers}/LocalDriver.d.ts +0 -0
  196. /package/dist/{ripple/src/drivers → drivers}/NATSDriver.d.ts +0 -0
  197. /package/dist/{ripple/src/drivers → drivers}/RedisDriver.d.ts +0 -0
  198. /package/dist/{ripple/src/drivers → drivers}/index.d.ts +0 -0
  199. /package/dist/{ripple/src/engines → engines}/IRippleEngine.d.ts +0 -0
  200. /package/dist/{ripple/src/engines → engines}/UWebSocketsEngine.d.ts +0 -0
  201. /package/dist/{ripple/src/engines → engines}/WsEngine.d.ts +0 -0
  202. /package/dist/{ripple/src/engines → engines}/index.d.ts +0 -0
  203. /package/dist/{ripple/src/errors → errors}/index.d.ts +0 -0
  204. /package/dist/{ripple/src/events → events}/BroadcastEvent.d.ts +0 -0
  205. /package/dist/{ripple/src/events → events}/BroadcastManager.d.ts +0 -0
  206. /package/dist/{ripple/src/events → events}/Broadcaster.d.ts +0 -0
  207. /package/dist/{ripple/src/events → events}/index.d.ts +0 -0
  208. /package/dist/{ripple/src/health → health}/HealthChecker.d.ts +0 -0
  209. /package/dist/{ripple/src/health → health}/index.d.ts +0 -0
  210. /package/dist/{ripple/src/index.d.ts → index.d.ts} +0 -0
  211. /package/dist/{ripple/src/logging → logging}/Logger.d.ts +0 -0
  212. /package/dist/{ripple/src/logging → logging}/index.d.ts +0 -0
  213. /package/dist/{ripple/src/middleware → middleware}/InterceptorManager.d.ts +0 -0
  214. /package/dist/{ripple/src/observability → observability}/RippleMetrics.d.ts +0 -0
  215. /package/dist/{ripple/src/reliability → reliability}/AckManager.d.ts +0 -0
  216. /package/dist/{ripple/src/serializers → serializers}/ISerializer.d.ts +0 -0
  217. /package/dist/{ripple/src/serializers → serializers}/JsonSerializer.d.ts +0 -0
  218. /package/dist/{ripple/src/serializers → serializers}/ProtobufSerializer.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/types.d.ts → types.d.ts} +0 -0
  224. /package/dist/{ripple/src/utils → utils}/MessageSerializer.d.ts +0 -0
  225. /package/dist/{ripple/src/utils → utils}/TokenBucket.d.ts +0 -0
  226. /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,66 @@
1
+ /**
2
+ * @fileoverview Ripple error types
3
+ *
4
+ * @module @gravito/ripple/errors
5
+ */
6
+ import { InfrastructureException, type InfrastructureExceptionOptions } from '@gravito/core';
7
+ /**
8
+ * Error codes for Ripple module operations.
9
+ * Follows dot-separated namespace convention.
10
+ */
11
+ export declare const RippleErrorCodes: {
12
+ readonly CONNECTION_FAILED: "ripple.connection_failed";
13
+ readonly QUERY_FAILED: "ripple.query_failed";
14
+ readonly DRIVER_ERROR: "ripple.driver_error";
15
+ readonly UNSUPPORTED_RUNTIME: "ripple.unsupported_runtime";
16
+ readonly NOT_INITIALIZED: "ripple.not_initialized";
17
+ readonly INVALID_OPERATION: "ripple.invalid_operation";
18
+ readonly SERIALIZATION_FAILED: "ripple.serialization_failed";
19
+ readonly MIDDLEWARE_ERROR: "ripple.middleware_error";
20
+ };
21
+ export type RippleErrorCode = (typeof RippleErrorCodes)[keyof typeof RippleErrorCodes];
22
+ /**
23
+ * Base error class for Ripple module.
24
+ *
25
+ * Provides structured error handling with error codes and messages.
26
+ * Extends InfrastructureException for unified error handling across Gravito.
27
+ *
28
+ * @example
29
+ * ```typescript
30
+ * throw new RippleError('ripple.invalid_format', 'Invalid message format')
31
+ * ```
32
+ */
33
+ export declare class RippleError extends InfrastructureException {
34
+ /**
35
+ * Creates a new RippleError instance.
36
+ *
37
+ * @param code - The error code.
38
+ * @param message - The error message.
39
+ * @param options - Optional infrastructure exception options.
40
+ */
41
+ constructor(code: string, message: string, options?: InfrastructureExceptionOptions);
42
+ }
43
+ /**
44
+ * Error class for driver-related issues.
45
+ *
46
+ * Used specifically for errors that occur in driver implementations
47
+ * (LocalDriver, RedisDriver).
48
+ *
49
+ * @example
50
+ * ```typescript
51
+ * throw new RippleDriverError(
52
+ * 'REDIS_NOT_INSTALLED',
53
+ * 'ioredis is required for RedisDriver'
54
+ * )
55
+ * ```
56
+ */
57
+ export declare class RippleDriverError extends RippleError {
58
+ /**
59
+ * Creates a new RippleDriverError instance.
60
+ *
61
+ * @param code - The error code.
62
+ * @param message - The error message.
63
+ * @param options - Optional infrastructure exception options.
64
+ */
65
+ constructor(code: string, message: string, options?: InfrastructureExceptionOptions);
66
+ }