@zapier/zapier-sdk 0.18.4 → 0.19.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 (372) hide show
  1. package/CHANGELOG.md +35 -0
  2. package/README.md +43 -31
  3. package/dist/index.cjs +365 -64
  4. package/dist/index.d.mts +220 -33
  5. package/dist/index.d.ts +2541 -40
  6. package/dist/index.mjs +345 -63
  7. package/package.json +14 -13
  8. package/dist/api/auth.d.ts +0 -19
  9. package/dist/api/auth.d.ts.map +0 -1
  10. package/dist/api/auth.js +0 -70
  11. package/dist/api/auth.test.d.ts +0 -2
  12. package/dist/api/auth.test.d.ts.map +0 -1
  13. package/dist/api/auth.test.js +0 -220
  14. package/dist/api/client.d.ts +0 -9
  15. package/dist/api/client.d.ts.map +0 -1
  16. package/dist/api/client.js +0 -356
  17. package/dist/api/client.test.d.ts +0 -2
  18. package/dist/api/client.test.d.ts.map +0 -1
  19. package/dist/api/client.test.js +0 -96
  20. package/dist/api/debug.d.ts +0 -14
  21. package/dist/api/debug.d.ts.map +0 -1
  22. package/dist/api/debug.js +0 -131
  23. package/dist/api/debug.test.d.ts +0 -2
  24. package/dist/api/debug.test.d.ts.map +0 -1
  25. package/dist/api/debug.test.js +0 -59
  26. package/dist/api/index.d.ts +0 -30
  27. package/dist/api/index.d.ts.map +0 -1
  28. package/dist/api/index.js +0 -43
  29. package/dist/api/polling.d.ts +0 -46
  30. package/dist/api/polling.d.ts.map +0 -1
  31. package/dist/api/polling.js +0 -139
  32. package/dist/api/polling.test.d.ts +0 -2
  33. package/dist/api/polling.test.d.ts.map +0 -1
  34. package/dist/api/polling.test.js +0 -318
  35. package/dist/api/schemas.d.ts +0 -422
  36. package/dist/api/schemas.d.ts.map +0 -1
  37. package/dist/api/schemas.js +0 -322
  38. package/dist/api/types.d.ts +0 -83
  39. package/dist/api/types.d.ts.map +0 -1
  40. package/dist/api/types.js +0 -1
  41. package/dist/auth.d.ts +0 -52
  42. package/dist/auth.d.ts.map +0 -1
  43. package/dist/auth.js +0 -72
  44. package/dist/auth.test.d.ts +0 -2
  45. package/dist/auth.test.d.ts.map +0 -1
  46. package/dist/auth.test.js +0 -102
  47. package/dist/constants.d.ts +0 -14
  48. package/dist/constants.d.ts.map +0 -1
  49. package/dist/constants.js +0 -13
  50. package/dist/index.d.ts.map +0 -1
  51. package/dist/index.js +0 -42
  52. package/dist/plugins/api/index.d.ts +0 -12
  53. package/dist/plugins/api/index.d.ts.map +0 -1
  54. package/dist/plugins/api/index.js +0 -24
  55. package/dist/plugins/apps/index.d.ts +0 -15
  56. package/dist/plugins/apps/index.d.ts.map +0 -1
  57. package/dist/plugins/apps/index.js +0 -112
  58. package/dist/plugins/apps/schemas.d.ts +0 -42
  59. package/dist/plugins/apps/schemas.d.ts.map +0 -1
  60. package/dist/plugins/apps/schemas.js +0 -14
  61. package/dist/plugins/eventEmission/builders.d.ts +0 -14
  62. package/dist/plugins/eventEmission/builders.d.ts.map +0 -1
  63. package/dist/plugins/eventEmission/builders.js +0 -109
  64. package/dist/plugins/eventEmission/index.d.ts +0 -38
  65. package/dist/plugins/eventEmission/index.d.ts.map +0 -1
  66. package/dist/plugins/eventEmission/index.js +0 -336
  67. package/dist/plugins/eventEmission/index.test.d.ts +0 -5
  68. package/dist/plugins/eventEmission/index.test.d.ts.map +0 -1
  69. package/dist/plugins/eventEmission/index.test.js +0 -581
  70. package/dist/plugins/eventEmission/transport.d.ts +0 -27
  71. package/dist/plugins/eventEmission/transport.d.ts.map +0 -1
  72. package/dist/plugins/eventEmission/transport.js +0 -104
  73. package/dist/plugins/eventEmission/transport.test.d.ts +0 -5
  74. package/dist/plugins/eventEmission/transport.test.d.ts.map +0 -1
  75. package/dist/plugins/eventEmission/transport.test.js +0 -164
  76. package/dist/plugins/eventEmission/types.d.ts +0 -63
  77. package/dist/plugins/eventEmission/types.d.ts.map +0 -1
  78. package/dist/plugins/eventEmission/types.js +0 -1
  79. package/dist/plugins/eventEmission/utils.d.ts +0 -45
  80. package/dist/plugins/eventEmission/utils.d.ts.map +0 -1
  81. package/dist/plugins/eventEmission/utils.js +0 -114
  82. package/dist/plugins/fetch/index.d.ts +0 -36
  83. package/dist/plugins/fetch/index.d.ts.map +0 -1
  84. package/dist/plugins/fetch/index.js +0 -62
  85. package/dist/plugins/fetch/schemas.d.ts +0 -19
  86. package/dist/plugins/fetch/schemas.d.ts.map +0 -1
  87. package/dist/plugins/fetch/schemas.js +0 -31
  88. package/dist/plugins/findFirstAuthentication/index.d.ts +0 -21
  89. package/dist/plugins/findFirstAuthentication/index.d.ts.map +0 -1
  90. package/dist/plugins/findFirstAuthentication/index.js +0 -36
  91. package/dist/plugins/findFirstAuthentication/index.test.d.ts +0 -2
  92. package/dist/plugins/findFirstAuthentication/index.test.d.ts.map +0 -1
  93. package/dist/plugins/findFirstAuthentication/index.test.js +0 -177
  94. package/dist/plugins/findFirstAuthentication/schemas.d.ts +0 -20
  95. package/dist/plugins/findFirstAuthentication/schemas.d.ts.map +0 -1
  96. package/dist/plugins/findFirstAuthentication/schemas.js +0 -18
  97. package/dist/plugins/findUniqueAuthentication/index.d.ts +0 -21
  98. package/dist/plugins/findUniqueAuthentication/index.d.ts.map +0 -1
  99. package/dist/plugins/findUniqueAuthentication/index.js +0 -39
  100. package/dist/plugins/findUniqueAuthentication/index.test.d.ts +0 -2
  101. package/dist/plugins/findUniqueAuthentication/index.test.d.ts.map +0 -1
  102. package/dist/plugins/findUniqueAuthentication/index.test.js +0 -159
  103. package/dist/plugins/findUniqueAuthentication/schemas.d.ts +0 -20
  104. package/dist/plugins/findUniqueAuthentication/schemas.d.ts.map +0 -1
  105. package/dist/plugins/findUniqueAuthentication/schemas.js +0 -18
  106. package/dist/plugins/getAction/index.d.ts +0 -25
  107. package/dist/plugins/getAction/index.d.ts.map +0 -1
  108. package/dist/plugins/getAction/index.js +0 -42
  109. package/dist/plugins/getAction/index.test.d.ts +0 -2
  110. package/dist/plugins/getAction/index.test.d.ts.map +0 -1
  111. package/dist/plugins/getAction/index.test.js +0 -211
  112. package/dist/plugins/getAction/schemas.d.ts +0 -30
  113. package/dist/plugins/getAction/schemas.d.ts.map +0 -1
  114. package/dist/plugins/getAction/schemas.js +0 -12
  115. package/dist/plugins/getApp/index.d.ts +0 -21
  116. package/dist/plugins/getApp/index.d.ts.map +0 -1
  117. package/dist/plugins/getApp/index.js +0 -44
  118. package/dist/plugins/getApp/index.test.d.ts +0 -2
  119. package/dist/plugins/getApp/index.test.d.ts.map +0 -1
  120. package/dist/plugins/getApp/index.test.js +0 -157
  121. package/dist/plugins/getApp/schemas.d.ts +0 -16
  122. package/dist/plugins/getApp/schemas.d.ts.map +0 -1
  123. package/dist/plugins/getApp/schemas.js +0 -8
  124. package/dist/plugins/getAuthentication/index.d.ts +0 -21
  125. package/dist/plugins/getAuthentication/index.d.ts.map +0 -1
  126. package/dist/plugins/getAuthentication/index.js +0 -29
  127. package/dist/plugins/getAuthentication/index.test.d.ts +0 -2
  128. package/dist/plugins/getAuthentication/index.test.d.ts.map +0 -1
  129. package/dist/plugins/getAuthentication/index.test.js +0 -106
  130. package/dist/plugins/getAuthentication/schemas.d.ts +0 -7
  131. package/dist/plugins/getAuthentication/schemas.d.ts.map +0 -1
  132. package/dist/plugins/getAuthentication/schemas.js +0 -1
  133. package/dist/plugins/getInputFieldsSchema/index.d.ts +0 -23
  134. package/dist/plugins/getInputFieldsSchema/index.d.ts.map +0 -1
  135. package/dist/plugins/getInputFieldsSchema/index.js +0 -53
  136. package/dist/plugins/getInputFieldsSchema/index.test.d.ts +0 -2
  137. package/dist/plugins/getInputFieldsSchema/index.test.d.ts.map +0 -1
  138. package/dist/plugins/getInputFieldsSchema/index.test.js +0 -291
  139. package/dist/plugins/getInputFieldsSchema/schemas.d.ts +0 -28
  140. package/dist/plugins/getInputFieldsSchema/schemas.d.ts.map +0 -1
  141. package/dist/plugins/getInputFieldsSchema/schemas.js +0 -13
  142. package/dist/plugins/getProfile/index.d.ts +0 -25
  143. package/dist/plugins/getProfile/index.d.ts.map +0 -1
  144. package/dist/plugins/getProfile/index.js +0 -39
  145. package/dist/plugins/getProfile/schemas.d.ts +0 -13
  146. package/dist/plugins/getProfile/schemas.d.ts.map +0 -1
  147. package/dist/plugins/getProfile/schemas.js +0 -6
  148. package/dist/plugins/listActions/index.d.ts +0 -30
  149. package/dist/plugins/listActions/index.d.ts.map +0 -1
  150. package/dist/plugins/listActions/index.js +0 -75
  151. package/dist/plugins/listActions/index.test.d.ts +0 -2
  152. package/dist/plugins/listActions/index.test.d.ts.map +0 -1
  153. package/dist/plugins/listActions/index.test.js +0 -453
  154. package/dist/plugins/listActions/schemas.d.ts +0 -35
  155. package/dist/plugins/listActions/schemas.d.ts.map +0 -1
  156. package/dist/plugins/listActions/schemas.js +0 -22
  157. package/dist/plugins/listApps/index.d.ts +0 -19
  158. package/dist/plugins/listApps/index.d.ts.map +0 -1
  159. package/dist/plugins/listApps/index.js +0 -67
  160. package/dist/plugins/listApps/index.test.d.ts +0 -2
  161. package/dist/plugins/listApps/index.test.d.ts.map +0 -1
  162. package/dist/plugins/listApps/index.test.js +0 -121
  163. package/dist/plugins/listApps/schemas.d.ts +0 -47
  164. package/dist/plugins/listApps/schemas.d.ts.map +0 -1
  165. package/dist/plugins/listApps/schemas.js +0 -49
  166. package/dist/plugins/listAuthentications/index.d.ts +0 -24
  167. package/dist/plugins/listAuthentications/index.d.ts.map +0 -1
  168. package/dist/plugins/listAuthentications/index.js +0 -77
  169. package/dist/plugins/listAuthentications/index.test.d.ts +0 -2
  170. package/dist/plugins/listAuthentications/index.test.d.ts.map +0 -1
  171. package/dist/plugins/listAuthentications/index.test.js +0 -848
  172. package/dist/plugins/listAuthentications/schemas.d.ts +0 -30
  173. package/dist/plugins/listAuthentications/schemas.d.ts.map +0 -1
  174. package/dist/plugins/listAuthentications/schemas.js +0 -32
  175. package/dist/plugins/listInputFieldChoices/index.d.ts +0 -33
  176. package/dist/plugins/listInputFieldChoices/index.d.ts.map +0 -1
  177. package/dist/plugins/listInputFieldChoices/index.js +0 -115
  178. package/dist/plugins/listInputFieldChoices/index.test.d.ts +0 -2
  179. package/dist/plugins/listInputFieldChoices/index.test.d.ts.map +0 -1
  180. package/dist/plugins/listInputFieldChoices/index.test.js +0 -717
  181. package/dist/plugins/listInputFieldChoices/schemas.d.ts +0 -43
  182. package/dist/plugins/listInputFieldChoices/schemas.d.ts.map +0 -1
  183. package/dist/plugins/listInputFieldChoices/schemas.js +0 -65
  184. package/dist/plugins/listInputFields/index.d.ts +0 -34
  185. package/dist/plugins/listInputFields/index.d.ts.map +0 -1
  186. package/dist/plugins/listInputFields/index.js +0 -204
  187. package/dist/plugins/listInputFields/index.test.d.ts +0 -2
  188. package/dist/plugins/listInputFields/index.test.d.ts.map +0 -1
  189. package/dist/plugins/listInputFields/index.test.js +0 -359
  190. package/dist/plugins/listInputFields/schemas.d.ts +0 -35
  191. package/dist/plugins/listInputFields/schemas.d.ts.map +0 -1
  192. package/dist/plugins/listInputFields/schemas.js +0 -23
  193. package/dist/plugins/manifest/index.d.ts +0 -85
  194. package/dist/plugins/manifest/index.d.ts.map +0 -1
  195. package/dist/plugins/manifest/index.js +0 -376
  196. package/dist/plugins/manifest/index.test.d.ts +0 -2
  197. package/dist/plugins/manifest/index.test.d.ts.map +0 -1
  198. package/dist/plugins/manifest/index.test.js +0 -1139
  199. package/dist/plugins/manifest/schemas.d.ts +0 -57
  200. package/dist/plugins/manifest/schemas.d.ts.map +0 -1
  201. package/dist/plugins/manifest/schemas.js +0 -50
  202. package/dist/plugins/registry/index.d.ts +0 -21
  203. package/dist/plugins/registry/index.d.ts.map +0 -1
  204. package/dist/plugins/registry/index.js +0 -117
  205. package/dist/plugins/request/index.d.ts +0 -21
  206. package/dist/plugins/request/index.d.ts.map +0 -1
  207. package/dist/plugins/request/index.js +0 -76
  208. package/dist/plugins/request/index.test.d.ts +0 -2
  209. package/dist/plugins/request/index.test.d.ts.map +0 -1
  210. package/dist/plugins/request/index.test.js +0 -337
  211. package/dist/plugins/request/schemas.d.ts +0 -54
  212. package/dist/plugins/request/schemas.d.ts.map +0 -1
  213. package/dist/plugins/request/schemas.js +0 -41
  214. package/dist/plugins/runAction/index.d.ts +0 -33
  215. package/dist/plugins/runAction/index.d.ts.map +0 -1
  216. package/dist/plugins/runAction/index.js +0 -108
  217. package/dist/plugins/runAction/index.test.d.ts +0 -2
  218. package/dist/plugins/runAction/index.test.d.ts.map +0 -1
  219. package/dist/plugins/runAction/index.test.js +0 -333
  220. package/dist/plugins/runAction/schemas.d.ts +0 -34
  221. package/dist/plugins/runAction/schemas.d.ts.map +0 -1
  222. package/dist/plugins/runAction/schemas.js +0 -23
  223. package/dist/resolvers/actionKey.d.ts +0 -15
  224. package/dist/resolvers/actionKey.d.ts.map +0 -1
  225. package/dist/resolvers/actionKey.js +0 -19
  226. package/dist/resolvers/actionType.d.ts +0 -10
  227. package/dist/resolvers/actionType.d.ts.map +0 -1
  228. package/dist/resolvers/actionType.js +0 -21
  229. package/dist/resolvers/appKey.d.ts +0 -3
  230. package/dist/resolvers/appKey.d.ts.map +0 -1
  231. package/dist/resolvers/appKey.js +0 -5
  232. package/dist/resolvers/authenticationId.d.ts +0 -9
  233. package/dist/resolvers/authenticationId.d.ts.map +0 -1
  234. package/dist/resolvers/authenticationId.js +0 -42
  235. package/dist/resolvers/index.d.ts +0 -8
  236. package/dist/resolvers/index.d.ts.map +0 -1
  237. package/dist/resolvers/index.js +0 -8
  238. package/dist/resolvers/inputFieldKey.d.ts +0 -11
  239. package/dist/resolvers/inputFieldKey.d.ts.map +0 -1
  240. package/dist/resolvers/inputFieldKey.js +0 -47
  241. package/dist/resolvers/inputs.d.ts +0 -17
  242. package/dist/resolvers/inputs.d.ts.map +0 -1
  243. package/dist/resolvers/inputs.js +0 -50
  244. package/dist/schemas/Action.d.ts +0 -24
  245. package/dist/schemas/Action.d.ts.map +0 -1
  246. package/dist/schemas/Action.js +0 -40
  247. package/dist/schemas/App.d.ts +0 -57
  248. package/dist/schemas/App.d.ts.map +0 -1
  249. package/dist/schemas/App.js +0 -26
  250. package/dist/schemas/Auth.d.ts +0 -55
  251. package/dist/schemas/Auth.d.ts.map +0 -1
  252. package/dist/schemas/Auth.js +0 -33
  253. package/dist/schemas/Field.d.ts +0 -61
  254. package/dist/schemas/Field.d.ts.map +0 -1
  255. package/dist/schemas/Field.js +0 -116
  256. package/dist/schemas/Run.d.ts +0 -3
  257. package/dist/schemas/Run.d.ts.map +0 -1
  258. package/dist/schemas/Run.js +0 -31
  259. package/dist/schemas/UserProfile.d.ts +0 -13
  260. package/dist/schemas/UserProfile.d.ts.map +0 -1
  261. package/dist/schemas/UserProfile.js +0 -32
  262. package/dist/sdk.d.ts +0 -146
  263. package/dist/sdk.d.ts.map +0 -1
  264. package/dist/sdk.js +0 -112
  265. package/dist/sdk.test.d.ts +0 -2
  266. package/dist/sdk.test.d.ts.map +0 -1
  267. package/dist/sdk.test.js +0 -258
  268. package/dist/services/implementations.d.ts +0 -63
  269. package/dist/services/implementations.d.ts.map +0 -1
  270. package/dist/services/implementations.js +0 -80
  271. package/dist/types/domain.d.ts +0 -52
  272. package/dist/types/domain.d.ts.map +0 -1
  273. package/dist/types/domain.js +0 -1
  274. package/dist/types/domain.test.d.ts +0 -2
  275. package/dist/types/domain.test.d.ts.map +0 -1
  276. package/dist/types/domain.test.js +0 -39
  277. package/dist/types/errors.d.ts +0 -143
  278. package/dist/types/errors.d.ts.map +0 -1
  279. package/dist/types/errors.js +0 -187
  280. package/dist/types/events.d.ts +0 -38
  281. package/dist/types/events.d.ts.map +0 -1
  282. package/dist/types/events.js +0 -7
  283. package/dist/types/functions.d.ts +0 -27
  284. package/dist/types/functions.d.ts.map +0 -1
  285. package/dist/types/functions.js +0 -1
  286. package/dist/types/plugin.d.ts +0 -75
  287. package/dist/types/plugin.d.ts.map +0 -1
  288. package/dist/types/plugin.js +0 -9
  289. package/dist/types/properties.d.ts +0 -33
  290. package/dist/types/properties.d.ts.map +0 -1
  291. package/dist/types/properties.js +0 -52
  292. package/dist/types/sdk.d.ts +0 -69
  293. package/dist/types/sdk.d.ts.map +0 -1
  294. package/dist/types/sdk.js +0 -4
  295. package/dist/types/telemetry-events.d.ts +0 -105
  296. package/dist/types/telemetry-events.d.ts.map +0 -1
  297. package/dist/types/telemetry-events.js +0 -8
  298. package/dist/utils/array-utils.d.ts +0 -31
  299. package/dist/utils/array-utils.d.ts.map +0 -1
  300. package/dist/utils/array-utils.js +0 -36
  301. package/dist/utils/array-utils.test.d.ts +0 -2
  302. package/dist/utils/array-utils.test.d.ts.map +0 -1
  303. package/dist/utils/array-utils.test.js +0 -107
  304. package/dist/utils/batch-utils.d.ts +0 -72
  305. package/dist/utils/batch-utils.d.ts.map +0 -1
  306. package/dist/utils/batch-utils.js +0 -162
  307. package/dist/utils/batch-utils.test.d.ts +0 -2
  308. package/dist/utils/batch-utils.test.d.ts.map +0 -1
  309. package/dist/utils/batch-utils.test.js +0 -476
  310. package/dist/utils/domain-utils.d.ts +0 -66
  311. package/dist/utils/domain-utils.d.ts.map +0 -1
  312. package/dist/utils/domain-utils.js +0 -164
  313. package/dist/utils/domain-utils.test.d.ts +0 -2
  314. package/dist/utils/domain-utils.test.d.ts.map +0 -1
  315. package/dist/utils/domain-utils.test.js +0 -346
  316. package/dist/utils/file-utils.d.ts +0 -4
  317. package/dist/utils/file-utils.d.ts.map +0 -1
  318. package/dist/utils/file-utils.js +0 -74
  319. package/dist/utils/file-utils.test.d.ts +0 -2
  320. package/dist/utils/file-utils.test.d.ts.map +0 -1
  321. package/dist/utils/file-utils.test.js +0 -51
  322. package/dist/utils/function-utils.d.ts +0 -73
  323. package/dist/utils/function-utils.d.ts.map +0 -1
  324. package/dist/utils/function-utils.js +0 -245
  325. package/dist/utils/function-utils.test.d.ts +0 -2
  326. package/dist/utils/function-utils.test.d.ts.map +0 -1
  327. package/dist/utils/function-utils.test.js +0 -110
  328. package/dist/utils/id-utils.d.ts +0 -13
  329. package/dist/utils/id-utils.d.ts.map +0 -1
  330. package/dist/utils/id-utils.js +0 -22
  331. package/dist/utils/id-utils.test.d.ts +0 -2
  332. package/dist/utils/id-utils.test.d.ts.map +0 -1
  333. package/dist/utils/id-utils.test.js +0 -22
  334. package/dist/utils/pagination-utils.d.ts +0 -37
  335. package/dist/utils/pagination-utils.d.ts.map +0 -1
  336. package/dist/utils/pagination-utils.js +0 -165
  337. package/dist/utils/pagination-utils.test.d.ts +0 -17
  338. package/dist/utils/pagination-utils.test.d.ts.map +0 -1
  339. package/dist/utils/pagination-utils.test.js +0 -461
  340. package/dist/utils/retry-utils.d.ts +0 -45
  341. package/dist/utils/retry-utils.d.ts.map +0 -1
  342. package/dist/utils/retry-utils.js +0 -51
  343. package/dist/utils/retry-utils.test.d.ts +0 -2
  344. package/dist/utils/retry-utils.test.d.ts.map +0 -1
  345. package/dist/utils/retry-utils.test.js +0 -90
  346. package/dist/utils/schema-utils.d.ts +0 -69
  347. package/dist/utils/schema-utils.d.ts.map +0 -1
  348. package/dist/utils/schema-utils.js +0 -72
  349. package/dist/utils/string-utils.d.ts +0 -40
  350. package/dist/utils/string-utils.d.ts.map +0 -1
  351. package/dist/utils/string-utils.js +0 -69
  352. package/dist/utils/string-utils.test.d.ts +0 -2
  353. package/dist/utils/string-utils.test.d.ts.map +0 -1
  354. package/dist/utils/string-utils.test.js +0 -59
  355. package/dist/utils/telemetry-utils.d.ts +0 -44
  356. package/dist/utils/telemetry-utils.d.ts.map +0 -1
  357. package/dist/utils/telemetry-utils.js +0 -55
  358. package/dist/utils/telemetry-utils.test.d.ts +0 -2
  359. package/dist/utils/telemetry-utils.test.d.ts.map +0 -1
  360. package/dist/utils/telemetry-utils.test.js +0 -94
  361. package/dist/utils/url-utils.d.ts +0 -19
  362. package/dist/utils/url-utils.d.ts.map +0 -1
  363. package/dist/utils/url-utils.js +0 -62
  364. package/dist/utils/url-utils.test.d.ts +0 -2
  365. package/dist/utils/url-utils.test.d.ts.map +0 -1
  366. package/dist/utils/url-utils.test.js +0 -103
  367. package/dist/utils/validation.d.ts +0 -4
  368. package/dist/utils/validation.d.ts.map +0 -1
  369. package/dist/utils/validation.js +0 -30
  370. package/dist/utils/validation.test.d.ts +0 -2
  371. package/dist/utils/validation.test.d.ts.map +0 -1
  372. package/dist/utils/validation.test.js +0 -44
