@zapier/zapier-sdk 0.4.0 → 0.5.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 (374) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/dist/api/auth.d.ts +9 -0
  3. package/dist/api/auth.d.ts.map +1 -0
  4. package/dist/api/auth.js +25 -0
  5. package/dist/api/client.d.ts +9 -0
  6. package/dist/api/client.d.ts.map +1 -0
  7. package/dist/api/client.js +322 -0
  8. package/dist/api/debug.d.ts +13 -0
  9. package/dist/api/debug.d.ts.map +1 -0
  10. package/dist/api/debug.js +55 -0
  11. package/dist/api/index.d.ts +29 -0
  12. package/dist/api/index.d.ts.map +1 -0
  13. package/dist/api/index.js +41 -0
  14. package/dist/api/polling.d.ts +16 -0
  15. package/dist/api/polling.d.ts.map +1 -0
  16. package/dist/api/polling.js +45 -0
  17. package/dist/api/schemas.d.ts +2473 -0
  18. package/dist/api/schemas.d.ts.map +1 -0
  19. package/dist/api/schemas.js +355 -0
  20. package/dist/api/types.d.ts +75 -0
  21. package/dist/api/types.d.ts.map +1 -0
  22. package/dist/api/types.js +11 -0
  23. package/dist/auth.d.ts +34 -0
  24. package/dist/auth.d.ts.map +1 -0
  25. package/dist/auth.js +47 -0
  26. package/dist/constants.d.ts +10 -0
  27. package/dist/constants.d.ts.map +1 -0
  28. package/dist/constants.js +9 -0
  29. package/dist/index.cjs +2134 -1444
  30. package/dist/index.d.mts +2456 -584
  31. package/dist/index.d.ts +17 -840
  32. package/dist/index.d.ts.map +1 -0
  33. package/dist/index.js +20 -0
  34. package/dist/index.mjs +2118 -1428
  35. package/dist/plugins/api/index.d.ts +14 -0
  36. package/dist/plugins/api/index.d.ts.map +1 -0
  37. package/dist/plugins/api/index.js +21 -0
  38. package/dist/plugins/apps/index.d.ts +11 -0
  39. package/dist/plugins/apps/index.d.ts.map +1 -0
  40. package/dist/plugins/apps/index.js +91 -0
  41. package/dist/plugins/apps/types.d.ts +30 -0
  42. package/dist/plugins/apps/types.d.ts.map +1 -0
  43. package/dist/plugins/apps/types.js +2 -0
  44. package/dist/plugins/fetch/index.d.ts +21 -0
  45. package/dist/plugins/fetch/index.d.ts.map +1 -0
  46. package/dist/plugins/fetch/index.js +20 -0
  47. package/dist/plugins/findFirstAuthentication/index.d.ts +20 -0
  48. package/dist/plugins/findFirstAuthentication/index.d.ts.map +1 -0
  49. package/dist/plugins/findFirstAuthentication/index.js +24 -0
  50. package/dist/plugins/findFirstAuthentication/index.test.d.ts +2 -0
  51. package/dist/plugins/findFirstAuthentication/index.test.d.ts.map +1 -0
  52. package/dist/plugins/findFirstAuthentication/index.test.js +171 -0
  53. package/dist/plugins/findFirstAuthentication/schemas.d.ts +29 -0
  54. package/dist/plugins/findFirstAuthentication/schemas.d.ts.map +1 -0
  55. package/dist/plugins/findFirstAuthentication/schemas.js +18 -0
  56. package/dist/plugins/findUniqueAuthentication/index.d.ts +20 -0
  57. package/dist/plugins/findUniqueAuthentication/index.d.ts.map +1 -0
  58. package/dist/plugins/findUniqueAuthentication/index.js +31 -0
  59. package/dist/plugins/findUniqueAuthentication/index.test.d.ts +2 -0
  60. package/dist/plugins/findUniqueAuthentication/index.test.d.ts.map +1 -0
  61. package/dist/plugins/findUniqueAuthentication/index.test.js +152 -0
  62. package/dist/plugins/findUniqueAuthentication/schemas.d.ts +29 -0
  63. package/dist/plugins/findUniqueAuthentication/schemas.d.ts.map +1 -0
  64. package/dist/plugins/findUniqueAuthentication/schemas.js +18 -0
  65. package/dist/plugins/getAction/index.d.ts +23 -0
  66. package/dist/plugins/getAction/index.d.ts.map +1 -0
  67. package/dist/plugins/getAction/index.js +28 -0
  68. package/dist/plugins/getAction/index.test.d.ts +2 -0
  69. package/dist/plugins/getAction/index.test.d.ts.map +1 -0
  70. package/dist/plugins/getAction/index.test.js +186 -0
  71. package/dist/plugins/getAction/schemas.d.ts +23 -0
  72. package/dist/plugins/getAction/schemas.d.ts.map +1 -0
  73. package/dist/plugins/getAction/schemas.js +10 -0
  74. package/dist/plugins/getApp/index.d.ts +22 -0
  75. package/dist/plugins/getApp/index.d.ts.map +1 -0
  76. package/dist/plugins/getApp/index.js +39 -0
  77. package/dist/plugins/getApp/index.test.d.ts +2 -0
  78. package/dist/plugins/getApp/index.test.d.ts.map +1 -0
  79. package/dist/plugins/getApp/index.test.js +100 -0
  80. package/dist/plugins/getApp/schemas.d.ts +18 -0
  81. package/dist/plugins/getApp/schemas.d.ts.map +1 -0
  82. package/dist/plugins/getApp/schemas.js +10 -0
  83. package/dist/plugins/getAuthentication/index.d.ts +22 -0
  84. package/dist/plugins/getAuthentication/index.d.ts.map +1 -0
  85. package/dist/plugins/getAuthentication/index.js +41 -0
  86. package/dist/plugins/getAuthentication/index.test.d.ts +2 -0
  87. package/dist/plugins/getAuthentication/index.test.d.ts.map +1 -0
  88. package/dist/plugins/getAuthentication/index.test.js +205 -0
  89. package/dist/plugins/getAuthentication/schemas.d.ts +17 -0
  90. package/dist/plugins/getAuthentication/schemas.d.ts.map +1 -0
  91. package/dist/plugins/getAuthentication/schemas.js +11 -0
  92. package/dist/plugins/getProfile/index.d.ts +23 -0
  93. package/dist/plugins/getProfile/index.d.ts.map +1 -0
  94. package/dist/plugins/getProfile/index.js +29 -0
  95. package/dist/plugins/getProfile/schemas.d.ts +13 -0
  96. package/dist/plugins/getProfile/schemas.d.ts.map +1 -0
  97. package/dist/plugins/getProfile/schemas.js +5 -0
  98. package/dist/plugins/listActions/index.d.ts +28 -0
  99. package/dist/plugins/listActions/index.d.ts.map +1 -0
  100. package/dist/plugins/listActions/index.js +61 -0
  101. package/dist/plugins/listActions/index.test.d.ts +2 -0
  102. package/dist/plugins/listActions/index.test.d.ts.map +1 -0
  103. package/dist/plugins/listActions/index.test.js +467 -0
  104. package/dist/plugins/listActions/schemas.d.ts +29 -0
  105. package/dist/plugins/listActions/schemas.d.ts.map +1 -0
  106. package/dist/plugins/listActions/schemas.js +21 -0
  107. package/dist/plugins/listApps/index.d.ts +28 -0
  108. package/dist/plugins/listApps/index.d.ts.map +1 -0
  109. package/dist/plugins/listApps/index.js +62 -0
  110. package/dist/plugins/listApps/index.test.d.ts +2 -0
  111. package/dist/plugins/listApps/index.test.d.ts.map +1 -0
  112. package/dist/plugins/listApps/index.test.js +313 -0
  113. package/dist/plugins/listApps/schemas.d.ts +30 -0
  114. package/dist/plugins/listApps/schemas.d.ts.map +1 -0
  115. package/dist/plugins/listApps/schemas.js +23 -0
  116. package/dist/plugins/listAuthentications/index.d.ts +28 -0
  117. package/dist/plugins/listAuthentications/index.d.ts.map +1 -0
  118. package/dist/plugins/listAuthentications/index.js +77 -0
  119. package/dist/plugins/listAuthentications/index.test.d.ts +2 -0
  120. package/dist/plugins/listAuthentications/index.test.d.ts.map +1 -0
  121. package/dist/plugins/listAuthentications/index.test.js +564 -0
  122. package/dist/plugins/listAuthentications/schemas.d.ts +38 -0
  123. package/dist/plugins/listAuthentications/schemas.d.ts.map +1 -0
  124. package/dist/plugins/listAuthentications/schemas.js +28 -0
  125. package/dist/plugins/listInputFields/index.d.ts +28 -0
  126. package/dist/plugins/listInputFields/index.d.ts.map +1 -0
  127. package/dist/plugins/listInputFields/index.js +133 -0
  128. package/dist/plugins/listInputFields/index.test.d.ts +2 -0
  129. package/dist/plugins/listInputFields/index.test.d.ts.map +1 -0
  130. package/dist/plugins/listInputFields/index.test.js +325 -0
  131. package/dist/plugins/listInputFields/schemas.d.ts +38 -0
  132. package/dist/plugins/listInputFields/schemas.d.ts.map +1 -0
  133. package/dist/plugins/listInputFields/schemas.js +22 -0
  134. package/dist/plugins/registry/index.d.ts +11 -0
  135. package/dist/plugins/registry/index.d.ts.map +1 -0
  136. package/dist/plugins/registry/index.js +14 -0
  137. package/dist/plugins/request/index.d.ts +19 -0
  138. package/dist/plugins/request/index.d.ts.map +1 -0
  139. package/dist/plugins/request/index.js +62 -0
  140. package/dist/plugins/request/index.test.d.ts +2 -0
  141. package/dist/plugins/request/index.test.d.ts.map +1 -0
  142. package/dist/plugins/request/index.test.js +256 -0
  143. package/dist/plugins/request/schemas.d.ts +69 -0
  144. package/dist/plugins/request/schemas.d.ts.map +1 -0
  145. package/dist/plugins/request/schemas.js +42 -0
  146. package/dist/plugins/runAction/index.d.ts +28 -0
  147. package/dist/plugins/runAction/index.d.ts.map +1 -0
  148. package/dist/plugins/runAction/index.js +86 -0
  149. package/dist/plugins/runAction/index.test.d.ts +2 -0
  150. package/dist/plugins/runAction/index.test.d.ts.map +1 -0
  151. package/dist/plugins/runAction/index.test.js +320 -0
  152. package/dist/plugins/runAction/schemas.d.ts +37 -0
  153. package/dist/plugins/runAction/schemas.d.ts.map +1 -0
  154. package/dist/plugins/runAction/schemas.js +22 -0
  155. package/dist/resolvers/actionKey.d.ts +9 -0
  156. package/dist/resolvers/actionKey.d.ts.map +1 -0
  157. package/dist/resolvers/actionKey.js +19 -0
  158. package/dist/resolvers/actionType.d.ts +9 -0
  159. package/dist/resolvers/actionType.d.ts.map +1 -0
  160. package/dist/resolvers/actionType.js +22 -0
  161. package/dist/resolvers/appKey.d.ts +7 -0
  162. package/dist/resolvers/appKey.d.ts.map +1 -0
  163. package/dist/resolvers/appKey.js +5 -0
  164. package/dist/resolvers/authenticationId.d.ts +9 -0
  165. package/dist/resolvers/authenticationId.d.ts.map +1 -0
  166. package/dist/resolvers/authenticationId.js +33 -0
  167. package/dist/resolvers/index.d.ts +40 -0
  168. package/dist/resolvers/index.d.ts.map +1 -0
  169. package/dist/resolvers/index.js +91 -0
  170. package/dist/resolvers/inputs.d.ts +8 -0
  171. package/dist/resolvers/inputs.d.ts.map +1 -0
  172. package/dist/resolvers/inputs.js +14 -0
  173. package/dist/schemas/Action.d.ts +243 -0
  174. package/dist/schemas/Action.d.ts.map +1 -0
  175. package/dist/schemas/Action.js +34 -0
  176. package/dist/schemas/App.d.ts +26 -0
  177. package/dist/schemas/App.d.ts.map +1 -0
  178. package/dist/schemas/App.js +22 -0
  179. package/dist/schemas/Auth.d.ts +161 -0
  180. package/dist/schemas/Auth.d.ts.map +1 -0
  181. package/dist/schemas/Auth.js +41 -0
  182. package/dist/schemas/Field.d.ts +144 -0
  183. package/dist/schemas/Field.d.ts.map +1 -0
  184. package/dist/schemas/Field.js +105 -0
  185. package/dist/schemas/UserProfile.d.ts +163 -0
  186. package/dist/schemas/UserProfile.d.ts.map +1 -0
  187. package/dist/schemas/UserProfile.js +29 -0
  188. package/dist/sdk.d.ts +10 -0
  189. package/dist/sdk.d.ts.map +1 -0
  190. package/dist/sdk.js +94 -0
  191. package/dist/sdk.test.d.ts +2 -0
  192. package/dist/sdk.test.d.ts.map +1 -0
  193. package/dist/sdk.test.js +135 -0
  194. package/dist/types/domain.d.ts +36 -0
  195. package/dist/types/domain.d.ts.map +1 -0
  196. package/dist/types/domain.js +1 -0
  197. package/dist/types/domain.test.d.ts +2 -0
  198. package/dist/types/domain.test.d.ts.map +1 -0
  199. package/dist/types/domain.test.js +39 -0
  200. package/dist/types/errors.d.ts +143 -0
  201. package/dist/types/errors.d.ts.map +1 -0
  202. package/dist/types/errors.js +187 -0
  203. package/dist/types/events.d.ts +38 -0
  204. package/dist/types/events.d.ts.map +1 -0
  205. package/dist/types/events.js +7 -0
  206. package/dist/types/functions.d.ts +26 -0
  207. package/dist/types/functions.d.ts.map +1 -0
  208. package/dist/types/functions.js +4 -0
  209. package/dist/types/plugin.d.ts +61 -0
  210. package/dist/types/plugin.d.ts.map +1 -0
  211. package/dist/types/plugin.js +9 -0
  212. package/dist/types/properties.d.ts +22 -0
  213. package/dist/types/properties.d.ts.map +1 -0
  214. package/dist/types/properties.js +50 -0
  215. package/dist/types/sdk.d.ts +43 -0
  216. package/dist/types/sdk.d.ts.map +1 -0
  217. package/dist/types/sdk.js +4 -0
  218. package/dist/utils/array-utils.d.ts +31 -0
  219. package/dist/utils/array-utils.d.ts.map +1 -0
  220. package/dist/utils/array-utils.js +36 -0
  221. package/dist/utils/array-utils.test.d.ts +2 -0
  222. package/dist/utils/array-utils.test.d.ts.map +1 -0
  223. package/dist/utils/array-utils.test.js +107 -0
  224. package/dist/utils/domain-utils.d.ts +78 -0
  225. package/dist/utils/domain-utils.d.ts.map +1 -0
  226. package/dist/utils/domain-utils.js +218 -0
  227. package/dist/utils/domain-utils.test.d.ts +2 -0
  228. package/dist/utils/domain-utils.test.d.ts.map +1 -0
  229. package/dist/utils/domain-utils.test.js +192 -0
  230. package/dist/utils/function-utils.d.ts +45 -0
  231. package/dist/utils/function-utils.d.ts.map +1 -0
  232. package/dist/utils/function-utils.js +158 -0
  233. package/dist/utils/function-utils.test.d.ts +2 -0
  234. package/dist/utils/function-utils.test.d.ts.map +1 -0
  235. package/dist/utils/function-utils.test.js +110 -0
  236. package/dist/utils/pagination-utils.d.ts +37 -0
  237. package/dist/utils/pagination-utils.d.ts.map +1 -0
  238. package/dist/utils/pagination-utils.js +165 -0
  239. package/dist/utils/pagination-utils.test.d.ts +17 -0
  240. package/dist/utils/pagination-utils.test.d.ts.map +1 -0
  241. package/dist/utils/pagination-utils.test.js +461 -0
  242. package/dist/utils/schema-utils.d.ts +45 -0
  243. package/dist/utils/schema-utils.d.ts.map +1 -0
  244. package/dist/utils/schema-utils.js +65 -0
  245. package/dist/utils/validation.d.ts +4 -0
  246. package/dist/utils/validation.d.ts.map +1 -0
  247. package/dist/utils/validation.js +30 -0
  248. package/dist/utils/validation.test.d.ts +2 -0
  249. package/dist/utils/validation.test.d.ts.map +1 -0
  250. package/dist/utils/validation.test.js +43 -0
  251. package/package.json +12 -3
  252. package/src/api/client.ts +403 -167
  253. package/src/api/debug.ts +10 -1
  254. package/src/api/index.ts +0 -2
  255. package/src/api/polling.ts +31 -14
  256. package/src/api/schemas.ts +387 -0
  257. package/src/api/types.ts +73 -138
  258. package/src/constants.ts +10 -0
  259. package/src/index.ts +45 -20
  260. package/src/plugins/api/index.ts +47 -0
  261. package/src/plugins/apps/index.ts +36 -31
  262. package/src/plugins/apps/types.ts +24 -12
  263. package/src/plugins/fetch/index.ts +58 -0
  264. package/src/plugins/findFirstAuthentication/index.test.ts +206 -0
  265. package/src/plugins/findFirstAuthentication/index.ts +55 -0
  266. package/src/plugins/findFirstAuthentication/schemas.ts +41 -0
  267. package/src/plugins/findUniqueAuthentication/index.test.ts +197 -0
  268. package/src/plugins/findUniqueAuthentication/index.ts +72 -0
  269. package/src/plugins/findUniqueAuthentication/schemas.ts +42 -0
  270. package/src/plugins/getAction/index.test.ts +239 -0
  271. package/src/plugins/getAction/index.ts +57 -0
  272. package/src/plugins/getAction/schemas.ts +33 -0
  273. package/src/plugins/getApp/index.test.ts +127 -0
  274. package/src/plugins/getApp/index.ts +66 -0
  275. package/src/plugins/getApp/schemas.ts +38 -0
  276. package/src/plugins/getAuthentication/index.test.ts +284 -0
  277. package/src/plugins/getAuthentication/index.ts +86 -0
  278. package/src/plugins/getAuthentication/schemas.ts +31 -0
  279. package/src/plugins/getProfile/index.ts +55 -0
  280. package/src/plugins/getProfile/schemas.ts +26 -0
  281. package/src/plugins/listActions/index.test.ts +582 -0
  282. package/src/plugins/listActions/index.ts +115 -0
  283. package/src/plugins/listActions/schemas.ts +54 -0
  284. package/src/plugins/listApps/index.test.ts +357 -0
  285. package/src/plugins/listApps/index.ts +121 -0
  286. package/src/plugins/listApps/schemas.ts +49 -0
  287. package/src/plugins/listAuthentications/index.test.ts +709 -0
  288. package/src/plugins/listAuthentications/index.ts +136 -0
  289. package/src/plugins/listAuthentications/schemas.ts +60 -0
  290. package/src/plugins/listInputFields/index.test.ts +408 -0
  291. package/src/plugins/listInputFields/index.ts +204 -0
  292. package/src/plugins/listInputFields/schemas.ts +56 -0
  293. package/src/plugins/registry/index.ts +30 -0
  294. package/src/plugins/request/index.test.ts +329 -0
  295. package/src/plugins/request/index.ts +103 -0
  296. package/src/plugins/request/schemas.ts +64 -0
  297. package/src/plugins/runAction/index.test.ts +387 -0
  298. package/src/plugins/runAction/index.ts +176 -0
  299. package/src/plugins/runAction/schemas.ts +53 -0
  300. package/src/resolvers/actionKey.ts +6 -4
  301. package/src/resolvers/actionType.ts +7 -2
  302. package/src/resolvers/appKey.ts +1 -1
  303. package/src/resolvers/authenticationId.ts +12 -3
  304. package/src/resolvers/inputs.ts +3 -1
  305. package/src/schemas/Action.ts +18 -12
  306. package/src/schemas/App.ts +11 -19
  307. package/src/schemas/Auth.ts +18 -13
  308. package/src/schemas/Field.ts +106 -11
  309. package/src/schemas/UserProfile.ts +43 -0
  310. package/src/sdk.test.ts +212 -0
  311. package/src/sdk.ts +133 -105
  312. package/src/types/domain.test.ts +50 -0
  313. package/src/types/domain.ts +43 -75
  314. package/src/types/errors.ts +275 -0
  315. package/src/types/functions.ts +27 -0
  316. package/src/types/optional-zapier-sdk-cli-login.d.ts +37 -0
  317. package/src/types/plugin.ts +105 -0
  318. package/src/types/properties.ts +4 -3
  319. package/src/types/sdk.ts +71 -46
  320. package/src/utils/array-utils.test.ts +131 -0
  321. package/src/utils/array-utils.ts +41 -0
  322. package/src/utils/domain-utils.test.ts +239 -0
  323. package/src/utils/domain-utils.ts +283 -0
  324. package/src/utils/function-utils.test.ts +141 -0
  325. package/src/utils/function-utils.ts +245 -0
  326. package/src/utils/pagination-utils.test.ts +620 -0
  327. package/src/utils/pagination-utils.ts +242 -0
  328. package/src/utils/validation.test.ts +50 -0
  329. package/src/utils/validation.ts +44 -0
  330. package/tsconfig.build.json +16 -2
  331. package/tsconfig.json +3 -1
  332. package/tsconfig.tsbuildinfo +1 -0
  333. package/tsup.config.ts +2 -0
  334. package/src/functions/bundleCode/index.ts +0 -78
  335. package/src/functions/bundleCode/info.ts +0 -9
  336. package/src/functions/bundleCode/schemas.ts +0 -30
  337. package/src/functions/fetch/index.ts +0 -180
  338. package/src/functions/fetch/info.ts +0 -8
  339. package/src/functions/fetch/schemas.ts +0 -46
  340. package/src/functions/findFirstAuthentication/index.ts +0 -24
  341. package/src/functions/findFirstAuthentication/info.ts +0 -9
  342. package/src/functions/findFirstAuthentication/schemas.ts +0 -50
  343. package/src/functions/findUniqueAuthentication/index.ts +0 -35
  344. package/src/functions/findUniqueAuthentication/info.ts +0 -9
  345. package/src/functions/findUniqueAuthentication/schemas.ts +0 -50
  346. package/src/functions/generateTypes/index.ts +0 -363
  347. package/src/functions/generateTypes/info.ts +0 -9
  348. package/src/functions/generateTypes/schemas.ts +0 -31
  349. package/src/functions/getAction/index.ts +0 -33
  350. package/src/functions/getAction/info.ts +0 -9
  351. package/src/functions/getAction/schemas.ts +0 -25
  352. package/src/functions/getApp/index.ts +0 -41
  353. package/src/functions/getApp/info.ts +0 -9
  354. package/src/functions/getApp/schemas.ts +0 -20
  355. package/src/functions/getAuthentication/index.ts +0 -50
  356. package/src/functions/getAuthentication/info.ts +0 -9
  357. package/src/functions/getAuthentication/schemas.ts +0 -29
  358. package/src/functions/listActions/index.ts +0 -149
  359. package/src/functions/listActions/info.ts +0 -9
  360. package/src/functions/listActions/schemas.ts +0 -30
  361. package/src/functions/listApps/index.ts +0 -60
  362. package/src/functions/listApps/info.ts +0 -9
  363. package/src/functions/listApps/schemas.ts +0 -32
  364. package/src/functions/listAuthentications/index.ts +0 -162
  365. package/src/functions/listAuthentications/info.ts +0 -9
  366. package/src/functions/listAuthentications/schemas.ts +0 -50
  367. package/src/functions/listFields/index.ts +0 -86
  368. package/src/functions/listFields/info.ts +0 -9
  369. package/src/functions/listFields/schemas.ts +0 -36
  370. package/src/functions/runAction/index.ts +0 -127
  371. package/src/functions/runAction/info.ts +0 -9
  372. package/src/functions/runAction/schemas.ts +0 -34
  373. package/src/plugins/apps/info.ts +0 -12
  374. /package/src/{schema-utils.ts → utils/schema-utils.ts} +0 -0
