@restatedev/restate-sdk 0.9.2 → 1.0.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 (499) hide show
  1. package/README.md +10 -0
  2. package/dist/cjs/package.json +1 -0
  3. package/dist/cjs/src/common_api.d.ts +7 -0
  4. package/dist/cjs/src/common_api.d.ts.map +1 -0
  5. package/dist/cjs/src/common_api.js +25 -0
  6. package/dist/cjs/src/common_api.js.map +1 -0
  7. package/dist/{src → cjs/src}/connection/buffered_connection.d.ts +3 -4
  8. package/dist/cjs/src/connection/buffered_connection.d.ts.map +1 -0
  9. package/dist/{src → cjs/src}/connection/buffered_connection.js +2 -2
  10. package/dist/cjs/src/connection/buffered_connection.js.map +1 -0
  11. package/dist/{src → cjs/src}/connection/connection.d.ts +2 -1
  12. package/dist/cjs/src/connection/connection.d.ts.map +1 -0
  13. package/dist/cjs/src/connection/connection.js.map +1 -0
  14. package/dist/{src → cjs/src}/connection/http_connection.d.ts +9 -5
  15. package/dist/cjs/src/connection/http_connection.d.ts.map +1 -0
  16. package/dist/{src → cjs/src}/connection/http_connection.js +16 -11
  17. package/dist/cjs/src/connection/http_connection.js.map +1 -0
  18. package/dist/{src → cjs/src}/connection/lambda_connection.d.ts +5 -3
  19. package/dist/cjs/src/connection/lambda_connection.d.ts.map +1 -0
  20. package/dist/{src → cjs/src}/connection/lambda_connection.js +14 -9
  21. package/dist/cjs/src/connection/lambda_connection.js.map +1 -0
  22. package/dist/{src → cjs/src}/context.d.ts +149 -44
  23. package/dist/cjs/src/context.d.ts.map +1 -0
  24. package/dist/{src → cjs/src}/context.js +5 -5
  25. package/dist/cjs/src/context.js.map +1 -0
  26. package/dist/cjs/src/context_impl.d.ts +54 -0
  27. package/dist/cjs/src/context_impl.d.ts.map +1 -0
  28. package/dist/{src → cjs/src}/context_impl.js +168 -106
  29. package/dist/cjs/src/context_impl.js.map +1 -0
  30. package/dist/cjs/src/endpoint/endpoint_builder.d.ts +18 -0
  31. package/dist/cjs/src/endpoint/endpoint_builder.d.ts.map +1 -0
  32. package/dist/cjs/src/endpoint/endpoint_builder.js +130 -0
  33. package/dist/cjs/src/endpoint/endpoint_builder.js.map +1 -0
  34. package/dist/cjs/src/endpoint/fetch_endpoint.d.ts +37 -0
  35. package/dist/cjs/src/endpoint/fetch_endpoint.d.ts.map +1 -0
  36. package/dist/cjs/src/endpoint/fetch_endpoint.js +46 -0
  37. package/dist/cjs/src/endpoint/fetch_endpoint.js.map +1 -0
  38. package/dist/cjs/src/endpoint/handlers/fetch.d.ts +6 -0
  39. package/dist/cjs/src/endpoint/handlers/fetch.d.ts.map +1 -0
  40. package/dist/cjs/src/endpoint/handlers/fetch.js +34 -0
  41. package/dist/cjs/src/endpoint/handlers/fetch.js.map +1 -0
  42. package/dist/cjs/src/endpoint/handlers/generic.d.ts +44 -0
  43. package/dist/cjs/src/endpoint/handlers/generic.d.ts.map +1 -0
  44. package/dist/cjs/src/endpoint/handlers/generic.js +193 -0
  45. package/dist/cjs/src/endpoint/handlers/generic.js.map +1 -0
  46. package/dist/cjs/src/endpoint/handlers/lambda.d.ts +8 -0
  47. package/dist/cjs/src/endpoint/handlers/lambda.d.ts.map +1 -0
  48. package/dist/cjs/src/endpoint/handlers/lambda.js +66 -0
  49. package/dist/cjs/src/endpoint/handlers/lambda.js.map +1 -0
  50. package/dist/{src/endpoint/http2_handler.d.ts → cjs/src/endpoint/handlers/node.d.ts} +4 -4
  51. package/dist/cjs/src/endpoint/handlers/node.d.ts.map +1 -0
  52. package/dist/cjs/src/endpoint/handlers/node.js +188 -0
  53. package/dist/cjs/src/endpoint/handlers/node.js.map +1 -0
  54. package/dist/cjs/src/endpoint/lambda_endpoint.d.ts +32 -0
  55. package/dist/cjs/src/endpoint/lambda_endpoint.d.ts.map +1 -0
  56. package/dist/cjs/src/endpoint/lambda_endpoint.js +55 -0
  57. package/dist/cjs/src/endpoint/lambda_endpoint.js.map +1 -0
  58. package/dist/cjs/src/endpoint/node_endpoint.d.ts +19 -0
  59. package/dist/cjs/src/endpoint/node_endpoint.d.ts.map +1 -0
  60. package/dist/cjs/src/endpoint/node_endpoint.js +116 -0
  61. package/dist/cjs/src/endpoint/node_endpoint.js.map +1 -0
  62. package/dist/cjs/src/endpoint/request_signing/basex.d.ts.map +1 -0
  63. package/dist/cjs/src/endpoint/request_signing/basex.js.map +1 -0
  64. package/dist/{src → cjs/src}/endpoint/request_signing/ed25519.d.ts +1 -1
  65. package/dist/cjs/src/endpoint/request_signing/ed25519.d.ts.map +1 -0
  66. package/dist/{src → cjs/src}/endpoint/request_signing/ed25519.js +3 -1
  67. package/dist/cjs/src/endpoint/request_signing/ed25519.js.map +1 -0
  68. package/dist/{src → cjs/src}/endpoint/request_signing/v1.d.ts +2 -2
  69. package/dist/cjs/src/endpoint/request_signing/v1.d.ts.map +1 -0
  70. package/dist/{src → cjs/src}/endpoint/request_signing/v1.js +9 -16
  71. package/dist/cjs/src/endpoint/request_signing/v1.js.map +1 -0
  72. package/dist/{src → cjs/src}/endpoint/request_signing/validate.d.ts +1 -1
  73. package/dist/cjs/src/endpoint/request_signing/validate.d.ts.map +1 -0
  74. package/dist/{src → cjs/src}/endpoint/request_signing/validate.js +3 -3
  75. package/dist/cjs/src/endpoint/request_signing/validate.js.map +1 -0
  76. package/dist/{src → cjs/src}/endpoint.d.ts +27 -26
  77. package/dist/cjs/src/endpoint.d.ts.map +1 -0
  78. package/dist/{src → cjs/src}/endpoint.js +0 -9
  79. package/dist/cjs/src/endpoint.js.map +1 -0
  80. package/dist/cjs/src/fetch.d.ts +7 -0
  81. package/dist/cjs/src/fetch.d.ts.map +1 -0
  82. package/dist/cjs/src/fetch.js +37 -0
  83. package/dist/cjs/src/fetch.js.map +1 -0
  84. package/dist/cjs/src/generated/proto/discovery_pb.d.ts +18 -0
  85. package/dist/cjs/src/generated/proto/discovery_pb.d.ts.map +1 -0
  86. package/dist/cjs/src/generated/proto/discovery_pb.js +40 -0
  87. package/dist/cjs/src/generated/proto/discovery_pb.js.map +1 -0
  88. package/dist/cjs/src/generated/proto/javascript_pb.d.ts.map +1 -0
  89. package/dist/cjs/src/generated/proto/javascript_pb.js.map +1 -0
  90. package/dist/{src → cjs/src}/generated/proto/protocol_pb.d.ts +186 -0
  91. package/dist/cjs/src/generated/proto/protocol_pb.d.ts.map +1 -0
  92. package/dist/{src → cjs/src}/generated/proto/protocol_pb.js +177 -1
  93. package/dist/cjs/src/generated/proto/protocol_pb.js.map +1 -0
  94. package/dist/cjs/src/generated/version.d.ts +2 -0
  95. package/dist/cjs/src/generated/version.d.ts.map +1 -0
  96. package/dist/{src → cjs/src}/generated/version.js +1 -1
  97. package/dist/cjs/src/generated/version.js.map +1 -0
  98. package/dist/{src → cjs/src}/invocation.d.ts +5 -5
  99. package/dist/cjs/src/invocation.d.ts.map +1 -0
  100. package/dist/{src → cjs/src}/invocation.js +14 -14
  101. package/dist/cjs/src/invocation.js.map +1 -0
  102. package/dist/{src → cjs/src}/io/decoder.d.ts +1 -2
  103. package/dist/cjs/src/io/decoder.d.ts.map +1 -0
  104. package/dist/{src → cjs/src}/io/decoder.js +20 -24
  105. package/dist/cjs/src/io/decoder.js.map +1 -0
  106. package/dist/{src → cjs/src}/io/encoder.d.ts +1 -1
  107. package/dist/cjs/src/io/encoder.d.ts.map +1 -0
  108. package/dist/{src → cjs/src}/io/encoder.js +6 -6
  109. package/dist/cjs/src/io/encoder.js.map +1 -0
  110. package/dist/{src → cjs/src}/journal.d.ts +7 -7
  111. package/dist/cjs/src/journal.d.ts.map +1 -0
  112. package/dist/{src → cjs/src}/journal.js +54 -37
  113. package/dist/cjs/src/journal.js.map +1 -0
  114. package/dist/cjs/src/lambda.d.ts +7 -0
  115. package/dist/cjs/src/lambda.d.ts.map +1 -0
  116. package/dist/cjs/src/lambda.js +37 -0
  117. package/dist/cjs/src/lambda.js.map +1 -0
  118. package/dist/{src → cjs/src}/local_state_store.d.ts +2 -1
  119. package/dist/cjs/src/local_state_store.d.ts.map +1 -0
  120. package/dist/{src → cjs/src}/local_state_store.js +10 -10
  121. package/dist/cjs/src/local_state_store.js.map +1 -0
  122. package/dist/cjs/src/logger.d.ts.map +1 -0
  123. package/dist/{src → cjs/src}/logger.js +1 -8
  124. package/dist/cjs/src/logger.js.map +1 -0
  125. package/dist/{src → cjs/src}/promise_combinator_tracker.d.ts +1 -1
  126. package/dist/cjs/src/promise_combinator_tracker.d.ts.map +1 -0
  127. package/dist/{src → cjs/src}/promise_combinator_tracker.js +7 -5
  128. package/dist/cjs/src/promise_combinator_tracker.js.map +1 -0
  129. package/dist/cjs/src/public_api.d.ts +7 -0
  130. package/dist/cjs/src/public_api.d.ts.map +1 -0
  131. package/dist/cjs/src/public_api.js +37 -0
  132. package/dist/cjs/src/public_api.js.map +1 -0
  133. package/dist/{src → cjs/src}/state_machine.d.ts +14 -13
  134. package/dist/cjs/src/state_machine.d.ts.map +1 -0
  135. package/dist/{src → cjs/src}/state_machine.js +59 -59
  136. package/dist/cjs/src/state_machine.js.map +1 -0
  137. package/dist/cjs/src/types/components.d.ts +78 -0
  138. package/dist/cjs/src/types/components.d.ts.map +1 -0
  139. package/dist/cjs/src/types/components.js +260 -0
  140. package/dist/cjs/src/types/components.js.map +1 -0
  141. package/dist/{src → cjs/src}/types/discovery.d.ts +6 -3
  142. package/dist/cjs/src/types/discovery.d.ts.map +1 -0
  143. package/dist/{src → cjs/src}/types/discovery.js +5 -3
  144. package/dist/cjs/src/types/discovery.js.map +1 -0
  145. package/dist/{src → cjs/src}/types/errors.d.ts +2 -2
  146. package/dist/cjs/src/types/errors.d.ts.map +1 -0
  147. package/dist/{src → cjs/src}/types/errors.js +8 -8
  148. package/dist/cjs/src/types/errors.js.map +1 -0
  149. package/dist/{src → cjs/src}/types/protocol.d.ts +16 -9
  150. package/dist/cjs/src/types/protocol.d.ts.map +1 -0
  151. package/dist/cjs/src/types/protocol.js +237 -0
  152. package/dist/cjs/src/types/protocol.js.map +1 -0
  153. package/dist/cjs/src/types/rpc.d.ts +300 -0
  154. package/dist/cjs/src/types/rpc.d.ts.map +1 -0
  155. package/dist/cjs/src/types/rpc.js +419 -0
  156. package/dist/cjs/src/types/rpc.js.map +1 -0
  157. package/dist/{src → cjs/src}/types/types.d.ts +3 -5
  158. package/dist/cjs/src/types/types.d.ts.map +1 -0
  159. package/dist/{src → cjs/src}/types/types.js +17 -28
  160. package/dist/cjs/src/types/types.js.map +1 -0
  161. package/dist/cjs/src/user_agent.d.ts +2 -0
  162. package/dist/cjs/src/user_agent.d.ts.map +1 -0
  163. package/dist/{src → cjs/src}/user_agent.js +2 -2
  164. package/dist/cjs/src/user_agent.js.map +1 -0
  165. package/dist/cjs/src/utils/buffer.d.ts +5 -0
  166. package/dist/cjs/src/utils/buffer.d.ts.map +1 -0
  167. package/dist/cjs/src/utils/buffer.js +59 -0
  168. package/dist/cjs/src/utils/buffer.js.map +1 -0
  169. package/dist/{src → cjs/src}/utils/message_logger.d.ts +1 -1
  170. package/dist/cjs/src/utils/message_logger.d.ts.map +1 -0
  171. package/dist/{src → cjs/src}/utils/message_logger.js +7 -7
  172. package/dist/cjs/src/utils/message_logger.js.map +1 -0
  173. package/dist/cjs/src/utils/promises.d.ts.map +1 -0
  174. package/dist/{src → cjs/src}/utils/promises.js +2 -1
  175. package/dist/cjs/src/utils/promises.js.map +1 -0
  176. package/dist/{src → cjs/src}/utils/rand.d.ts +3 -3
  177. package/dist/cjs/src/utils/rand.d.ts.map +1 -0
  178. package/dist/{src → cjs/src}/utils/rand.js +10 -15
  179. package/dist/cjs/src/utils/rand.js.map +1 -0
  180. package/dist/cjs/src/utils/serde.d.ts +5 -0
  181. package/dist/cjs/src/utils/serde.d.ts.map +1 -0
  182. package/dist/cjs/src/utils/serde.js +50 -0
  183. package/dist/cjs/src/utils/serde.js.map +1 -0
  184. package/dist/cjs/src/utils/utils.d.ts.map +1 -0
  185. package/dist/{src → cjs/src}/utils/utils.js +11 -11
  186. package/dist/cjs/src/utils/utils.js.map +1 -0
  187. package/dist/cjs/tsconfig.tsbuildinfo +1 -0
  188. package/dist/esm/src/common_api.d.ts +7 -0
  189. package/dist/esm/src/common_api.d.ts.map +1 -0
  190. package/dist/esm/src/common_api.js +14 -0
  191. package/dist/esm/src/common_api.js.map +1 -0
  192. package/dist/esm/src/connection/buffered_connection.d.ts +14 -0
  193. package/dist/esm/src/connection/buffered_connection.d.ts.map +1 -0
  194. package/dist/esm/src/connection/buffered_connection.js +40 -0
  195. package/dist/esm/src/connection/buffered_connection.js.map +1 -0
  196. package/dist/esm/src/connection/connection.d.ts +20 -0
  197. package/dist/esm/src/connection/connection.d.ts.map +1 -0
  198. package/dist/esm/src/connection/connection.js +12 -0
  199. package/dist/esm/src/connection/connection.js.map +1 -0
  200. package/dist/esm/src/connection/http_connection.d.ts +77 -0
  201. package/dist/esm/src/connection/http_connection.d.ts.map +1 -0
  202. package/dist/esm/src/connection/http_connection.js +204 -0
  203. package/dist/esm/src/connection/http_connection.js.map +1 -0
  204. package/dist/esm/src/connection/lambda_connection.d.ts +17 -0
  205. package/dist/esm/src/connection/lambda_connection.d.ts.map +1 -0
  206. package/dist/esm/src/connection/lambda_connection.js +60 -0
  207. package/dist/esm/src/connection/lambda_connection.js.map +1 -0
  208. package/dist/esm/src/context.d.ts +541 -0
  209. package/dist/esm/src/context.d.ts.map +1 -0
  210. package/dist/esm/src/context.js +75 -0
  211. package/dist/esm/src/context.js.map +1 -0
  212. package/dist/esm/src/context_impl.d.ts +54 -0
  213. package/dist/esm/src/context_impl.d.ts.map +1 -0
  214. package/dist/esm/src/context_impl.js +515 -0
  215. package/dist/esm/src/context_impl.js.map +1 -0
  216. package/dist/esm/src/endpoint/endpoint_builder.d.ts +18 -0
  217. package/dist/esm/src/endpoint/endpoint_builder.d.ts.map +1 -0
  218. package/dist/esm/src/endpoint/endpoint_builder.js +126 -0
  219. package/dist/esm/src/endpoint/endpoint_builder.js.map +1 -0
  220. package/dist/esm/src/endpoint/fetch_endpoint.d.ts +37 -0
  221. package/dist/esm/src/endpoint/fetch_endpoint.d.ts.map +1 -0
  222. package/dist/esm/src/endpoint/fetch_endpoint.js +42 -0
  223. package/dist/esm/src/endpoint/fetch_endpoint.js.map +1 -0
  224. package/dist/esm/src/endpoint/handlers/fetch.d.ts +6 -0
  225. package/dist/esm/src/endpoint/handlers/fetch.d.ts.map +1 -0
  226. package/dist/esm/src/endpoint/handlers/fetch.js +30 -0
  227. package/dist/esm/src/endpoint/handlers/fetch.js.map +1 -0
  228. package/dist/esm/src/endpoint/handlers/generic.d.ts +44 -0
  229. package/dist/esm/src/endpoint/handlers/generic.d.ts.map +1 -0
  230. package/dist/esm/src/endpoint/handlers/generic.js +189 -0
  231. package/dist/esm/src/endpoint/handlers/generic.js.map +1 -0
  232. package/dist/esm/src/endpoint/handlers/lambda.d.ts +8 -0
  233. package/dist/esm/src/endpoint/handlers/lambda.d.ts.map +1 -0
  234. package/dist/esm/src/endpoint/handlers/lambda.js +62 -0
  235. package/dist/esm/src/endpoint/handlers/lambda.js.map +1 -0
  236. package/dist/esm/src/endpoint/handlers/node.d.ts +11 -0
  237. package/dist/esm/src/endpoint/handlers/node.d.ts.map +1 -0
  238. package/dist/esm/src/endpoint/handlers/node.js +181 -0
  239. package/dist/esm/src/endpoint/handlers/node.js.map +1 -0
  240. package/dist/esm/src/endpoint/lambda_endpoint.d.ts +32 -0
  241. package/dist/esm/src/endpoint/lambda_endpoint.d.ts.map +1 -0
  242. package/dist/esm/src/endpoint/lambda_endpoint.js +51 -0
  243. package/dist/esm/src/endpoint/lambda_endpoint.js.map +1 -0
  244. package/dist/esm/src/endpoint/node_endpoint.d.ts +19 -0
  245. package/dist/esm/src/endpoint/node_endpoint.d.ts.map +1 -0
  246. package/dist/esm/src/endpoint/node_endpoint.js +89 -0
  247. package/dist/esm/src/endpoint/node_endpoint.js.map +1 -0
  248. package/dist/esm/src/endpoint/request_signing/basex.d.ts +10 -0
  249. package/dist/esm/src/endpoint/request_signing/basex.d.ts.map +1 -0
  250. package/dist/esm/src/endpoint/request_signing/basex.js +136 -0
  251. package/dist/esm/src/endpoint/request_signing/basex.js.map +1 -0
  252. package/dist/esm/src/endpoint/request_signing/ed25519.d.ts +17 -0
  253. package/dist/esm/src/endpoint/request_signing/ed25519.d.ts.map +1 -0
  254. package/dist/esm/src/endpoint/request_signing/ed25519.js +52 -0
  255. package/dist/esm/src/endpoint/request_signing/ed25519.js.map +1 -0
  256. package/dist/esm/src/endpoint/request_signing/v1.d.ts +9 -0
  257. package/dist/esm/src/endpoint/request_signing/v1.d.ts.map +1 -0
  258. package/dist/esm/src/endpoint/request_signing/v1.js +133 -0
  259. package/dist/esm/src/endpoint/request_signing/v1.js.map +1 -0
  260. package/dist/esm/src/endpoint/request_signing/validate.d.ts +18 -0
  261. package/dist/esm/src/endpoint/request_signing/validate.d.ts.map +1 -0
  262. package/dist/esm/src/endpoint/request_signing/validate.js +40 -0
  263. package/dist/esm/src/endpoint/request_signing/validate.js.map +1 -0
  264. package/dist/esm/src/endpoint.d.ts +103 -0
  265. package/dist/esm/src/endpoint.d.ts.map +1 -0
  266. package/dist/esm/src/endpoint.js +12 -0
  267. package/dist/esm/src/endpoint.js.map +1 -0
  268. package/dist/esm/src/fetch.d.ts +7 -0
  269. package/dist/esm/src/fetch.d.ts.map +1 -0
  270. package/dist/esm/src/fetch.js +19 -0
  271. package/dist/esm/src/fetch.js.map +1 -0
  272. package/dist/esm/src/generated/proto/discovery_pb.d.ts +18 -0
  273. package/dist/esm/src/generated/proto/discovery_pb.d.ts.map +1 -0
  274. package/dist/esm/src/generated/proto/discovery_pb.js +37 -0
  275. package/dist/esm/src/generated/proto/discovery_pb.js.map +1 -0
  276. package/dist/esm/src/generated/proto/javascript_pb.d.ts +26 -0
  277. package/dist/esm/src/generated/proto/javascript_pb.d.ts.map +1 -0
  278. package/dist/esm/src/generated/proto/javascript_pb.js +48 -0
  279. package/dist/esm/src/generated/proto/javascript_pb.js.map +1 -0
  280. package/dist/esm/src/generated/proto/protocol_pb.d.ts +1051 -0
  281. package/dist/esm/src/generated/proto/protocol_pb.d.ts.map +1 -0
  282. package/dist/esm/src/generated/proto/protocol_pb.js +1258 -0
  283. package/dist/esm/src/generated/proto/protocol_pb.js.map +1 -0
  284. package/dist/esm/src/generated/version.d.ts +2 -0
  285. package/dist/esm/src/generated/version.d.ts.map +1 -0
  286. package/dist/esm/src/generated/version.js +2 -0
  287. package/dist/esm/src/generated/version.js.map +1 -0
  288. package/dist/esm/src/invocation.d.ts +48 -0
  289. package/dist/esm/src/invocation.d.ts.map +1 -0
  290. package/dist/esm/src/invocation.js +153 -0
  291. package/dist/esm/src/invocation.js.map +1 -0
  292. package/dist/esm/src/io/decoder.d.ts +9 -0
  293. package/dist/esm/src/io/decoder.d.ts.map +1 -0
  294. package/dist/esm/src/io/decoder.js +129 -0
  295. package/dist/esm/src/io/decoder.js.map +1 -0
  296. package/dist/esm/src/io/encoder.d.ts +7 -0
  297. package/dist/esm/src/io/encoder.d.ts.map +1 -0
  298. package/dist/esm/src/io/encoder.js +49 -0
  299. package/dist/esm/src/io/encoder.js.map +1 -0
  300. package/dist/esm/src/journal.d.ts +52 -0
  301. package/dist/esm/src/journal.d.ts.map +1 -0
  302. package/dist/esm/src/journal.js +412 -0
  303. package/dist/esm/src/journal.js.map +1 -0
  304. package/dist/esm/src/lambda.d.ts +7 -0
  305. package/dist/esm/src/lambda.d.ts.map +1 -0
  306. package/dist/esm/src/lambda.js +19 -0
  307. package/dist/esm/src/lambda.js.map +1 -0
  308. package/dist/esm/src/local_state_store.d.ts +16 -0
  309. package/dist/esm/src/local_state_store.d.ts.map +1 -0
  310. package/dist/esm/src/local_state_store.js +80 -0
  311. package/dist/esm/src/local_state_store.js.map +1 -0
  312. package/dist/esm/src/logger.d.ts +27 -0
  313. package/dist/esm/src/logger.d.ts.map +1 -0
  314. package/dist/esm/src/logger.js +146 -0
  315. package/dist/esm/src/logger.js.map +1 -0
  316. package/dist/esm/src/promise_combinator_tracker.d.ts +29 -0
  317. package/dist/esm/src/promise_combinator_tracker.d.ts.map +1 -0
  318. package/dist/esm/src/promise_combinator_tracker.js +125 -0
  319. package/dist/esm/src/promise_combinator_tracker.js.map +1 -0
  320. package/dist/esm/src/public_api.d.ts +7 -0
  321. package/dist/esm/src/public_api.d.ts.map +1 -0
  322. package/dist/esm/src/public_api.js +19 -0
  323. package/dist/esm/src/public_api.js.map +1 -0
  324. package/dist/esm/src/state_machine.d.ts +86 -0
  325. package/dist/esm/src/state_machine.d.ts.map +1 -0
  326. package/dist/esm/src/state_machine.js +407 -0
  327. package/dist/esm/src/state_machine.js.map +1 -0
  328. package/dist/esm/src/types/components.d.ts +78 -0
  329. package/dist/esm/src/types/components.d.ts.map +1 -0
  330. package/dist/esm/src/types/components.js +227 -0
  331. package/dist/esm/src/types/components.js.map +1 -0
  332. package/dist/esm/src/types/discovery.d.ts +43 -0
  333. package/dist/esm/src/types/discovery.d.ts.map +1 -0
  334. package/dist/esm/src/types/discovery.js +28 -0
  335. package/dist/esm/src/types/discovery.js.map +1 -0
  336. package/dist/esm/src/types/errors.d.ts +53 -0
  337. package/dist/esm/src/types/errors.d.ts.map +1 -0
  338. package/dist/esm/src/types/errors.js +117 -0
  339. package/dist/esm/src/types/errors.js.map +1 -0
  340. package/dist/esm/src/types/protocol.d.ts +40 -0
  341. package/dist/esm/src/types/protocol.d.ts.map +1 -0
  342. package/dist/esm/src/types/protocol.js +206 -0
  343. package/dist/esm/src/types/protocol.js.map +1 -0
  344. package/dist/esm/src/types/rpc.d.ts +300 -0
  345. package/dist/esm/src/types/rpc.d.ts.map +1 -0
  346. package/dist/esm/src/types/rpc.js +412 -0
  347. package/dist/esm/src/types/rpc.js.map +1 -0
  348. package/dist/esm/src/types/types.d.ts +20 -0
  349. package/dist/esm/src/types/types.d.ts.map +1 -0
  350. package/dist/esm/src/types/types.js +105 -0
  351. package/dist/esm/src/types/types.js.map +1 -0
  352. package/dist/esm/src/user_agent.d.ts +2 -0
  353. package/dist/esm/src/user_agent.d.ts.map +1 -0
  354. package/dist/esm/src/user_agent.js +13 -0
  355. package/dist/esm/src/user_agent.js.map +1 -0
  356. package/dist/esm/src/utils/buffer.d.ts +5 -0
  357. package/dist/esm/src/utils/buffer.d.ts.map +1 -0
  358. package/dist/esm/src/utils/buffer.js +53 -0
  359. package/dist/esm/src/utils/buffer.js.map +1 -0
  360. package/dist/esm/src/utils/message_logger.d.ts +7 -0
  361. package/dist/esm/src/utils/message_logger.d.ts.map +1 -0
  362. package/dist/esm/src/utils/message_logger.js +75 -0
  363. package/dist/esm/src/utils/message_logger.js.map +1 -0
  364. package/dist/esm/src/utils/promises.d.ts +15 -0
  365. package/dist/esm/src/utils/promises.d.ts.map +1 -0
  366. package/dist/esm/src/utils/promises.js +63 -0
  367. package/dist/esm/src/utils/promises.js.map +1 -0
  368. package/dist/esm/src/utils/rand.d.ts +15 -0
  369. package/dist/esm/src/utils/rand.d.ts.map +1 -0
  370. package/dist/esm/src/utils/rand.js +106 -0
  371. package/dist/esm/src/utils/rand.js.map +1 -0
  372. package/dist/esm/src/utils/serde.d.ts +5 -0
  373. package/dist/esm/src/utils/serde.d.ts.map +1 -0
  374. package/dist/esm/src/utils/serde.js +43 -0
  375. package/dist/esm/src/utils/serde.js.map +1 -0
  376. package/dist/esm/src/utils/utils.d.ts +5 -0
  377. package/dist/esm/src/utils/utils.d.ts.map +1 -0
  378. package/dist/esm/src/utils/utils.js +109 -0
  379. package/dist/esm/src/utils/utils.js.map +1 -0
  380. package/dist/esm/tsconfig.tsbuildinfo +1 -0
  381. package/package.json +58 -20
  382. package/dist/src/clients/workflow_client.d.ts +0 -77
  383. package/dist/src/clients/workflow_client.d.ts.map +0 -1
  384. package/dist/src/clients/workflow_client.js +0 -172
  385. package/dist/src/clients/workflow_client.js.map +0 -1
  386. package/dist/src/connection/buffered_connection.d.ts.map +0 -1
  387. package/dist/src/connection/buffered_connection.js.map +0 -1
  388. package/dist/src/connection/connection.d.ts.map +0 -1
  389. package/dist/src/connection/connection.js.map +0 -1
  390. package/dist/src/connection/http_connection.d.ts.map +0 -1
  391. package/dist/src/connection/http_connection.js.map +0 -1
  392. package/dist/src/connection/lambda_connection.d.ts.map +0 -1
  393. package/dist/src/connection/lambda_connection.js.map +0 -1
  394. package/dist/src/context.d.ts.map +0 -1
  395. package/dist/src/context.js.map +0 -1
  396. package/dist/src/context_impl.d.ts +0 -62
  397. package/dist/src/context_impl.d.ts.map +0 -1
  398. package/dist/src/context_impl.js.map +0 -1
  399. package/dist/src/endpoint/endpoint_impl.d.ts +0 -28
  400. package/dist/src/endpoint/endpoint_impl.d.ts.map +0 -1
  401. package/dist/src/endpoint/endpoint_impl.js +0 -164
  402. package/dist/src/endpoint/endpoint_impl.js.map +0 -1
  403. package/dist/src/endpoint/http2_handler.d.ts.map +0 -1
  404. package/dist/src/endpoint/http2_handler.js +0 -153
  405. package/dist/src/endpoint/http2_handler.js.map +0 -1
  406. package/dist/src/endpoint/lambda_handler.d.ts +0 -15
  407. package/dist/src/endpoint/lambda_handler.d.ts.map +0 -1
  408. package/dist/src/endpoint/lambda_handler.js +0 -154
  409. package/dist/src/endpoint/lambda_handler.js.map +0 -1
  410. package/dist/src/endpoint/request_signing/basex.d.ts.map +0 -1
  411. package/dist/src/endpoint/request_signing/basex.js.map +0 -1
  412. package/dist/src/endpoint/request_signing/ed25519.d.ts.map +0 -1
  413. package/dist/src/endpoint/request_signing/ed25519.js.map +0 -1
  414. package/dist/src/endpoint/request_signing/v1.d.ts.map +0 -1
  415. package/dist/src/endpoint/request_signing/v1.js.map +0 -1
  416. package/dist/src/endpoint/request_signing/validate.d.ts.map +0 -1
  417. package/dist/src/endpoint/request_signing/validate.js.map +0 -1
  418. package/dist/src/endpoint.d.ts.map +0 -1
  419. package/dist/src/endpoint.js.map +0 -1
  420. package/dist/src/generated/proto/javascript_pb.d.ts.map +0 -1
  421. package/dist/src/generated/proto/javascript_pb.js.map +0 -1
  422. package/dist/src/generated/proto/protocol_pb.d.ts.map +0 -1
  423. package/dist/src/generated/proto/protocol_pb.js.map +0 -1
  424. package/dist/src/generated/version.d.ts +0 -2
  425. package/dist/src/generated/version.d.ts.map +0 -1
  426. package/dist/src/generated/version.js.map +0 -1
  427. package/dist/src/invocation.d.ts.map +0 -1
  428. package/dist/src/invocation.js.map +0 -1
  429. package/dist/src/io/decoder.d.ts.map +0 -1
  430. package/dist/src/io/decoder.js.map +0 -1
  431. package/dist/src/io/encoder.d.ts.map +0 -1
  432. package/dist/src/io/encoder.js.map +0 -1
  433. package/dist/src/journal.d.ts.map +0 -1
  434. package/dist/src/journal.js.map +0 -1
  435. package/dist/src/local_state_store.d.ts.map +0 -1
  436. package/dist/src/local_state_store.js.map +0 -1
  437. package/dist/src/logger.d.ts.map +0 -1
  438. package/dist/src/logger.js.map +0 -1
  439. package/dist/src/promise_combinator_tracker.d.ts.map +0 -1
  440. package/dist/src/promise_combinator_tracker.js.map +0 -1
  441. package/dist/src/public_api.d.ts +0 -7
  442. package/dist/src/public_api.d.ts.map +0 -1
  443. package/dist/src/public_api.js +0 -50
  444. package/dist/src/public_api.js.map +0 -1
  445. package/dist/src/state_machine.d.ts.map +0 -1
  446. package/dist/src/state_machine.js.map +0 -1
  447. package/dist/src/types/components.d.ts +0 -65
  448. package/dist/src/types/components.d.ts.map +0 -1
  449. package/dist/src/types/components.js +0 -163
  450. package/dist/src/types/components.js.map +0 -1
  451. package/dist/src/types/discovery.d.ts.map +0 -1
  452. package/dist/src/types/discovery.js.map +0 -1
  453. package/dist/src/types/errors.d.ts.map +0 -1
  454. package/dist/src/types/errors.js.map +0 -1
  455. package/dist/src/types/protocol.d.ts.map +0 -1
  456. package/dist/src/types/protocol.js +0 -147
  457. package/dist/src/types/protocol.js.map +0 -1
  458. package/dist/src/types/rpc.d.ts +0 -50
  459. package/dist/src/types/rpc.d.ts.map +0 -1
  460. package/dist/src/types/rpc.js +0 -38
  461. package/dist/src/types/rpc.js.map +0 -1
  462. package/dist/src/types/types.d.ts.map +0 -1
  463. package/dist/src/types/types.js.map +0 -1
  464. package/dist/src/user_agent.d.ts +0 -2
  465. package/dist/src/user_agent.d.ts.map +0 -1
  466. package/dist/src/user_agent.js.map +0 -1
  467. package/dist/src/utils/message_logger.d.ts.map +0 -1
  468. package/dist/src/utils/message_logger.js.map +0 -1
  469. package/dist/src/utils/promises.d.ts.map +0 -1
  470. package/dist/src/utils/promises.js.map +0 -1
  471. package/dist/src/utils/rand.d.ts.map +0 -1
  472. package/dist/src/utils/rand.js.map +0 -1
  473. package/dist/src/utils/serde.d.ts +0 -3
  474. package/dist/src/utils/serde.d.ts.map +0 -1
  475. package/dist/src/utils/serde.js +0 -24
  476. package/dist/src/utils/serde.js.map +0 -1
  477. package/dist/src/utils/utils.d.ts.map +0 -1
  478. package/dist/src/utils/utils.js.map +0 -1
  479. package/dist/src/workflows/workflow.d.ts +0 -101
  480. package/dist/src/workflows/workflow.d.ts.map +0 -1
  481. package/dist/src/workflows/workflow.js +0 -84
  482. package/dist/src/workflows/workflow.js.map +0 -1
  483. package/dist/src/workflows/workflow_state_service.d.ts +0 -35
  484. package/dist/src/workflows/workflow_state_service.d.ts.map +0 -1
  485. package/dist/src/workflows/workflow_state_service.js +0 -201
  486. package/dist/src/workflows/workflow_state_service.js.map +0 -1
  487. package/dist/src/workflows/workflow_wrapper_service.d.ts +0 -10
  488. package/dist/src/workflows/workflow_wrapper_service.d.ts.map +0 -1
  489. package/dist/src/workflows/workflow_wrapper_service.js +0 -285
  490. package/dist/src/workflows/workflow_wrapper_service.js.map +0 -1
  491. package/dist/tsconfig.tsbuildinfo +0 -1
  492. /package/dist/{src → cjs/src}/connection/connection.js +0 -0
  493. /package/dist/{src → cjs/src}/endpoint/request_signing/basex.d.ts +0 -0
  494. /package/dist/{src → cjs/src}/endpoint/request_signing/basex.js +0 -0
  495. /package/dist/{src → cjs/src}/generated/proto/javascript_pb.d.ts +0 -0
  496. /package/dist/{src → cjs/src}/generated/proto/javascript_pb.js +0 -0
  497. /package/dist/{src → cjs/src}/logger.d.ts +0 -0
  498. /package/dist/{src → cjs/src}/utils/promises.d.ts +0 -0
  499. /package/dist/{src → cjs/src}/utils/utils.d.ts +0 -0
