@milaboratories/pl-client 2.17.6 → 2.17.8

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 (274) hide show
  1. package/dist/_virtual/_rolldown/runtime.cjs +43 -0
  2. package/dist/_virtual/_rolldown/runtime.js +18 -0
  3. package/dist/core/PromiseTracker.cjs +33 -33
  4. package/dist/core/PromiseTracker.cjs.map +1 -1
  5. package/dist/core/PromiseTracker.d.ts +10 -7
  6. package/dist/core/PromiseTracker.js +33 -31
  7. package/dist/core/PromiseTracker.js.map +1 -1
  8. package/dist/core/StatefulPromise.cjs +60 -61
  9. package/dist/core/StatefulPromise.cjs.map +1 -1
  10. package/dist/core/StatefulPromise.js +60 -60
  11. package/dist/core/StatefulPromise.js.map +1 -1
  12. package/dist/core/abstract_stream.d.ts +18 -15
  13. package/dist/core/advisory_locks.cjs +42 -49
  14. package/dist/core/advisory_locks.cjs.map +1 -1
  15. package/dist/core/advisory_locks.js +42 -48
  16. package/dist/core/advisory_locks.js.map +1 -1
  17. package/dist/core/auth.cjs +10 -15
  18. package/dist/core/auth.cjs.map +1 -1
  19. package/dist/core/auth.d.ts +7 -3
  20. package/dist/core/auth.js +10 -13
  21. package/dist/core/auth.js.map +1 -1
  22. package/dist/core/cache.d.ts +11 -7
  23. package/dist/core/client.cjs +255 -306
  24. package/dist/core/client.cjs.map +1 -1
  25. package/dist/core/client.d.ts +72 -68
  26. package/dist/core/client.js +253 -285
  27. package/dist/core/client.js.map +1 -1
  28. package/dist/core/config.cjs +81 -99
  29. package/dist/core/config.cjs.map +1 -1
  30. package/dist/core/config.d.ts +93 -90
  31. package/dist/core/config.js +81 -98
  32. package/dist/core/config.js.map +1 -1
  33. package/dist/core/default_client.cjs +84 -125
  34. package/dist/core/default_client.cjs.map +1 -1
  35. package/dist/core/default_client.d.ts +9 -6
  36. package/dist/core/default_client.js +78 -103
  37. package/dist/core/default_client.js.map +1 -1
  38. package/dist/core/driver.cjs +12 -16
  39. package/dist/core/driver.cjs.map +1 -1
  40. package/dist/core/driver.d.ts +18 -14
  41. package/dist/core/driver.js +12 -15
  42. package/dist/core/driver.js.map +1 -1
  43. package/dist/core/error_resource.cjs +5 -4
  44. package/dist/core/error_resource.cjs.map +1 -1
  45. package/dist/core/error_resource.js +5 -3
  46. package/dist/core/error_resource.js.map +1 -1
  47. package/dist/core/errors.cjs +104 -140
  48. package/dist/core/errors.cjs.map +1 -1
  49. package/dist/core/errors.d.ts +34 -30
  50. package/dist/core/errors.js +102 -137
  51. package/dist/core/errors.js.map +1 -1
  52. package/dist/core/final.cjs +63 -89
  53. package/dist/core/final.cjs.map +1 -1
  54. package/dist/core/final.d.ts +8 -4
  55. package/dist/core/final.js +63 -87
  56. package/dist/core/final.js.map +1 -1
  57. package/dist/core/ll_client.cjs +416 -521
  58. package/dist/core/ll_client.cjs.map +1 -1
  59. package/dist/core/ll_client.d.ts +100 -97
  60. package/dist/core/ll_client.js +415 -519
  61. package/dist/core/ll_client.js.map +1 -1
  62. package/dist/core/ll_transaction.cjs +206 -240
  63. package/dist/core/ll_transaction.cjs.map +1 -1
  64. package/dist/core/ll_transaction.d.ts +50 -52
  65. package/dist/core/ll_transaction.js +205 -238
  66. package/dist/core/ll_transaction.js.map +1 -1
  67. package/dist/core/stat.cjs +64 -63
  68. package/dist/core/stat.cjs.map +1 -1
  69. package/dist/core/stat.d.ts +35 -36
  70. package/dist/core/stat.js +64 -62
  71. package/dist/core/stat.js.map +1 -1
  72. package/dist/core/transaction.cjs +613 -650
  73. package/dist/core/transaction.cjs.map +1 -1
  74. package/dist/core/transaction.d.ts +165 -162
  75. package/dist/core/transaction.js +612 -648
  76. package/dist/core/transaction.js.map +1 -1
  77. package/dist/core/type_conversion.cjs +62 -83
  78. package/dist/core/type_conversion.cjs.map +1 -1
  79. package/dist/core/type_conversion.js +61 -81
  80. package/dist/core/type_conversion.js.map +1 -1
  81. package/dist/core/types.cjs +56 -86
  82. package/dist/core/types.cjs.map +1 -1
  83. package/dist/core/types.d.ts +63 -62
  84. package/dist/core/types.js +54 -83
  85. package/dist/core/types.js.map +1 -1
  86. package/dist/core/unauth_client.cjs +35 -41
  87. package/dist/core/unauth_client.cjs.map +1 -1
  88. package/dist/core/unauth_client.d.ts +18 -14
  89. package/dist/core/unauth_client.js +34 -39
  90. package/dist/core/unauth_client.js.map +1 -1
  91. package/dist/core/websocket_stream.cjs +277 -349
  92. package/dist/core/websocket_stream.cjs.map +1 -1
  93. package/dist/core/websocket_stream.js +275 -347
  94. package/dist/core/websocket_stream.js.map +1 -1
  95. package/dist/core/wire.d.ts +21 -17
  96. package/dist/helpers/pl.cjs +71 -73
  97. package/dist/helpers/pl.cjs.map +1 -1
  98. package/dist/helpers/pl.d.ts +40 -41
  99. package/dist/helpers/pl.js +66 -46
  100. package/dist/helpers/pl.js.map +1 -1
  101. package/dist/helpers/poll.cjs +99 -134
  102. package/dist/helpers/poll.cjs.map +1 -1
  103. package/dist/helpers/poll.d.ts +37 -34
  104. package/dist/helpers/poll.js +97 -113
  105. package/dist/helpers/poll.js.map +1 -1
  106. package/dist/helpers/retry_strategy.cjs +82 -87
  107. package/dist/helpers/retry_strategy.cjs.map +1 -1
  108. package/dist/helpers/retry_strategy.js +83 -86
  109. package/dist/helpers/retry_strategy.js.map +1 -1
  110. package/dist/helpers/tx_helpers.cjs +21 -20
  111. package/dist/helpers/tx_helpers.cjs.map +1 -1
  112. package/dist/helpers/tx_helpers.d.ts +11 -7
  113. package/dist/helpers/tx_helpers.js +20 -18
  114. package/dist/helpers/tx_helpers.js.map +1 -1
  115. package/dist/index.cjs +117 -106
  116. package/dist/index.d.ts +17 -17
  117. package/dist/index.js +17 -19
  118. package/dist/proto-grpc/github.com/googleapis/googleapis/google/rpc/status.cjs +72 -66
  119. package/dist/proto-grpc/github.com/googleapis/googleapis/google/rpc/status.cjs.map +1 -1
  120. package/dist/proto-grpc/github.com/googleapis/googleapis/google/rpc/status.d.ts +35 -37
  121. package/dist/proto-grpc/github.com/googleapis/googleapis/google/rpc/status.js +71 -64
  122. package/dist/proto-grpc/github.com/googleapis/googleapis/google/rpc/status.js.map +1 -1
  123. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api.cjs +12611 -12866
  124. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api.cjs.map +1 -1
  125. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api.client.cjs +226 -226
  126. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api.client.cjs.map +1 -1
  127. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api.client.d.ts +281 -330
  128. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api.client.js +225 -224
  129. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api.client.js.map +1 -1
  130. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api.d.ts +2640 -4294
  131. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api.js +12608 -12706
  132. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api.js.map +1 -1
  133. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api_types.cjs +1230 -1089
  134. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api_types.cjs.map +1 -1
  135. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api_types.d.ts +393 -420
  136. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api_types.js +1228 -1083
  137. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api_types.js.map +1 -1
  138. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/base_types.cjs +142 -143
  139. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/base_types.cjs.map +1 -1
  140. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/base_types.d.ts +62 -64
  141. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/base_types.js +140 -141
  142. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/base_types.js.map +1 -1
  143. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/resource_types.cjs +572 -487
  144. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/resource_types.cjs.map +1 -1
  145. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/resource_types.d.ts +125 -228
  146. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/resource_types.js +572 -485
  147. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/resource_types.js.map +1 -1
  148. package/dist/proto-grpc/google/protobuf/any.cjs +131 -146
  149. package/dist/proto-grpc/google/protobuf/any.cjs.map +1 -1
  150. package/dist/proto-grpc/google/protobuf/any.d.ts +78 -84
  151. package/dist/proto-grpc/google/protobuf/any.js +130 -144
  152. package/dist/proto-grpc/google/protobuf/any.js.map +1 -1
  153. package/dist/proto-grpc/google/protobuf/duration.cjs +92 -100
  154. package/dist/proto-grpc/google/protobuf/duration.cjs.map +1 -1
  155. package/dist/proto-grpc/google/protobuf/duration.d.ts +38 -43
  156. package/dist/proto-grpc/google/protobuf/duration.js +91 -98
  157. package/dist/proto-grpc/google/protobuf/duration.js.map +1 -1
  158. package/dist/proto-grpc/google/protobuf/timestamp.cjs +117 -128
  159. package/dist/proto-grpc/google/protobuf/timestamp.cjs.map +1 -1
  160. package/dist/proto-grpc/google/protobuf/timestamp.d.ts +50 -55
  161. package/dist/proto-grpc/google/protobuf/timestamp.js +116 -126
  162. package/dist/proto-grpc/google/protobuf/timestamp.js.map +1 -1
  163. package/dist/proto-grpc/google/rpc/code.cjs +223 -238
  164. package/dist/proto-grpc/google/rpc/code.cjs.map +1 -1
  165. package/dist/proto-grpc/google/rpc/code.d.ts +209 -206
  166. package/dist/proto-grpc/google/rpc/code.js +221 -237
  167. package/dist/proto-grpc/google/rpc/code.js.map +1 -1
  168. package/dist/proto-rest/index.cjs +67 -66
  169. package/dist/proto-rest/index.cjs.map +1 -1
  170. package/dist/proto-rest/index.d.ts +24 -18
  171. package/dist/proto-rest/index.js +61 -65
  172. package/dist/proto-rest/index.js.map +1 -1
  173. package/dist/proto-rest/plapi.d.ts +1400 -1477
  174. package/dist/test/tcp-proxy.cjs +100 -126
  175. package/dist/test/tcp-proxy.cjs.map +1 -1
  176. package/dist/test/tcp-proxy.d.ts +17 -13
  177. package/dist/test/tcp-proxy.js +97 -104
  178. package/dist/test/tcp-proxy.js.map +1 -1
  179. package/dist/test/test_config.cjs +145 -194
  180. package/dist/test/test_config.cjs.map +1 -1
  181. package/dist/test/test_config.d.ts +34 -30
  182. package/dist/test/test_config.js +138 -166
  183. package/dist/test/test_config.js.map +1 -1
  184. package/dist/util/pl.cjs +4 -3
  185. package/dist/util/pl.cjs.map +1 -1
  186. package/dist/util/pl.js +4 -2
  187. package/dist/util/pl.js.map +1 -1
  188. package/dist/util/util.cjs +7 -10
  189. package/dist/util/util.cjs.map +1 -1
  190. package/dist/util/util.js +7 -9
  191. package/dist/util/util.js.map +1 -1
  192. package/package.json +10 -10
  193. package/src/core/transaction.ts +123 -133
  194. package/dist/__external/.pnpm/@rollup_plugin-typescript@12.3.0_rollup@4.52.4_tslib@2.8.1_typescript@5.6.3/__external/tslib/tslib.es6.cjs +0 -61
  195. package/dist/__external/.pnpm/@rollup_plugin-typescript@12.3.0_rollup@4.52.4_tslib@2.8.1_typescript@5.6.3/__external/tslib/tslib.es6.cjs.map +0 -1
  196. package/dist/__external/.pnpm/@rollup_plugin-typescript@12.3.0_rollup@4.52.4_tslib@2.8.1_typescript@5.6.3/__external/tslib/tslib.es6.js +0 -58
  197. package/dist/__external/.pnpm/@rollup_plugin-typescript@12.3.0_rollup@4.52.4_tslib@2.8.1_typescript@5.6.3/__external/tslib/tslib.es6.js.map +0 -1
  198. package/dist/core/PromiseTracker.d.ts.map +0 -1
  199. package/dist/core/StatefulPromise.d.ts +0 -39
  200. package/dist/core/StatefulPromise.d.ts.map +0 -1
  201. package/dist/core/abstract_stream.d.ts.map +0 -1
  202. package/dist/core/advisory_locks.d.ts +0 -10
  203. package/dist/core/advisory_locks.d.ts.map +0 -1
  204. package/dist/core/auth.d.ts.map +0 -1
  205. package/dist/core/cache.d.ts.map +0 -1
  206. package/dist/core/client.d.ts.map +0 -1
  207. package/dist/core/config.d.ts.map +0 -1
  208. package/dist/core/default_client.d.ts.map +0 -1
  209. package/dist/core/driver.d.ts.map +0 -1
  210. package/dist/core/error_resource.d.ts +0 -6
  211. package/dist/core/error_resource.d.ts.map +0 -1
  212. package/dist/core/errors.d.ts.map +0 -1
  213. package/dist/core/final.d.ts.map +0 -1
  214. package/dist/core/ll_client.d.ts.map +0 -1
  215. package/dist/core/ll_transaction.d.ts.map +0 -1
  216. package/dist/core/stat.d.ts.map +0 -1
  217. package/dist/core/transaction.d.ts.map +0 -1
  218. package/dist/core/type_conversion.d.ts +0 -8
  219. package/dist/core/type_conversion.d.ts.map +0 -1
  220. package/dist/core/types.d.ts.map +0 -1
  221. package/dist/core/unauth_client.d.ts.map +0 -1
  222. package/dist/core/websocket_stream.d.ts +0 -67
  223. package/dist/core/websocket_stream.d.ts.map +0 -1
  224. package/dist/core/wire.d.ts.map +0 -1
  225. package/dist/helpers/pl.d.ts.map +0 -1
  226. package/dist/helpers/poll.d.ts.map +0 -1
  227. package/dist/helpers/retry_strategy.d.ts +0 -24
  228. package/dist/helpers/retry_strategy.d.ts.map +0 -1
  229. package/dist/helpers/state_helpers.d.ts +0 -3
  230. package/dist/helpers/state_helpers.d.ts.map +0 -1
  231. package/dist/helpers/tx_helpers.d.ts.map +0 -1
  232. package/dist/index.cjs.map +0 -1
  233. package/dist/index.d.ts.map +0 -1
  234. package/dist/index.js.map +0 -1
  235. package/dist/proto-grpc/github.com/googleapis/googleapis/google/rpc/status.d.ts.map +0 -1
  236. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api.client.d.ts.map +0 -1
  237. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api.d.ts.map +0 -1
  238. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/api_types.d.ts.map +0 -1
  239. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/base_types.d.ts.map +0 -1
  240. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/import.d.ts +0 -106
  241. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/import.d.ts.map +0 -1
  242. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/resource_types.d.ts.map +0 -1
  243. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/ws-test.d.ts +0 -73
  244. package/dist/proto-grpc/github.com/milaboratory/pl/plapi/plapiproto/ws-test.d.ts.map +0 -1
  245. package/dist/proto-grpc/google/api/http.d.ts +0 -456
  246. package/dist/proto-grpc/google/api/http.d.ts.map +0 -1
  247. package/dist/proto-grpc/google/protobuf/any.d.ts.map +0 -1
  248. package/dist/proto-grpc/google/protobuf/descriptor.d.ts +0 -2340
  249. package/dist/proto-grpc/google/protobuf/descriptor.d.ts.map +0 -1
  250. package/dist/proto-grpc/google/protobuf/duration.d.ts.map +0 -1
  251. package/dist/proto-grpc/google/protobuf/empty.d.ts +0 -32
  252. package/dist/proto-grpc/google/protobuf/empty.d.ts.map +0 -1
  253. package/dist/proto-grpc/google/protobuf/struct.d.ts +0 -187
  254. package/dist/proto-grpc/google/protobuf/struct.d.ts.map +0 -1
  255. package/dist/proto-grpc/google/protobuf/timestamp.d.ts.map +0 -1
  256. package/dist/proto-grpc/google/protobuf/wrappers.d.ts +0 -308
  257. package/dist/proto-grpc/google/protobuf/wrappers.d.ts.map +0 -1
  258. package/dist/proto-grpc/google/rpc/code.d.ts.map +0 -1
  259. package/dist/proto-grpc/google/rpc/error_details.d.ts +0 -654
  260. package/dist/proto-grpc/google/rpc/error_details.d.ts.map +0 -1
  261. package/dist/proto-grpc/google/rpc/http.d.ts +0 -121
  262. package/dist/proto-grpc/google/rpc/http.d.ts.map +0 -1
  263. package/dist/proto-grpc/google/rpc/status.d.ts +0 -55
  264. package/dist/proto-grpc/google/rpc/status.d.ts.map +0 -1
  265. package/dist/proto-rest/index.d.ts.map +0 -1
  266. package/dist/proto-rest/plapi.d.ts.map +0 -1
  267. package/dist/test/tcp-proxy.d.ts.map +0 -1
  268. package/dist/test/test_config.d.ts.map +0 -1
  269. package/dist/util/branding.d.ts +0 -7
  270. package/dist/util/branding.d.ts.map +0 -1
  271. package/dist/util/pl.d.ts +0 -9
  272. package/dist/util/pl.d.ts.map +0 -1
  273. package/dist/util/util.d.ts +0 -2
  274. package/dist/util/util.d.ts.map +0 -1