@@ -1,149 +0,0 @@
1
- import { getOrCreateApiClient } from "../../api";
2
- import type { Action } from "../../types/domain";
3
- import { getApp } from "../getApp";
4
- import type { ListActionsOptions } from "./schemas";
5
-
6
- /**
7
- * List available actions with optional filtering
8
- *
9
- * This function can be used standalone without instantiating a full SDK,
10
- * which enables better tree-shaking in applications that only need this functionality.
11
- *
12
- * @param options - Filtering and API configuration options
13
- * @returns Promise<Action[]> with pagination metadata
14
- */
15
- export async function listActions(
16
- options: Partial<ListActionsOptions> = {},
17
- ): Promise<Action[]> {
18
- const api = getOrCreateApiClient(options);
19
-
20
- // If filtering by appKey, use optimized approach with selected_apis parameter
21
- if (options.appKey) {
22
- try {
23
- // Use the standalone getApp function
24
- const appData = await getApp({
25
- appKey: options.appKey,
26
- api,
27
- token: options.token,
28
- baseUrl: options.baseUrl,
29
- debug: options.debug,
30
- fetch: options.fetch,
31
- });
32
-
33
- // Extract implementation name from current_implementation_id (e.g., "SlackCLIAPI@1.20.0" -> "SlackCLIAPI")
34
- const implementationId = appData.current_implementation_id?.split("@")[0];
35
- if (!implementationId) {
36
- throw new Error("No current_implementation_id found for app");
37
- }
38
-
39
- const searchParams = {
40
- global: "true",
41
- public_only: "true",
42
- selected_apis: implementationId,
43
- };
44
-
45
- const data = await api.get("/api/v4/implementations/", {
46
- searchParams,
47
- });
48
- const actions: Action[] = [];
49
-
50
- // Transform implementations to actions
51
- for (const implementation of data.results || []) {
52
- if (implementation.actions) {
53
- for (const action of implementation.actions) {
54
- const transformedAction: Action = {
55
- key: action.key,
56
- name: action.name || action.label,
57
- description: action.description || "",
58
- appKey: implementation.slug || "",
59
- type: action.type || action.type_of || "read",
60
- inputFields: [], // Would need additional API call for detailed fields
61
- outputFields: [],
62
- };
63
-
64
- // Apply type filter if provided
65
- if (options?.type && transformedAction.type !== options.type) {
66
- continue;
67
- }
68
-
69
- actions.push(transformedAction);
70
- }
71
- }
72
- }
73
-
74
- // Add pagination metadata for app-specific queries
75
- if (actions.length > 0) {
76
- (actions as any).__pagination = {
77
- count: data.count,
78
- hasNext: !!data.next,
79
- hasPrevious: !!data.previous,
80
- nextUrl: data.next,
81
- previousUrl: data.previous,
82
- };
83
- }
84
-
85
- return actions;
86
- } catch (error) {
87
- // If it's an AppNotFoundError, don't try fallback - just re-throw
88
- if (error instanceof Error && error.name === "AppNotFoundError") {
89
- throw error;
90
- }
91
- // Fallback to original approach if optimized approach fails
92
- console.warn(
93
- "Optimized app lookup failed, falling back to full scan:",
94
- error,
95
- );
96
- }
97
- }
98
-
99
- // Original approach for general queries or when optimization fails
100
- const searchParams = {
101
- global: "true",
102
- public_only: "true",
103
- };
104
-
105
- const data = await api.get("/api/v4/implementations/", { searchParams });
106
- const actions: Action[] = [];
107
-
108
- // Transform implementations to actions
109
- for (const implementation of data.results || []) {
110
- if (implementation.actions) {
111
- for (const action of implementation.actions) {
112
- const transformedAction: Action = {
113
- key: action.key,
114
- name: action.name || action.label,
115
- description: action.description || "",
116
- appKey: implementation.slug || "",
117
- type: action.type || action.type_of || "read",
118
- inputFields: [], // Would need additional API call for detailed fields
119
- outputFields: [],
120
- };
121
-
122
- // Apply filters
123
- if (options?.appKey && transformedAction.appKey !== options.appKey) {
124
- continue;
125
- }
126
- if (options?.type && transformedAction.type !== options.type) {
127
- continue;
128
- }
129
-
130
- actions.push(transformedAction);
131
- }
132
- }
133
- }
134
-
135
- // Add pagination metadata for general queries
136
- if (actions.length > 0) {
137
- (actions as any).__pagination = {
138
- count: data.count,
139
- hasNext: !!data.next,
140
- hasPrevious: !!data.previous,
141
- nextUrl: data.next,
142
- previousUrl: data.previous,
143
- };
144
- }
145
-
146
- return actions;
147
- }
148
-
149
- // No registry info here - moved to info.ts for proper tree-shaking
@@ -1,9 +0,0 @@
1
- import { listActions } from "./index";
2
- import { ListActionsSchema } from "./schemas";
3
-
4
- // Function registry info - imports both function and schema
5
- export const listActionsInfo = {
6
- name: listActions.name,
7
- inputSchema: ListActionsSchema,
8
- implementation: listActions,
9
- };
@@ -1,30 +0,0 @@
1
- import { z } from "zod";
2
- import {
3
- AppKeyPropertySchema,
4
- ActionTypePropertySchema,
5
- } from "../../types/properties";
6
- import { withOutputSchema } from "../../schema-utils";
7
- import { ActionItemSchema } from "../../schemas/Action";
8
- import type { Action, FunctionOptions } from "../../types/domain";
9
-
10
- // Pure Zod schema - no resolver metadata!
11
- export const ListActionsSchema = withOutputSchema(
12
- z
13
- .object({
14
- appKey: AppKeyPropertySchema.optional(),
15
- type: ActionTypePropertySchema.optional().describe(
16
- "Filter actions by type",
17
- ),
18
- })
19
- .describe("List all actions for a specific app"),
20
- ActionItemSchema,
21
- );
22
-
23
- // Type inferred from schema + function config
24
- export type ListActionsOptions = z.infer<typeof ListActionsSchema> &
25
- FunctionOptions;
26
-
27
- // SDK function interface - ready to be mixed into main SDK interface
28
- export interface ListActionsSdkFunction {
29
- listActions: (options?: Partial<ListActionsOptions>) => Promise<Action[]>;
30
- }
@@ -1,60 +0,0 @@
1
- import { getOrCreateApiClient } from "../../api";
2
- import type { Integration } from "../../types/domain";
3
- import type { ListAppsOptions } from "./schemas";
4
-
5
- /**
6
- * List available apps with optional filtering
7
- *
8
- * This function can be used standalone without instantiating a full SDK,
9
- * which enables better tree-shaking in applications that only need this functionality.
10
- *
11
- * @param options - Filtering, pagination, and API configuration options
12
- * @returns Promise<Integration[]> with pagination metadata
13
- */
14
- export async function listApps(
15
- options: ListAppsOptions = {},
16
- ): Promise<Integration[]> {
17
- const api = getOrCreateApiClient(options);
18
-
19
- // Build search parameters
20
- const searchParams: Record<string, string> = {};
21
- if (options.category) {
22
- searchParams.category = options.category;
23
- }
24
- if (options.limit) {
25
- searchParams.limit = options.limit.toString();
26
- }
27
- if (options.offset) {
28
- searchParams.offset = options.offset.toString();
29
- }
30
-
31
- const data = await api.get("/api/v4/apps/", { searchParams });
32
-
33
- // Transform API response to our Integration interface
34
- const apps =
35
- data.results?.map(
36
- (app: any): Integration => ({
37
- key: app.slug,
38
- name: app.name,
39
- description: app.description,
40
- version: "1.0.0", // API doesn't provide version
41
- category: app.category?.name,
42
- actions: [], // Will be populated separately
43
- triggers: [],
44
- current_implementation_id: app.current_implementation_id,
45
- }),
46
- ) || [];
47
-
48
- // Add pagination metadata to the response
49
- if (apps.length > 0) {
50
- (apps as any).__pagination = {
51
- count: data.count,
52
- hasNext: !!data.next,
53
- hasPrevious: !!data.previous,
54
- nextUrl: data.next,
55
- previousUrl: data.previous,
56
- };
57
- }
58
-
59
- return apps;
60
- }
@@ -1,9 +0,0 @@
1
- import { listApps } from "./index";
2
- import { ListAppsSchema } from "./schemas";
3
-
4
- // Function registry info - imports both function and schema
5
- export const listAppsInfo = {
6
- name: listApps.name,
7
- inputSchema: ListAppsSchema,
8
- implementation: listApps,
9
- };
@@ -1,32 +0,0 @@
1
- import { z } from "zod";
2
- import {
3
- LimitPropertySchema,
4
- OffsetPropertySchema,
5
- } from "../../types/properties";
6
- import { withOutputSchema } from "../../schema-utils";
7
- import { AppItemSchema } from "../../schemas/App";
8
- import type { Integration, FunctionOptions } from "../../types/domain";
9
-
10
- // Pure Zod schema - no resolver metadata!
11
- export const ListAppsSchema = withOutputSchema(
12
- z
13
- .object({
14
- category: z.string().optional().describe("Filter apps by category"),
15
- limit: LimitPropertySchema.optional().describe(
16
- "Maximum number of items to return (1-200)",
17
- ),
18
- offset: OffsetPropertySchema.optional().describe(
19
- "Number of items to skip for pagination",
20
- ),
21
- })
22
- .describe("List all available apps with optional filtering"),
23
- AppItemSchema,
24
- );
25
-
26
- // Type inferred from schema + function config
27
- export type ListAppsOptions = z.infer<typeof ListAppsSchema> & FunctionOptions;
28
-
29
- // SDK function interface - ready to be mixed into main SDK interface
30
- export interface ListAppsSdkFunction {
31
- listApps: (options?: Partial<ListAppsOptions>) => Promise<Integration[]>;
32
- }
@@ -1,162 +0,0 @@
1
- import { getOrCreateApiClient } from "../../api";
2
- import type {
3
- Authentication,
4
- AuthenticationsResponse,
5
- } from "../../types/domain";
6
- import { getApp } from "../getApp";
7
- import type { ListAuthenticationsOptions } from "./schemas";
8
-
9
- /**
10
- * List available authentications with optional filtering
11
- *
12
- * This function can be used standalone without instantiating a full SDK,
13
- * which enables better tree-shaking in applications that only need this functionality.
14
- *
15
- * @param options - Filtering, pagination, and API configuration options
16
- * @returns Promise<Authentication[]> with pagination metadata
17
- */
18
- export async function listAuthentications(
19
- options: Partial<ListAuthenticationsOptions> = {},
20
- ): Promise<Authentication[]> {
21
- const api = getOrCreateApiClient(options);
22
-
23
- // Local function to handle the actual API fetching
24
- const listAuthenticationsInternal = async (
25
- options: ListAuthenticationsOptions = {},
26
- ): Promise<Authentication[]> => {
27
- // Build search parameters
28
- const searchParams: Record<string, string> = {};
29
-
30
- // Handle appKey filtering by getting the selected_api first
31
- if (options.appKey) {
32
- try {
33
- // Use the standalone getApp function
34
- const app = await getApp({
35
- appKey: options.appKey,
36
- api,
37
- token: options.token,
38
- baseUrl: options.baseUrl,
39
- debug: options.debug,
40
- fetch: options.fetch,
41
- });
42
- const selectedApi = app.current_implementation_id;
43
- if (selectedApi) {
44
- // Use versionless_selected_api to find auths across all app versions
45
- // Extract the base name without the version (e.g., "SlackCLIAPI" from "SlackCLIAPI@1.21.1")
46
- const versionlessApi = selectedApi.split("@")[0];
47
- searchParams.versionless_selected_api = versionlessApi;
48
- }
49
- } catch (error) {
50
- // If it's an AppNotFoundError, re-throw it
51
- if (error instanceof Error && error.name === "AppNotFoundError") {
52
- throw error;
53
- }
54
- // For other errors, continue without app filtering
55
- console.warn(
56
- `Warning: Could not filter by app ${options.appKey}:`,
57
- error instanceof Error ? error.message : "Unknown error",
58
- );
59
- }
60
- }
61
-
62
- // Add other query parameters if provided
63
- // Use title as search if no explicit search provided
64
- if (options.search) {
65
- searchParams.search = options.search;
66
- } else if (options.title) {
67
- searchParams.search = options.title;
68
- }
69
- if (options.account_id) {
70
- searchParams.account_id = options.account_id;
71
- }
72
- if (options.owner) {
73
- searchParams.owner = options.owner;
74
- }
75
- if (options.limit) {
76
- searchParams.limit = options.limit.toString();
77
- }
78
- if (options.offset) {
79
- searchParams.offset = options.offset.toString();
80
- }
81
-
82
- const data: AuthenticationsResponse = await api.get(
83
- "/api/v4/authentications/",
84
- {
85
- searchParams,
86
- customErrorHandler: (response) => {
87
- if (response.status === 401) {
88
- return new Error(
89
- `Authentication failed. Your token may not have permission to access authentications or may be expired. (HTTP ${response.status})`,
90
- );
91
- }
92
- if (response.status === 403) {
93
- return new Error(
94
- `Access forbidden. Your token may not have the required scopes to list authentications. (HTTP ${response.status})`,
95
- );
96
- }
97
- return undefined;
98
- },
99
- },
100
- );
101
-
102
- // Transform API response
103
- let auths = data.results || [];
104
-
105
- // Coerce title from label if title is missing (API cleanup)
106
- auths = auths.map((auth) => ({
107
- ...auth,
108
- title: auth.title || (auth as any).label || undefined,
109
- }));
110
-
111
- // Filter by exact title match if specified
112
- if (options.title) {
113
- auths = auths.filter((auth) => auth.title === options.title);
114
- }
115
-
116
- // Add pagination metadata to the response
117
- if (auths.length > 0) {
118
- (auths as any).__pagination = {
119
- count: data.count,
120
- hasNext: !!data.next,
121
- hasPrevious: !!data.previous,
122
- nextUrl: data.next,
123
- previousUrl: data.previous,
124
- };
125
- }
126
-
127
- return auths;
128
- };
129
-
130
- // If a limit is provided and no specific owner filter, prioritize owned auths
131
- if (options.limit && options.owner === undefined) {
132
- // First get owned auths
133
- const ownedAuths = await listAuthenticationsInternal({
134
- ...options,
135
- owner: "me",
136
- });
137
-
138
- // If we have enough owned auths, just slice and return
139
- if (ownedAuths.length >= options.limit) {
140
- return ownedAuths.slice(0, options.limit);
141
- }
142
-
143
- // Get all auths up to the original limit to fill remaining slots
144
- const allAuths = await listAuthenticationsInternal({
145
- ...options,
146
- owner: undefined,
147
- });
148
-
149
- // Filter out auths the user already owns to avoid duplicates
150
- const ownedAuthenticationIds = new Set(ownedAuths.map((auth) => auth.id));
151
- const additionalAuths = allAuths.filter(
152
- (auth) => !ownedAuthenticationIds.has(auth.id),
153
- );
154
-
155
- // Combine and slice to the requested limit
156
- const combined = [...ownedAuths, ...additionalAuths];
157
- return combined.slice(0, options.limit);
158
- }
159
-
160
- // Standard implementation for non-prioritized requests
161
- return listAuthenticationsInternal(options);
162
- }
@@ -1,9 +0,0 @@
1
- import { listAuthentications } from "./index";
2
- import { ListAuthenticationsSchema } from "./schemas";
3
-
4
- // Function registry info - imports both function and schema
5
- export const listAuthenticationsInfo = {
6
- name: listAuthentications.name,
7
- inputSchema: ListAuthenticationsSchema,
8
- implementation: listAuthentications,
9
- };
@@ -1,50 +0,0 @@
1
- import { z } from "zod";
2
- import {
3
- AppKeyPropertySchema,
4
- LimitPropertySchema,
5
- OffsetPropertySchema,
6
- } from "../../types/properties";
7
- import { withOutputSchema } from "../../schema-utils";
8
- import { AuthItemSchema } from "../../schemas/Auth";
9
- import type { Authentication, FunctionOptions } from "../../types/domain";
10
-
11
- // Pure Zod schema - no resolver metadata!
12
- export const ListAuthenticationsSchema = withOutputSchema(
13
- z
14
- .object({
15
- appKey: AppKeyPropertySchema.optional().describe(
16
- "App slug to get authentications for (e.g., 'slack', 'github')",
17
- ),
18
- search: z
19
- .string()
20
- .optional()
21
- .describe("Search term to filter authentications by title"),
22
- title: z
23
- .string()
24
- .optional()
25
- .describe("Filter authentications by exact title match"),
26
- account_id: z.string().optional().describe("Filter by account ID"),
27
- owner: z.string().optional().describe("Filter by owner"),
28
- limit: LimitPropertySchema.optional().describe(
29
- "Maximum number of items to return (1-200)",
30
- ),
31
- offset: OffsetPropertySchema.optional().describe(
32
- "Number of items to skip for pagination",
33
- ),
34
- })
35
- .describe("List available authentications with optional filtering"),
36
- AuthItemSchema,
37
- );
38
-
39
- // Type inferred from schema + function config
40
- export type ListAuthenticationsOptions = z.infer<
41
- typeof ListAuthenticationsSchema
42
- > &
43
- FunctionOptions;
44
-
45
- // SDK function interface - ready to be mixed into main SDK interface
46
- export interface ListAuthenticationsSdkFunction {
47
- listAuthentications: (
48
- options?: Partial<ListAuthenticationsOptions>,
49
- ) => Promise<Authentication[]>;
50
- }
@@ -1,86 +0,0 @@
1
- import { getOrCreateApiClient } from "../../api";
2
- import type {
3
- ActionField,
4
- NeedsRequest,
5
- NeedsResponse,
6
- } from "../../types/domain";
7
- import { getApp } from "../getApp";
8
- import type { ListFieldsOptions } from "./schemas";
9
-
10
- /**
11
- * List available fields for an action
12
- *
13
- * This function can be used standalone without instantiating a full SDK,
14
- * which enables better tree-shaking in applications that only need this functionality.
15
- *
16
- * @param options - Action details, authentication ID, params, and API configuration options
17
- * @returns Promise<ActionField[]>
18
- */
19
- export async function listFields(
20
- options: ListFieldsOptions,
21
- ): Promise<ActionField[]> {
22
- const api = getOrCreateApiClient(options);
23
-
24
- // Extract parameters
25
- const { appKey, actionKey, actionType, authenticationId, params } = options;
26
-
27
- // Use the standalone getApp function
28
- const appData = await getApp({
29
- appKey,
30
- api,
31
- token: options.token,
32
- baseUrl: options.baseUrl,
33
- debug: options.debug,
34
- fetch: options.fetch,
35
- });
36
- const selectedApi = appData.current_implementation_id;
37
-
38
- if (!selectedApi) {
39
- throw new Error("No current_implementation_id found for app");
40
- }
41
-
42
- // Build needs request
43
- const needsRequest: NeedsRequest = {
44
- selected_api: selectedApi,
45
- action: actionKey,
46
- type_of: actionType,
47
- authentication_id: authenticationId,
48
- params: params || {},
49
- };
50
-
51
- const needsData: NeedsResponse = await api.post(
52
- "/api/v4/implementations/needs/",
53
- needsRequest,
54
- );
55
-
56
- if (!needsData.success) {
57
- throw new Error(
58
- `Failed to get action fields: ${
59
- needsData.errors?.join(", ") || "Unknown error"
60
- }`,
61
- );
62
- }
63
-
64
- // Transform API response to our ActionField interface
65
- return (needsData.needs || []).map((need: any) => ({
66
- key: need.key,
67
- label: need.label,
68
- required: need.required || false,
69
- type: need.type,
70
- helpText: need.help_text,
71
- helpTextHtml: need.help_text_html,
72
- choices: need.choices?.map((choice: any) => ({
73
- value: choice.value,
74
- label: choice.label,
75
- })),
76
- default: need.default,
77
- placeholder: need.placeholder,
78
- computed: need.computed,
79
- customField: need.custom_field,
80
- dependsOn: need.depends_on,
81
- format: need.format,
82
- inputFormat: need.input_format,
83
- }));
84
- }
85
-
86
- // No registry info here - moved to info.ts for proper tree-shaking
@@ -1,9 +0,0 @@
1
- import { listFields } from "./index";
2
- import { ListFieldsSchema } from "./schemas";
3
-
4
- // Function registry info - imports both function and schema
5
- export const listFieldsInfo = {
6
- name: listFields.name,
7
- inputSchema: ListFieldsSchema,
8
- implementation: listFields,
9
- };
@@ -1,36 +0,0 @@
1
- import { z } from "zod";
2
- import {
3
- AppKeyPropertySchema,
4
- ActionTypePropertySchema,
5
- ActionKeyPropertySchema,
6
- AuthenticationIdPropertySchema,
7
- ParamsPropertySchema,
8
- } from "../../types/properties";
9
- import { withOutputSchema } from "../../schema-utils";
10
- import { FieldItemSchema } from "../../schemas/Field";
11
- import type { ActionField, FunctionOptions } from "../../types/domain";
12
-
13
- // Pure Zod schema - no resolver metadata!
14
- export const ListFieldsSchema = withOutputSchema(
15
- z
16
- .object({
17
- appKey: AppKeyPropertySchema,
18
- actionType: ActionTypePropertySchema,
19
- actionKey: ActionKeyPropertySchema,
20
- authenticationId: AuthenticationIdPropertySchema.optional(),
21
- params: ParamsPropertySchema.optional().describe(
22
- "Additional parameters that may affect available fields",
23
- ),
24
- })
25
- .describe("Get the input fields required for a specific action"),
26
- FieldItemSchema,
27
- );
28
-
29
- // Type inferred from schema + function config
30
- export type ListFieldsOptions = z.infer<typeof ListFieldsSchema> &
31
- FunctionOptions;
32
-
33
- // SDK function interface - ready to be mixed into main SDK interface
34
- export interface ListFieldsSdkFunction {
35
- listFields: (options: ListFieldsOptions) => Promise<ActionField[]>;
36
- }