package/README.md CHANGED
@@ -46,3 +46,13 @@ For brand-new projects, we recommend using the [Restate Node Template](https://g
46
46
  ```shell
47
47
  npx -y @restatedev/create-app@latest
48
48
  ```
49
+
50
+ ## Versions
51
+
52
+ This library follows [Semantic Versioning](https://semver.org/).
53
+
54
+ The compatibility with Restate is described in the following table:
55
+
56
+ | Restate Server\sdk-typescript | 1.0 |
57
+ |-------------------------------|-----|
58
+ | 1.0 | ✅ |
@@ -0,0 +1 @@
1
+ {"type":"commonjs"}
@@ -0,0 +1,7 @@
1
+ export { Context, ObjectContext, ObjectSharedContext, CombineablePromise, WorkflowContext, WorkflowSharedContext, Rand, } from "./context.js";
2
+ export type { Client, SendClient } from "./types/rpc.js";
3
+ export { service, object, workflow, handlers } from "./types/rpc.js";
4
+ export type { ServiceDefinition, VirtualObjectDefinition, WorkflowDefinition, } from "@restatedev/restate-sdk-core";
5
+ export { ServiceBundle, RestateEndpoint } from "./endpoint.js";
6
+ export { RestateError, TerminalError, TimeoutError } from "./types/errors.js";
7
+ //# sourceMappingURL=common_api.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"common_api.d.ts","sourceRoot":"","sources":["../../../src/common_api.ts"],"names":[],"mappings":"AAWA,OAAO,EACL,OAAO,EACP,aAAa,EACb,mBAAmB,EACnB,kBAAkB,EAClB,eAAe,EACf,qBAAqB,EACrB,IAAI,GACL,MAAM,cAAc,CAAC;AAEtB,YAAY,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACzD,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAErE,YAAY,EACV,iBAAiB,EACjB,uBAAuB,EACvB,kBAAkB,GACnB,MAAM,8BAA8B,CAAC;AAEtC,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ /*
3
+ * Copyright (c) 2023-2024 - Restate Software, Inc., Restate GmbH
4
+ *
5
+ * This file is part of the Restate SDK for Node.js/TypeScript,
6
+ * which is released under the MIT license.
7
+ *
8
+ * You can find a copy of the license in file LICENSE in the root
9
+ * directory of this repository or package, or at
10
+ * https://github.com/restatedev/sdk-typescript/blob/main/LICENSE
11
+ */
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ exports.TimeoutError = exports.TerminalError = exports.RestateError = exports.handlers = exports.workflow = exports.object = exports.service = exports.CombineablePromise = void 0;
14
+ var context_js_1 = require("./context.js");
15
+ Object.defineProperty(exports, "CombineablePromise", { enumerable: true, get: function () { return context_js_1.CombineablePromise; } });
16
+ var rpc_js_1 = require("./types/rpc.js");
17
+ Object.defineProperty(exports, "service", { enumerable: true, get: function () { return rpc_js_1.service; } });
18
+ Object.defineProperty(exports, "object", { enumerable: true, get: function () { return rpc_js_1.object; } });
19
+ Object.defineProperty(exports, "workflow", { enumerable: true, get: function () { return rpc_js_1.workflow; } });
20
+ Object.defineProperty(exports, "handlers", { enumerable: true, get: function () { return rpc_js_1.handlers; } });
21
+ var errors_js_1 = require("./types/errors.js");
22
+ Object.defineProperty(exports, "RestateError", { enumerable: true, get: function () { return errors_js_1.RestateError; } });
23
+ Object.defineProperty(exports, "TerminalError", { enumerable: true, get: function () { return errors_js_1.TerminalError; } });
24
+ Object.defineProperty(exports, "TimeoutError", { enumerable: true, get: function () { return errors_js_1.TimeoutError; } });
25
+ //# sourceMappingURL=common_api.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"common_api.js","sourceRoot":"","sources":["../../../src/common_api.ts"],"names":[],"mappings":";AAAA;;;;;;;;;GASG;;;AAEH,2CAQsB;AAJpB,gHAAA,kBAAkB,OAAA;AAOpB,yCAAqE;AAA5D,iGAAA,OAAO,OAAA;AAAE,gGAAA,MAAM,OAAA;AAAE,kGAAA,QAAQ,OAAA;AAAE,kGAAA,QAAQ,OAAA;AAS5C,+CAA8E;AAArE,yGAAA,YAAY,OAAA;AAAE,0GAAA,aAAa,OAAA;AAAE,yGAAA,YAAY,OAAA"}
@@ -1,8 +1,7 @@
1
1
  /// <reference types="node" />
2
- import { Message } from "../types/types";
3
- import { Connection } from "./connection";
4
- import { Buffer } from "node:buffer";
5
- export declare class BufferedConnection implements Connection {
2
+ import type { Message } from "../types/types.js";
3
+ import type { Buffer } from "node:buffer";
4
+ export declare class BufferedConnection {
6
5
  private readonly flushFn;
7
6
  private queue;
8
7
  private flushing;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buffered_connection.d.ts","sourceRoot":"","sources":["../../../../src/connection/buffered_connection.ts"],"names":[],"mappings":";AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAE1C,qBAAa,kBAAkB;IAIjB,OAAO,CAAC,QAAQ,CAAC,OAAO;IAHpC,OAAO,CAAC,KAAK,CAAiB;IAC9B,OAAO,CAAC,QAAQ,CAAoC;gBAEvB,OAAO,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC;IAEvE,IAAI,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAajC,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;IAKpB,OAAO,CAAC,aAAa;YASP,KAAK;CASpB"}
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.BufferedConnection = void 0;
4
- const encoder_1 = require("../io/encoder");
4
+ const encoder_js_1 = require("../io/encoder.js");
5
5
  class BufferedConnection {
6
6
  flushFn;
7
7
  queue = [];
@@ -35,7 +35,7 @@ class BufferedConnection {
35
35
  if (this.queue.length === 0) {
36
36
  return Promise.resolve();
37
37
  }
38
- const buffer = (0, encoder_1.encodeMessages)(this.queue);
38
+ const buffer = (0, encoder_js_1.encodeMessages)(this.queue);
39
39
  this.queue = [];
40
40
  return this.flushFn(buffer);
41
41
  }
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buffered_connection.js","sourceRoot":"","sources":["../../../../src/connection/buffered_connection.ts"],"names":[],"mappings":";;;AAAA,iDAAkD;AAIlD,MAAa,kBAAkB;IAIA;IAHrB,KAAK,GAAc,EAAE,CAAC;IACtB,QAAQ,GAAkB,OAAO,CAAC,OAAO,EAAE,CAAC;IAEpD,YAA6B,OAA0C;QAA1C,YAAO,GAAP,OAAO,CAAmC;IAAG,CAAC;IAE3E,IAAI,CAAC,GAAY;QACf,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACjC,IAAI,GAAG,KAAK,CAAC,EAAE,CAAC;YACd,2DAA2D;YAC3D,kDAAkD;YAClD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;QACjE,CAAC;QACD,gDAAgD;QAChD,mFAAmF;QACnF,+CAA+C;QAC/C,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,GAAG;QACD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QACvD,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAEO,aAAa;QACnB,mEAAmE;QACnE,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,CACrC,YAAY,CAAC,GAAG,EAAE;YAChB,IAAI,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAC3C,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEO,KAAK,CAAC,KAAK;QACjB,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC5B,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;QAC3B,CAAC;QACD,MAAM,MAAM,GAAG,IAAA,2BAAc,EAAC,IAAI,CAAC,KAAK,CAAW,CAAC;QACpD,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAEhB,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAC9B,CAAC;CACF;AA1CD,gDA0CC"}
@@ -1,4 +1,4 @@
1
- import { Message } from "../types/types";
1
+ import type { Message } from "../types/types.js";
2
2
  /**
3
3
  * A connection from the service/SDK to Restate.
4
4
  * Accepts messages to be sent and committed to the journal.
@@ -6,6 +6,7 @@ import { Message } from "../types/types";
6
6
  export interface Connection {
7
7
  send(msg: Message): Promise<void>;
8
8
  end(): Promise<void>;
9
+ headers(): ReadonlyMap<string, string | string[] | undefined>;
9
10
  }
10
11
  /**
11
12
  * A consumer of a message stream from Restate.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connection.d.ts","sourceRoot":"","sources":["../../../../src/connection/connection.ts"],"names":[],"mappings":"AAWA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAEjD;;;GAGG;AACH,MAAM,WAAW,UAAU;IACzB,IAAI,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAElC,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAErB,OAAO,IAAI,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAC,CAAC;CAC/D;AAED;;;GAGG;AACH,MAAM,WAAW,qBAAqB;IACpC,aAAa,CAAC,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC;IAEnC,iBAAiB,CAAC,CAAC,EAAE,KAAK,GAAG,IAAI,CAAC;IAElC,iBAAiB,IAAI,IAAI,CAAC;CAC3B"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connection.js","sourceRoot":"","sources":["../../../../src/connection/connection.ts"],"names":[],"mappings":";AAAA;;;;;;;;;GASG"}
@@ -1,7 +1,9 @@
1
1
  /// <reference types="node" />
2
- import stream from "node:stream";
3
- import { Connection, RestateStreamConsumer } from "./connection";
4
- import { Message } from "../types/types";
2
+ /// <reference types="node" />
3
+ import type stream from "node:stream";
4
+ import type { Connection, RestateStreamConsumer } from "./connection.js";
5
+ import type { Message } from "../types/types.js";
6
+ import type { Http2ServerRequest, IncomingHttpHeaders } from "node:http2";
5
7
  /**
6
8
  * A duplex stream with Restate Messages over HTTP2.
7
9
  *
@@ -25,18 +27,20 @@ import { Message } from "../types/types";
25
27
  * notifications for cleanly closed input (to trigger suspension).
26
28
  */
27
29
  export declare class RestateHttp2Connection implements Connection {
30
+ private readonly attemptHeaders;
28
31
  private readonly rawStream;
29
32
  /**
30
33
  * create a RestateDuplex stream from an http2 (duplex) stream.
31
34
  */
32
- static from(http2stream: stream.Duplex): RestateHttp2Connection;
35
+ static from(request: Http2ServerRequest, http2stream: stream.Duplex): RestateHttp2Connection;
33
36
  private readonly sdkInput;
34
37
  private currentConsumer;
35
38
  private inputBuffer;
36
39
  private consumerError?;
37
40
  private consumerInputClosed;
38
41
  private outputBuffer;
39
- constructor(rawStream: stream.Duplex);
42
+ constructor(attemptHeaders: IncomingHttpHeaders, rawStream: stream.Duplex);
43
+ headers(): ReadonlyMap<string, string | string[] | undefined>;
40
44
  /**
41
45
  * Pipes the messages from this connection to the given consumer. The consumer
42
46
  * will also receive error and stream closing notifications.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"http_connection.d.ts","sourceRoot":"","sources":["../../../../src/connection/http_connection.ts"],"names":[],"mappings":";;AAWA,OAAO,KAAK,MAAM,MAAM,aAAa,CAAC;AAEtC,OAAO,KAAK,EAAE,UAAU,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAC;AACzE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAIjD,OAAO,KAAK,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAK1E;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,qBAAa,sBAAuB,YAAW,UAAU;IAyBrD,OAAO,CAAC,QAAQ,CAAC,cAAc;IAC/B,OAAO,CAAC,QAAQ,CAAC,SAAS;IAzB5B;;OAEG;WACW,IAAI,CAChB,OAAO,EAAE,kBAAkB,EAC3B,WAAW,EAAE,MAAM,CAAC,MAAM,GACzB,sBAAsB;IAOzB,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAkB;IAG3C,OAAO,CAAC,eAAe,CAAsC;IAC7D,OAAO,CAAC,WAAW,CAAiB;IACpC,OAAO,CAAC,aAAa,CAAC,CAAQ;IAC9B,OAAO,CAAC,mBAAmB,CAAS;IAEpC,OAAO,CAAC,YAAY,CAAqB;gBAGtB,cAAc,EAAE,mBAAmB,EACnC,SAAS,EAAE,MAAM,CAAC,MAAM;IA4E3C,OAAO,IAAI,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAC;IAQ7D;;;;;;;;OAQG;IACI,cAAc,CAAC,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IA+B5D;;OAEG;IACI,qBAAqB,IAAI,IAAI;IAQpC;;;;;;;;;;;;OAYG;IACI,IAAI,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAIxC;;OAEG;IACU,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAYlC"}
@@ -11,10 +11,10 @@
11
11
  */
12
12
  Object.defineProperty(exports, "__esModule", { value: true });
13
13
  exports.RestateHttp2Connection = void 0;
14
- const decoder_1 = require("../io/decoder");
15
- const logger_1 = require("../logger");
14
+ const decoder_js_1 = require("../io/decoder.js");
15
+ const logger_js_1 = require("../logger.js");
16
16
  const promises_1 = require("node:stream/promises");
17
- const buffered_connection_1 = require("./buffered_connection");
17
+ const buffered_connection_js_1 = require("./buffered_connection.js");
18
18
  // utility promise, for cases where we want to save allocation of an extra promise
19
19
  const RESOLVED = Promise.resolve();
20
20
  /**
@@ -40,12 +40,13 @@ const RESOLVED = Promise.resolve();
40
40
  * notifications for cleanly closed input (to trigger suspension).
41
41
  */
42
42
  class RestateHttp2Connection {
43
+ attemptHeaders;
43
44
  rawStream;
44
45
  /**
45
46
  * create a RestateDuplex stream from an http2 (duplex) stream.
46
47
  */
47
- static from(http2stream) {
48
- return new RestateHttp2Connection(http2stream);
48
+ static from(request, http2stream) {
49
+ return new RestateHttp2Connection(request.headers, http2stream);
49
50
  }
50
51
  // --------------------------------------------------------------------------
51
52
  // input as decoded messages
@@ -56,10 +57,11 @@ class RestateHttp2Connection {
56
57
  consumerError;
57
58
  consumerInputClosed = false;
58
59
  outputBuffer;
59
- constructor(rawStream) {
60
+ constructor(attemptHeaders, rawStream) {
61
+ this.attemptHeaders = attemptHeaders;
60
62
  this.rawStream = rawStream;
61
- this.sdkInput = rawStream.pipe((0, decoder_1.streamDecoder)());
62
- this.outputBuffer = new buffered_connection_1.BufferedConnection((buffer) => {
63
+ this.sdkInput = rawStream.pipe((0, decoder_js_1.streamDecoder)());
64
+ this.outputBuffer = new buffered_connection_js_1.BufferedConnection((buffer) => {
63
65
  const hasMoreCapacity = rawStream.write(buffer);
64
66
  if (hasMoreCapacity) {
65
67
  return RESOLVED;
@@ -102,17 +104,17 @@ class RestateHttp2Connection {
102
104
  };
103
105
  // those two event types should cover all types of connection losses
104
106
  rawStream.on("aborted", () => {
105
- logger_1.rlog.error("Connection to Restate was lost");
107
+ logger_js_1.rlog.error("Connection to Restate was lost");
106
108
  errorHandler(new Error("Connection to Restate was lost"));
107
109
  });
108
110
  // this is both the raw http2 stream and the output SDK->Restate
109
111
  rawStream.on("error", (e) => {
110
- logger_1.rlog.error("Error in http2 stream to Restate: " + (e.stack ?? e.message));
112
+ logger_js_1.rlog.error("Error in http2 stream to Restate: " + (e.stack ?? e.message));
111
113
  errorHandler(e);
112
114
  });
113
115
  // these events notify of errors in the decoding pipeline
114
116
  this.sdkInput.on("error", (e) => {
115
- logger_1.rlog.error("Error in input stream (Restate to Service): " + (e.stack ?? e.message));
117
+ logger_js_1.rlog.error("Error in input stream (Restate to Service): " + (e.stack ?? e.message));
116
118
  errorHandler(e);
117
119
  });
118
120
  // see if streams get torn down before they end cleanly
@@ -122,6 +124,9 @@ class RestateHttp2Connection {
122
124
  }
123
125
  });
124
126
  }
127
+ headers() {
128
+ return new Map(Object.entries(this.attemptHeaders));
129
+ }
125
130
  // --------------------------------------------------------------------------
126
131
  // input stream handling
127
132
  // --------------------------------------------------------------------------
@@ -0,0 +1 @@
1
+ {"version":3,"file":"http_connection.js","sourceRoot":"","sources":["../../../../src/connection/http_connection.ts"],"names":[],"mappings":"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"}
@@ -1,13 +1,15 @@
1
1
  /// <reference types="node" />
2
- import { Connection } from "./connection";
3
- import { Message } from "../types/types";
2
+ import type { Connection } from "./connection.js";
3
+ import type { Message } from "../types/types.js";
4
4
  import { Buffer } from "node:buffer";
5
5
  export declare class LambdaConnection implements Connection {
6
+ private readonly attemptHeaders;
6
7
  private suspendedOrCompleted;
7
8
  private outputBuffer;
8
9
  private readonly completionPromise;
9
10
  private resolveOnCompleted;
10
- constructor(suspendedOrCompleted?: boolean);
11
+ constructor(attemptHeaders: Record<string, string | string[] | undefined>, suspendedOrCompleted?: boolean);
12
+ headers(): ReadonlyMap<string, string | string[] | undefined>;
11
13
  send(msg: Message): Promise<void>;
12
14
  getResult(): Promise<Buffer>;
13
15
  end(): Promise<void>;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lambda_connection.d.ts","sourceRoot":"","sources":["../../../../src/connection/lambda_connection.ts"],"names":[],"mappings":";AAWA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAOlD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAEjD,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAIrC,qBAAa,gBAAiB,YAAW,UAAU;IAS/C,OAAO,CAAC,QAAQ,CAAC,cAAc;IAI/B,OAAO,CAAC,oBAAoB;IAX9B,OAAO,CAAC,YAAY,CAA2B;IAG/C,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAkB;IACpD,OAAO,CAAC,kBAAkB,CAAiD;gBAGxD,cAAc,EAAE,MAAM,CACrC,MAAM,EACN,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAC9B,EACO,oBAAoB,UAAQ;IAQtC,OAAO,IAAI,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAC;IAK7D,IAAI,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAiBjC,SAAS,IAAI,OAAO,CAAC,MAAM,CAAC;IAI5B,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAQrB"}
@@ -11,34 +11,39 @@
11
11
  */
12
12
  Object.defineProperty(exports, "__esModule", { value: true });
13
13
  exports.LambdaConnection = void 0;
14
- const encoder_1 = require("../io/encoder");
15
- const protocol_1 = require("../types/protocol");
16
- const logger_1 = require("../logger");
14
+ const encoder_js_1 = require("../io/encoder.js");
15
+ const protocol_js_1 = require("../types/protocol.js");
16
+ const logger_js_1 = require("../logger.js");
17
17
  const node_buffer_1 = require("node:buffer");
18
18
  const RESOLVED = Promise.resolve();
19
19
  class LambdaConnection {
20
+ attemptHeaders;
20
21
  suspendedOrCompleted;
21
22
  // Empty buffer to store journal output messages
22
23
  outputBuffer = node_buffer_1.Buffer.alloc(0);
23
24
  // Callback to resolve the invocation promise of the Lambda handler when the response is ready
24
25
  completionPromise;
25
26
  resolveOnCompleted;
26
- constructor(suspendedOrCompleted = false) {
27
+ constructor(attemptHeaders, suspendedOrCompleted = false) {
28
+ this.attemptHeaders = attemptHeaders;
27
29
  this.suspendedOrCompleted = suspendedOrCompleted;
28
30
  // Promise that signals when the invocation is over, to then flush the messages
29
31
  this.completionPromise = new Promise((resolve) => {
30
32
  this.resolveOnCompleted = resolve;
31
33
  });
32
34
  }
35
+ headers() {
36
+ return new Map(Object.entries(this.attemptHeaders));
37
+ }
33
38
  // Send a message back to the runtime
34
39
  send(msg) {
35
40
  // Add the header and the body to buffer and add to the output buffer
36
- const msgBuffer = (0, encoder_1.encodeMessage)(msg);
41
+ const msgBuffer = (0, encoder_js_1.encodeMessage)(msg);
37
42
  this.outputBuffer = node_buffer_1.Buffer.concat([this.outputBuffer, msgBuffer]);
38
43
  // An output message, suspension message or error message is the end of a Lambda invocation
39
- if (msg.messageType === protocol_1.OUTPUT_ENTRY_MESSAGE_TYPE ||
40
- msg.messageType === protocol_1.SUSPENSION_MESSAGE_TYPE ||
41
- msg.messageType === protocol_1.ERROR_MESSAGE_TYPE) {
44
+ if (msg.messageType === protocol_js_1.OUTPUT_ENTRY_MESSAGE_TYPE ||
45
+ msg.messageType === protocol_js_1.SUSPENSION_MESSAGE_TYPE ||
46
+ msg.messageType === protocol_js_1.ERROR_MESSAGE_TYPE) {
42
47
  this.suspendedOrCompleted = true;
43
48
  }
44
49
  return RESOLVED;
@@ -48,7 +53,7 @@ class LambdaConnection {
48
53
  }
49
54
  end() {
50
55
  if (this.suspendedOrCompleted) {
51
- logger_1.rlog.debug("Flushing output buffer...");
56
+ logger_js_1.rlog.debug("Flushing output buffer...");
52
57
  this.resolveOnCompleted(this.outputBuffer);
53
58
  }
54
59
  this.outputBuffer = node_buffer_1.Buffer.alloc(0);
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lambda_connection.js","sourceRoot":"","sources":["../../../../src/connection/lambda_connection.ts"],"names":[],"mappings":";AAAA;;;;;;;;;GASG;;;AAGH,iDAAiD;AACjD,sDAI8B;AAE9B,4CAAoC;AACpC,6CAAqC;AAErC,MAAM,QAAQ,GAAkB,OAAO,CAAC,OAAO,EAAE,CAAC;AAElD,MAAa,gBAAgB;IASR;IAIT;IAZV,gDAAgD;IACxC,YAAY,GAAW,oBAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAE/C,8FAA8F;IAC7E,iBAAiB,CAAkB;IAC5C,kBAAkB,CAAiD;IAE3E,YACmB,cAGhB,EACO,uBAAuB,KAAK;QAJnB,mBAAc,GAAd,cAAc,CAG9B;QACO,yBAAoB,GAApB,oBAAoB,CAAQ;QAEpC,+EAA+E;QAC/E,IAAI,CAAC,iBAAiB,GAAG,IAAI,OAAO,CAAS,CAAC,OAAO,EAAE,EAAE;YACvD,IAAI,CAAC,kBAAkB,GAAG,OAAO,CAAC;QACpC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,OAAO;QACL,OAAO,IAAI,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;IACtD,CAAC;IAED,qCAAqC;IACrC,IAAI,CAAC,GAAY;QACf,qEAAqE;QACrE,MAAM,SAAS,GAAG,IAAA,0BAAa,EAAC,GAAG,CAAC,CAAC;QACrC,IAAI,CAAC,YAAY,GAAG,oBAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,SAAS,CAAC,CAAC,CAAC;QAElE,2FAA2F;QAC3F,IACE,GAAG,CAAC,WAAW,KAAK,uCAAyB;YAC7C,GAAG,CAAC,WAAW,KAAK,qCAAuB;YAC3C,GAAG,CAAC,WAAW,KAAK,gCAAkB,EACtC,CAAC;YACD,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;QACnC,CAAC;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IAED,GAAG;QACD,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC9B,gBAAI,CAAC,KAAK,CAAC,2BAA2B,CAAC,CAAC;YACxC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC7C,CAAC;QACD,IAAI,CAAC,YAAY,GAAG,oBAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACpC,OAAO,QAAQ,CAAC;IAClB,CAAC;CACF;AAvDD,4CAuDC"}