mavenagi 1.0.15 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (371) hide show
  1. package/Client.d.ts +3 -4
  2. package/Client.js +51 -12
  3. package/README.md +14 -1
  4. package/api/resources/actions/client/Client.d.ts +9 -4
  5. package/api/resources/actions/client/Client.js +68 -39
  6. package/api/resources/agents/client/Client.d.ts +9 -4
  7. package/api/resources/agents/client/Client.js +76 -44
  8. package/api/resources/analytics/client/Client.d.ts +9 -4
  9. package/api/resources/analytics/client/Client.js +76 -40
  10. package/api/resources/analytics/types/ConversationTableResponse.d.ts +3 -3
  11. package/api/resources/appSettings/client/Client.d.ts +9 -4
  12. package/api/resources/appSettings/client/Client.js +76 -44
  13. package/api/resources/appSettings/client/index.d.ts +1 -0
  14. package/api/resources/commons/errors/BadRequestError.d.ts +2 -1
  15. package/api/resources/commons/errors/BadRequestError.js +2 -1
  16. package/api/resources/commons/errors/NotFoundError.d.ts +2 -1
  17. package/api/resources/commons/errors/NotFoundError.js +2 -1
  18. package/api/resources/commons/errors/ServerError.d.ts +2 -1
  19. package/api/resources/commons/errors/ServerError.js +2 -1
  20. package/api/resources/commons/types/AppUserRequest.d.ts +2 -2
  21. package/api/resources/commons/types/AppUserResponse.d.ts +2 -2
  22. package/api/resources/commons/types/ConversationResponse.d.ts +2 -1
  23. package/api/resources/commons/types/InboxItemFixType.d.ts +14 -0
  24. package/{dist/api/resources/realtime/types/AudioFormat.js → api/resources/commons/types/InboxItemFixType.js} +4 -4
  25. package/api/resources/commons/types/UserMessageAttachment.d.ts +16 -0
  26. package/api/resources/commons/types/index.d.ts +1 -0
  27. package/api/resources/commons/types/index.js +1 -0
  28. package/api/resources/conversation/client/Client.d.ts +43 -58
  29. package/api/resources/conversation/client/Client.js +342 -281
  30. package/api/resources/conversation/client/index.d.ts +1 -0
  31. package/api/resources/conversation/types/Attachment.d.ts +18 -1
  32. package/api/resources/conversation/types/ConversationMessageRequest.d.ts +2 -0
  33. package/api/resources/conversation/types/index.d.ts +0 -1
  34. package/api/resources/conversation/types/index.js +0 -1
  35. package/api/resources/events/client/Client.d.ts +5 -2
  36. package/api/resources/events/client/Client.js +26 -16
  37. package/api/resources/inbox/client/Client.d.ts +21 -10
  38. package/api/resources/inbox/client/Client.js +126 -67
  39. package/api/resources/inbox/client/index.d.ts +1 -0
  40. package/api/resources/inbox/client/requests/InboxItemFixRequest.d.ts +7 -1
  41. package/api/resources/inbox/client/requests/InboxItemIgnoreRequest.d.ts +7 -1
  42. package/api/resources/inbox/client/requests/InboxItemRequest.d.ts +7 -1
  43. package/api/resources/inbox/types/ApplyInboxItemFixRequest.d.ts +2 -0
  44. package/api/resources/inbox/types/InboxSearchRequest.d.ts +4 -0
  45. package/api/resources/index.d.ts +0 -2
  46. package/api/resources/index.js +1 -3
  47. package/api/resources/knowledge/client/Client.d.ts +17 -8
  48. package/api/resources/knowledge/client/Client.js +168 -87
  49. package/api/resources/organizations/client/Client.d.ts +7 -3
  50. package/api/resources/organizations/client/Client.js +51 -28
  51. package/api/resources/translations/client/Client.d.ts +5 -2
  52. package/api/resources/translations/client/Client.js +26 -16
  53. package/api/resources/triggers/client/Client.d.ts +13 -6
  54. package/api/resources/triggers/client/Client.js +118 -63
  55. package/api/resources/triggers/client/index.d.ts +1 -0
  56. package/api/resources/users/client/Client.d.ts +11 -6
  57. package/api/resources/users/client/Client.js +72 -43
  58. package/api/resources/users/client/index.d.ts +1 -0
  59. package/core/auth/BasicAuth.js +3 -3
  60. package/core/base64.d.ts +2 -0
  61. package/core/base64.js +26 -0
  62. package/core/fetcher/APIResponse.d.ts +10 -0
  63. package/core/fetcher/BinaryResponse.d.ts +20 -0
  64. package/core/fetcher/BinaryResponse.js +17 -0
  65. package/core/fetcher/Fetcher.d.ts +3 -2
  66. package/core/fetcher/Fetcher.js +32 -12
  67. package/core/fetcher/Headers.d.ts +2 -0
  68. package/core/fetcher/Headers.js +84 -0
  69. package/core/fetcher/HttpResponsePromise.d.ts +58 -0
  70. package/core/fetcher/HttpResponsePromise.js +103 -0
  71. package/core/fetcher/RawResponse.d.ts +29 -0
  72. package/core/fetcher/RawResponse.js +44 -0
  73. package/core/fetcher/ResponseWithBody.d.ts +4 -0
  74. package/core/fetcher/ResponseWithBody.js +6 -0
  75. package/core/fetcher/createRequestUrl.d.ts +1 -1
  76. package/core/fetcher/createRequestUrl.js +3 -7
  77. package/core/fetcher/getErrorResponseBody.d.ts +1 -0
  78. package/core/fetcher/getErrorResponseBody.js +44 -0
  79. package/core/fetcher/getFetchFn.d.ts +1 -4
  80. package/core/fetcher/getFetchFn.js +1 -52
  81. package/core/fetcher/getResponseBody.js +34 -33
  82. package/core/fetcher/index.d.ts +4 -0
  83. package/core/fetcher/index.js +7 -1
  84. package/core/headers.d.ts +3 -0
  85. package/core/headers.js +29 -0
  86. package/core/index.d.ts +3 -2
  87. package/core/index.js +4 -3
  88. package/core/runtime/runtime.js +0 -1
  89. package/core/{streaming-fetcher → stream}/Stream.d.ts +1 -2
  90. package/core/url/index.d.ts +2 -0
  91. package/core/url/index.js +7 -0
  92. package/core/url/join.d.ts +1 -0
  93. package/core/url/join.js +49 -0
  94. package/core/url/qs.d.ts +6 -0
  95. package/core/url/qs.js +64 -0
  96. package/dist/Client.d.ts +3 -4
  97. package/dist/Client.js +51 -12
  98. package/dist/api/resources/actions/client/Client.d.ts +9 -4
  99. package/dist/api/resources/actions/client/Client.js +68 -39
  100. package/dist/api/resources/agents/client/Client.d.ts +9 -4
  101. package/dist/api/resources/agents/client/Client.js +76 -44
  102. package/dist/api/resources/analytics/client/Client.d.ts +9 -4
  103. package/dist/api/resources/analytics/client/Client.js +76 -40
  104. package/dist/api/resources/analytics/types/ConversationTableResponse.d.ts +3 -3
  105. package/dist/api/resources/appSettings/client/Client.d.ts +9 -4
  106. package/dist/api/resources/appSettings/client/Client.js +76 -44
  107. package/dist/api/resources/appSettings/client/index.d.ts +1 -0
  108. package/dist/api/resources/commons/errors/BadRequestError.d.ts +2 -1
  109. package/dist/api/resources/commons/errors/BadRequestError.js +2 -1
  110. package/dist/api/resources/commons/errors/NotFoundError.d.ts +2 -1
  111. package/dist/api/resources/commons/errors/NotFoundError.js +2 -1
  112. package/dist/api/resources/commons/errors/ServerError.d.ts +2 -1
  113. package/dist/api/resources/commons/errors/ServerError.js +2 -1
  114. package/dist/api/resources/commons/types/AppUserRequest.d.ts +2 -2
  115. package/dist/api/resources/commons/types/AppUserResponse.d.ts +2 -2
  116. package/dist/api/resources/commons/types/ConversationResponse.d.ts +2 -1
  117. package/dist/api/resources/commons/types/InboxItemFixType.d.ts +14 -0
  118. package/{api/resources/realtime/types/AudioFormat.js → dist/api/resources/commons/types/InboxItemFixType.js} +4 -4
  119. package/dist/api/resources/commons/types/UserMessageAttachment.d.ts +16 -0
  120. package/dist/api/resources/commons/types/index.d.ts +1 -0
  121. package/dist/api/resources/commons/types/index.js +1 -0
  122. package/dist/api/resources/conversation/client/Client.d.ts +43 -58
  123. package/dist/api/resources/conversation/client/Client.js +342 -281
  124. package/dist/api/resources/conversation/client/index.d.ts +1 -0
  125. package/dist/api/resources/conversation/types/Attachment.d.ts +18 -1
  126. package/dist/api/resources/conversation/types/ConversationMessageRequest.d.ts +2 -0
  127. package/dist/api/resources/conversation/types/index.d.ts +0 -1
  128. package/dist/api/resources/conversation/types/index.js +0 -1
  129. package/dist/api/resources/events/client/Client.d.ts +5 -2
  130. package/dist/api/resources/events/client/Client.js +26 -16
  131. package/dist/api/resources/inbox/client/Client.d.ts +21 -10
  132. package/dist/api/resources/inbox/client/Client.js +126 -67
  133. package/dist/api/resources/inbox/client/index.d.ts +1 -0
  134. package/dist/api/resources/inbox/client/requests/InboxItemFixRequest.d.ts +7 -1
  135. package/dist/api/resources/inbox/client/requests/InboxItemIgnoreRequest.d.ts +7 -1
  136. package/dist/api/resources/inbox/client/requests/InboxItemRequest.d.ts +7 -1
  137. package/dist/api/resources/inbox/types/ApplyInboxItemFixRequest.d.ts +2 -0
  138. package/dist/api/resources/inbox/types/InboxSearchRequest.d.ts +4 -0
  139. package/dist/api/resources/index.d.ts +0 -2
  140. package/dist/api/resources/index.js +1 -3
  141. package/dist/api/resources/knowledge/client/Client.d.ts +17 -8
  142. package/dist/api/resources/knowledge/client/Client.js +168 -87
  143. package/dist/api/resources/organizations/client/Client.d.ts +7 -3
  144. package/dist/api/resources/organizations/client/Client.js +51 -28
  145. package/dist/api/resources/translations/client/Client.d.ts +5 -2
  146. package/dist/api/resources/translations/client/Client.js +26 -16
  147. package/dist/api/resources/triggers/client/Client.d.ts +13 -6
  148. package/dist/api/resources/triggers/client/Client.js +118 -63
  149. package/dist/api/resources/triggers/client/index.d.ts +1 -0
  150. package/dist/api/resources/users/client/Client.d.ts +11 -6
  151. package/dist/api/resources/users/client/Client.js +72 -43
  152. package/dist/api/resources/users/client/index.d.ts +1 -0
  153. package/dist/core/auth/BasicAuth.js +3 -3
  154. package/dist/core/base64.d.ts +2 -0
  155. package/dist/core/base64.js +26 -0
  156. package/dist/core/fetcher/APIResponse.d.ts +10 -0
  157. package/dist/core/fetcher/BinaryResponse.d.ts +20 -0
  158. package/dist/core/fetcher/BinaryResponse.js +17 -0
  159. package/dist/core/fetcher/Fetcher.d.ts +3 -2
  160. package/dist/core/fetcher/Fetcher.js +32 -12
  161. package/dist/core/fetcher/Headers.d.ts +2 -0
  162. package/dist/core/fetcher/Headers.js +84 -0
  163. package/dist/core/fetcher/HttpResponsePromise.d.ts +58 -0
  164. package/dist/core/fetcher/HttpResponsePromise.js +103 -0
  165. package/dist/core/fetcher/RawResponse.d.ts +29 -0
  166. package/dist/core/fetcher/RawResponse.js +44 -0
  167. package/dist/core/fetcher/ResponseWithBody.d.ts +4 -0
  168. package/dist/core/fetcher/ResponseWithBody.js +6 -0
  169. package/dist/core/fetcher/createRequestUrl.d.ts +1 -1
  170. package/dist/core/fetcher/createRequestUrl.js +3 -7
  171. package/dist/core/fetcher/getErrorResponseBody.d.ts +1 -0
  172. package/dist/core/fetcher/getErrorResponseBody.js +44 -0
  173. package/dist/core/fetcher/getFetchFn.d.ts +1 -4
  174. package/dist/core/fetcher/getFetchFn.js +1 -52
  175. package/dist/core/fetcher/getResponseBody.js +34 -33
  176. package/dist/core/fetcher/index.d.ts +4 -0
  177. package/dist/core/fetcher/index.js +7 -1
  178. package/dist/core/headers.d.ts +3 -0
  179. package/dist/core/headers.js +29 -0
  180. package/dist/core/index.d.ts +3 -2
  181. package/dist/core/index.js +4 -3
  182. package/dist/core/runtime/runtime.js +0 -1
  183. package/dist/core/{streaming-fetcher → stream}/Stream.d.ts +1 -2
  184. package/dist/core/url/index.d.ts +2 -0
  185. package/dist/core/url/index.js +7 -0
  186. package/dist/core/url/join.d.ts +1 -0
  187. package/dist/core/url/join.js +49 -0
  188. package/dist/core/url/qs.d.ts +6 -0
  189. package/dist/core/url/qs.js +64 -0
  190. package/dist/errors/MavenAGIError.d.ts +4 -1
  191. package/dist/errors/MavenAGIError.js +4 -7
  192. package/dist/index.d.ts +2 -2
  193. package/dist/index.js +5 -5
  194. package/dist/serialization/resources/commons/types/InboxItemFixType.d.ts +10 -0
  195. package/{serialization/resources/realtime/types/AudioFormat.js → dist/serialization/resources/commons/types/InboxItemFixType.js} +2 -2
  196. package/dist/serialization/resources/commons/types/UserMessageAttachment.d.ts +2 -0
  197. package/dist/serialization/resources/commons/types/UserMessageAttachment.js +2 -0
  198. package/dist/serialization/resources/commons/types/index.d.ts +1 -0
  199. package/dist/serialization/resources/commons/types/index.js +1 -0
  200. package/dist/serialization/resources/conversation/types/Attachment.d.ts +1 -0
  201. package/dist/serialization/resources/conversation/types/Attachment.js +1 -0
  202. package/dist/serialization/resources/conversation/types/ConversationMessageRequest.d.ts +2 -0
  203. package/dist/serialization/resources/conversation/types/ConversationMessageRequest.js +2 -0
  204. package/dist/serialization/resources/conversation/types/index.d.ts +0 -1
  205. package/dist/serialization/resources/conversation/types/index.js +0 -1
  206. package/dist/serialization/resources/inbox/types/ApplyInboxItemFixRequest.d.ts +2 -0
  207. package/dist/serialization/resources/inbox/types/ApplyInboxItemFixRequest.js +2 -0
  208. package/dist/serialization/resources/inbox/types/InboxSearchRequest.d.ts +2 -0
  209. package/dist/serialization/resources/inbox/types/InboxSearchRequest.js +2 -0
  210. package/dist/serialization/resources/index.d.ts +0 -2
  211. package/dist/serialization/resources/index.js +1 -3
  212. package/dist/version.d.ts +1 -1
  213. package/dist/version.js +1 -1
  214. package/errors/MavenAGIError.d.ts +4 -1
  215. package/errors/MavenAGIError.js +4 -7
  216. package/index.d.ts +2 -2
  217. package/index.js +5 -5
  218. package/jest.config.mjs +6 -1
  219. package/package.json +13 -21
  220. package/reference.md +16 -98
  221. package/scripts/rename-to-esm-files.js +10 -2
  222. package/serialization/resources/commons/types/InboxItemFixType.d.ts +10 -0
  223. package/{dist/serialization/resources/realtime/types/AudioFormat.js → serialization/resources/commons/types/InboxItemFixType.js} +2 -2
  224. package/serialization/resources/commons/types/UserMessageAttachment.d.ts +2 -0
  225. package/serialization/resources/commons/types/UserMessageAttachment.js +2 -0
  226. package/serialization/resources/commons/types/index.d.ts +1 -0
  227. package/serialization/resources/commons/types/index.js +1 -0
  228. package/serialization/resources/conversation/types/Attachment.d.ts +1 -0
  229. package/serialization/resources/conversation/types/Attachment.js +1 -0
  230. package/serialization/resources/conversation/types/ConversationMessageRequest.d.ts +2 -0
  231. package/serialization/resources/conversation/types/ConversationMessageRequest.js +2 -0
  232. package/serialization/resources/conversation/types/index.d.ts +0 -1
  233. package/serialization/resources/conversation/types/index.js +0 -1
  234. package/serialization/resources/inbox/types/ApplyInboxItemFixRequest.d.ts +2 -0
  235. package/serialization/resources/inbox/types/ApplyInboxItemFixRequest.js +2 -0
  236. package/serialization/resources/inbox/types/InboxSearchRequest.d.ts +2 -0
  237. package/serialization/resources/inbox/types/InboxSearchRequest.js +2 -0
  238. package/serialization/resources/index.d.ts +0 -2
  239. package/serialization/resources/index.js +1 -3
  240. package/version.d.ts +1 -1
  241. package/version.js +1 -1
  242. package/api/resources/conversation/types/GenerateObjectRequest.d.ts +0 -8
  243. package/api/resources/conversation/types/GenerateObjectRequest.js +0 -5
  244. package/api/resources/realtime/client/Client.d.ts +0 -36
  245. package/api/resources/realtime/client/Client.js +0 -90
  246. package/api/resources/realtime/client/Socket.d.ts +0 -41
  247. package/api/resources/realtime/client/Socket.js +0 -155
  248. package/api/resources/realtime/client/index.d.ts +0 -1
  249. package/api/resources/realtime/client/index.js +0 -2
  250. package/api/resources/realtime/index.d.ts +0 -2
  251. package/api/resources/realtime/index.js +0 -18
  252. package/api/resources/realtime/types/AudioFormat.d.ts +0 -8
  253. package/api/resources/realtime/types/AudioPublishEvent.d.ts +0 -6
  254. package/api/resources/realtime/types/AudioPublishEvent.js +0 -5
  255. package/api/resources/realtime/types/AudioSubscribeEvent.d.ts +0 -6
  256. package/api/resources/realtime/types/AudioSubscribeEvent.js +0 -5
  257. package/api/resources/realtime/types/ControlEvent.d.ts +0 -9
  258. package/api/resources/realtime/types/ControlEvent.js +0 -5
  259. package/api/resources/realtime/types/HangUpPublishEvent.d.ts +0 -6
  260. package/api/resources/realtime/types/HangUpPublishEvent.js +0 -5
  261. package/api/resources/realtime/types/MessageBase.d.ts +0 -6
  262. package/api/resources/realtime/types/MessageBase.js +0 -5
  263. package/api/resources/realtime/types/PublishEvent.d.ts +0 -16
  264. package/api/resources/realtime/types/PublishEvent.js +0 -5
  265. package/api/resources/realtime/types/SubscribeEvent.d.ts +0 -25
  266. package/api/resources/realtime/types/SubscribeEvent.js +0 -5
  267. package/api/resources/realtime/types/index.d.ts +0 -8
  268. package/api/resources/realtime/types/index.js +0 -24
  269. package/core/fetcher/stream-wrappers/Node18UniversalStreamWrapper.d.ts +0 -30
  270. package/core/fetcher/stream-wrappers/Node18UniversalStreamWrapper.js +0 -247
  271. package/core/fetcher/stream-wrappers/NodePre18StreamWrapper.d.ts +0 -21
  272. package/core/fetcher/stream-wrappers/NodePre18StreamWrapper.js +0 -126
  273. package/core/fetcher/stream-wrappers/UndiciStreamWrapper.d.ts +0 -31
  274. package/core/fetcher/stream-wrappers/UndiciStreamWrapper.js +0 -229
  275. package/core/fetcher/stream-wrappers/chooseStreamWrapper.d.ts +0 -18
  276. package/core/fetcher/stream-wrappers/chooseStreamWrapper.js +0 -59
  277. package/core/websocket/events.d.ts +0 -36
  278. package/core/websocket/events.js +0 -27
  279. package/core/websocket/index.d.ts +0 -1
  280. package/core/websocket/index.js +0 -17
  281. package/core/websocket/ws.d.ts +0 -137
  282. package/core/websocket/ws.js +0 -452
  283. package/dist/api/resources/conversation/types/GenerateObjectRequest.d.ts +0 -8
  284. package/dist/api/resources/conversation/types/GenerateObjectRequest.js +0 -5
  285. package/dist/api/resources/realtime/client/Client.d.ts +0 -36
  286. package/dist/api/resources/realtime/client/Client.js +0 -90
  287. package/dist/api/resources/realtime/client/Socket.d.ts +0 -41
  288. package/dist/api/resources/realtime/client/Socket.js +0 -155
  289. package/dist/api/resources/realtime/client/index.d.ts +0 -1
  290. package/dist/api/resources/realtime/client/index.js +0 -2
  291. package/dist/api/resources/realtime/index.d.ts +0 -2
  292. package/dist/api/resources/realtime/index.js +0 -18
  293. package/dist/api/resources/realtime/types/AudioFormat.d.ts +0 -8
  294. package/dist/api/resources/realtime/types/AudioPublishEvent.d.ts +0 -6
  295. package/dist/api/resources/realtime/types/AudioPublishEvent.js +0 -5
  296. package/dist/api/resources/realtime/types/AudioSubscribeEvent.d.ts +0 -6
  297. package/dist/api/resources/realtime/types/AudioSubscribeEvent.js +0 -5
  298. package/dist/api/resources/realtime/types/ControlEvent.d.ts +0 -9
  299. package/dist/api/resources/realtime/types/ControlEvent.js +0 -5
  300. package/dist/api/resources/realtime/types/HangUpPublishEvent.d.ts +0 -6
  301. package/dist/api/resources/realtime/types/HangUpPublishEvent.js +0 -5
  302. package/dist/api/resources/realtime/types/MessageBase.d.ts +0 -6
  303. package/dist/api/resources/realtime/types/MessageBase.js +0 -5
  304. package/dist/api/resources/realtime/types/PublishEvent.d.ts +0 -16
  305. package/dist/api/resources/realtime/types/PublishEvent.js +0 -5
  306. package/dist/api/resources/realtime/types/SubscribeEvent.d.ts +0 -25
  307. package/dist/api/resources/realtime/types/SubscribeEvent.js +0 -5
  308. package/dist/api/resources/realtime/types/index.d.ts +0 -8
  309. package/dist/api/resources/realtime/types/index.js +0 -24
  310. package/dist/core/fetcher/stream-wrappers/Node18UniversalStreamWrapper.d.ts +0 -30
  311. package/dist/core/fetcher/stream-wrappers/Node18UniversalStreamWrapper.js +0 -247
  312. package/dist/core/fetcher/stream-wrappers/NodePre18StreamWrapper.d.ts +0 -21
  313. package/dist/core/fetcher/stream-wrappers/NodePre18StreamWrapper.js +0 -126
  314. package/dist/core/fetcher/stream-wrappers/UndiciStreamWrapper.d.ts +0 -31
  315. package/dist/core/fetcher/stream-wrappers/UndiciStreamWrapper.js +0 -229
  316. package/dist/core/fetcher/stream-wrappers/chooseStreamWrapper.d.ts +0 -18
  317. package/dist/core/fetcher/stream-wrappers/chooseStreamWrapper.js +0 -59
  318. package/dist/core/websocket/events.d.ts +0 -36
  319. package/dist/core/websocket/events.js +0 -27
  320. package/dist/core/websocket/index.d.ts +0 -1
  321. package/dist/core/websocket/index.js +0 -17
  322. package/dist/core/websocket/ws.d.ts +0 -137
  323. package/dist/core/websocket/ws.js +0 -452
  324. package/dist/serialization/resources/conversation/types/GenerateObjectRequest.d.ts +0 -13
  325. package/dist/serialization/resources/conversation/types/GenerateObjectRequest.js +0 -46
  326. package/dist/serialization/resources/realtime/index.d.ts +0 -1
  327. package/dist/serialization/resources/realtime/index.js +0 -17
  328. package/dist/serialization/resources/realtime/types/AudioFormat.d.ts +0 -10
  329. package/dist/serialization/resources/realtime/types/AudioPublishEvent.d.ts +0 -12
  330. package/dist/serialization/resources/realtime/types/AudioPublishEvent.js +0 -43
  331. package/dist/serialization/resources/realtime/types/AudioSubscribeEvent.d.ts +0 -12
  332. package/dist/serialization/resources/realtime/types/AudioSubscribeEvent.js +0 -43
  333. package/dist/serialization/resources/realtime/types/ControlEvent.d.ts +0 -15
  334. package/dist/serialization/resources/realtime/types/ControlEvent.js +0 -48
  335. package/dist/serialization/resources/realtime/types/HangUpPublishEvent.d.ts +0 -12
  336. package/dist/serialization/resources/realtime/types/HangUpPublishEvent.js +0 -43
  337. package/dist/serialization/resources/realtime/types/MessageBase.d.ts +0 -12
  338. package/dist/serialization/resources/realtime/types/MessageBase.js +0 -43
  339. package/dist/serialization/resources/realtime/types/PublishEvent.d.ts +0 -18
  340. package/dist/serialization/resources/realtime/types/PublishEvent.js +0 -51
  341. package/dist/serialization/resources/realtime/types/SubscribeEvent.d.ts +0 -27
  342. package/dist/serialization/resources/realtime/types/SubscribeEvent.js +0 -54
  343. package/dist/serialization/resources/realtime/types/index.d.ts +0 -8
  344. package/dist/serialization/resources/realtime/types/index.js +0 -24
  345. package/serialization/resources/conversation/types/GenerateObjectRequest.d.ts +0 -13
  346. package/serialization/resources/conversation/types/GenerateObjectRequest.js +0 -46
  347. package/serialization/resources/realtime/index.d.ts +0 -1
  348. package/serialization/resources/realtime/index.js +0 -17
  349. package/serialization/resources/realtime/types/AudioFormat.d.ts +0 -10
  350. package/serialization/resources/realtime/types/AudioPublishEvent.d.ts +0 -12
  351. package/serialization/resources/realtime/types/AudioPublishEvent.js +0 -43
  352. package/serialization/resources/realtime/types/AudioSubscribeEvent.d.ts +0 -12
  353. package/serialization/resources/realtime/types/AudioSubscribeEvent.js +0 -43
  354. package/serialization/resources/realtime/types/ControlEvent.d.ts +0 -15
  355. package/serialization/resources/realtime/types/ControlEvent.js +0 -48
  356. package/serialization/resources/realtime/types/HangUpPublishEvent.d.ts +0 -12
  357. package/serialization/resources/realtime/types/HangUpPublishEvent.js +0 -43
  358. package/serialization/resources/realtime/types/MessageBase.d.ts +0 -12
  359. package/serialization/resources/realtime/types/MessageBase.js +0 -43
  360. package/serialization/resources/realtime/types/PublishEvent.d.ts +0 -18
  361. package/serialization/resources/realtime/types/PublishEvent.js +0 -51
  362. package/serialization/resources/realtime/types/SubscribeEvent.d.ts +0 -27
  363. package/serialization/resources/realtime/types/SubscribeEvent.js +0 -54
  364. package/serialization/resources/realtime/types/index.d.ts +0 -8
  365. package/serialization/resources/realtime/types/index.js +0 -24
  366. /package/core/{streaming-fetcher → stream}/Stream.js +0 -0
  367. /package/core/{streaming-fetcher → stream}/index.d.ts +0 -0
  368. /package/core/{streaming-fetcher → stream}/index.js +0 -0
  369. /package/dist/core/{streaming-fetcher → stream}/Stream.js +0 -0
  370. /package/dist/core/{streaming-fetcher → stream}/index.d.ts +0 -0
  371. /package/dist/core/{streaming-fetcher → stream}/index.js +0 -0