@@ -1,318 +0,0 @@
1
- import { describe, it, expect, vi, beforeEach, afterEach } from "vitest";
2
- import { pollUntilComplete } from "./polling";
3
- import { ZapierTimeoutError, ZapierApiError, ZapierValidationError, } from "../types/errors";
4
- // Mock the timers/promises module
5
- vi.mock("timers/promises", () => ({
6
- setTimeout: vi.fn(() => Promise.resolve()),
7
- }));
8
- describe("pollUntilComplete", () => {
9
- beforeEach(() => {
10
- vi.clearAllMocks();
11
- });
12
- afterEach(() => {
13
- vi.clearAllMocks();
14
- });
15
- describe("successful polling", () => {
16
- it("should return immediately on first successful response", async () => {
17
- const mockResponse = {
18
- ok: true,
19
- status: 200,
20
- json: vi.fn().mockResolvedValue({ data: "success" }),
21
- };
22
- const fetchPoll = vi.fn().mockResolvedValue(mockResponse);
23
- const result = await pollUntilComplete({ fetchPoll });
24
- expect(result).toEqual({ data: "success" });
25
- expect(fetchPoll).toHaveBeenCalledTimes(1);
26
- });
27
- it("should poll until success status is received", async () => {
28
- const pendingResponse = {
29
- ok: true,
30
- status: 202,
31
- };
32
- const successResponse = {
33
- ok: true,
34
- status: 200,
35
- json: vi.fn().mockResolvedValue({ data: "complete" }),
36
- };
37
- const fetchPoll = vi
38
- .fn()
39
- .mockResolvedValueOnce(pendingResponse)
40
- .mockResolvedValueOnce(pendingResponse)
41
- .mockResolvedValueOnce(successResponse);
42
- const result = await pollUntilComplete({ fetchPoll });
43
- expect(result).toEqual({ data: "complete" });
44
- expect(fetchPoll).toHaveBeenCalledTimes(3);
45
- });
46
- it("should use custom success and pending status codes", async () => {
47
- const pendingResponse = {
48
- ok: true,
49
- status: 301,
50
- };
51
- const successResponse = {
52
- ok: true,
53
- status: 204,
54
- json: vi.fn().mockResolvedValue({ done: true }),
55
- };
56
- const fetchPoll = vi
57
- .fn()
58
- .mockResolvedValueOnce(pendingResponse)
59
- .mockResolvedValueOnce(successResponse);
60
- const result = await pollUntilComplete({
61
- fetchPoll,
62
- successStatus: 204,
63
- pendingStatus: 301,
64
- });
65
- expect(result).toEqual({ done: true });
66
- expect(fetchPoll).toHaveBeenCalledTimes(2);
67
- });
68
- it("should apply result extractor function", async () => {
69
- const mockResponse = {
70
- ok: true,
71
- status: 200,
72
- json: vi.fn().mockResolvedValue({
73
- nested: { data: { value: "extracted" } },
74
- }),
75
- };
76
- const fetchPoll = vi.fn().mockResolvedValue(mockResponse);
77
- const resultExtractor = (response) => response.nested.data.value;
78
- const result = await pollUntilComplete({
79
- fetchPoll,
80
- resultExtractor,
81
- });
82
- expect(result).toBe("extracted");
83
- });
84
- });
85
- describe("initial delay", () => {
86
- it("should wait for initial delay before first poll", async () => {
87
- const mockResponse = {
88
- ok: true,
89
- status: 200,
90
- json: vi.fn().mockResolvedValue({ data: "success" }),
91
- };
92
- const fetchPoll = vi.fn().mockResolvedValue(mockResponse);
93
- const { setTimeout: mockSetTimeout } = await import("timers/promises");
94
- const result = await pollUntilComplete({
95
- fetchPoll,
96
- initialDelay: 500,
97
- });
98
- expect(result).toEqual({ data: "success" });
99
- expect(fetchPoll).toHaveBeenCalledTimes(1);
100
- // Verify setTimeout was called with the initial delay
101
- expect(mockSetTimeout).toHaveBeenCalledWith(500);
102
- });
103
- });
104
- describe("error handling", () => {
105
- it("should retry on transient network errors", async () => {
106
- const successResponse = {
107
- ok: true,
108
- status: 200,
109
- json: vi.fn().mockResolvedValue({ data: "recovered" }),
110
- };
111
- const fetchPoll = vi
112
- .fn()
113
- .mockRejectedValueOnce(new Error("Network error"))
114
- .mockRejectedValueOnce(new Error("Network error"))
115
- .mockResolvedValueOnce(successResponse);
116
- const result = await pollUntilComplete({ fetchPoll });
117
- expect(result).toEqual({ data: "recovered" });
118
- expect(fetchPoll).toHaveBeenCalledTimes(3);
119
- });
120
- it("should fail after MAX_CONSECUTIVE_ERRORS network failures", async () => {
121
- const fetchPoll = vi
122
- .fn()
123
- .mockRejectedValue(new Error("Persistent network error"));
124
- await expect(pollUntilComplete({ fetchPoll })).rejects.toThrow(ZapierApiError);
125
- expect(fetchPoll).toHaveBeenCalledTimes(3);
126
- });
127
- it("should retry on HTTP error responses", async () => {
128
- const errorResponse = {
129
- ok: false,
130
- status: 500,
131
- statusText: "Internal Server Error",
132
- };
133
- const successResponse = {
134
- ok: true,
135
- status: 200,
136
- json: vi.fn().mockResolvedValue({ data: "recovered" }),
137
- };
138
- const fetchPoll = vi
139
- .fn()
140
- .mockResolvedValueOnce(errorResponse)
141
- .mockResolvedValueOnce(errorResponse)
142
- .mockResolvedValueOnce(successResponse);
143
- const result = await pollUntilComplete({ fetchPoll });
144
- expect(result).toEqual({ data: "recovered" });
145
- expect(fetchPoll).toHaveBeenCalledTimes(3);
146
- });
147
- it("should fail after MAX_CONSECUTIVE_ERRORS HTTP failures", async () => {
148
- const errorResponse = {
149
- ok: false,
150
- status: 503,
151
- statusText: "Service Unavailable",
152
- };
153
- const fetchPoll = vi.fn().mockResolvedValue(errorResponse);
154
- await expect(pollUntilComplete({ fetchPoll })).rejects.toThrow(ZapierApiError);
155
- expect(fetchPoll).toHaveBeenCalledTimes(3);
156
- });
157
- it("should throw error for unexpected response status", async () => {
158
- const unexpectedResponse = {
159
- ok: true,
160
- status: 301, // Not success (200) or pending (202)
161
- };
162
- const fetchPoll = vi.fn().mockResolvedValue(unexpectedResponse);
163
- await expect(pollUntilComplete({ fetchPoll })).rejects.toThrow("Unexpected response status");
164
- // Will retry 3 times before failing
165
- expect(fetchPoll).toHaveBeenCalledTimes(3);
166
- });
167
- it("should throw error if successful response is not valid JSON", async () => {
168
- const mockResponse = {
169
- ok: true,
170
- status: 200,
171
- json: vi.fn().mockRejectedValue(new Error("Invalid JSON")),
172
- };
173
- const fetchPoll = vi.fn().mockResolvedValue(mockResponse);
174
- await expect(pollUntilComplete({ fetchPoll })).rejects.toThrow("Failed to poll after 3 consecutive errors");
175
- // Will retry 3 times before failing
176
- expect(fetchPoll).toHaveBeenCalledTimes(3);
177
- });
178
- });
179
- describe("timeout behavior", () => {
180
- it("should timeout after specified duration", async () => {
181
- // Mock Date.now to simulate time passing
182
- const originalDateNow = Date.now;
183
- let currentTime = 1000;
184
- Date.now = vi.fn(() => currentTime);
185
- const pendingResponse = {
186
- ok: true,
187
- status: 202,
188
- };
189
- const fetchPoll = vi.fn().mockImplementation(() => {
190
- // Simulate time passing with each poll
191
- currentTime += 500;
192
- return Promise.resolve(pendingResponse);
193
- });
194
- try {
195
- await expect(pollUntilComplete({
196
- fetchPoll,
197
- timeoutMs: 1000,
198
- initialDelay: 0,
199
- })).rejects.toThrow(ZapierTimeoutError);
200
- }
201
- finally {
202
- Date.now = originalDateNow;
203
- }
204
- });
205
- it("should use default timeout when not specified", async () => {
206
- // Mock Date.now to simulate time passing beyond default timeout
207
- const originalDateNow = Date.now;
208
- let currentTime = 1000;
209
- Date.now = vi.fn(() => currentTime);
210
- const pendingResponse = {
211
- ok: true,
212
- status: 202,
213
- };
214
- const fetchPoll = vi.fn().mockImplementation(() => {
215
- // Simulate time passing beyond default timeout (180 seconds + buffer)
216
- currentTime += 50000;
217
- return Promise.resolve(pendingResponse);
218
- });
219
- try {
220
- await expect(pollUntilComplete({
221
- fetchPoll,
222
- initialDelay: 0,
223
- })).rejects.toThrow(ZapierTimeoutError);
224
- }
225
- finally {
226
- Date.now = originalDateNow;
227
- }
228
- });
229
- });
230
- describe("input validation", () => {
231
- it("should throw error for invalid timeout", async () => {
232
- const fetchPoll = vi.fn();
233
- await expect(pollUntilComplete({
234
- fetchPoll,
235
- timeoutMs: 0,
236
- })).rejects.toThrow(ZapierValidationError);
237
- await expect(pollUntilComplete({
238
- fetchPoll,
239
- timeoutMs: -1000,
240
- })).rejects.toThrow(/Timeout must be greater than 0/);
241
- });
242
- it("should throw error for negative initial delay", async () => {
243
- const fetchPoll = vi.fn();
244
- await expect(pollUntilComplete({
245
- fetchPoll,
246
- initialDelay: -100,
247
- })).rejects.toThrow(ZapierValidationError);
248
- await expect(pollUntilComplete({
249
- fetchPoll,
250
- initialDelay: -1,
251
- })).rejects.toThrow(/Initial delay must be non-negative/);
252
- });
253
- });
254
- describe("edge cases", () => {
255
- it("should handle rapid status changes", async () => {
256
- const responses = [
257
- { ok: true, status: 202 },
258
- { ok: false, status: 500 },
259
- { ok: true, status: 202 },
260
- {
261
- ok: true,
262
- status: 200,
263
- json: vi.fn().mockResolvedValue({ data: "success" }),
264
- },
265
- ];
266
- let index = 0;
267
- const fetchPoll = vi.fn().mockImplementation(() => {
268
- const response = responses[index];
269
- index++;
270
- return Promise.resolve(response);
271
- });
272
- const result = await pollUntilComplete({ fetchPoll });
273
- expect(result).toEqual({ data: "success" });
274
- expect(fetchPoll).toHaveBeenCalledTimes(4);
275
- });
276
- it("should handle immediate success with no initial delay", async () => {
277
- const mockResponse = {
278
- ok: true,
279
- status: 200,
280
- json: vi.fn().mockResolvedValue({ instant: true }),
281
- };
282
- const fetchPoll = vi.fn().mockResolvedValue(mockResponse);
283
- const result = await pollUntilComplete({
284
- fetchPoll,
285
- initialDelay: 0,
286
- });
287
- expect(result).toEqual({ instant: true });
288
- expect(fetchPoll).toHaveBeenCalledTimes(1);
289
- });
290
- it("should handle very short timeout", async () => {
291
- // Mock Date.now to simulate time passing
292
- const originalDateNow = Date.now;
293
- let currentTime = 1000;
294
- Date.now = vi.fn(() => currentTime);
295
- const pendingResponse = {
296
- ok: true,
297
- status: 202,
298
- };
299
- const fetchPoll = vi.fn().mockImplementation(() => {
300
- // Simulate time passing beyond the short timeout
301
- currentTime += 200;
302
- return Promise.resolve(pendingResponse);
303
- });
304
- try {
305
- await expect(pollUntilComplete({
306
- fetchPoll,
307
- timeoutMs: 100,
308
- initialDelay: 0,
309
- })).rejects.toThrow(ZapierTimeoutError);
310
- // Should have made at least 1 attempt before timing out
311
- expect(fetchPoll.mock.calls.length).toBeGreaterThanOrEqual(1);
312
- }
313
- finally {
314
- Date.now = originalDateNow;
315
- }
316
- });
317
- });
318
- });