@reptilestyle/grpc-js 1.9.14-compression.1

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 (436) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +79 -0
  3. package/build/src/admin.d.ts +11 -0
  4. package/build/src/admin.js +30 -0
  5. package/build/src/admin.js.map +1 -0
  6. package/build/src/backoff-timeout.d.ts +90 -0
  7. package/build/src/backoff-timeout.js +174 -0
  8. package/build/src/backoff-timeout.js.map +1 -0
  9. package/build/src/call-credentials.d.ts +56 -0
  10. package/build/src/call-credentials.js +153 -0
  11. package/build/src/call-credentials.js.map +1 -0
  12. package/build/src/call-interface.d.ts +85 -0
  13. package/build/src/call-interface.js +84 -0
  14. package/build/src/call-interface.js.map +1 -0
  15. package/build/src/call-number.d.ts +1 -0
  16. package/build/src/call-number.js +24 -0
  17. package/build/src/call-number.js.map +1 -0
  18. package/build/src/call.d.ts +80 -0
  19. package/build/src/call.js +136 -0
  20. package/build/src/call.js.map +1 -0
  21. package/build/src/channel-credentials.d.ts +81 -0
  22. package/build/src/channel-credentials.js +177 -0
  23. package/build/src/channel-credentials.js.map +1 -0
  24. package/build/src/channel-options.d.ts +72 -0
  25. package/build/src/channel-options.js +69 -0
  26. package/build/src/channel-options.js.map +1 -0
  27. package/build/src/channel.d.ts +76 -0
  28. package/build/src/channel.js +68 -0
  29. package/build/src/channel.js.map +1 -0
  30. package/build/src/channelz.d.ts +108 -0
  31. package/build/src/channelz.js +637 -0
  32. package/build/src/channelz.js.map +1 -0
  33. package/build/src/client-interceptors.d.ts +120 -0
  34. package/build/src/client-interceptors.js +428 -0
  35. package/build/src/client-interceptors.js.map +1 -0
  36. package/build/src/client.d.ts +74 -0
  37. package/build/src/client.js +431 -0
  38. package/build/src/client.js.map +1 -0
  39. package/build/src/compression-algorithms.d.ts +5 -0
  40. package/build/src/compression-algorithms.js +26 -0
  41. package/build/src/compression-algorithms.js.map +1 -0
  42. package/build/src/compression-filter.d.ts +26 -0
  43. package/build/src/compression-filter.js +257 -0
  44. package/build/src/compression-filter.js.map +1 -0
  45. package/build/src/connectivity-state.d.ts +7 -0
  46. package/build/src/connectivity-state.js +28 -0
  47. package/build/src/connectivity-state.js.map +1 -0
  48. package/build/src/constants.d.ts +38 -0
  49. package/build/src/constants.js +64 -0
  50. package/build/src/constants.js.map +1 -0
  51. package/build/src/control-plane-status.d.ts +5 -0
  52. package/build/src/control-plane-status.js +42 -0
  53. package/build/src/control-plane-status.js.map +1 -0
  54. package/build/src/deadline.d.ts +14 -0
  55. package/build/src/deadline.js +97 -0
  56. package/build/src/deadline.js.map +1 -0
  57. package/build/src/duration.d.ts +7 -0
  58. package/build/src/duration.js +34 -0
  59. package/build/src/duration.js.map +1 -0
  60. package/build/src/error.d.ts +2 -0
  61. package/build/src/error.js +40 -0
  62. package/build/src/error.js.map +1 -0
  63. package/build/src/events.d.ts +9 -0
  64. package/build/src/events.js +19 -0
  65. package/build/src/events.js.map +1 -0
  66. package/build/src/experimental.d.ts +16 -0
  67. package/build/src/experimental.js +39 -0
  68. package/build/src/experimental.js.map +1 -0
  69. package/build/src/filter-stack.d.ts +21 -0
  70. package/build/src/filter-stack.js +82 -0
  71. package/build/src/filter-stack.js.map +1 -0
  72. package/build/src/filter.d.ts +25 -0
  73. package/build/src/filter.js +38 -0
  74. package/build/src/filter.js.map +1 -0
  75. package/build/src/generated/channelz.d.ts +72 -0
  76. package/build/src/generated/channelz.js +3 -0
  77. package/build/src/generated/channelz.js.map +1 -0
  78. package/build/src/generated/google/protobuf/Any.d.ts +9 -0
  79. package/build/src/generated/google/protobuf/Any.js +4 -0
  80. package/build/src/generated/google/protobuf/Any.js.map +1 -0
  81. package/build/src/generated/google/protobuf/BoolValue.d.ts +6 -0
  82. package/build/src/generated/google/protobuf/BoolValue.js +4 -0
  83. package/build/src/generated/google/protobuf/BoolValue.js.map +1 -0
  84. package/build/src/generated/google/protobuf/BytesValue.d.ts +6 -0
  85. package/build/src/generated/google/protobuf/BytesValue.js +4 -0
  86. package/build/src/generated/google/protobuf/BytesValue.js.map +1 -0
  87. package/build/src/generated/google/protobuf/DoubleValue.d.ts +6 -0
  88. package/build/src/generated/google/protobuf/DoubleValue.js +4 -0
  89. package/build/src/generated/google/protobuf/DoubleValue.js.map +1 -0
  90. package/build/src/generated/google/protobuf/Duration.d.ts +9 -0
  91. package/build/src/generated/google/protobuf/Duration.js +4 -0
  92. package/build/src/generated/google/protobuf/Duration.js.map +1 -0
  93. package/build/src/generated/google/protobuf/FloatValue.d.ts +6 -0
  94. package/build/src/generated/google/protobuf/FloatValue.js +4 -0
  95. package/build/src/generated/google/protobuf/FloatValue.js.map +1 -0
  96. package/build/src/generated/google/protobuf/Int32Value.d.ts +6 -0
  97. package/build/src/generated/google/protobuf/Int32Value.js +4 -0
  98. package/build/src/generated/google/protobuf/Int32Value.js.map +1 -0
  99. package/build/src/generated/google/protobuf/Int64Value.d.ts +7 -0
  100. package/build/src/generated/google/protobuf/Int64Value.js +4 -0
  101. package/build/src/generated/google/protobuf/Int64Value.js.map +1 -0
  102. package/build/src/generated/google/protobuf/StringValue.d.ts +6 -0
  103. package/build/src/generated/google/protobuf/StringValue.js +4 -0
  104. package/build/src/generated/google/protobuf/StringValue.js.map +1 -0
  105. package/build/src/generated/google/protobuf/Timestamp.d.ts +9 -0
  106. package/build/src/generated/google/protobuf/Timestamp.js +4 -0
  107. package/build/src/generated/google/protobuf/Timestamp.js.map +1 -0
  108. package/build/src/generated/google/protobuf/UInt32Value.d.ts +6 -0
  109. package/build/src/generated/google/protobuf/UInt32Value.js +4 -0
  110. package/build/src/generated/google/protobuf/UInt32Value.js.map +1 -0
  111. package/build/src/generated/google/protobuf/UInt64Value.d.ts +7 -0
  112. package/build/src/generated/google/protobuf/UInt64Value.js +4 -0
  113. package/build/src/generated/google/protobuf/UInt64Value.js.map +1 -0
  114. package/build/src/generated/grpc/channelz/v1/Address.d.ts +79 -0
  115. package/build/src/generated/grpc/channelz/v1/Address.js +4 -0
  116. package/build/src/generated/grpc/channelz/v1/Address.js.map +1 -0
  117. package/build/src/generated/grpc/channelz/v1/Channel.d.ts +64 -0
  118. package/build/src/generated/grpc/channelz/v1/Channel.js +4 -0
  119. package/build/src/generated/grpc/channelz/v1/Channel.js.map +1 -0
  120. package/build/src/generated/grpc/channelz/v1/ChannelConnectivityState.d.ts +24 -0
  121. package/build/src/generated/grpc/channelz/v1/ChannelConnectivityState.js +14 -0
  122. package/build/src/generated/grpc/channelz/v1/ChannelConnectivityState.js.map +1 -0
  123. package/build/src/generated/grpc/channelz/v1/ChannelData.d.ts +72 -0
  124. package/build/src/generated/grpc/channelz/v1/ChannelData.js +4 -0
  125. package/build/src/generated/grpc/channelz/v1/ChannelData.js.map +1 -0
  126. package/build/src/generated/grpc/channelz/v1/ChannelRef.d.ts +27 -0
  127. package/build/src/generated/grpc/channelz/v1/ChannelRef.js +4 -0
  128. package/build/src/generated/grpc/channelz/v1/ChannelRef.js.map +1 -0
  129. package/build/src/generated/grpc/channelz/v1/ChannelTrace.d.ts +41 -0
  130. package/build/src/generated/grpc/channelz/v1/ChannelTrace.js +4 -0
  131. package/build/src/generated/grpc/channelz/v1/ChannelTrace.js.map +1 -0
  132. package/build/src/generated/grpc/channelz/v1/ChannelTraceEvent.d.ts +74 -0
  133. package/build/src/generated/grpc/channelz/v1/ChannelTraceEvent.js +15 -0
  134. package/build/src/generated/grpc/channelz/v1/ChannelTraceEvent.js.map +1 -0
  135. package/build/src/generated/grpc/channelz/v1/Channelz.d.ts +159 -0
  136. package/build/src/generated/grpc/channelz/v1/Channelz.js +4 -0
  137. package/build/src/generated/grpc/channelz/v1/Channelz.js.map +1 -0
  138. package/build/src/generated/grpc/channelz/v1/GetChannelRequest.d.ts +13 -0
  139. package/build/src/generated/grpc/channelz/v1/GetChannelRequest.js +4 -0
  140. package/build/src/generated/grpc/channelz/v1/GetChannelRequest.js.map +1 -0
  141. package/build/src/generated/grpc/channelz/v1/GetChannelResponse.d.ts +15 -0
  142. package/build/src/generated/grpc/channelz/v1/GetChannelResponse.js +4 -0
  143. package/build/src/generated/grpc/channelz/v1/GetChannelResponse.js.map +1 -0
  144. package/build/src/generated/grpc/channelz/v1/GetServerRequest.d.ts +13 -0
  145. package/build/src/generated/grpc/channelz/v1/GetServerRequest.js +4 -0
  146. package/build/src/generated/grpc/channelz/v1/GetServerRequest.js.map +1 -0
  147. package/build/src/generated/grpc/channelz/v1/GetServerResponse.d.ts +15 -0
  148. package/build/src/generated/grpc/channelz/v1/GetServerResponse.js +4 -0
  149. package/build/src/generated/grpc/channelz/v1/GetServerResponse.js.map +1 -0
  150. package/build/src/generated/grpc/channelz/v1/GetServerSocketsRequest.d.ts +35 -0
  151. package/build/src/generated/grpc/channelz/v1/GetServerSocketsRequest.js +4 -0
  152. package/build/src/generated/grpc/channelz/v1/GetServerSocketsRequest.js.map +1 -0
  153. package/build/src/generated/grpc/channelz/v1/GetServerSocketsResponse.d.ts +29 -0
  154. package/build/src/generated/grpc/channelz/v1/GetServerSocketsResponse.js +4 -0
  155. package/build/src/generated/grpc/channelz/v1/GetServerSocketsResponse.js.map +1 -0
  156. package/build/src/generated/grpc/channelz/v1/GetServersRequest.d.ts +33 -0
  157. package/build/src/generated/grpc/channelz/v1/GetServersRequest.js +4 -0
  158. package/build/src/generated/grpc/channelz/v1/GetServersRequest.js.map +1 -0
  159. package/build/src/generated/grpc/channelz/v1/GetServersResponse.d.ts +29 -0
  160. package/build/src/generated/grpc/channelz/v1/GetServersResponse.js +4 -0
  161. package/build/src/generated/grpc/channelz/v1/GetServersResponse.js.map +1 -0
  162. package/build/src/generated/grpc/channelz/v1/GetSocketRequest.d.ts +25 -0
  163. package/build/src/generated/grpc/channelz/v1/GetSocketRequest.js +4 -0
  164. package/build/src/generated/grpc/channelz/v1/GetSocketRequest.js.map +1 -0
  165. package/build/src/generated/grpc/channelz/v1/GetSocketResponse.d.ts +15 -0
  166. package/build/src/generated/grpc/channelz/v1/GetSocketResponse.js +4 -0
  167. package/build/src/generated/grpc/channelz/v1/GetSocketResponse.js.map +1 -0
  168. package/build/src/generated/grpc/channelz/v1/GetSubchannelRequest.d.ts +13 -0
  169. package/build/src/generated/grpc/channelz/v1/GetSubchannelRequest.js +4 -0
  170. package/build/src/generated/grpc/channelz/v1/GetSubchannelRequest.js.map +1 -0
  171. package/build/src/generated/grpc/channelz/v1/GetSubchannelResponse.d.ts +15 -0
  172. package/build/src/generated/grpc/channelz/v1/GetSubchannelResponse.js +4 -0
  173. package/build/src/generated/grpc/channelz/v1/GetSubchannelResponse.js.map +1 -0
  174. package/build/src/generated/grpc/channelz/v1/GetTopChannelsRequest.d.ts +33 -0
  175. package/build/src/generated/grpc/channelz/v1/GetTopChannelsRequest.js +4 -0
  176. package/build/src/generated/grpc/channelz/v1/GetTopChannelsRequest.js.map +1 -0
  177. package/build/src/generated/grpc/channelz/v1/GetTopChannelsResponse.d.ts +29 -0
  178. package/build/src/generated/grpc/channelz/v1/GetTopChannelsResponse.js +4 -0
  179. package/build/src/generated/grpc/channelz/v1/GetTopChannelsResponse.js.map +1 -0
  180. package/build/src/generated/grpc/channelz/v1/Security.d.ts +79 -0
  181. package/build/src/generated/grpc/channelz/v1/Security.js +4 -0
  182. package/build/src/generated/grpc/channelz/v1/Security.js.map +1 -0
  183. package/build/src/generated/grpc/channelz/v1/Server.d.ts +41 -0
  184. package/build/src/generated/grpc/channelz/v1/Server.js +4 -0
  185. package/build/src/generated/grpc/channelz/v1/Server.js.map +1 -0
  186. package/build/src/generated/grpc/channelz/v1/ServerData.d.ts +53 -0
  187. package/build/src/generated/grpc/channelz/v1/ServerData.js +4 -0
  188. package/build/src/generated/grpc/channelz/v1/ServerData.js.map +1 -0
  189. package/build/src/generated/grpc/channelz/v1/ServerRef.d.ts +27 -0
  190. package/build/src/generated/grpc/channelz/v1/ServerRef.js +4 -0
  191. package/build/src/generated/grpc/channelz/v1/ServerRef.js.map +1 -0
  192. package/build/src/generated/grpc/channelz/v1/Socket.d.ts +66 -0
  193. package/build/src/generated/grpc/channelz/v1/Socket.js +4 -0
  194. package/build/src/generated/grpc/channelz/v1/Socket.js.map +1 -0
  195. package/build/src/generated/grpc/channelz/v1/SocketData.d.ts +146 -0
  196. package/build/src/generated/grpc/channelz/v1/SocketData.js +4 -0
  197. package/build/src/generated/grpc/channelz/v1/SocketData.js.map +1 -0
  198. package/build/src/generated/grpc/channelz/v1/SocketOption.d.ts +43 -0
  199. package/build/src/generated/grpc/channelz/v1/SocketOption.js +4 -0
  200. package/build/src/generated/grpc/channelz/v1/SocketOption.js.map +1 -0
  201. package/build/src/generated/grpc/channelz/v1/SocketOptionLinger.d.ts +29 -0
  202. package/build/src/generated/grpc/channelz/v1/SocketOptionLinger.js +4 -0
  203. package/build/src/generated/grpc/channelz/v1/SocketOptionLinger.js.map +1 -0
  204. package/build/src/generated/grpc/channelz/v1/SocketOptionTcpInfo.d.ts +70 -0
  205. package/build/src/generated/grpc/channelz/v1/SocketOptionTcpInfo.js +4 -0
  206. package/build/src/generated/grpc/channelz/v1/SocketOptionTcpInfo.js.map +1 -0
  207. package/build/src/generated/grpc/channelz/v1/SocketOptionTimeout.d.ts +15 -0
  208. package/build/src/generated/grpc/channelz/v1/SocketOptionTimeout.js +4 -0
  209. package/build/src/generated/grpc/channelz/v1/SocketOptionTimeout.js.map +1 -0
  210. package/build/src/generated/grpc/channelz/v1/SocketRef.d.ts +27 -0
  211. package/build/src/generated/grpc/channelz/v1/SocketRef.js +4 -0
  212. package/build/src/generated/grpc/channelz/v1/SocketRef.js.map +1 -0
  213. package/build/src/generated/grpc/channelz/v1/Subchannel.d.ts +66 -0
  214. package/build/src/generated/grpc/channelz/v1/Subchannel.js +4 -0
  215. package/build/src/generated/grpc/channelz/v1/Subchannel.js.map +1 -0
  216. package/build/src/generated/grpc/channelz/v1/SubchannelRef.d.ts +27 -0
  217. package/build/src/generated/grpc/channelz/v1/SubchannelRef.js +4 -0
  218. package/build/src/generated/grpc/channelz/v1/SubchannelRef.js.map +1 -0
  219. package/build/src/http_proxy.d.ts +15 -0
  220. package/build/src/http_proxy.js +259 -0
  221. package/build/src/http_proxy.js.map +1 -0
  222. package/build/src/index.d.ts +76 -0
  223. package/build/src/index.js +140 -0
  224. package/build/src/index.js.map +1 -0
  225. package/build/src/internal-channel.d.ts +118 -0
  226. package/build/src/internal-channel.js +535 -0
  227. package/build/src/internal-channel.js.map +1 -0
  228. package/build/src/load-balancer-child-handler.d.ts +24 -0
  229. package/build/src/load-balancer-child-handler.js +151 -0
  230. package/build/src/load-balancer-child-handler.js.map +1 -0
  231. package/build/src/load-balancer-outlier-detection.d.ts +61 -0
  232. package/build/src/load-balancer-outlier-detection.js +608 -0
  233. package/build/src/load-balancer-outlier-detection.js.map +1 -0
  234. package/build/src/load-balancer-pick-first.d.ts +97 -0
  235. package/build/src/load-balancer-pick-first.js +393 -0
  236. package/build/src/load-balancer-pick-first.js.map +1 -0
  237. package/build/src/load-balancer-round-robin.d.ts +21 -0
  238. package/build/src/load-balancer-round-robin.js +174 -0
  239. package/build/src/load-balancer-round-robin.js.map +1 -0
  240. package/build/src/load-balancer.d.ts +97 -0
  241. package/build/src/load-balancer.js +102 -0
  242. package/build/src/load-balancer.js.map +1 -0
  243. package/build/src/load-balancing-call.d.ts +44 -0
  244. package/build/src/load-balancing-call.js +269 -0
  245. package/build/src/load-balancing-call.js.map +1 -0
  246. package/build/src/logging.d.ts +7 -0
  247. package/build/src/logging.js +114 -0
  248. package/build/src/logging.js.map +1 -0
  249. package/build/src/make-client.d.ts +71 -0
  250. package/build/src/make-client.js +143 -0
  251. package/build/src/make-client.js.map +1 -0
  252. package/build/src/max-message-size-filter.d.ts +15 -0
  253. package/build/src/max-message-size-filter.js +86 -0
  254. package/build/src/max-message-size-filter.js.map +1 -0
  255. package/build/src/metadata.d.ts +84 -0
  256. package/build/src/metadata.js +249 -0
  257. package/build/src/metadata.js.map +1 -0
  258. package/build/src/object-stream.d.ts +27 -0
  259. package/build/src/object-stream.js +19 -0
  260. package/build/src/object-stream.js.map +1 -0
  261. package/build/src/picker.d.ts +91 -0
  262. package/build/src/picker.js +78 -0
  263. package/build/src/picker.js.map +1 -0
  264. package/build/src/resolver-dns.d.ts +13 -0
  265. package/build/src/resolver-dns.js +328 -0
  266. package/build/src/resolver-dns.js.map +1 -0
  267. package/build/src/resolver-ip.d.ts +1 -0
  268. package/build/src/resolver-ip.js +104 -0
  269. package/build/src/resolver-ip.js.map +1 -0
  270. package/build/src/resolver-uds.d.ts +1 -0
  271. package/build/src/resolver-uds.js +50 -0
  272. package/build/src/resolver-uds.js.map +1 -0
  273. package/build/src/resolver.d.ts +105 -0
  274. package/build/src/resolver.js +87 -0
  275. package/build/src/resolver.js.map +1 -0
  276. package/build/src/resolving-call.d.ts +44 -0
  277. package/build/src/resolving-call.js +273 -0
  278. package/build/src/resolving-call.js.map +1 -0
  279. package/build/src/resolving-load-balancer.d.ts +67 -0
  280. package/build/src/resolving-load-balancer.js +304 -0
  281. package/build/src/resolving-load-balancer.js.map +1 -0
  282. package/build/src/retrying-call.d.ts +94 -0
  283. package/build/src/retrying-call.js +639 -0
  284. package/build/src/retrying-call.js.map +1 -0
  285. package/build/src/server-call.d.ts +159 -0
  286. package/build/src/server-call.js +700 -0
  287. package/build/src/server-call.js.map +1 -0
  288. package/build/src/server-credentials.d.ts +11 -0
  289. package/build/src/server-credentials.js +81 -0
  290. package/build/src/server-credentials.js.map +1 -0
  291. package/build/src/server.d.ts +56 -0
  292. package/build/src/server.js +892 -0
  293. package/build/src/server.js.map +1 -0
  294. package/build/src/service-config.d.ts +56 -0
  295. package/build/src/service-config.js +416 -0
  296. package/build/src/service-config.js.map +1 -0
  297. package/build/src/status-builder.d.ts +28 -0
  298. package/build/src/status-builder.js +68 -0
  299. package/build/src/status-builder.js.map +1 -0
  300. package/build/src/stream-decoder.d.ts +10 -0
  301. package/build/src/stream-decoder.js +96 -0
  302. package/build/src/stream-decoder.js.map +1 -0
  303. package/build/src/subchannel-address.d.ts +18 -0
  304. package/build/src/subchannel-address.js +65 -0
  305. package/build/src/subchannel-address.js.map +1 -0
  306. package/build/src/subchannel-call.d.ts +61 -0
  307. package/build/src/subchannel-call.js +461 -0
  308. package/build/src/subchannel-call.js.map +1 -0
  309. package/build/src/subchannel-interface.d.ts +49 -0
  310. package/build/src/subchannel-interface.js +59 -0
  311. package/build/src/subchannel-interface.js.map +1 -0
  312. package/build/src/subchannel-pool.d.ts +40 -0
  313. package/build/src/subchannel-pool.js +137 -0
  314. package/build/src/subchannel-pool.js.map +1 -0
  315. package/build/src/subchannel.d.ts +119 -0
  316. package/build/src/subchannel.js +353 -0
  317. package/build/src/subchannel.js.map +1 -0
  318. package/build/src/tls-helpers.d.ts +2 -0
  319. package/build/src/tls-helpers.js +34 -0
  320. package/build/src/tls-helpers.js.map +1 -0
  321. package/build/src/transport.d.ts +130 -0
  322. package/build/src/transport.js +640 -0
  323. package/build/src/transport.js.map +1 -0
  324. package/build/src/uri-parser.d.ts +12 -0
  325. package/build/src/uri-parser.js +110 -0
  326. package/build/src/uri-parser.js.map +1 -0
  327. package/package.json +85 -0
  328. package/proto/channelz.proto +564 -0
  329. package/src/admin.ts +45 -0
  330. package/src/backoff-timeout.ts +196 -0
  331. package/src/call-credentials.ts +226 -0
  332. package/src/call-interface.ts +173 -0
  333. package/src/call-number.ts +22 -0
  334. package/src/call.ts +200 -0
  335. package/src/channel-credentials.ts +267 -0
  336. package/src/channel-options.ts +119 -0
  337. package/src/channel.ts +174 -0
  338. package/src/channelz.ts +886 -0
  339. package/src/client-interceptors.ts +577 -0
  340. package/src/client.ts +715 -0
  341. package/src/compression-algorithms.ts +22 -0
  342. package/src/compression-filter.ts +315 -0
  343. package/src/connectivity-state.ts +24 -0
  344. package/src/constants.ts +66 -0
  345. package/src/control-plane-status.ts +43 -0
  346. package/src/deadline.ts +95 -0
  347. package/src/duration.ts +36 -0
  348. package/src/error.ts +37 -0
  349. package/src/events.ts +26 -0
  350. package/src/experimental.ts +48 -0
  351. package/src/filter-stack.ts +100 -0
  352. package/src/filter.ts +63 -0
  353. package/src/generated/channelz.ts +73 -0
  354. package/src/generated/google/protobuf/Any.ts +13 -0
  355. package/src/generated/google/protobuf/BoolValue.ts +10 -0
  356. package/src/generated/google/protobuf/BytesValue.ts +10 -0
  357. package/src/generated/google/protobuf/DoubleValue.ts +10 -0
  358. package/src/generated/google/protobuf/Duration.ts +13 -0
  359. package/src/generated/google/protobuf/FloatValue.ts +10 -0
  360. package/src/generated/google/protobuf/Int32Value.ts +10 -0
  361. package/src/generated/google/protobuf/Int64Value.ts +11 -0
  362. package/src/generated/google/protobuf/StringValue.ts +10 -0
  363. package/src/generated/google/protobuf/Timestamp.ts +13 -0
  364. package/src/generated/google/protobuf/UInt32Value.ts +10 -0
  365. package/src/generated/google/protobuf/UInt64Value.ts +11 -0
  366. package/src/generated/grpc/channelz/v1/Address.ts +89 -0
  367. package/src/generated/grpc/channelz/v1/Channel.ts +68 -0
  368. package/src/generated/grpc/channelz/v1/ChannelConnectivityState.ts +45 -0
  369. package/src/generated/grpc/channelz/v1/ChannelData.ts +76 -0
  370. package/src/generated/grpc/channelz/v1/ChannelRef.ts +31 -0
  371. package/src/generated/grpc/channelz/v1/ChannelTrace.ts +45 -0
  372. package/src/generated/grpc/channelz/v1/ChannelTraceEvent.ts +91 -0
  373. package/src/generated/grpc/channelz/v1/Channelz.ts +178 -0
  374. package/src/generated/grpc/channelz/v1/GetChannelRequest.ts +17 -0
  375. package/src/generated/grpc/channelz/v1/GetChannelResponse.ts +19 -0
  376. package/src/generated/grpc/channelz/v1/GetServerRequest.ts +17 -0
  377. package/src/generated/grpc/channelz/v1/GetServerResponse.ts +19 -0
  378. package/src/generated/grpc/channelz/v1/GetServerSocketsRequest.ts +39 -0
  379. package/src/generated/grpc/channelz/v1/GetServerSocketsResponse.ts +33 -0
  380. package/src/generated/grpc/channelz/v1/GetServersRequest.ts +37 -0
  381. package/src/generated/grpc/channelz/v1/GetServersResponse.ts +33 -0
  382. package/src/generated/grpc/channelz/v1/GetSocketRequest.ts +29 -0
  383. package/src/generated/grpc/channelz/v1/GetSocketResponse.ts +19 -0
  384. package/src/generated/grpc/channelz/v1/GetSubchannelRequest.ts +17 -0
  385. package/src/generated/grpc/channelz/v1/GetSubchannelResponse.ts +19 -0
  386. package/src/generated/grpc/channelz/v1/GetTopChannelsRequest.ts +37 -0
  387. package/src/generated/grpc/channelz/v1/GetTopChannelsResponse.ts +33 -0
  388. package/src/generated/grpc/channelz/v1/Security.ts +87 -0
  389. package/src/generated/grpc/channelz/v1/Server.ts +45 -0
  390. package/src/generated/grpc/channelz/v1/ServerData.ts +57 -0
  391. package/src/generated/grpc/channelz/v1/ServerRef.ts +31 -0
  392. package/src/generated/grpc/channelz/v1/Socket.ts +70 -0
  393. package/src/generated/grpc/channelz/v1/SocketData.ts +150 -0
  394. package/src/generated/grpc/channelz/v1/SocketOption.ts +47 -0
  395. package/src/generated/grpc/channelz/v1/SocketOptionLinger.ts +33 -0
  396. package/src/generated/grpc/channelz/v1/SocketOptionTcpInfo.ts +74 -0
  397. package/src/generated/grpc/channelz/v1/SocketOptionTimeout.ts +19 -0
  398. package/src/generated/grpc/channelz/v1/SocketRef.ts +31 -0
  399. package/src/generated/grpc/channelz/v1/Subchannel.ts +70 -0
  400. package/src/generated/grpc/channelz/v1/SubchannelRef.ts +31 -0
  401. package/src/http_proxy.ts +311 -0
  402. package/src/index.ts +284 -0
  403. package/src/internal-channel.ts +832 -0
  404. package/src/load-balancer-child-handler.ts +169 -0
  405. package/src/load-balancer-outlier-detection.ts +882 -0
  406. package/src/load-balancer-pick-first.ts +487 -0
  407. package/src/load-balancer-round-robin.ts +249 -0
  408. package/src/load-balancer.ts +230 -0
  409. package/src/load-balancing-call.ts +351 -0
  410. package/src/logging.ts +123 -0
  411. package/src/make-client.ts +238 -0
  412. package/src/max-message-size-filter.ts +88 -0
  413. package/src/metadata.ts +298 -0
  414. package/src/object-stream.ts +66 -0
  415. package/src/picker.ts +146 -0
  416. package/src/resolver-dns.ts +412 -0
  417. package/src/resolver-ip.ts +120 -0
  418. package/src/resolver-uds.ts +63 -0
  419. package/src/resolver.ts +180 -0
  420. package/src/resolving-call.ts +331 -0
  421. package/src/resolving-load-balancer.ts +403 -0
  422. package/src/retrying-call.ts +821 -0
  423. package/src/server-call.ts +1033 -0
  424. package/src/server-credentials.ts +108 -0
  425. package/src/server.ts +1300 -0
  426. package/src/service-config.ts +542 -0
  427. package/src/status-builder.ts +80 -0
  428. package/src/stream-decoder.ts +105 -0
  429. package/src/subchannel-address.ts +88 -0
  430. package/src/subchannel-call.ts +539 -0
  431. package/src/subchannel-interface.ts +97 -0
  432. package/src/subchannel-pool.ts +176 -0
  433. package/src/subchannel.ts +482 -0
  434. package/src/tls-helpers.ts +35 -0
  435. package/src/transport.ts +824 -0
  436. package/src/uri-parser.ts +114 -0