@@ -44,16 +44,13 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
44
44
  step((generator = generator.apply(thisArg, _arguments || [])).next());
45
45
  });
46
46
  };
47
- var __importDefault = (this && this.__importDefault) || function (mod) {
48
- return (mod && mod.__esModule) ? mod : { "default": mod };
49
- };
50
47
  Object.defineProperty(exports, "__esModule", { value: true });
51
48
  exports.Users = void 0;
52
49
  const environments = __importStar(require("../../../../environments"));
53
50
  const core = __importStar(require("../../../../core"));
54
51
  const MavenAGI = __importStar(require("../../../index"));
52
+ const headers_1 = require("../../../../core/headers");
55
53
  const serializers = __importStar(require("../../../../serialization/index"));
56
- const url_join_1 = __importDefault(require("url-join"));
57
54
  const errors = __importStar(require("../../../../errors/index"));
58
55
  class Users {
59
56
  constructor(_options) {
@@ -74,10 +71,10 @@ class Users {
74
71
  * userId: {
75
72
  * referenceId: "user-0"
76
73
  * },
77
- * identifiers: new Set([{
74
+ * identifiers: [{
78
75
  * value: "joe@myapp.com",
79
76
  * type: "EMAIL"
80
- * }]),
77
+ * }],
81
78
  * data: {
82
79
  * "name": {
83
80
  * value: "Joe",
@@ -87,12 +84,19 @@ class Users {
87
84
  * })
88
85
  */
89
86
  createOrUpdate(request, requestOptions) {
87
+ return core.HttpResponsePromise.fromPromise(this.__createOrUpdate(request, requestOptions));
88
+ }
89
+ __createOrUpdate(request, requestOptions) {
90
90
  return __awaiter(this, void 0, void 0, function* () {
91
- var _a, _b, _c;
91
+ var _a, _b, _c, _d;
92
92
  const _response = yield ((_a = this._options.fetcher) !== null && _a !== void 0 ? _a : core.fetcher)({
93
- url: (0, url_join_1.default)((_c = (_b = (yield core.Supplier.get(this._options.baseUrl))) !== null && _b !== void 0 ? _b : (yield core.Supplier.get(this._options.environment))) !== null && _c !== void 0 ? _c : environments.MavenAGIEnvironment.Production, "/v1/users"),
93
+ url: core.url.join((_c = (_b = (yield core.Supplier.get(this._options.baseUrl))) !== null && _b !== void 0 ? _b : (yield core.Supplier.get(this._options.environment))) !== null && _c !== void 0 ? _c : environments.MavenAGIEnvironment.Production, "/v1/users"),
94
94
  method: "PUT",
95
- headers: Object.assign({ Authorization: yield this._getAuthorizationHeader(), "X-Organization-Id": yield core.Supplier.get(this._options.organizationId), "X-Agent-Id": yield core.Supplier.get(this._options.agentId), "X-Fern-Language": "JavaScript", "X-Fern-SDK-Name": "mavenagi", "X-Fern-SDK-Version": "1.0.15", "User-Agent": "mavenagi/1.0.15", "X-Fern-Runtime": core.RUNTIME.type, "X-Fern-Runtime-Version": core.RUNTIME.version }, requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.headers),
95
+ headers: (0, headers_1.mergeHeaders)((_d = this._options) === null || _d === void 0 ? void 0 : _d.headers, (0, headers_1.mergeOnlyDefinedHeaders)({
96
+ Authorization: yield this._getAuthorizationHeader(),
97
+ "X-Organization-Id": requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.organizationId,
98
+ "X-Agent-Id": requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.agentId,
99
+ }), requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.headers),
96
100
  contentType: "application/json",
97
101
  requestType: "json",
98
102
  body: serializers.AppUserRequest.jsonOrThrow(request, { unrecognizedObjectKeys: "strip" }),
@@ -101,12 +105,15 @@ class Users {
101
105
  abortSignal: requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.abortSignal,
102
106
  });
103
107
  if (_response.ok) {
104
- return serializers.AppUserResponse.parseOrThrow(_response.body, {
105
- unrecognizedObjectKeys: "passthrough",
106
- allowUnrecognizedUnionMembers: true,
107
- allowUnrecognizedEnumValues: true,
108
- breadcrumbsPrefix: ["response"],
109
- });
108
+ return {
109
+ data: serializers.AppUserResponse.parseOrThrow(_response.body, {
110
+ unrecognizedObjectKeys: "passthrough",
111
+ allowUnrecognizedUnionMembers: true,
112
+ allowUnrecognizedEnumValues: true,
113
+ breadcrumbsPrefix: ["response"],
114
+ }),
115
+ rawResponse: _response.rawResponse,
116
+ };
110
117
  }
111
118
  if (_response.error.reason === "status-code") {
112
119
  switch (_response.error.statusCode) {
@@ -116,25 +123,26 @@ class Users {
116
123
  allowUnrecognizedUnionMembers: true,
117
124
  allowUnrecognizedEnumValues: true,
118
125
  breadcrumbsPrefix: ["response"],
119
- }));
126
+ }), _response.rawResponse);
120
127
  case 400:
121
128
  throw new MavenAGI.BadRequestError(serializers.ErrorMessage.parseOrThrow(_response.error.body, {
122
129
  unrecognizedObjectKeys: "passthrough",
123
130
  allowUnrecognizedUnionMembers: true,
124
131
  allowUnrecognizedEnumValues: true,
125
132
  breadcrumbsPrefix: ["response"],
126
- }));
133
+ }), _response.rawResponse);
127
134
  case 500:
128
135
  throw new MavenAGI.ServerError(serializers.ErrorMessage.parseOrThrow(_response.error.body, {
129
136
  unrecognizedObjectKeys: "passthrough",
130
137
  allowUnrecognizedUnionMembers: true,
131
138
  allowUnrecognizedEnumValues: true,
132
139
  breadcrumbsPrefix: ["response"],
133
- }));
140
+ }), _response.rawResponse);
134
141
  default:
135
142
  throw new errors.MavenAGIError({
136
143
  statusCode: _response.error.statusCode,
137
144
  body: _response.error.body,
145
+ rawResponse: _response.rawResponse,
138
146
  });
139
147
  }
140
148
  }
@@ -143,12 +151,14 @@ class Users {
143
151
  throw new errors.MavenAGIError({
144
152
  statusCode: _response.error.statusCode,
145
153
  body: _response.error.rawBody,
154
+ rawResponse: _response.rawResponse,
146
155
  });
147
156
  case "timeout":
148
157
  throw new errors.MavenAGITimeoutError("Timeout exceeded when calling PUT /v1/users.");
149
158
  case "unknown":
150
159
  throw new errors.MavenAGIError({
151
160
  message: _response.error.errorMessage,
161
+ rawResponse: _response.rawResponse,
152
162
  });
153
163
  }
154
164
  });
@@ -167,32 +177,40 @@ class Users {
167
177
  * @example
168
178
  * await client.users.get("user-0")
169
179
  */
170
- get(userId_1) {
180
+ get(userId, request = {}, requestOptions) {
181
+ return core.HttpResponsePromise.fromPromise(this.__get(userId, request, requestOptions));
182
+ }
183
+ __get(userId_1) {
171
184
  return __awaiter(this, arguments, void 0, function* (userId, request = {}, requestOptions) {
172
- var _a, _b, _c;
185
+ var _a, _b, _c, _d;
173
186
  const { appId } = request;
174
187
  const _queryParams = {};
175
188
  if (appId != null) {
176
189
  _queryParams["appId"] = appId;
177
190
  }
178
191
  const _response = yield ((_a = this._options.fetcher) !== null && _a !== void 0 ? _a : core.fetcher)({
179
- url: (0, url_join_1.default)((_c = (_b = (yield core.Supplier.get(this._options.baseUrl))) !== null && _b !== void 0 ? _b : (yield core.Supplier.get(this._options.environment))) !== null && _c !== void 0 ? _c : environments.MavenAGIEnvironment.Production, `/v1/users/${encodeURIComponent(userId)}`),
192
+ url: core.url.join((_c = (_b = (yield core.Supplier.get(this._options.baseUrl))) !== null && _b !== void 0 ? _b : (yield core.Supplier.get(this._options.environment))) !== null && _c !== void 0 ? _c : environments.MavenAGIEnvironment.Production, `/v1/users/${encodeURIComponent(userId)}`),
180
193
  method: "GET",
181
- headers: Object.assign({ Authorization: yield this._getAuthorizationHeader(), "X-Organization-Id": yield core.Supplier.get(this._options.organizationId), "X-Agent-Id": yield core.Supplier.get(this._options.agentId), "X-Fern-Language": "JavaScript", "X-Fern-SDK-Name": "mavenagi", "X-Fern-SDK-Version": "1.0.15", "User-Agent": "mavenagi/1.0.15", "X-Fern-Runtime": core.RUNTIME.type, "X-Fern-Runtime-Version": core.RUNTIME.version }, requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.headers),
182
- contentType: "application/json",
194
+ headers: (0, headers_1.mergeHeaders)((_d = this._options) === null || _d === void 0 ? void 0 : _d.headers, (0, headers_1.mergeOnlyDefinedHeaders)({
195
+ Authorization: yield this._getAuthorizationHeader(),
196
+ "X-Organization-Id": requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.organizationId,
197
+ "X-Agent-Id": requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.agentId,
198
+ }), requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.headers),
183
199
  queryParameters: _queryParams,
184
- requestType: "json",
185
200
  timeoutMs: (requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.timeoutInSeconds) != null ? requestOptions.timeoutInSeconds * 1000 : 60000,
186
201
  maxRetries: requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.maxRetries,
187
202
  abortSignal: requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.abortSignal,
188
203
  });
189
204
  if (_response.ok) {
190
- return serializers.AppUserResponse.parseOrThrow(_response.body, {
191
- unrecognizedObjectKeys: "passthrough",
192
- allowUnrecognizedUnionMembers: true,
193
- allowUnrecognizedEnumValues: true,
194
- breadcrumbsPrefix: ["response"],
195
- });
205
+ return {
206
+ data: serializers.AppUserResponse.parseOrThrow(_response.body, {
207
+ unrecognizedObjectKeys: "passthrough",
208
+ allowUnrecognizedUnionMembers: true,
209
+ allowUnrecognizedEnumValues: true,
210
+ breadcrumbsPrefix: ["response"],
211
+ }),
212
+ rawResponse: _response.rawResponse,
213
+ };
196
214
  }
197
215
  if (_response.error.reason === "status-code") {
198
216
  switch (_response.error.statusCode) {
@@ -202,25 +220,26 @@ class Users {
202
220
  allowUnrecognizedUnionMembers: true,
203
221
  allowUnrecognizedEnumValues: true,
204
222
  breadcrumbsPrefix: ["response"],
205
- }));
223
+ }), _response.rawResponse);
206
224
  case 400:
207
225
  throw new MavenAGI.BadRequestError(serializers.ErrorMessage.parseOrThrow(_response.error.body, {
208
226
  unrecognizedObjectKeys: "passthrough",
209
227
  allowUnrecognizedUnionMembers: true,
210
228
  allowUnrecognizedEnumValues: true,
211
229
  breadcrumbsPrefix: ["response"],
212
- }));
230
+ }), _response.rawResponse);
213
231
  case 500:
214
232
  throw new MavenAGI.ServerError(serializers.ErrorMessage.parseOrThrow(_response.error.body, {
215
233
  unrecognizedObjectKeys: "passthrough",
216
234
  allowUnrecognizedUnionMembers: true,
217
235
  allowUnrecognizedEnumValues: true,
218
236
  breadcrumbsPrefix: ["response"],
219
- }));
237
+ }), _response.rawResponse);
220
238
  default:
221
239
  throw new errors.MavenAGIError({
222
240
  statusCode: _response.error.statusCode,
223
241
  body: _response.error.body,
242
+ rawResponse: _response.rawResponse,
224
243
  });
225
244
  }
226
245
  }
@@ -229,12 +248,14 @@ class Users {
229
248
  throw new errors.MavenAGIError({
230
249
  statusCode: _response.error.statusCode,
231
250
  body: _response.error.rawBody,
251
+ rawResponse: _response.rawResponse,
232
252
  });
233
253
  case "timeout":
234
254
  throw new errors.MavenAGITimeoutError("Timeout exceeded when calling GET /v1/users/{userId}.");
235
255
  case "unknown":
236
256
  throw new errors.MavenAGIError({
237
257
  message: _response.error.errorMessage,
258
+ rawResponse: _response.rawResponse,
238
259
  });
239
260
  }