@@ -1,351 +1,279 @@
1
- import { WebSocket, ErrorEvent } from 'undici';
2
- import Denque from 'denque';
3
- import { RetryStrategy } from '../helpers/retry_strategy.js';
4
- import { DisconnectedError } from './errors.js';
1
+ import { DisconnectedError } from "./errors.js";
2
+ import { RetryStrategy } from "../helpers/retry_strategy.js";
3
+ import Denque from "denque";
4
+ import { ErrorEvent, WebSocket } from "undici";
5
5
 
6
- var ConnectionState;
7
- (function (ConnectionState) {
8
- ConnectionState[ConnectionState["NEW"] = 0] = "NEW";
9
- ConnectionState[ConnectionState["CONNECTING"] = 1] = "CONNECTING";
10
- ConnectionState[ConnectionState["CONNECTED"] = 2] = "CONNECTED";
11
- ConnectionState[ConnectionState["CLOSING"] = 3] = "CLOSING";
12
- ConnectionState[ConnectionState["CLOSED"] = 4] = "CLOSED";
13
- })(ConnectionState || (ConnectionState = {}));
6
+ //#region src/core/websocket_stream.ts
7
+ var ConnectionState = /* @__PURE__ */ function(ConnectionState) {
8
+ ConnectionState[ConnectionState["NEW"] = 0] = "NEW";
9
+ ConnectionState[ConnectionState["CONNECTING"] = 1] = "CONNECTING";
10
+ ConnectionState[ConnectionState["CONNECTED"] = 2] = "CONNECTED";
11
+ ConnectionState[ConnectionState["CLOSING"] = 3] = "CLOSING";
12
+ ConnectionState[ConnectionState["CLOSED"] = 4] = "CLOSED";
13
+ return ConnectionState;
14
+ }(ConnectionState || {});
14
15
  /**
15
- * WebSocket-based bidirectional stream implementation for LLTransaction.
16
- * Implements BiDiStream interface which is compatible with DuplexStreamingCall.
17
- */
18
- class WebSocketBiDiStream {
19
- url;
20
- serializeClientMessage;
21
- parseServerMessage;
22
- options;
23
- // Connection
24
- ws = null;
25
- connectionState = ConnectionState.NEW;
26
- reconnection;
27
- // Send management
28
- sendQueue = new Denque();
29
- sendCompleted = false;
30
- onComplete;
31
- // Response management
32
- responseQueue = new Denque();
33
- responseResolvers = [];
34
- // Error tracking
35
- lastError;
36
- // === Public API ===
37
- requests = {
38
- send: async (message) => {
39
- return await this.enqueueSend(message);
40
- },
41
- complete: async () => {
42
- if (this.sendCompleted)
43
- return;
44
- await this.drainSendQueue(); // ensure we sent all already queued messages before closing the stream
45
- try {
46
- await this.onComplete(this); // custom onComplete may send additional messages
47
- }
48
- catch {
49
- // When 'complete' gets called concurrently with connection break or over a broken
50
- // transaction stream (server decided it should drop transaction), server would close
51
- // connection anyway on its end. We can safely ignore error here and just continue working.
52
- }
53
- this.sendCompleted = true;
54
- },
55
- };
56
- responses = {
57
- [Symbol.asyncIterator]: () => this.createResponseIterator(),
58
- };
59
- close() {
60
- this.reconnection.cancel();
61
- if (this.connectionState < ConnectionState.CONNECTED) {
62
- // Never reached CONNECTED state. ws.close() will never trigger 'close' event.
63
- this.ws?.close();
64
- this.onClose();
65
- return;
66
- }
67
- if (!this.progressConnectionState(ConnectionState.CLOSING))
68
- return;
69
- this.ws.close();
70
- }
71
- constructor(url, serializeClientMessage, parseServerMessage, options = {}) {
72
- this.url = url;
73
- this.serializeClientMessage = serializeClientMessage;
74
- this.parseServerMessage = parseServerMessage;
75
- this.options = options;
76
- this.onComplete = this.options.onComplete ?? ((stream) => stream.close());
77
- const retryConfig = this.options.retryConfig ?? {};
78
- this.reconnection = new RetryStrategy(retryConfig, {
79
- onRetry: () => {
80
- void this.connect();
81
- },
82
- onMaxAttemptsReached: (error) => this.handleError(error),
83
- });
84
- if (this.options.abortSignal?.aborted) {
85
- this.progressConnectionState(ConnectionState.CLOSED);
86
- return;
87
- }
88
- this.options.abortSignal?.addEventListener("abort", () => this.close());
89
- this.connect();
90
- }
91
- // === Connection Lifecycle ===
92
- connect() {
93
- if (this.options.abortSignal?.aborted)
94
- return;
95
- // Prevent reconnecting after first successful connection.
96
- if (!this.progressConnectionState(ConnectionState.CONNECTING))
97
- return;
98
- try {
99
- this.ws = this.createWebSocket();
100
- this.ws.addEventListener("open", () => this.onOpen());
101
- this.ws.addEventListener("message", (event) => this.onMessage(event.data));
102
- this.ws.addEventListener("error", (error) => this.onError(error));
103
- this.ws.addEventListener("close", () => this.onClose());
104
- }
105
- catch (error) {
106
- this.lastError = this.toError(error);
107
- this.reconnection.schedule();
108
- }
109
- }
110
- createWebSocket() {
111
- const options = {};
112
- if (this.options.jwtToken)
113
- options.headers = { authorization: `Bearer ${this.options.jwtToken}` };
114
- if (this.options.dispatcher)
115
- options.dispatcher = this.options.dispatcher;
116
- const ws = new WebSocket(this.url, options);
117
- ws.binaryType = "arraybuffer";
118
- return ws;
119
- }
120
- onOpen() {
121
- this.progressConnectionState(ConnectionState.CONNECTED);
122
- this.processSendQueue();
123
- }
124
- onMessage(data) {
125
- if (!(data instanceof ArrayBuffer)) {
126
- this.handleError(new Error(`Unexpected WS message format: ${typeof data}`));
127
- return;
128
- }
129
- try {
130
- const message = this.parseServerMessage(new Uint8Array(data));
131
- this.deliverResponse(message);
132
- }
133
- catch (error) {
134
- this.handleError(this.toError(error));
135
- }
136
- }
137
- onError(error) {
138
- if (this.connectionState < ConnectionState.CONNECTED) {
139
- // Try to connect several times until we succeed or run out of attempts.
140
- this.lastError = this.toError(error);
141
- this.reconnection.schedule();
142
- return;
143
- }
144
- this.handleError(this.toError(error));
145
- }
146
- onClose() {
147
- this.progressConnectionState(ConnectionState.CLOSED);
148
- // If abort signal was triggered, use that as the error source
149
- if (this.options.abortSignal?.aborted && !this.lastError) {
150
- const reason = this.options.abortSignal.reason;
151
- if (reason instanceof Error) {
152
- this.lastError = reason;
153
- }
154
- else if (reason !== undefined) {
155
- this.lastError = new Error(String(reason), { cause: reason });
156
- }
157
- else {
158
- this.lastError = this.createStreamClosedError();
159
- }
160
- }
161
- if (!this.lastError) {
162
- this.rejectAllSendOperations(this.createStreamClosedError());
163
- this.resolveAllPendingResponses(); // unblock active async iterator
164
- }
165
- else {
166
- this.rejectAllPendingOperations(this.lastError);
167
- }
168
- }
169
- // === Send Queue Management ===
170
- enqueueSend(message) {
171
- if (this.sendCompleted) {
172
- throw new Error("Cannot send: stream already completed");
173
- }
174
- if (this.options.abortSignal?.aborted) {
175
- throw new Error("Cannot send: stream aborted");
176
- }
177
- return new Promise((resolve, reject) => {
178
- this.sendQueue.push({ message, resolve, reject });
179
- this.processSendQueue();
180
- });
181
- }
182
- processSendQueue() {
183
- if (!this.canSendMessages())
184
- return;
185
- while (this.sendQueue.length > 0) {
186
- const queued = this.sendQueue.shift();
187
- this.sendQueuedMessage(queued);
188
- }
189
- }
190
- canSendMessages() {
191
- return this.connectionState === ConnectionState.CONNECTED;
192
- }
193
- sendQueuedMessage(queued) {
194
- try {
195
- const ws = this.ws;
196
- if (!ws) {
197
- throw new Error("WebSocket is not connected");
198
- }
199
- // Check if WebSocket is in a valid state for sending
200
- if (ws.readyState !== WebSocket.OPEN) {
201
- throw new Error(`WebSocket is not open (readyState: ${ws.readyState})`);
202
- }
203
- const binary = this.serializeClientMessage(queued.message);
204
- ws.send(binary);
205
- queued.resolve();
206
- }
207
- catch (error) {
208
- queued.reject(this.toError(error));
209
- }
210
- }
211
- async drainSendQueue() {
212
- const POLL_INTERVAL_MS = 5;
213
- while (this.sendQueue.length > 0) {
214
- await this.waitForCondition(() => this.sendQueue.length === 0, POLL_INTERVAL_MS);
215
- }
216
- }
217
- waitForCondition(condition, intervalMs) {
218
- return new Promise((resolve, reject) => {
219
- if (this.options.abortSignal?.aborted) {
220
- return reject(this.toError(this.options.abortSignal.reason) ?? new Error("Stream aborted"));
221
- }
222
- let timeoutId;
223
- const onAbort = () => {
224
- clearTimeout(timeoutId);
225
- reject(this.toError(this.options.abortSignal?.reason) ?? new Error("Stream aborted"));
226
- };
227
- this.options.abortSignal?.addEventListener("abort", onAbort, { once: true });
228
- const check = () => {
229
- if (condition() || this.isStreamEnded()) {
230
- this.options.abortSignal?.removeEventListener("abort", onAbort);
231
- resolve();
232
- }
233
- else {
234
- timeoutId = setTimeout(check, intervalMs);
235
- }
236
- };
237
- check();
238
- });
239
- }
240
- // === Response Delivery ===
241
- deliverResponse(message) {
242
- if (this.responseResolvers.length > 0) {
243
- const resolver = this.responseResolvers.shift();
244
- resolver.resolve({ value: message, done: false });
245
- }
246
- else {
247
- this.responseQueue.push(message);
248
- }
249
- }
250
- async *createResponseIterator() {
251
- while (true) {
252
- const result = await this.nextResponse();
253
- if (result.done)
254
- break;
255
- yield result.value;
256
- }
257
- }
258
- nextResponse() {
259
- return new Promise((resolve, reject) => {
260
- // Fast path: message already available
261
- if (this.responseQueue.length > 0) {
262
- const message = this.responseQueue.shift();
263
- resolve({ value: message, done: false });
264
- return;
265
- }
266
- // Stream ended
267
- if (this.isStreamEnded()) {
268
- if (this.lastError) {
269
- reject(this.lastError);
270
- }
271
- else {
272
- resolve({ value: undefined, done: true });
273
- }
274
- return;
275
- }
276
- // Wait for next message
277
- this.responseResolvers.push({ resolve, reject });
278
- });
279
- }
280
- resolveAllPendingResponses() {
281
- while (this.responseResolvers.length > 0) {
282
- const resolver = this.responseResolvers.shift();
283
- resolver.resolve({ value: undefined, done: true });
284
- }
285
- }
286
- // === Error Handling ===
287
- handleError(error) {
288
- this.lastError = error;
289
- this.close();
290
- }
291
- rejectAllPendingOperations(error) {
292
- this.rejectAllSendOperations(error);
293
- this.rejectAllResponseResolvers(error);
294
- }
295
- rejectAllSendOperations(error) {
296
- while (this.sendQueue.length > 0) {
297
- const queued = this.sendQueue.shift();
298
- queued.reject(error);
299
- }
300
- }
301
- rejectAllResponseResolvers(error) {
302
- while (this.responseResolvers.length > 0) {
303
- const resolver = this.responseResolvers.shift();
304
- resolver.reject(error);
305
- }
306
- }
307
- createStreamClosedError() {
308
- if (this.options.abortSignal?.aborted) {
309
- const reason = this.options.abortSignal.reason;
310
- if (reason instanceof Error) {
311
- return reason;
312
- }
313
- return new Error("Stream aborted", { cause: reason });
314
- }
315
- return new Error("Stream closed");
316
- }
317
- // === Helpers ===
318
- isStreamEnded() {
319
- return (this.connectionState === ConnectionState.CLOSED || this.options.abortSignal?.aborted || false);
320
- }
321
- toError(error) {
322
- if (error instanceof Error)
323
- return error;
324
- if (error instanceof ErrorEvent) {
325
- const err = error.error;
326
- // undici WebSocket throws TypeError with empty message on socket close
327
- // (e.g., when connection is lost or server disconnects)
328
- if (err instanceof TypeError && !err.message) {
329
- return new DisconnectedError("WebSocket connection closed unexpectedly");
330
- }
331
- return err instanceof Error ? err : new Error("WebSocket error", { cause: error });
332
- }
333
- return new Error(String(error));
334
- }
335
- /**
336
- * Connection state progresses linearly from NEW to CLOSED and never goes back.
337
- * This internal contract dramatically simplifies the internal stream state management.
338
- *
339
- * If you ever feel the need to make this contract less strict, think twice.
340
- */
341
- progressConnectionState(newState) {
342
- if (newState < this.connectionState) {
343
- return false;
344
- }
345
- this.connectionState = newState;
346
- return true;
347
- }
348
- }
16
+ * WebSocket-based bidirectional stream implementation for LLTransaction.
17
+ * Implements BiDiStream interface which is compatible with DuplexStreamingCall.
18
+ */
19
+ var WebSocketBiDiStream = class {
20
+ ws = null;
21
+ connectionState = ConnectionState.NEW;
22
+ reconnection;
23
+ sendQueue = new Denque();
24
+ sendCompleted = false;
25
+ onComplete;
26
+ responseQueue = new Denque();
27
+ responseResolvers = [];
28
+ lastError;
29
+ requests = {
30
+ send: async (message) => {
31
+ return await this.enqueueSend(message);
32
+ },
33
+ complete: async () => {
34
+ if (this.sendCompleted) return;
35
+ await this.drainSendQueue();
36
+ try {
37
+ await this.onComplete(this);
38
+ } catch {}
39
+ this.sendCompleted = true;
40
+ }
41
+ };
42
+ responses = { [Symbol.asyncIterator]: () => this.createResponseIterator() };
43
+ close() {
44
+ this.reconnection.cancel();
45
+ if (this.connectionState < ConnectionState.CONNECTED) {
46
+ this.ws?.close();
47
+ this.onClose();
48
+ return;
49
+ }
50
+ if (!this.progressConnectionState(ConnectionState.CLOSING)) return;
51
+ this.ws.close();
52
+ }
53
+ constructor(url, serializeClientMessage, parseServerMessage, options = {}) {
54
+ this.url = url;
55
+ this.serializeClientMessage = serializeClientMessage;
56
+ this.parseServerMessage = parseServerMessage;
57
+ this.options = options;
58
+ this.onComplete = this.options.onComplete ?? ((stream) => stream.close());
59
+ this.reconnection = new RetryStrategy(this.options.retryConfig ?? {}, {
60
+ onRetry: () => {
61
+ this.connect();
62
+ },
63
+ onMaxAttemptsReached: (error) => this.handleError(error)
64
+ });
65
+ if (this.options.abortSignal?.aborted) {
66
+ this.progressConnectionState(ConnectionState.CLOSED);
67
+ return;
68
+ }
69
+ this.options.abortSignal?.addEventListener("abort", () => this.close());
70
+ this.connect();
71
+ }
72
+ connect() {
73
+ if (this.options.abortSignal?.aborted) return;
74
+ if (!this.progressConnectionState(ConnectionState.CONNECTING)) return;
75
+ try {
76
+ this.ws = this.createWebSocket();
77
+ this.ws.addEventListener("open", () => this.onOpen());
78
+ this.ws.addEventListener("message", (event) => this.onMessage(event.data));
79
+ this.ws.addEventListener("error", (error) => this.onError(error));
80
+ this.ws.addEventListener("close", () => this.onClose());
81
+ } catch (error) {
82
+ this.lastError = this.toError(error);
83
+ this.reconnection.schedule();
84
+ }
85
+ }
86
+ createWebSocket() {
87
+ const options = {};
88
+ if (this.options.jwtToken) options.headers = { authorization: `Bearer ${this.options.jwtToken}` };
89
+ if (this.options.dispatcher) options.dispatcher = this.options.dispatcher;
90
+ const ws = new WebSocket(this.url, options);
91
+ ws.binaryType = "arraybuffer";
92
+ return ws;
93
+ }
94
+ onOpen() {
95
+ this.progressConnectionState(ConnectionState.CONNECTED);
96
+ this.processSendQueue();
97
+ }
98
+ onMessage(data) {
99
+ if (!(data instanceof ArrayBuffer)) {
100
+ this.handleError(/* @__PURE__ */ new Error(`Unexpected WS message format: ${typeof data}`));
101
+ return;
102
+ }
103
+ try {
104
+ const message = this.parseServerMessage(new Uint8Array(data));
105
+ this.deliverResponse(message);
106
+ } catch (error) {
107
+ this.handleError(this.toError(error));
108
+ }
109
+ }
110
+ onError(error) {
111
+ if (this.connectionState < ConnectionState.CONNECTED) {
112
+ this.lastError = this.toError(error);
113
+ this.reconnection.schedule();
114
+ return;
115
+ }
116
+ this.handleError(this.toError(error));
117
+ }
118
+ onClose() {
119
+ this.progressConnectionState(ConnectionState.CLOSED);
120
+ if (this.options.abortSignal?.aborted && !this.lastError) {
121
+ const reason = this.options.abortSignal.reason;
122
+ if (reason instanceof Error) this.lastError = reason;
123
+ else if (reason !== void 0) this.lastError = new Error(String(reason), { cause: reason });
124
+ else this.lastError = this.createStreamClosedError();
125
+ }
126
+ if (!this.lastError) {
127
+ this.rejectAllSendOperations(this.createStreamClosedError());
128
+ this.resolveAllPendingResponses();
129
+ } else this.rejectAllPendingOperations(this.lastError);
130
+ }
131
+ enqueueSend(message) {
132
+ if (this.sendCompleted) throw new Error("Cannot send: stream already completed");
133
+ if (this.options.abortSignal?.aborted) throw new Error("Cannot send: stream aborted");
134
+ return new Promise((resolve, reject) => {
135
+ this.sendQueue.push({
136
+ message,
137
+ resolve,
138
+ reject
139
+ });
140
+ this.processSendQueue();
141
+ });
142
+ }
143
+ processSendQueue() {
144
+ if (!this.canSendMessages()) return;
145
+ while (this.sendQueue.length > 0) {
146
+ const queued = this.sendQueue.shift();
147
+ this.sendQueuedMessage(queued);
148
+ }
149
+ }
150
+ canSendMessages() {
151
+ return this.connectionState === ConnectionState.CONNECTED;
152
+ }
153
+ sendQueuedMessage(queued) {
154
+ try {
155
+ const ws = this.ws;
156
+ if (!ws) throw new Error("WebSocket is not connected");
157
+ if (ws.readyState !== WebSocket.OPEN) throw new Error(`WebSocket is not open (readyState: ${ws.readyState})`);
158
+ const binary = this.serializeClientMessage(queued.message);
159
+ ws.send(binary);
160
+ queued.resolve();
161
+ } catch (error) {
162
+ queued.reject(this.toError(error));
163
+ }
164
+ }
165
+ async drainSendQueue() {
166
+ const POLL_INTERVAL_MS = 5;
167
+ while (this.sendQueue.length > 0) await this.waitForCondition(() => this.sendQueue.length === 0, POLL_INTERVAL_MS);
168
+ }
169
+ waitForCondition(condition, intervalMs) {
170
+ return new Promise((resolve, reject) => {
171
+ if (this.options.abortSignal?.aborted) return reject(this.toError(this.options.abortSignal.reason) ?? /* @__PURE__ */ new Error("Stream aborted"));
172
+ let timeoutId;
173
+ const onAbort = () => {
174
+ clearTimeout(timeoutId);
175
+ reject(this.toError(this.options.abortSignal?.reason) ?? /* @__PURE__ */ new Error("Stream aborted"));
176
+ };
177
+ this.options.abortSignal?.addEventListener("abort", onAbort, { once: true });
178
+ const check = () => {
179
+ if (condition() || this.isStreamEnded()) {
180
+ this.options.abortSignal?.removeEventListener("abort", onAbort);
181
+ resolve();
182
+ } else timeoutId = setTimeout(check, intervalMs);
183
+ };
184
+ check();
185
+ });
186
+ }
187
+ deliverResponse(message) {
188
+ if (this.responseResolvers.length > 0) this.responseResolvers.shift().resolve({
189
+ value: message,
190
+ done: false
191
+ });
192
+ else this.responseQueue.push(message);
193
+ }
194
+ async *createResponseIterator() {
195
+ while (true) {
196
+ const result = await this.nextResponse();
197
+ if (result.done) break;
198
+ yield result.value;
199
+ }
200
+ }
201
+ nextResponse() {
202
+ return new Promise((resolve, reject) => {
203
+ if (this.responseQueue.length > 0) {
204
+ resolve({
205
+ value: this.responseQueue.shift(),
206
+ done: false
207
+ });
208
+ return;
209
+ }
210
+ if (this.isStreamEnded()) {
211
+ if (this.lastError) reject(this.lastError);
212
+ else resolve({
213
+ value: void 0,
214
+ done: true
215
+ });
216
+ return;
217
+ }
218
+ this.responseResolvers.push({
219
+ resolve,
220
+ reject
221
+ });
222
+ });
223
+ }
224
+ resolveAllPendingResponses() {
225
+ while (this.responseResolvers.length > 0) this.responseResolvers.shift().resolve({
226
+ value: void 0,
227
+ done: true
228
+ });
229
+ }
230
+ handleError(error) {
231
+ this.lastError = error;
232
+ this.close();
233
+ }
234
+ rejectAllPendingOperations(error) {
235
+ this.rejectAllSendOperations(error);
236
+ this.rejectAllResponseResolvers(error);
237
+ }
238
+ rejectAllSendOperations(error) {
239
+ while (this.sendQueue.length > 0) this.sendQueue.shift().reject(error);
240
+ }
241
+ rejectAllResponseResolvers(error) {
242
+ while (this.responseResolvers.length > 0) this.responseResolvers.shift().reject(error);
243
+ }
244
+ createStreamClosedError() {
245
+ if (this.options.abortSignal?.aborted) {
246
+ const reason = this.options.abortSignal.reason;
247
+ if (reason instanceof Error) return reason;
248
+ return new Error("Stream aborted", { cause: reason });
249
+ }
250
+ return /* @__PURE__ */ new Error("Stream closed");
251
+ }
252
+ isStreamEnded() {
253
+ return this.connectionState === ConnectionState.CLOSED || this.options.abortSignal?.aborted || false;
254
+ }
255
+ toError(error) {
256
+ if (error instanceof Error) return error;
257
+ if (error instanceof ErrorEvent) {
258
+ const err = error.error;
259
+ if (err instanceof TypeError && !err.message) return new DisconnectedError("WebSocket connection closed unexpectedly");
260
+ return err instanceof Error ? err : new Error("WebSocket error", { cause: error });
261
+ }
262
+ return new Error(String(error));
263
+ }
264
+ /**
265
+ * Connection state progresses linearly from NEW to CLOSED and never goes back.
266
+ * This internal contract dramatically simplifies the internal stream state management.
267
+ *
268
+ * If you ever feel the need to make this contract less strict, think twice.
269
+ */
270
+ progressConnectionState(newState) {
271
+ if (newState < this.connectionState) return false;
272
+ this.connectionState = newState;
273
+ return true;
274
+ }
275
+ };
349
276
 
277
+ //#endregion
350
278
  export { WebSocketBiDiStream };
351
- //# sourceMappingURL=websocket_stream.js.map
279
+ //# sourceMappingURL=websocket_stream.js.map