package/src/client.ts ADDED
@@ -0,0 +1,715 @@
1
+ /*
2
+ * Copyright 2019 gRPC authors.
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * http://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ *
16
+ */
17
+
18
+ import {
19
+ ClientDuplexStream,
20
+ ClientDuplexStreamImpl,
21
+ ClientReadableStream,
22
+ ClientReadableStreamImpl,
23
+ ClientUnaryCall,
24
+ ClientUnaryCallImpl,
25
+ ClientWritableStream,
26
+ ClientWritableStreamImpl,
27
+ ServiceError,
28
+ callErrorFromStatus,
29
+ SurfaceCall,
30
+ } from './call';
31
+ import { CallCredentials } from './call-credentials';
32
+ import { StatusObject } from './call-interface';
33
+ import { Channel, ChannelImplementation } from './channel';
34
+ import { ConnectivityState } from './connectivity-state';
35
+ import { ChannelCredentials } from './channel-credentials';
36
+ import { ChannelOptions } from './channel-options';
37
+ import { Status } from './constants';
38
+ import { Metadata } from './metadata';
39
+ import { ClientMethodDefinition } from './make-client';
40
+ import {
41
+ getInterceptingCall,
42
+ Interceptor,
43
+ InterceptorProvider,
44
+ InterceptorArguments,
45
+ InterceptingCallInterface,
46
+ } from './client-interceptors';
47
+ import {
48
+ ServerUnaryCall,
49
+ ServerReadableStream,
50
+ ServerWritableStream,
51
+ ServerDuplexStream,
52
+ } from './server-call';
53
+ import { Deadline } from './deadline';
54
+
55
+ const CHANNEL_SYMBOL = Symbol();
56
+ const INTERCEPTOR_SYMBOL = Symbol();
57
+ const INTERCEPTOR_PROVIDER_SYMBOL = Symbol();
58
+ const CALL_INVOCATION_TRANSFORMER_SYMBOL = Symbol();
59
+
60
+ function isFunction<ResponseType>(
61
+ arg: Metadata | CallOptions | UnaryCallback<ResponseType> | undefined
62
+ ): arg is UnaryCallback<ResponseType> {
63
+ return typeof arg === 'function';
64
+ }
65
+
66
+ export interface UnaryCallback<ResponseType> {
67
+ (err: ServiceError | null, value?: ResponseType): void;
68
+ }
69
+
70
+ /* eslint-disable @typescript-eslint/no-explicit-any */
71
+ export interface CallOptions {
72
+ deadline?: Deadline;
73
+ host?: string;
74
+ parent?:
75
+ | ServerUnaryCall<any, any>
76
+ | ServerReadableStream<any, any>
77
+ | ServerWritableStream<any, any>
78
+ | ServerDuplexStream<any, any>;
79
+ propagate_flags?: number;
80
+ credentials?: CallCredentials;
81
+ interceptors?: Interceptor[];
82
+ interceptor_providers?: InterceptorProvider[];
83
+ }
84
+ /* eslint-enable @typescript-eslint/no-explicit-any */
85
+
86
+ export interface CallProperties<RequestType, ResponseType> {
87
+ argument?: RequestType;
88
+ metadata: Metadata;
89
+ call: SurfaceCall;
90
+ channel: Channel;
91
+ methodDefinition: ClientMethodDefinition<RequestType, ResponseType>;
92
+ callOptions: CallOptions;
93
+ callback?: UnaryCallback<ResponseType>;
94
+ }
95
+
96
+ export interface CallInvocationTransformer {
97
+ (callProperties: CallProperties<any, any>): CallProperties<any, any>; // eslint-disable-line @typescript-eslint/no-explicit-any
98
+ }
99
+
100
+ export type ClientOptions = Partial<ChannelOptions> & {
101
+ channelOverride?: Channel;
102
+ channelFactoryOverride?: (
103
+ address: string,
104
+ credentials: ChannelCredentials,
105
+ options: ClientOptions
106
+ ) => Channel;
107
+ interceptors?: Interceptor[];
108
+ interceptor_providers?: InterceptorProvider[];
109
+ callInvocationTransformer?: CallInvocationTransformer;
110
+ };
111
+
112
+ function getErrorStackString(error: Error): string {
113
+ return error.stack!.split('\n').slice(1).join('\n');
114
+ }
115
+
116
+ /**
117
+ * A generic gRPC client. Primarily useful as a base class for all generated
118
+ * clients.
119
+ */
120
+ export class Client {
121
+ private readonly [CHANNEL_SYMBOL]: Channel;
122
+ private readonly [INTERCEPTOR_SYMBOL]: Interceptor[];
123
+ private readonly [INTERCEPTOR_PROVIDER_SYMBOL]: InterceptorProvider[];
124
+ private readonly [CALL_INVOCATION_TRANSFORMER_SYMBOL]?: CallInvocationTransformer;
125
+ constructor(
126
+ address: string,
127
+ credentials: ChannelCredentials,
128
+ options: ClientOptions = {}
129
+ ) {
130
+ options = Object.assign({}, options);
131
+ this[INTERCEPTOR_SYMBOL] = options.interceptors ?? [];
132
+ delete options.interceptors;
133
+ this[INTERCEPTOR_PROVIDER_SYMBOL] = options.interceptor_providers ?? [];
134
+ delete options.interceptor_providers;
135
+ if (
136
+ this[INTERCEPTOR_SYMBOL].length > 0 &&
137
+ this[INTERCEPTOR_PROVIDER_SYMBOL].length > 0
138
+ ) {
139
+ throw new Error(
140
+ 'Both interceptors and interceptor_providers were passed as options ' +
141
+ 'to the client constructor. Only one of these is allowed.'
142
+ );
143
+ }
144
+ this[CALL_INVOCATION_TRANSFORMER_SYMBOL] =
145
+ options.callInvocationTransformer;
146
+ delete options.callInvocationTransformer;
147
+ if (options.channelOverride) {
148
+ this[CHANNEL_SYMBOL] = options.channelOverride;
149
+ } else if (options.channelFactoryOverride) {
150
+ const channelFactoryOverride = options.channelFactoryOverride;
151
+ delete options.channelFactoryOverride;
152
+ this[CHANNEL_SYMBOL] = channelFactoryOverride(
153
+ address,
154
+ credentials,
155
+ options
156
+ );
157
+ } else {
158
+ this[CHANNEL_SYMBOL] = new ChannelImplementation(
159
+ address,
160
+ credentials,
161
+ options
162
+ );
163
+ }
164
+ }
165
+
166
+ close(): void {
167
+ this[CHANNEL_SYMBOL].close();
168
+ }
169
+
170
+ getChannel(): Channel {
171
+ return this[CHANNEL_SYMBOL];
172
+ }
173
+
174
+ waitForReady(deadline: Deadline, callback: (error?: Error) => void): void {
175
+ const checkState = (err?: Error) => {
176
+ if (err) {
177
+ callback(new Error('Failed to connect before the deadline'));
178
+ return;
179
+ }
180
+ let newState;
181
+ try {
182
+ newState = this[CHANNEL_SYMBOL].getConnectivityState(true);
183
+ } catch (e) {
184
+ callback(new Error('The channel has been closed'));
185
+ return;
186
+ }
187
+ if (newState === ConnectivityState.READY) {
188
+ callback();
189
+ } else {
190
+ try {
191
+ this[CHANNEL_SYMBOL].watchConnectivityState(
192
+ newState,
193
+ deadline,
194
+ checkState
195
+ );
196
+ } catch (e) {
197
+ callback(new Error('The channel has been closed'));
198
+ }
199
+ }
200
+ };
201
+ setImmediate(checkState);
202
+ }
203
+
204
+ private checkOptionalUnaryResponseArguments<ResponseType>(
205
+ arg1: Metadata | CallOptions | UnaryCallback<ResponseType>,
206
+ arg2?: CallOptions | UnaryCallback<ResponseType>,
207
+ arg3?: UnaryCallback<ResponseType>
208
+ ): {
209
+ metadata: Metadata;
210
+ options: CallOptions;
211
+ callback: UnaryCallback<ResponseType>;
212
+ } {
213
+ if (isFunction(arg1)) {
214
+ return { metadata: new Metadata(), options: {}, callback: arg1 };
215
+ } else if (isFunction(arg2)) {
216
+ if (arg1 instanceof Metadata) {
217
+ return { metadata: arg1, options: {}, callback: arg2 };
218
+ } else {
219
+ return { metadata: new Metadata(), options: arg1, callback: arg2 };
220
+ }
221
+ } else {
222
+ if (
223
+ !(
224
+ arg1 instanceof Metadata &&
225
+ arg2 instanceof Object &&
226
+ isFunction(arg3)
227
+ )
228
+ ) {
229
+ throw new Error('Incorrect arguments passed');
230
+ }
231
+ return { metadata: arg1, options: arg2, callback: arg3 };
232
+ }
233
+ }
234
+
235
+ makeUnaryRequest<RequestType, ResponseType>(
236
+ method: string,
237
+ serialize: (value: RequestType) => Buffer,
238
+ deserialize: (value: Buffer) => ResponseType,
239
+ argument: RequestType,
240
+ metadata: Metadata,
241
+ options: CallOptions,
242
+ callback: UnaryCallback<ResponseType>
243
+ ): ClientUnaryCall;
244
+ makeUnaryRequest<RequestType, ResponseType>(
245
+ method: string,
246
+ serialize: (value: RequestType) => Buffer,
247
+ deserialize: (value: Buffer) => ResponseType,
248
+ argument: RequestType,
249
+ metadata: Metadata,
250
+ callback: UnaryCallback<ResponseType>
251
+ ): ClientUnaryCall;
252
+ makeUnaryRequest<RequestType, ResponseType>(
253
+ method: string,
254
+ serialize: (value: RequestType) => Buffer,
255
+ deserialize: (value: Buffer) => ResponseType,
256
+ argument: RequestType,
257
+ options: CallOptions,
258
+ callback: UnaryCallback<ResponseType>
259
+ ): ClientUnaryCall;
260
+ makeUnaryRequest<RequestType, ResponseType>(
261
+ method: string,
262
+ serialize: (value: RequestType) => Buffer,
263
+ deserialize: (value: Buffer) => ResponseType,
264
+ argument: RequestType,
265
+ callback: UnaryCallback<ResponseType>
266
+ ): ClientUnaryCall;
267
+ makeUnaryRequest<RequestType, ResponseType>(
268
+ method: string,
269
+ serialize: (value: RequestType) => Buffer,
270
+ deserialize: (value: Buffer) => ResponseType,
271
+ argument: RequestType,
272
+ metadata: Metadata | CallOptions | UnaryCallback<ResponseType>,
273
+ options?: CallOptions | UnaryCallback<ResponseType>,
274
+ callback?: UnaryCallback<ResponseType>
275
+ ): ClientUnaryCall {
276
+ const checkedArguments =
277
+ this.checkOptionalUnaryResponseArguments<ResponseType>(
278
+ metadata,
279
+ options,
280
+ callback
281
+ );
282
+ const methodDefinition: ClientMethodDefinition<RequestType, ResponseType> =
283
+ {
284
+ path: method,
285
+ requestStream: false,
286
+ responseStream: false,
287
+ requestSerialize: serialize,
288
+ responseDeserialize: deserialize,
289
+ };
290
+ let callProperties: CallProperties<RequestType, ResponseType> = {
291
+ argument: argument,
292
+ metadata: checkedArguments.metadata,
293
+ call: new ClientUnaryCallImpl(),
294
+ channel: this[CHANNEL_SYMBOL],
295
+ methodDefinition: methodDefinition,
296
+ callOptions: checkedArguments.options,
297
+ callback: checkedArguments.callback,
298
+ };
299
+ if (this[CALL_INVOCATION_TRANSFORMER_SYMBOL]) {
300
+ callProperties = this[CALL_INVOCATION_TRANSFORMER_SYMBOL]!(
301
+ callProperties
302
+ ) as CallProperties<RequestType, ResponseType>;
303
+ }
304
+ const emitter: ClientUnaryCall = callProperties.call;
305
+ const interceptorArgs: InterceptorArguments = {
306
+ clientInterceptors: this[INTERCEPTOR_SYMBOL],
307
+ clientInterceptorProviders: this[INTERCEPTOR_PROVIDER_SYMBOL],
308
+ callInterceptors: callProperties.callOptions.interceptors ?? [],
309
+ callInterceptorProviders:
310
+ callProperties.callOptions.interceptor_providers ?? [],
311
+ };
312
+ const call: InterceptingCallInterface = getInterceptingCall(
313
+ interceptorArgs,
314
+ callProperties.methodDefinition,
315
+ callProperties.callOptions,
316
+ callProperties.channel
317
+ );
318
+ /* This needs to happen before the emitter is used. Unfortunately we can't
319
+ * enforce this with the type system. We need to construct this emitter
320
+ * before calling the CallInvocationTransformer, and we need to create the
321
+ * call after that. */
322
+ emitter.call = call;
323
+ let responseMessage: ResponseType | null = null;
324
+ let receivedStatus = false;
325
+ let callerStackError: Error | null = new Error();
326
+ call.start(callProperties.metadata, {
327
+ onReceiveMetadata: metadata => {
328
+ emitter.emit('metadata', metadata);
329
+ },
330
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
331
+ onReceiveMessage(message: any) {
332
+ if (responseMessage !== null) {
333
+ call.cancelWithStatus(Status.INTERNAL, 'Too many responses received');
334
+ }
335
+ responseMessage = message;
336
+ },
337
+ onReceiveStatus(status: StatusObject) {
338
+ if (receivedStatus) {
339
+ return;
340
+ }
341
+ receivedStatus = true;
342
+ if (status.code === Status.OK) {
343
+ if (responseMessage === null) {
344
+ const callerStack = getErrorStackString(callerStackError!);
345
+ callProperties.callback!(
346
+ callErrorFromStatus(
347
+ {
348
+ code: Status.INTERNAL,
349
+ details: 'No message received',
350
+ metadata: status.metadata,
351
+ },
352
+ callerStack
353
+ )
354
+ );
355
+ } else {
356
+ callProperties.callback!(null, responseMessage);
357
+ }
358
+ } else {
359
+ const callerStack = getErrorStackString(callerStackError!);
360
+ callProperties.callback!(callErrorFromStatus(status, callerStack));
361
+ }
362
+ /* Avoid retaining the callerStackError object in the call context of
363
+ * the status event handler. */
364
+ callerStackError = null;
365
+ emitter.emit('status', status);
366
+ },
367
+ });
368
+ call.sendMessage(argument);
369
+ call.halfClose();
370
+ return emitter;
371
+ }
372
+
373
+ makeClientStreamRequest<RequestType, ResponseType>(
374
+ method: string,
375
+ serialize: (value: RequestType) => Buffer,
376
+ deserialize: (value: Buffer) => ResponseType,
377
+ metadata: Metadata,
378
+ options: CallOptions,
379
+ callback: UnaryCallback<ResponseType>
380
+ ): ClientWritableStream<RequestType>;
381
+ makeClientStreamRequest<RequestType, ResponseType>(
382
+ method: string,
383
+ serialize: (value: RequestType) => Buffer,
384
+ deserialize: (value: Buffer) => ResponseType,
385
+ metadata: Metadata,
386
+ callback: UnaryCallback<ResponseType>
387
+ ): ClientWritableStream<RequestType>;
388
+ makeClientStreamRequest<RequestType, ResponseType>(
389
+ method: string,
390
+ serialize: (value: RequestType) => Buffer,
391
+ deserialize: (value: Buffer) => ResponseType,
392
+ options: CallOptions,
393
+ callback: UnaryCallback<ResponseType>
394
+ ): ClientWritableStream<RequestType>;
395
+ makeClientStreamRequest<RequestType, ResponseType>(
396
+ method: string,
397
+ serialize: (value: RequestType) => Buffer,
398
+ deserialize: (value: Buffer) => ResponseType,
399
+ callback: UnaryCallback<ResponseType>
400
+ ): ClientWritableStream<RequestType>;
401
+ makeClientStreamRequest<RequestType, ResponseType>(
402
+ method: string,
403
+ serialize: (value: RequestType) => Buffer,
404
+ deserialize: (value: Buffer) => ResponseType,
405
+ metadata: Metadata | CallOptions | UnaryCallback<ResponseType>,
406
+ options?: CallOptions | UnaryCallback<ResponseType>,
407
+ callback?: UnaryCallback<ResponseType>
408
+ ): ClientWritableStream<RequestType> {
409
+ const checkedArguments =
410
+ this.checkOptionalUnaryResponseArguments<ResponseType>(
411
+ metadata,
412
+ options,
413
+ callback
414
+ );
415
+ const methodDefinition: ClientMethodDefinition<RequestType, ResponseType> =
416
+ {
417
+ path: method,
418
+ requestStream: true,
419
+ responseStream: false,
420
+ requestSerialize: serialize,
421
+ responseDeserialize: deserialize,
422
+ };
423
+ let callProperties: CallProperties<RequestType, ResponseType> = {
424
+ metadata: checkedArguments.metadata,
425
+ call: new ClientWritableStreamImpl<RequestType>(serialize),
426
+ channel: this[CHANNEL_SYMBOL],
427
+ methodDefinition: methodDefinition,
428
+ callOptions: checkedArguments.options,
429
+ callback: checkedArguments.callback,
430
+ };
431
+ if (this[CALL_INVOCATION_TRANSFORMER_SYMBOL]) {
432
+ callProperties = this[CALL_INVOCATION_TRANSFORMER_SYMBOL]!(
433
+ callProperties
434
+ ) as CallProperties<RequestType, ResponseType>;
435
+ }
436
+ const emitter: ClientWritableStream<RequestType> =
437
+ callProperties.call as ClientWritableStream<RequestType>;
438
+ const interceptorArgs: InterceptorArguments = {
439
+ clientInterceptors: this[INTERCEPTOR_SYMBOL],
440
+ clientInterceptorProviders: this[INTERCEPTOR_PROVIDER_SYMBOL],
441
+ callInterceptors: callProperties.callOptions.interceptors ?? [],
442
+ callInterceptorProviders:
443
+ callProperties.callOptions.interceptor_providers ?? [],
444
+ };
445
+ const call: InterceptingCallInterface = getInterceptingCall(
446
+ interceptorArgs,
447
+ callProperties.methodDefinition,
448
+ callProperties.callOptions,
449
+ callProperties.channel
450
+ );
451
+ /* This needs to happen before the emitter is used. Unfortunately we can't
452
+ * enforce this with the type system. We need to construct this emitter
453
+ * before calling the CallInvocationTransformer, and we need to create the
454
+ * call after that. */
455
+ emitter.call = call;
456
+ let responseMessage: ResponseType | null = null;
457
+ let receivedStatus = false;
458
+ let callerStackError: Error | null = new Error();
459
+ call.start(callProperties.metadata, {
460
+ onReceiveMetadata: metadata => {
461
+ emitter.emit('metadata', metadata);
462
+ },
463
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
464
+ onReceiveMessage(message: any) {
465
+ if (responseMessage !== null) {
466
+ call.cancelWithStatus(Status.INTERNAL, 'Too many responses received');
467
+ }
468
+ responseMessage = message;
469
+ },
470
+ onReceiveStatus(status: StatusObject) {
471
+ if (receivedStatus) {
472
+ return;
473
+ }
474
+ receivedStatus = true;
475
+ if (status.code === Status.OK) {
476
+ if (responseMessage === null) {
477
+ const callerStack = getErrorStackString(callerStackError!);
478
+ callProperties.callback!(
479
+ callErrorFromStatus(
480
+ {
481
+ code: Status.INTERNAL,
482
+ details: 'No message received',
483
+ metadata: status.metadata,
484
+ },
485
+ callerStack
486
+ )
487
+ );
488
+ } else {
489
+ callProperties.callback!(null, responseMessage);
490
+ }
491
+ } else {
492
+ const callerStack = getErrorStackString(callerStackError!);
493
+ callProperties.callback!(callErrorFromStatus(status, callerStack));
494
+ }
495
+ /* Avoid retaining the callerStackError object in the call context of
496
+ * the status event handler. */
497
+ callerStackError = null;
498
+ emitter.emit('status', status);
499
+ },
500
+ });
501
+ return emitter;
502
+ }
503
+
504
+ private checkMetadataAndOptions(
505
+ arg1?: Metadata | CallOptions,
506
+ arg2?: CallOptions
507
+ ): { metadata: Metadata; options: CallOptions } {
508
+ let metadata: Metadata;
509
+ let options: CallOptions;
510
+ if (arg1 instanceof Metadata) {
511
+ metadata = arg1;
512
+ if (arg2) {
513
+ options = arg2;
514
+ } else {
515
+ options = {};
516
+ }
517
+ } else {
518
+ if (arg1) {
519
+ options = arg1;
520
+ } else {
521
+ options = {};
522
+ }
523
+ metadata = new Metadata();
524
+ }
525
+ return { metadata, options };
526
+ }
527
+
528
+ makeServerStreamRequest<RequestType, ResponseType>(
529
+ method: string,
530
+ serialize: (value: RequestType) => Buffer,
531
+ deserialize: (value: Buffer) => ResponseType,
532
+ argument: RequestType,
533
+ metadata: Metadata,
534
+ options?: CallOptions
535
+ ): ClientReadableStream<ResponseType>;
536
+ makeServerStreamRequest<RequestType, ResponseType>(
537
+ method: string,
538
+ serialize: (value: RequestType) => Buffer,
539
+ deserialize: (value: Buffer) => ResponseType,
540
+ argument: RequestType,
541
+ options?: CallOptions
542
+ ): ClientReadableStream<ResponseType>;
543
+ makeServerStreamRequest<RequestType, ResponseType>(
544
+ method: string,
545
+ serialize: (value: RequestType) => Buffer,
546
+ deserialize: (value: Buffer) => ResponseType,
547
+ argument: RequestType,
548
+ metadata?: Metadata | CallOptions,
549
+ options?: CallOptions
550
+ ): ClientReadableStream<ResponseType> {
551
+ const checkedArguments = this.checkMetadataAndOptions(metadata, options);
552
+ const methodDefinition: ClientMethodDefinition<RequestType, ResponseType> =
553
+ {
554
+ path: method,
555
+ requestStream: false,
556
+ responseStream: true,
557
+ requestSerialize: serialize,
558
+ responseDeserialize: deserialize,
559
+ };
560
+ let callProperties: CallProperties<RequestType, ResponseType> = {
561
+ argument: argument,
562
+ metadata: checkedArguments.metadata,
563
+ call: new ClientReadableStreamImpl<ResponseType>(deserialize),
564
+ channel: this[CHANNEL_SYMBOL],
565
+ methodDefinition: methodDefinition,
566
+ callOptions: checkedArguments.options,
567
+ };
568
+ if (this[CALL_INVOCATION_TRANSFORMER_SYMBOL]) {
569
+ callProperties = this[CALL_INVOCATION_TRANSFORMER_SYMBOL]!(
570
+ callProperties
571
+ ) as CallProperties<RequestType, ResponseType>;
572
+ }
573
+ const stream: ClientReadableStream<ResponseType> =
574
+ callProperties.call as ClientReadableStream<ResponseType>;
575
+ const interceptorArgs: InterceptorArguments = {
576
+ clientInterceptors: this[INTERCEPTOR_SYMBOL],
577
+ clientInterceptorProviders: this[INTERCEPTOR_PROVIDER_SYMBOL],
578
+ callInterceptors: callProperties.callOptions.interceptors ?? [],
579
+ callInterceptorProviders:
580
+ callProperties.callOptions.interceptor_providers ?? [],
581
+ };
582
+ const call: InterceptingCallInterface = getInterceptingCall(
583
+ interceptorArgs,
584
+ callProperties.methodDefinition,
585
+ callProperties.callOptions,
586
+ callProperties.channel
587
+ );
588
+ /* This needs to happen before the emitter is used. Unfortunately we can't
589
+ * enforce this with the type system. We need to construct this emitter
590
+ * before calling the CallInvocationTransformer, and we need to create the
591
+ * call after that. */
592
+ stream.call = call;
593
+ let receivedStatus = false;
594
+ let callerStackError: Error | null = new Error();
595
+ call.start(callProperties.metadata, {
596
+ onReceiveMetadata(metadata: Metadata) {
597
+ stream.emit('metadata', metadata);
598
+ },
599
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
600
+ onReceiveMessage(message: any) {
601
+ stream.push(message);
602
+ },
603
+ onReceiveStatus(status: StatusObject) {
604
+ if (receivedStatus) {
605
+ return;
606
+ }
607
+ receivedStatus = true;
608
+ stream.push(null);
609
+ if (status.code !== Status.OK) {
610
+ const callerStack = getErrorStackString(callerStackError!);
611
+ stream.emit('error', callErrorFromStatus(status, callerStack));
612
+ }
613
+ /* Avoid retaining the callerStackError object in the call context of
614
+ * the status event handler. */
615
+ callerStackError = null;
616
+ stream.emit('status', status);
617
+ },
618
+ });
619
+ call.sendMessage(argument);
620
+ call.halfClose();
621
+ return stream;
622
+ }
623
+
624
+ makeBidiStreamRequest<RequestType, ResponseType>(
625
+ method: string,
626
+ serialize: (value: RequestType) => Buffer,
627
+ deserialize: (value: Buffer) => ResponseType,
628
+ metadata: Metadata,
629
+ options?: CallOptions
630
+ ): ClientDuplexStream<RequestType, ResponseType>;
631
+ makeBidiStreamRequest<RequestType, ResponseType>(
632
+ method: string,
633
+ serialize: (value: RequestType) => Buffer,
634
+ deserialize: (value: Buffer) => ResponseType,
635
+ options?: CallOptions
636
+ ): ClientDuplexStream<RequestType, ResponseType>;
637
+ makeBidiStreamRequest<RequestType, ResponseType>(
638
+ method: string,
639
+ serialize: (value: RequestType) => Buffer,
640
+ deserialize: (value: Buffer) => ResponseType,
641
+ metadata?: Metadata | CallOptions,
642
+ options?: CallOptions
643
+ ): ClientDuplexStream<RequestType, ResponseType> {
644
+ const checkedArguments = this.checkMetadataAndOptions(metadata, options);
645
+ const methodDefinition: ClientMethodDefinition<RequestType, ResponseType> =
646
+ {
647
+ path: method,
648
+ requestStream: true,
649
+ responseStream: true,
650
+ requestSerialize: serialize,
651
+ responseDeserialize: deserialize,
652
+ };
653
+ let callProperties: CallProperties<RequestType, ResponseType> = {
654
+ metadata: checkedArguments.metadata,
655
+ call: new ClientDuplexStreamImpl<RequestType, ResponseType>(
656
+ serialize,
657
+ deserialize
658
+ ),
659
+ channel: this[CHANNEL_SYMBOL],
660
+ methodDefinition: methodDefinition,
661
+ callOptions: checkedArguments.options,
662
+ };
663
+ if (this[CALL_INVOCATION_TRANSFORMER_SYMBOL]) {
664
+ callProperties = this[CALL_INVOCATION_TRANSFORMER_SYMBOL]!(
665
+ callProperties
666
+ ) as CallProperties<RequestType, ResponseType>;
667
+ }
668
+ const stream: ClientDuplexStream<RequestType, ResponseType> =
669
+ callProperties.call as ClientDuplexStream<RequestType, ResponseType>;
670
+ const interceptorArgs: InterceptorArguments = {
671
+ clientInterceptors: this[INTERCEPTOR_SYMBOL],
672
+ clientInterceptorProviders: this[INTERCEPTOR_PROVIDER_SYMBOL],
673
+ callInterceptors: callProperties.callOptions.interceptors ?? [],
674
+ callInterceptorProviders:
675
+ callProperties.callOptions.interceptor_providers ?? [],
676
+ };
677
+ const call: InterceptingCallInterface = getInterceptingCall(
678
+ interceptorArgs,
679
+ callProperties.methodDefinition,
680
+ callProperties.callOptions,
681
+ callProperties.channel
682
+ );
683
+ /* This needs to happen before the emitter is used. Unfortunately we can't
684
+ * enforce this with the type system. We need to construct this emitter
685
+ * before calling the CallInvocationTransformer, and we need to create the
686
+ * call after that. */
687
+ stream.call = call;
688
+ let receivedStatus = false;
689
+ let callerStackError: Error | null = new Error();
690
+ call.start(callProperties.metadata, {
691
+ onReceiveMetadata(metadata: Metadata) {
692
+ stream.emit('metadata', metadata);
693
+ },
694
+ onReceiveMessage(message: Buffer) {
695
+ stream.push(message);
696
+ },
697
+ onReceiveStatus(status: StatusObject) {
698
+ if (receivedStatus) {
699
+ return;
700
+ }
701
+ receivedStatus = true;
702
+ stream.push(null);
703
+ if (status.code !== Status.OK) {
704
+ const callerStack = getErrorStackString(callerStackError!);
705
+ stream.emit('error', callErrorFromStatus(status, callerStack));
706
+ }
707
+ /* Avoid retaining the callerStackError object in the call context of
708
+ * the status event handler. */
709
+ callerStackError = null;
710
+ stream.emit('status', status);
711
+ },
712
+ });
713
+ return stream;
714
+ }
715
+ }