240
261
  });
@@ -258,27 +279,32 @@ class Users {
258
279
  * @example
259
280
  * await client.users.delete("user-0")
260
281
  */
261
- delete(userId_1) {
282
+ delete(userId, request = {}, requestOptions) {
283
+ return core.HttpResponsePromise.fromPromise(this.__delete(userId, request, requestOptions));
284
+ }
285
+ __delete(userId_1) {
262
286
  return __awaiter(this, arguments, void 0, function* (userId, request = {}, requestOptions) {
263
- var _a, _b, _c;
287
+ var _a, _b, _c, _d;
264
288
  const { appId } = request;
265
289
  const _queryParams = {};
266
290
  if (appId != null) {
267
291
  _queryParams["appId"] = appId;
268
292
  }
269
293
  const _response = yield ((_a = this._options.fetcher) !== null && _a !== void 0 ? _a : core.fetcher)({
270
- url: (0, url_join_1.default)((_c = (_b = (yield core.Supplier.get(this._options.baseUrl))) !== null && _b !== void 0 ? _b : (yield core.Supplier.get(this._options.environment))) !== null && _c !== void 0 ? _c : environments.MavenAGIEnvironment.Production, `/v1/users/${encodeURIComponent(userId)}`),
294
+ url: core.url.join((_c = (_b = (yield core.Supplier.get(this._options.baseUrl))) !== null && _b !== void 0 ? _b : (yield core.Supplier.get(this._options.environment))) !== null && _c !== void 0 ? _c : environments.MavenAGIEnvironment.Production, `/v1/users/${encodeURIComponent(userId)}`),
271
295
  method: "DELETE",
272
- headers: Object.assign({ Authorization: yield this._getAuthorizationHeader(), "X-Organization-Id": yield core.Supplier.get(this._options.organizationId), "X-Agent-Id": yield core.Supplier.get(this._options.agentId), "X-Fern-Language": "JavaScript", "X-Fern-SDK-Name": "mavenagi", "X-Fern-SDK-Version": "1.0.15", "User-Agent": "mavenagi/1.0.15", "X-Fern-Runtime": core.RUNTIME.type, "X-Fern-Runtime-Version": core.RUNTIME.version }, requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.headers),
273
- contentType: "application/json",
296
+ headers: (0, headers_1.mergeHeaders)((_d = this._options) === null || _d === void 0 ? void 0 : _d.headers, (0, headers_1.mergeOnlyDefinedHeaders)({
297
+ Authorization: yield this._getAuthorizationHeader(),
298
+ "X-Organization-Id": requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.organizationId,
299
+ "X-Agent-Id": requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.agentId,
300
+ }), requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.headers),
274
301
  queryParameters: _queryParams,
275
- requestType: "json",
276
302
  timeoutMs: (requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.timeoutInSeconds) != null ? requestOptions.timeoutInSeconds * 1000 : 60000,
277
303
  maxRetries: requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.maxRetries,
278
304
  abortSignal: requestOptions === null || requestOptions === void 0 ? void 0 : requestOptions.abortSignal,
279
305
  });
280
306
  if (_response.ok) {
281
- return;
307
+ return { data: undefined, rawResponse: _response.rawResponse };
282
308
  }
283
309
  if (_response.error.reason === "status-code") {
284
310
  switch (_response.error.statusCode) {
@@ -288,25 +314,26 @@ class Users {
288
314
  allowUnrecognizedUnionMembers: true,
289
315
  allowUnrecognizedEnumValues: true,
290
316
  breadcrumbsPrefix: ["response"],
291
- }));
317
+ }), _response.rawResponse);
292
318
  case 400:
293
319
  throw new MavenAGI.BadRequestError(serializers.ErrorMessage.parseOrThrow(_response.error.body, {
294
320
  unrecognizedObjectKeys: "passthrough",
295
321
  allowUnrecognizedUnionMembers: true,
296
322
  allowUnrecognizedEnumValues: true,
297
323
  breadcrumbsPrefix: ["response"],
298
- }));
324
+ }), _response.rawResponse);
299
325
  case 500:
300
326
  throw new MavenAGI.ServerError(serializers.ErrorMessage.parseOrThrow(_response.error.body, {
301
327
  unrecognizedObjectKeys: "passthrough",
302
328
  allowUnrecognizedUnionMembers: true,
303
329
  allowUnrecognizedEnumValues: true,
304
330
  breadcrumbsPrefix: ["response"],
305
- }));
331
+ }), _response.rawResponse);
306
332
  default:
307
333
  throw new errors.MavenAGIError({
308
334
  statusCode: _response.error.statusCode,
309
335
  body: _response.error.body,
336
+ rawResponse: _response.rawResponse,
310
337
  });
311
338
  }
312
339
  }
@@ -315,12 +342,14 @@ class Users {
315
342
  throw new errors.MavenAGIError({
316
343
  statusCode: _response.error.statusCode,
317
344
  body: _response.error.rawBody,
345
+ rawResponse: _response.rawResponse,
318
346
  });
319
347
  case "timeout":
320
348
  throw new errors.MavenAGITimeoutError("Timeout exceeded when calling DELETE /v1/users/{userId}.");
321
349
  case "unknown":
322
350
  throw new errors.MavenAGIError({
323
351
  message: _response.error.errorMessage,
352
+ rawResponse: _response.rawResponse,
324
353
  });
325
354
  }
326
355
  });
@@ -1 +1,2 @@
1
+ export {};
1
2
  export * from "./requests";
@@ -1,19 +1,19 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.BasicAuth = void 0;
4
- const js_base64_1 = require("js-base64");
4
+ const base64_1 = require("../base64");
5
5
  const BASIC_AUTH_HEADER_PREFIX = /^Basic /i;
6
6
  exports.BasicAuth = {
7
7
  toAuthorizationHeader: (basicAuth) => {
8
8
  if (basicAuth == null) {
9
9
  return undefined;
10
10
  }
11
- const token = js_base64_1.Base64.encode(`${basicAuth.username}:${basicAuth.password}`);
11
+ const token = (0, base64_1.base64Encode)(`${basicAuth.username}:${basicAuth.password}`);
12
12
  return `Basic ${token}`;
13
13
  },
14
14
  fromAuthorizationHeader: (header) => {
15
15
  const credentials = header.replace(BASIC_AUTH_HEADER_PREFIX, "");
16
- const decoded = js_base64_1.Base64.decode(credentials);
16
+ const decoded = (0, base64_1.base64Decode)(credentials);
17
17
  const [username, password] = decoded.split(":", 2);
18
18
  if (username == null || password == null) {
19
19
  throw new Error("Invalid basic auth");
@@ -0,0 +1,2 @@
1
+ export declare function base64Encode(input: string): string;
2
+ export declare function base64Decode(input: string): string;
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.base64Encode = base64Encode;
4
+ exports.base64Decode = base64Decode;
5
+ function base64ToBytes(base64) {
6
+ const binString = atob(base64);
7
+ return Uint8Array.from(binString, (m) => m.codePointAt(0));
8
+ }
9
+ function bytesToBase64(bytes) {
10
+ const binString = String.fromCodePoint(...bytes);
11
+ return btoa(binString);
12
+ }
13
+ function base64Encode(input) {
14
+ if (typeof Buffer !== "undefined") {
15
+ return Buffer.from(input, "utf8").toString("base64");
16
+ }
17
+ const bytes = new TextEncoder().encode(input);
18
+ return bytesToBase64(bytes);
19
+ }
20
+ function base64Decode(input) {
21
+ if (typeof Buffer !== "undefined") {
22
+ return Buffer.from(input, "base64").toString("utf8");
23
+ }
24
+ const bytes = base64ToBytes(input);
25
+ return new TextDecoder().decode(bytes);
26
+ }
@@ -1,10 +1,20 @@
1
+ import { RawResponse } from "./RawResponse";
2
+ /**
3
+ * The response of an API call.
4
+ * It is a successful response or a failed response.
5
+ */
1
6
  export type APIResponse<Success, Failure> = SuccessfulResponse<Success> | FailedResponse<Failure>;
2
7
  export interface SuccessfulResponse<T> {
3
8
  ok: true;
4
9
  body: T;
10
+ /**
11
+ * @deprecated Use `rawResponse` instead
12
+ */
5
13
  headers?: Record<string, any>;
14
+ rawResponse: RawResponse;
6
15
  }
7
16
  export interface FailedResponse<T> {
8
17
  ok: false;
9
18
  error: T;
19
+ rawResponse: RawResponse;
10
20
  }
@@ -0,0 +1,20 @@
1
+ import { ResponseWithBody } from "./ResponseWithBody.js";
2
+ export type BinaryResponse = {
3
+ /** [MDN Reference](https://developer.mozilla.org/docs/Web/API/Request/bodyUsed) */
4
+ bodyUsed: boolean;
5
+ /**
6
+ * Returns a ReadableStream of the response body.
7
+ * [MDN Reference](https://developer.mozilla.org/docs/Web/API/Request/body)
8
+ */
9
+ stream: () => ReadableStream<Uint8Array>;
10
+ /** [MDN Reference](https://developer.mozilla.org/docs/Web/API/Request/arrayBuffer) */
11
+ arrayBuffer: () => Promise<ArrayBuffer>;
12
+ /** [MDN Reference](https://developer.mozilla.org/docs/Web/API/Request/blob) */
13
+ blob: () => Promise<Blob>;
14
+ /**
15
+ * [MDN Reference](https://developer.mozilla.org/docs/Web/API/Request/bytes)
16
+ * Some versions of the Fetch API may not support this method.
17
+ */
18
+ bytes?(): Promise<Uint8Array>;
19
+ };
20
+ export declare function getBinaryResponse(response: ResponseWithBody): BinaryResponse;
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getBinaryResponse = getBinaryResponse;
4
+ function getBinaryResponse(response) {
5
+ const binaryResponse = {
6
+ get bodyUsed() {
7
+ return response.bodyUsed;
8
+ },
9
+ stream: () => response.body,
10
+ arrayBuffer: response.arrayBuffer.bind(response),
11
+ blob: response.blob.bind(response),
12
+ };
13
+ if ("bytes" in response && typeof response.bytes === "function") {
14
+ binaryResponse.bytes = response.bytes.bind(response);
15
+ }
16
+ return binaryResponse;
17
+ }
@@ -1,11 +1,12 @@
1
1
  import { APIResponse } from "./APIResponse";
2
+ import { Supplier } from "./Supplier";
2
3
  export type FetchFunction = <R = unknown>(args: Fetcher.Args) => Promise<APIResponse<R, Fetcher.Error>>;
3
4
  export declare namespace Fetcher {
4
5
  interface Args {
5
6
  url: string;
6
7
  method: string;
7
8
  contentType?: string;
8
- headers?: Record<string, string | undefined>;
9
+ headers?: Record<string, string | Supplier<string | undefined> | undefined>;
9
10
  queryParameters?: Record<string, string | string[] | object | object[] | null>;
10
11
  body?: unknown;
11
12
  timeoutMs?: number;
@@ -13,7 +14,7 @@ export declare namespace Fetcher {
13
14
  withCredentials?: boolean;
14
15
  abortSignal?: AbortSignal;
15
16
  requestType?: "json" | "file" | "bytes";
16
- responseType?: "json" | "blob" | "sse" | "streaming" | "text" | "arrayBuffer";
17
+ responseType?: "json" | "blob" | "sse" | "streaming" | "text" | "arrayBuffer" | "binary-response";
17
18
  duplex?: "half";
18
19
  }
19
20
  type Error = FailedStatusCodeError | NonJsonError | TimeoutError | UnknownError;
@@ -12,25 +12,40 @@ Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.fetcher = void 0;
13
13
  exports.fetcherImpl = fetcherImpl;
14
14
  const json_1 = require("../json");
15
+ const RawResponse_1 = require("./RawResponse");
16
+ const Supplier_1 = require("./Supplier");
15
17
  const createRequestUrl_1 = require("./createRequestUrl");
18
+ const getErrorResponseBody_1 = require("./getErrorResponseBody");
16
19
  const getFetchFn_1 = require("./getFetchFn");
17
20
  const getRequestBody_1 = require("./getRequestBody");
18
21
  const getResponseBody_1 = require("./getResponseBody");
19
22
  const makeRequest_1 = require("./makeRequest");
20
23
  const requestWithRetries_1 = require("./requestWithRetries");
21
- function fetcherImpl(args) {
24
+ function getHeaders(args) {
22
25
  return __awaiter(this, void 0, void 0, function* () {
23
- const headers = {};
26
+ const newHeaders = {};
24
27
  if (args.body !== undefined && args.contentType != null) {
25
- headers["Content-Type"] = args.contentType;
28
+ newHeaders["Content-Type"] = args.contentType;
29
+ }
30
+ if (args.headers == null) {
31
+ return newHeaders;
26
32
  }
27
- if (args.headers != null) {
28
- for (const [key, value] of Object.entries(args.headers)) {
29
- if (value != null) {
30
- headers[key] = value;
31
- }
33
+ for (const [key, value] of Object.entries(args.headers)) {
34
+ const result = yield Supplier_1.Supplier.get(value);
35
+ if (typeof result === "string") {
36
+ newHeaders[key] = result;
37
+ continue;
32
38
  }
39
+ if (result == null) {
40
+ continue;
41
+ }
42
+ newHeaders[key] = `${result}`;
33
43
  }
44
+ return newHeaders;
45
+ });
46
+ }
47
+ function fetcherImpl(args) {
48
+ return __awaiter(this, void 0, void 0, function* () {
34
49
  const url = (0, createRequestUrl_1.createRequestUrl)(args.url, args.queryParameters);
35
50
  const requestBody = yield (0, getRequestBody_1.getRequestBody)({
36
51
  body: args.body,
@@ -39,14 +54,14 @@ function fetcherImpl(args) {
39
54
  const fetchFn = yield (0, getFetchFn_1.getFetchFn)();
40
55
  try {
41
56
  const response = yield (0, requestWithRetries_1.requestWithRetries)(() => __awaiter(this, void 0, void 0, function* () {
42
- return (0, makeRequest_1.makeRequest)(fetchFn, url, args.method, headers, requestBody, args.timeoutMs, args.abortSignal, args.withCredentials, args.duplex);
57
+ return (0, makeRequest_1.makeRequest)(fetchFn, url, args.method, yield getHeaders(args), requestBody, args.timeoutMs, args.abortSignal, args.withCredentials, args.duplex);
43
58
  }), args.maxRetries);
44
- const responseBody = yield (0, getResponseBody_1.getResponseBody)(response, args.responseType);
45
59
  if (response.status >= 200 && response.status < 400) {
46
60
  return {
47
61
  ok: true,
48
- body: responseBody,
62
+ body: (yield (0, getResponseBody_1.getResponseBody)(response, args.responseType)),
49
63
  headers: response.headers,
64
+ rawResponse: (0, RawResponse_1.toRawResponse)(response),
50
65
  };
51
66
  }
52
67
  else {
@@ -55,8 +70,9 @@ function fetcherImpl(args) {
55
70
  error: {
56
71
  reason: "status-code",
57
72
  statusCode: response.status,
58
- body: responseBody,
73
+ body: yield (0, getErrorResponseBody_1.getErrorResponseBody)(response),
59
74
  },
75
+ rawResponse: (0, RawResponse_1.toRawResponse)(response),
60
76
  };
61
77
  }
62
78
  }
@@ -68,6 +84,7 @@ function fetcherImpl(args) {
68
84
  reason: "unknown",
69
85
  errorMessage: "The user aborted a request",
70
86
  },
87
+ rawResponse: RawResponse_1.abortRawResponse,
71
88
  };
72
89
  }
73
90
  else if (error instanceof Error && error.name === "AbortError") {
@@ -76,6 +93,7 @@ function fetcherImpl(args) {
76
93
  error: {
77
94
  reason: "timeout",
78
95
  },
96
+ rawResponse: RawResponse_1.abortRawResponse,
79
97
  };
80
98
  }
81
99
  else if (error instanceof Error) {
@@ -85,6 +103,7 @@ function fetcherImpl(args) {
85
103
  reason: "unknown",
86
104
  errorMessage: error.message,
87
105
  },
106
+ rawResponse: RawResponse_1.unknownRawResponse,
88
107
  };
89
108
  }
90
109
  return {
@@ -93,6 +112,7 @@ function fetcherImpl(args) {
93
112
  reason: "unknown",
94
113
  errorMessage: (0, json_1.toJson)(error),
95
114
  },
115
+ rawResponse: RawResponse_1.unknownRawResponse,
96
116
  };
97
117
  }
98
118
  });
@@ -0,0 +1,2 @@
1
+ declare let Headers: typeof globalThis.Headers;
2
+ export { Headers };
@@ -0,0 +1,84 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Headers = void 0;
4
+ let Headers;
5
+ if (typeof globalThis.Headers !== "undefined") {
6
+ exports.Headers = Headers = globalThis.Headers;
7
+ }
8
+ else {
9
+ exports.Headers = Headers = class Headers {
10
+ constructor(init) {
11
+ this.headers = new Map();
12
+ if (init) {
13
+ if (init instanceof Headers) {
14
+ init.forEach((value, key) => this.append(key, value));
15
+ }
16
+ else if (Array.isArray(init)) {
17
+ for (const [key, value] of init) {
18
+ if (typeof key === "string" && typeof value === "string") {
19
+ this.append(key, value);
20
+ }
21
+ else {
22
+ throw new TypeError("Each header entry must be a [string, string] tuple");
23
+ }
24
+ }
25
+ }
26
+ else {
27
+ for (const [key, value] of Object.entries(init)) {
28
+ if (typeof value === "string") {
29
+ this.append(key, value);
30
+ }
31
+ else {
32
+ throw new TypeError("Header values must be strings");
33
+ }
34
+ }
35
+ }
36
+ }
37
+ }
38
+ append(name, value) {
39
+ const key = name.toLowerCase();
40
+ const existing = this.headers.get(key) || [];
41
+ this.headers.set(key, [...existing, value]);
42
+ }
43
+ delete(name) {
44
+ const key = name.toLowerCase();
45
+ this.headers.delete(key);
46
+ }
47
+ get(name) {
48
+ const key = name.toLowerCase();
49
+ const values = this.headers.get(key);
50
+ return values ? values.join(", ") : null;
51
+ }
52
+ has(name) {
53
+ const key = name.toLowerCase();
54
+ return this.headers.has(key);
55
+ }
56
+ set(name, value) {
57
+ const key = name.toLowerCase();
58
+ this.headers.set(key, [value]);
59
+ }
60
+ forEach(callbackfn, thisArg) {
61
+ const boundCallback = thisArg ? callbackfn.bind(thisArg) : callbackfn;
62
+ this.headers.forEach((values, key) => boundCallback(values.join(", "), key, this));
63
+ }
64
+ getSetCookie() {
65
+ return this.headers.get("set-cookie") || [];
66
+ }
67
+ *entries() {
68
+ for (const [key, values] of this.headers.entries()) {
69
+ yield [key, values.join(", ")];
70
+ }
71
+ }
72
+ *keys() {
73
+ yield* this.headers.keys();
74
+ }
75
+ *values() {
76
+ for (const values of this.headers.values()) {
77
+ yield values.join(", ");
78
+ }
79
+ }
80
+ [Symbol.iterator]() {
81
+ return this.entries();
82
+ }
83
+ };
84
+ }