@zavudev/sdk-mcp 0.15.1 → 0.17.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 (476) hide show
  1. package/README.md +13 -228
  2. package/code-tool.d.mts +2 -44
  3. package/code-tool.d.mts.map +1 -1
  4. package/code-tool.d.ts +2 -44
  5. package/code-tool.d.ts.map +1 -1
  6. package/code-tool.js +2 -2
  7. package/code-tool.js.map +1 -1
  8. package/code-tool.mjs +2 -2
  9. package/code-tool.mjs.map +1 -1
  10. package/docs-search-tool.d.mts +3 -3
  11. package/docs-search-tool.d.mts.map +1 -1
  12. package/docs-search-tool.d.ts +3 -3
  13. package/docs-search-tool.d.ts.map +1 -1
  14. package/docs-search-tool.js +1 -1
  15. package/docs-search-tool.js.map +1 -1
  16. package/docs-search-tool.mjs +1 -1
  17. package/http.d.mts.map +1 -1
  18. package/http.d.ts.map +1 -1
  19. package/http.js +1 -18
  20. package/http.js.map +1 -1
  21. package/http.mjs +1 -18
  22. package/http.mjs.map +1 -1
  23. package/index.js +4 -40
  24. package/index.js.map +1 -1
  25. package/index.mjs +4 -40
  26. package/index.mjs.map +1 -1
  27. package/options.d.mts +0 -9
  28. package/options.d.mts.map +1 -1
  29. package/options.d.ts +0 -9
  30. package/options.d.ts.map +1 -1
  31. package/options.js +4 -359
  32. package/options.js.map +1 -1
  33. package/options.mjs +4 -359
  34. package/options.mjs.map +1 -1
  35. package/package.json +9 -49
  36. package/server.d.mts +3 -8
  37. package/server.d.mts.map +1 -1
  38. package/server.d.ts +3 -8
  39. package/server.d.ts.map +1 -1
  40. package/server.js +12 -65
  41. package/server.js.map +1 -1
  42. package/server.mjs +11 -62
  43. package/server.mjs.map +1 -1
  44. package/src/code-tool.ts +2 -2
  45. package/src/docs-search-tool.ts +1 -1
  46. package/src/http.ts +1 -19
  47. package/src/index.ts +5 -52
  48. package/src/options.ts +5 -386
  49. package/src/server.ts +12 -72
  50. package/src/stdio.ts +2 -3
  51. package/src/{tools/types.ts → types.ts} +1 -1
  52. package/stdio.d.mts +1 -2
  53. package/stdio.d.mts.map +1 -1
  54. package/stdio.d.ts +1 -2
  55. package/stdio.d.ts.map +1 -1
  56. package/stdio.js +2 -2
  57. package/stdio.js.map +1 -1
  58. package/stdio.mjs +2 -2
  59. package/stdio.mjs.map +1 -1
  60. package/{tools/types.d.mts → types.d.mts} +1 -1
  61. package/types.d.mts.map +1 -0
  62. package/{tools/types.d.ts → types.d.ts} +1 -1
  63. package/types.d.ts.map +1 -0
  64. package/types.js.map +1 -0
  65. package/types.mjs.map +1 -0
  66. package/compat.d.mts +0 -58
  67. package/compat.d.mts.map +0 -1
  68. package/compat.d.ts +0 -58
  69. package/compat.d.ts.map +0 -1
  70. package/compat.js +0 -387
  71. package/compat.js.map +0 -1
  72. package/compat.mjs +0 -378
  73. package/compat.mjs.map +0 -1
  74. package/dynamic-tools.d.mts +0 -12
  75. package/dynamic-tools.d.mts.map +0 -1
  76. package/dynamic-tools.d.ts +0 -12
  77. package/dynamic-tools.d.ts.map +0 -1
  78. package/dynamic-tools.js +0 -135
  79. package/dynamic-tools.js.map +0 -1
  80. package/dynamic-tools.mjs +0 -132
  81. package/dynamic-tools.mjs.map +0 -1
  82. package/filtering.d.mts +0 -3
  83. package/filtering.d.mts.map +0 -1
  84. package/filtering.d.ts +0 -3
  85. package/filtering.d.ts.map +0 -1
  86. package/filtering.js +0 -24
  87. package/filtering.js.map +0 -1
  88. package/filtering.mjs +0 -16
  89. package/filtering.mjs.map +0 -1
  90. package/src/compat.ts +0 -483
  91. package/src/dynamic-tools.ts +0 -153
  92. package/src/filtering.ts +0 -18
  93. package/src/tools/broadcasts/cancel-broadcasts.ts +0 -52
  94. package/src/tools/broadcasts/contacts/add-broadcasts-contacts.ts +0 -73
  95. package/src/tools/broadcasts/contacts/list-broadcasts-contacts.ts +0 -71
  96. package/src/tools/broadcasts/contacts/remove-broadcasts-contacts.ts +0 -43
  97. package/src/tools/broadcasts/create-broadcasts.ts +0 -134
  98. package/src/tools/broadcasts/delete-broadcasts.ts +0 -40
  99. package/src/tools/broadcasts/list-broadcasts.ts +0 -68
  100. package/src/tools/broadcasts/progress-broadcasts.ts +0 -54
  101. package/src/tools/broadcasts/retrieve-broadcasts.ts +0 -54
  102. package/src/tools/broadcasts/send-broadcasts.ts +0 -57
  103. package/src/tools/broadcasts/update-broadcasts.ts +0 -106
  104. package/src/tools/contacts/list-contacts.ts +0 -61
  105. package/src/tools/contacts/retrieve-by-phone-contacts.ts +0 -56
  106. package/src/tools/contacts/retrieve-contacts.ts +0 -54
  107. package/src/tools/contacts/update-contacts.ts +0 -61
  108. package/src/tools/index.ts +0 -149
  109. package/src/tools/introspect/validate-phone-introspect.ts +0 -52
  110. package/src/tools/messages/list-messages.ts +0 -78
  111. package/src/tools/messages/react-messages.ts +0 -59
  112. package/src/tools/messages/retrieve-messages.ts +0 -54
  113. package/src/tools/messages/send-messages.ts +0 -233
  114. package/src/tools/phone-numbers/list-phone-numbers.ts +0 -68
  115. package/src/tools/phone-numbers/purchase-phone-numbers.ts +0 -57
  116. package/src/tools/phone-numbers/release-phone-numbers.ts +0 -40
  117. package/src/tools/phone-numbers/retrieve-phone-numbers.ts +0 -56
  118. package/src/tools/phone-numbers/search-available-phone-numbers.ts +0 -72
  119. package/src/tools/phone-numbers/update-phone-numbers.ts +0 -62
  120. package/src/tools/senders/create-senders.ts +0 -86
  121. package/src/tools/senders/delete-senders.ts +0 -40
  122. package/src/tools/senders/get-profile-senders.ts +0 -54
  123. package/src/tools/senders/list-senders.ts +0 -58
  124. package/src/tools/senders/regenerate-webhook-secret-senders.ts +0 -54
  125. package/src/tools/senders/retrieve-senders.ts +0 -54
  126. package/src/tools/senders/update-profile-senders.ts +0 -107
  127. package/src/tools/senders/update-senders.ts +0 -90
  128. package/src/tools/senders/upload-profile-picture-senders.ts +0 -63
  129. package/src/tools/templates/create-templates.ts +0 -74
  130. package/src/tools/templates/delete-templates.ts +0 -40
  131. package/src/tools/templates/list-templates.ts +0 -58
  132. package/src/tools/templates/retrieve-templates.ts +0 -54
  133. package/src/tools/templates/submit-templates.ts +0 -66
  134. package/src/tools.ts +0 -1
  135. package/tools/broadcasts/cancel-broadcasts.d.mts +0 -51
  136. package/tools/broadcasts/cancel-broadcasts.d.mts.map +0 -1
  137. package/tools/broadcasts/cancel-broadcasts.d.ts +0 -51
  138. package/tools/broadcasts/cancel-broadcasts.d.ts.map +0 -1
  139. package/tools/broadcasts/cancel-broadcasts.js +0 -52
  140. package/tools/broadcasts/cancel-broadcasts.js.map +0 -1
  141. package/tools/broadcasts/cancel-broadcasts.mjs +0 -45
  142. package/tools/broadcasts/cancel-broadcasts.mjs.map +0 -1
  143. package/tools/broadcasts/contacts/add-broadcasts-contacts.d.mts +0 -51
  144. package/tools/broadcasts/contacts/add-broadcasts-contacts.d.mts.map +0 -1
  145. package/tools/broadcasts/contacts/add-broadcasts-contacts.d.ts +0 -51
  146. package/tools/broadcasts/contacts/add-broadcasts-contacts.d.ts.map +0 -1
  147. package/tools/broadcasts/contacts/add-broadcasts-contacts.js +0 -71
  148. package/tools/broadcasts/contacts/add-broadcasts-contacts.js.map +0 -1
  149. package/tools/broadcasts/contacts/add-broadcasts-contacts.mjs +0 -64
  150. package/tools/broadcasts/contacts/add-broadcasts-contacts.mjs.map +0 -1
  151. package/tools/broadcasts/contacts/list-broadcasts-contacts.d.mts +0 -51
  152. package/tools/broadcasts/contacts/list-broadcasts-contacts.d.mts.map +0 -1
  153. package/tools/broadcasts/contacts/list-broadcasts-contacts.d.ts +0 -51
  154. package/tools/broadcasts/contacts/list-broadcasts-contacts.d.ts.map +0 -1
  155. package/tools/broadcasts/contacts/list-broadcasts-contacts.js +0 -71
  156. package/tools/broadcasts/contacts/list-broadcasts-contacts.js.map +0 -1
  157. package/tools/broadcasts/contacts/list-broadcasts-contacts.mjs +0 -64
  158. package/tools/broadcasts/contacts/list-broadcasts-contacts.mjs.map +0 -1
  159. package/tools/broadcasts/contacts/remove-broadcasts-contacts.d.mts +0 -51
  160. package/tools/broadcasts/contacts/remove-broadcasts-contacts.d.mts.map +0 -1
  161. package/tools/broadcasts/contacts/remove-broadcasts-contacts.d.ts +0 -51
  162. package/tools/broadcasts/contacts/remove-broadcasts-contacts.d.ts.map +0 -1
  163. package/tools/broadcasts/contacts/remove-broadcasts-contacts.js +0 -40
  164. package/tools/broadcasts/contacts/remove-broadcasts-contacts.js.map +0 -1
  165. package/tools/broadcasts/contacts/remove-broadcasts-contacts.mjs +0 -36
  166. package/tools/broadcasts/contacts/remove-broadcasts-contacts.mjs.map +0 -1
  167. package/tools/broadcasts/create-broadcasts.d.mts +0 -51
  168. package/tools/broadcasts/create-broadcasts.d.mts.map +0 -1
  169. package/tools/broadcasts/create-broadcasts.d.ts +0 -51
  170. package/tools/broadcasts/create-broadcasts.d.ts.map +0 -1
  171. package/tools/broadcasts/create-broadcasts.js +0 -134
  172. package/tools/broadcasts/create-broadcasts.js.map +0 -1
  173. package/tools/broadcasts/create-broadcasts.mjs +0 -127
  174. package/tools/broadcasts/create-broadcasts.mjs.map +0 -1
  175. package/tools/broadcasts/delete-broadcasts.d.mts +0 -51
  176. package/tools/broadcasts/delete-broadcasts.d.mts.map +0 -1
  177. package/tools/broadcasts/delete-broadcasts.d.ts +0 -51
  178. package/tools/broadcasts/delete-broadcasts.d.ts.map +0 -1
  179. package/tools/broadcasts/delete-broadcasts.js +0 -37
  180. package/tools/broadcasts/delete-broadcasts.js.map +0 -1
  181. package/tools/broadcasts/delete-broadcasts.mjs +0 -33
  182. package/tools/broadcasts/delete-broadcasts.mjs.map +0 -1
  183. package/tools/broadcasts/list-broadcasts.d.mts +0 -51
  184. package/tools/broadcasts/list-broadcasts.d.mts.map +0 -1
  185. package/tools/broadcasts/list-broadcasts.d.ts +0 -51
  186. package/tools/broadcasts/list-broadcasts.d.ts.map +0 -1
  187. package/tools/broadcasts/list-broadcasts.js +0 -68
  188. package/tools/broadcasts/list-broadcasts.js.map +0 -1
  189. package/tools/broadcasts/list-broadcasts.mjs +0 -61
  190. package/tools/broadcasts/list-broadcasts.mjs.map +0 -1
  191. package/tools/broadcasts/progress-broadcasts.d.mts +0 -51
  192. package/tools/broadcasts/progress-broadcasts.d.mts.map +0 -1
  193. package/tools/broadcasts/progress-broadcasts.d.ts +0 -51
  194. package/tools/broadcasts/progress-broadcasts.d.ts.map +0 -1
  195. package/tools/broadcasts/progress-broadcasts.js +0 -54
  196. package/tools/broadcasts/progress-broadcasts.js.map +0 -1
  197. package/tools/broadcasts/progress-broadcasts.mjs +0 -47
  198. package/tools/broadcasts/progress-broadcasts.mjs.map +0 -1
  199. package/tools/broadcasts/retrieve-broadcasts.d.mts +0 -51
  200. package/tools/broadcasts/retrieve-broadcasts.d.mts.map +0 -1
  201. package/tools/broadcasts/retrieve-broadcasts.d.ts +0 -51
  202. package/tools/broadcasts/retrieve-broadcasts.d.ts.map +0 -1
  203. package/tools/broadcasts/retrieve-broadcasts.js +0 -54
  204. package/tools/broadcasts/retrieve-broadcasts.js.map +0 -1
  205. package/tools/broadcasts/retrieve-broadcasts.mjs +0 -47
  206. package/tools/broadcasts/retrieve-broadcasts.mjs.map +0 -1
  207. package/tools/broadcasts/send-broadcasts.d.mts +0 -51
  208. package/tools/broadcasts/send-broadcasts.d.mts.map +0 -1
  209. package/tools/broadcasts/send-broadcasts.d.ts +0 -51
  210. package/tools/broadcasts/send-broadcasts.d.ts.map +0 -1
  211. package/tools/broadcasts/send-broadcasts.js +0 -57
  212. package/tools/broadcasts/send-broadcasts.js.map +0 -1
  213. package/tools/broadcasts/send-broadcasts.mjs +0 -50
  214. package/tools/broadcasts/send-broadcasts.mjs.map +0 -1
  215. package/tools/broadcasts/update-broadcasts.d.mts +0 -51
  216. package/tools/broadcasts/update-broadcasts.d.mts.map +0 -1
  217. package/tools/broadcasts/update-broadcasts.d.ts +0 -51
  218. package/tools/broadcasts/update-broadcasts.d.ts.map +0 -1
  219. package/tools/broadcasts/update-broadcasts.js +0 -104
  220. package/tools/broadcasts/update-broadcasts.js.map +0 -1
  221. package/tools/broadcasts/update-broadcasts.mjs +0 -97
  222. package/tools/broadcasts/update-broadcasts.mjs.map +0 -1
  223. package/tools/contacts/list-contacts.d.mts +0 -51
  224. package/tools/contacts/list-contacts.d.mts.map +0 -1
  225. package/tools/contacts/list-contacts.d.ts +0 -51
  226. package/tools/contacts/list-contacts.d.ts.map +0 -1
  227. package/tools/contacts/list-contacts.js +0 -61
  228. package/tools/contacts/list-contacts.js.map +0 -1
  229. package/tools/contacts/list-contacts.mjs +0 -54
  230. package/tools/contacts/list-contacts.mjs.map +0 -1
  231. package/tools/contacts/retrieve-by-phone-contacts.d.mts +0 -51
  232. package/tools/contacts/retrieve-by-phone-contacts.d.mts.map +0 -1
  233. package/tools/contacts/retrieve-by-phone-contacts.d.ts +0 -51
  234. package/tools/contacts/retrieve-by-phone-contacts.d.ts.map +0 -1
  235. package/tools/contacts/retrieve-by-phone-contacts.js +0 -54
  236. package/tools/contacts/retrieve-by-phone-contacts.js.map +0 -1
  237. package/tools/contacts/retrieve-by-phone-contacts.mjs +0 -47
  238. package/tools/contacts/retrieve-by-phone-contacts.mjs.map +0 -1
  239. package/tools/contacts/retrieve-contacts.d.mts +0 -51
  240. package/tools/contacts/retrieve-contacts.d.mts.map +0 -1
  241. package/tools/contacts/retrieve-contacts.d.ts +0 -51
  242. package/tools/contacts/retrieve-contacts.d.ts.map +0 -1
  243. package/tools/contacts/retrieve-contacts.js +0 -54
  244. package/tools/contacts/retrieve-contacts.js.map +0 -1
  245. package/tools/contacts/retrieve-contacts.mjs +0 -47
  246. package/tools/contacts/retrieve-contacts.mjs.map +0 -1
  247. package/tools/contacts/update-contacts.d.mts +0 -51
  248. package/tools/contacts/update-contacts.d.mts.map +0 -1
  249. package/tools/contacts/update-contacts.d.ts +0 -51
  250. package/tools/contacts/update-contacts.d.ts.map +0 -1
  251. package/tools/contacts/update-contacts.js +0 -61
  252. package/tools/contacts/update-contacts.js.map +0 -1
  253. package/tools/contacts/update-contacts.mjs +0 -54
  254. package/tools/contacts/update-contacts.mjs.map +0 -1
  255. package/tools/index.d.mts +0 -10
  256. package/tools/index.d.mts.map +0 -1
  257. package/tools/index.d.ts +0 -10
  258. package/tools/index.d.ts.map +0 -1
  259. package/tools/index.js +0 -133
  260. package/tools/index.js.map +0 -1
  261. package/tools/index.mjs +0 -126
  262. package/tools/index.mjs.map +0 -1
  263. package/tools/introspect/validate-phone-introspect.d.mts +0 -51
  264. package/tools/introspect/validate-phone-introspect.d.mts.map +0 -1
  265. package/tools/introspect/validate-phone-introspect.d.ts +0 -51
  266. package/tools/introspect/validate-phone-introspect.d.ts.map +0 -1
  267. package/tools/introspect/validate-phone-introspect.js +0 -52
  268. package/tools/introspect/validate-phone-introspect.js.map +0 -1
  269. package/tools/introspect/validate-phone-introspect.mjs +0 -45
  270. package/tools/introspect/validate-phone-introspect.mjs.map +0 -1
  271. package/tools/messages/list-messages.d.mts +0 -51
  272. package/tools/messages/list-messages.d.mts.map +0 -1
  273. package/tools/messages/list-messages.d.ts +0 -51
  274. package/tools/messages/list-messages.d.ts.map +0 -1
  275. package/tools/messages/list-messages.js +0 -78
  276. package/tools/messages/list-messages.js.map +0 -1
  277. package/tools/messages/list-messages.mjs +0 -71
  278. package/tools/messages/list-messages.mjs.map +0 -1
  279. package/tools/messages/react-messages.d.mts +0 -51
  280. package/tools/messages/react-messages.d.mts.map +0 -1
  281. package/tools/messages/react-messages.d.ts +0 -51
  282. package/tools/messages/react-messages.d.ts.map +0 -1
  283. package/tools/messages/react-messages.js +0 -59
  284. package/tools/messages/react-messages.js.map +0 -1
  285. package/tools/messages/react-messages.mjs +0 -52
  286. package/tools/messages/react-messages.mjs.map +0 -1
  287. package/tools/messages/retrieve-messages.d.mts +0 -51
  288. package/tools/messages/retrieve-messages.d.mts.map +0 -1
  289. package/tools/messages/retrieve-messages.d.ts +0 -51
  290. package/tools/messages/retrieve-messages.d.ts.map +0 -1
  291. package/tools/messages/retrieve-messages.js +0 -54
  292. package/tools/messages/retrieve-messages.js.map +0 -1
  293. package/tools/messages/retrieve-messages.mjs +0 -47
  294. package/tools/messages/retrieve-messages.mjs.map +0 -1
  295. package/tools/messages/send-messages.d.mts +0 -51
  296. package/tools/messages/send-messages.d.mts.map +0 -1
  297. package/tools/messages/send-messages.d.ts +0 -51
  298. package/tools/messages/send-messages.d.ts.map +0 -1
  299. package/tools/messages/send-messages.js +0 -233
  300. package/tools/messages/send-messages.js.map +0 -1
  301. package/tools/messages/send-messages.mjs +0 -226
  302. package/tools/messages/send-messages.mjs.map +0 -1
  303. package/tools/phone-numbers/list-phone-numbers.d.mts +0 -51
  304. package/tools/phone-numbers/list-phone-numbers.d.mts.map +0 -1
  305. package/tools/phone-numbers/list-phone-numbers.d.ts +0 -51
  306. package/tools/phone-numbers/list-phone-numbers.d.ts.map +0 -1
  307. package/tools/phone-numbers/list-phone-numbers.js +0 -68
  308. package/tools/phone-numbers/list-phone-numbers.js.map +0 -1
  309. package/tools/phone-numbers/list-phone-numbers.mjs +0 -61
  310. package/tools/phone-numbers/list-phone-numbers.mjs.map +0 -1
  311. package/tools/phone-numbers/purchase-phone-numbers.d.mts +0 -51
  312. package/tools/phone-numbers/purchase-phone-numbers.d.mts.map +0 -1
  313. package/tools/phone-numbers/purchase-phone-numbers.d.ts +0 -51
  314. package/tools/phone-numbers/purchase-phone-numbers.d.ts.map +0 -1
  315. package/tools/phone-numbers/purchase-phone-numbers.js +0 -57
  316. package/tools/phone-numbers/purchase-phone-numbers.js.map +0 -1
  317. package/tools/phone-numbers/purchase-phone-numbers.mjs +0 -50
  318. package/tools/phone-numbers/purchase-phone-numbers.mjs.map +0 -1
  319. package/tools/phone-numbers/release-phone-numbers.d.mts +0 -51
  320. package/tools/phone-numbers/release-phone-numbers.d.mts.map +0 -1
  321. package/tools/phone-numbers/release-phone-numbers.d.ts +0 -51
  322. package/tools/phone-numbers/release-phone-numbers.d.ts.map +0 -1
  323. package/tools/phone-numbers/release-phone-numbers.js +0 -37
  324. package/tools/phone-numbers/release-phone-numbers.js.map +0 -1
  325. package/tools/phone-numbers/release-phone-numbers.mjs +0 -33
  326. package/tools/phone-numbers/release-phone-numbers.mjs.map +0 -1
  327. package/tools/phone-numbers/retrieve-phone-numbers.d.mts +0 -51
  328. package/tools/phone-numbers/retrieve-phone-numbers.d.mts.map +0 -1
  329. package/tools/phone-numbers/retrieve-phone-numbers.d.ts +0 -51
  330. package/tools/phone-numbers/retrieve-phone-numbers.d.ts.map +0 -1
  331. package/tools/phone-numbers/retrieve-phone-numbers.js +0 -54
  332. package/tools/phone-numbers/retrieve-phone-numbers.js.map +0 -1
  333. package/tools/phone-numbers/retrieve-phone-numbers.mjs +0 -47
  334. package/tools/phone-numbers/retrieve-phone-numbers.mjs.map +0 -1
  335. package/tools/phone-numbers/search-available-phone-numbers.d.mts +0 -51
  336. package/tools/phone-numbers/search-available-phone-numbers.d.mts.map +0 -1
  337. package/tools/phone-numbers/search-available-phone-numbers.d.ts +0 -51
  338. package/tools/phone-numbers/search-available-phone-numbers.d.ts.map +0 -1
  339. package/tools/phone-numbers/search-available-phone-numbers.js +0 -72
  340. package/tools/phone-numbers/search-available-phone-numbers.js.map +0 -1
  341. package/tools/phone-numbers/search-available-phone-numbers.mjs +0 -65
  342. package/tools/phone-numbers/search-available-phone-numbers.mjs.map +0 -1
  343. package/tools/phone-numbers/update-phone-numbers.d.mts +0 -51
  344. package/tools/phone-numbers/update-phone-numbers.d.mts.map +0 -1
  345. package/tools/phone-numbers/update-phone-numbers.d.ts +0 -51
  346. package/tools/phone-numbers/update-phone-numbers.d.ts.map +0 -1
  347. package/tools/phone-numbers/update-phone-numbers.js +0 -60
  348. package/tools/phone-numbers/update-phone-numbers.js.map +0 -1
  349. package/tools/phone-numbers/update-phone-numbers.mjs +0 -53
  350. package/tools/phone-numbers/update-phone-numbers.mjs.map +0 -1
  351. package/tools/senders/create-senders.d.mts +0 -51
  352. package/tools/senders/create-senders.d.mts.map +0 -1
  353. package/tools/senders/create-senders.d.ts +0 -51
  354. package/tools/senders/create-senders.d.ts.map +0 -1
  355. package/tools/senders/create-senders.js +0 -85
  356. package/tools/senders/create-senders.js.map +0 -1
  357. package/tools/senders/create-senders.mjs +0 -78
  358. package/tools/senders/create-senders.mjs.map +0 -1
  359. package/tools/senders/delete-senders.d.mts +0 -51
  360. package/tools/senders/delete-senders.d.mts.map +0 -1
  361. package/tools/senders/delete-senders.d.ts +0 -51
  362. package/tools/senders/delete-senders.d.ts.map +0 -1
  363. package/tools/senders/delete-senders.js +0 -37
  364. package/tools/senders/delete-senders.js.map +0 -1
  365. package/tools/senders/delete-senders.mjs +0 -33
  366. package/tools/senders/delete-senders.mjs.map +0 -1
  367. package/tools/senders/get-profile-senders.d.mts +0 -51
  368. package/tools/senders/get-profile-senders.d.mts.map +0 -1
  369. package/tools/senders/get-profile-senders.d.ts +0 -51
  370. package/tools/senders/get-profile-senders.d.ts.map +0 -1
  371. package/tools/senders/get-profile-senders.js +0 -54
  372. package/tools/senders/get-profile-senders.js.map +0 -1
  373. package/tools/senders/get-profile-senders.mjs +0 -47
  374. package/tools/senders/get-profile-senders.mjs.map +0 -1
  375. package/tools/senders/list-senders.d.mts +0 -51
  376. package/tools/senders/list-senders.d.mts.map +0 -1
  377. package/tools/senders/list-senders.d.ts +0 -51
  378. package/tools/senders/list-senders.d.ts.map +0 -1
  379. package/tools/senders/list-senders.js +0 -58
  380. package/tools/senders/list-senders.js.map +0 -1
  381. package/tools/senders/list-senders.mjs +0 -51
  382. package/tools/senders/list-senders.mjs.map +0 -1
  383. package/tools/senders/regenerate-webhook-secret-senders.d.mts +0 -51
  384. package/tools/senders/regenerate-webhook-secret-senders.d.mts.map +0 -1
  385. package/tools/senders/regenerate-webhook-secret-senders.d.ts +0 -51
  386. package/tools/senders/regenerate-webhook-secret-senders.d.ts.map +0 -1
  387. package/tools/senders/regenerate-webhook-secret-senders.js +0 -52
  388. package/tools/senders/regenerate-webhook-secret-senders.js.map +0 -1
  389. package/tools/senders/regenerate-webhook-secret-senders.mjs +0 -45
  390. package/tools/senders/regenerate-webhook-secret-senders.mjs.map +0 -1
  391. package/tools/senders/retrieve-senders.d.mts +0 -51
  392. package/tools/senders/retrieve-senders.d.mts.map +0 -1
  393. package/tools/senders/retrieve-senders.d.ts +0 -51
  394. package/tools/senders/retrieve-senders.d.ts.map +0 -1
  395. package/tools/senders/retrieve-senders.js +0 -54
  396. package/tools/senders/retrieve-senders.js.map +0 -1
  397. package/tools/senders/retrieve-senders.mjs +0 -47
  398. package/tools/senders/retrieve-senders.mjs.map +0 -1
  399. package/tools/senders/update-profile-senders.d.mts +0 -51
  400. package/tools/senders/update-profile-senders.d.mts.map +0 -1
  401. package/tools/senders/update-profile-senders.d.ts +0 -51
  402. package/tools/senders/update-profile-senders.d.ts.map +0 -1
  403. package/tools/senders/update-profile-senders.js +0 -105
  404. package/tools/senders/update-profile-senders.js.map +0 -1
  405. package/tools/senders/update-profile-senders.mjs +0 -98
  406. package/tools/senders/update-profile-senders.mjs.map +0 -1
  407. package/tools/senders/update-senders.d.mts +0 -51
  408. package/tools/senders/update-senders.d.mts.map +0 -1
  409. package/tools/senders/update-senders.d.ts +0 -51
  410. package/tools/senders/update-senders.d.ts.map +0 -1
  411. package/tools/senders/update-senders.js +0 -89
  412. package/tools/senders/update-senders.js.map +0 -1
  413. package/tools/senders/update-senders.mjs +0 -82
  414. package/tools/senders/update-senders.mjs.map +0 -1
  415. package/tools/senders/upload-profile-picture-senders.d.mts +0 -51
  416. package/tools/senders/upload-profile-picture-senders.d.mts.map +0 -1
  417. package/tools/senders/upload-profile-picture-senders.d.ts +0 -51
  418. package/tools/senders/upload-profile-picture-senders.d.ts.map +0 -1
  419. package/tools/senders/upload-profile-picture-senders.js +0 -61
  420. package/tools/senders/upload-profile-picture-senders.js.map +0 -1
  421. package/tools/senders/upload-profile-picture-senders.mjs +0 -54
  422. package/tools/senders/upload-profile-picture-senders.mjs.map +0 -1
  423. package/tools/templates/create-templates.d.mts +0 -51
  424. package/tools/templates/create-templates.d.mts.map +0 -1
  425. package/tools/templates/create-templates.d.ts +0 -51
  426. package/tools/templates/create-templates.d.ts.map +0 -1
  427. package/tools/templates/create-templates.js +0 -74
  428. package/tools/templates/create-templates.js.map +0 -1
  429. package/tools/templates/create-templates.mjs +0 -67
  430. package/tools/templates/create-templates.mjs.map +0 -1
  431. package/tools/templates/delete-templates.d.mts +0 -51
  432. package/tools/templates/delete-templates.d.mts.map +0 -1
  433. package/tools/templates/delete-templates.d.ts +0 -51
  434. package/tools/templates/delete-templates.d.ts.map +0 -1
  435. package/tools/templates/delete-templates.js +0 -37
  436. package/tools/templates/delete-templates.js.map +0 -1
  437. package/tools/templates/delete-templates.mjs +0 -33
  438. package/tools/templates/delete-templates.mjs.map +0 -1
  439. package/tools/templates/list-templates.d.mts +0 -51
  440. package/tools/templates/list-templates.d.mts.map +0 -1
  441. package/tools/templates/list-templates.d.ts +0 -51
  442. package/tools/templates/list-templates.d.ts.map +0 -1
  443. package/tools/templates/list-templates.js +0 -58
  444. package/tools/templates/list-templates.js.map +0 -1
  445. package/tools/templates/list-templates.mjs +0 -51
  446. package/tools/templates/list-templates.mjs.map +0 -1
  447. package/tools/templates/retrieve-templates.d.mts +0 -51
  448. package/tools/templates/retrieve-templates.d.mts.map +0 -1
  449. package/tools/templates/retrieve-templates.d.ts +0 -51
  450. package/tools/templates/retrieve-templates.d.ts.map +0 -1
  451. package/tools/templates/retrieve-templates.js +0 -54
  452. package/tools/templates/retrieve-templates.js.map +0 -1
  453. package/tools/templates/retrieve-templates.mjs +0 -47
  454. package/tools/templates/retrieve-templates.mjs.map +0 -1
  455. package/tools/templates/submit-templates.d.mts +0 -51
  456. package/tools/templates/submit-templates.d.mts.map +0 -1
  457. package/tools/templates/submit-templates.d.ts +0 -51
  458. package/tools/templates/submit-templates.d.ts.map +0 -1
  459. package/tools/templates/submit-templates.js +0 -66
  460. package/tools/templates/submit-templates.js.map +0 -1
  461. package/tools/templates/submit-templates.mjs +0 -59
  462. package/tools/templates/submit-templates.mjs.map +0 -1
  463. package/tools/types.d.mts.map +0 -1
  464. package/tools/types.d.ts.map +0 -1
  465. package/tools/types.js.map +0 -1
  466. package/tools/types.mjs.map +0 -1
  467. package/tools.d.mts +0 -2
  468. package/tools.d.mts.map +0 -1
  469. package/tools.d.ts +0 -2
  470. package/tools.d.ts.map +0 -1
  471. package/tools.js +0 -18
  472. package/tools.js.map +0 -1
  473. package/tools.mjs +0 -2
  474. package/tools.mjs.map +0 -1
  475. /package/{tools/types.js → types.js} +0 -0
  476. /package/{tools/types.mjs → types.mjs} +0 -0
@@ -1,68 +0,0 @@
1
- // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
-
3
- import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
4
- import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
5
-
6
- import { Tool } from '@modelcontextprotocol/sdk/types.js';
7
- import Zavudev from '@zavudev/sdk';
8
-
9
- export const metadata: Metadata = {
10
- resource: 'broadcasts',
11
- operation: 'read',
12
- tags: [],
13
- httpMethod: 'get',
14
- httpPath: '/v1/broadcasts',
15
- operationId: 'listBroadcasts',
16
- };
17
-
18
- export const tool: Tool = {
19
- name: 'list_broadcasts',
20
- description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nList broadcasts for this project.\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n items: {\n type: 'array',\n items: {\n $ref: '#/$defs/broadcast'\n }\n },\n nextCursor: {\n type: 'string'\n }\n },\n required: [ 'items'\n ],\n $defs: {\n broadcast: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n channel: {\n $ref: '#/$defs/broadcast_channel'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n messageType: {\n $ref: '#/$defs/broadcast_message_type'\n },\n name: {\n type: 'string'\n },\n status: {\n $ref: '#/$defs/broadcast_status'\n },\n totalContacts: {\n type: 'integer',\n description: 'Total number of contacts in the broadcast.'\n },\n actualCost: {\n type: 'number',\n description: 'Actual cost so far in USD.'\n },\n completedAt: {\n type: 'string',\n format: 'date-time'\n },\n content: {\n $ref: '#/$defs/broadcast_content'\n },\n deliveredCount: {\n type: 'integer'\n },\n emailSubject: {\n type: 'string'\n },\n estimatedCost: {\n type: 'number',\n description: 'Estimated total cost in USD.'\n },\n failedCount: {\n type: 'integer'\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n pendingCount: {\n type: 'integer'\n },\n reservedAmount: {\n type: 'number',\n description: 'Amount reserved from balance in USD.'\n },\n scheduledAt: {\n type: 'string',\n format: 'date-time'\n },\n senderId: {\n type: 'string'\n },\n sendingCount: {\n type: 'integer'\n },\n startedAt: {\n type: 'string',\n format: 'date-time'\n },\n text: {\n type: 'string'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'id',\n 'channel',\n 'createdAt',\n 'messageType',\n 'name',\n 'status',\n 'totalContacts'\n ]\n },\n broadcast_channel: {\n type: 'string',\n description: 'Broadcast delivery channel.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n broadcast_message_type: {\n type: 'string',\n description: 'Type of message for broadcast.',\n enum: [ 'text',\n 'image',\n 'video',\n 'audio',\n 'document',\n 'template'\n ]\n },\n broadcast_status: {\n type: 'string',\n description: 'Current status of the broadcast.',\n enum: [ 'draft',\n 'scheduled',\n 'sending',\n 'paused',\n 'completed',\n 'cancelled',\n 'failed'\n ]\n },\n broadcast_content: {\n type: 'object',\n description: 'Content for non-text broadcast message types.',\n properties: {\n filename: {\n type: 'string',\n description: 'Filename for documents.'\n },\n mediaId: {\n type: 'string',\n description: 'Media ID if already uploaded.'\n },\n mediaUrl: {\n type: 'string',\n description: 'URL of the media file.'\n },\n mimeType: {\n type: 'string',\n description: 'MIME type of the media.'\n },\n templateId: {\n type: 'string',\n description: 'Template ID for template messages.'\n },\n templateVariables: {\n type: 'object',\n description: 'Default template variables (can be overridden per contact).',\n additionalProperties: true\n }\n }\n }\n }\n}\n```",
22
- inputSchema: {
23
- type: 'object',
24
- properties: {
25
- cursor: {
26
- type: 'string',
27
- },
28
- limit: {
29
- type: 'integer',
30
- },
31
- status: {
32
- $ref: '#/$defs/broadcast_status',
33
- },
34
- jq_filter: {
35
- type: 'string',
36
- title: 'jq Filter',
37
- description:
38
- 'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
39
- },
40
- },
41
- required: [],
42
- $defs: {
43
- broadcast_status: {
44
- type: 'string',
45
- description: 'Current status of the broadcast.',
46
- enum: ['draft', 'scheduled', 'sending', 'paused', 'completed', 'cancelled', 'failed'],
47
- },
48
- },
49
- },
50
- annotations: {
51
- readOnlyHint: true,
52
- },
53
- };
54
-
55
- export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
56
- const { jq_filter, ...body } = args as any;
57
- const response = await client.broadcasts.list(body).asResponse();
58
- try {
59
- return asTextContentResult(await maybeFilter(jq_filter, await response.json()));
60
- } catch (error) {
61
- if (error instanceof Zavudev.APIError || isJqError(error)) {
62
- return asErrorResult(error.message);
63
- }
64
- throw error;
65
- }
66
- };
67
-
68
- export default { metadata, tool, handler };
@@ -1,54 +0,0 @@
1
- // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
-
3
- import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
4
- import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
5
-
6
- import { Tool } from '@modelcontextprotocol/sdk/types.js';
7
- import Zavudev from '@zavudev/sdk';
8
-
9
- export const metadata: Metadata = {
10
- resource: 'broadcasts',
11
- operation: 'read',
12
- tags: [],
13
- httpMethod: 'get',
14
- httpPath: '/v1/broadcasts/{broadcastId}/progress',
15
- operationId: 'getBroadcastProgress',
16
- };
17
-
18
- export const tool: Tool = {
19
- name: 'progress_broadcasts',
20
- description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nGet real-time progress of a broadcast including delivery counts and estimated completion time.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/broadcast_progress',\n $defs: {\n broadcast_progress: {\n type: 'object',\n properties: {\n broadcastId: {\n type: 'string'\n },\n delivered: {\n type: 'integer',\n description: 'Successfully delivered.'\n },\n failed: {\n type: 'integer',\n description: 'Failed to deliver.'\n },\n pending: {\n type: 'integer',\n description: 'Not yet queued for sending.'\n },\n percentComplete: {\n type: 'number',\n description: 'Percentage complete (0-100).'\n },\n sending: {\n type: 'integer',\n description: 'Currently being sent.'\n },\n skipped: {\n type: 'integer',\n description: 'Skipped (broadcast cancelled).'\n },\n status: {\n $ref: '#/$defs/broadcast_status'\n },\n total: {\n type: 'integer',\n description: 'Total contacts in broadcast.'\n },\n actualCost: {\n type: 'number',\n description: 'Actual cost so far in USD.'\n },\n estimatedCompletionAt: {\n type: 'string',\n format: 'date-time'\n },\n estimatedCost: {\n type: 'number',\n description: 'Estimated total cost in USD.'\n },\n reservedAmount: {\n type: 'number',\n description: 'Amount reserved from balance in USD.'\n },\n startedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'broadcastId',\n 'delivered',\n 'failed',\n 'pending',\n 'percentComplete',\n 'sending',\n 'skipped',\n 'status',\n 'total'\n ]\n },\n broadcast_status: {\n type: 'string',\n description: 'Current status of the broadcast.',\n enum: [ 'draft',\n 'scheduled',\n 'sending',\n 'paused',\n 'completed',\n 'cancelled',\n 'failed'\n ]\n }\n }\n}\n```",
22
- inputSchema: {
23
- type: 'object',
24
- properties: {
25
- broadcastId: {
26
- type: 'string',
27
- },
28
- jq_filter: {
29
- type: 'string',
30
- title: 'jq Filter',
31
- description:
32
- 'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
33
- },
34
- },
35
- required: ['broadcastId'],
36
- },
37
- annotations: {
38
- readOnlyHint: true,
39
- },
40
- };
41
-
42
- export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
43
- const { broadcastId, jq_filter, ...body } = args as any;
44
- try {
45
- return asTextContentResult(await maybeFilter(jq_filter, await client.broadcasts.progress(broadcastId)));
46
- } catch (error) {
47
- if (error instanceof Zavudev.APIError || isJqError(error)) {
48
- return asErrorResult(error.message);
49
- }
50
- throw error;
51
- }
52
- };
53
-
54
- export default { metadata, tool, handler };
@@ -1,54 +0,0 @@
1
- // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
-
3
- import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
4
- import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
5
-
6
- import { Tool } from '@modelcontextprotocol/sdk/types.js';
7
- import Zavudev from '@zavudev/sdk';
8
-
9
- export const metadata: Metadata = {
10
- resource: 'broadcasts',
11
- operation: 'read',
12
- tags: [],
13
- httpMethod: 'get',
14
- httpPath: '/v1/broadcasts/{broadcastId}',
15
- operationId: 'getBroadcast',
16
- };
17
-
18
- export const tool: Tool = {
19
- name: 'retrieve_broadcasts',
20
- description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nGet broadcast\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/broadcast_retrieve_response',\n $defs: {\n broadcast_retrieve_response: {\n type: 'object',\n properties: {\n broadcast: {\n $ref: '#/$defs/broadcast'\n }\n },\n required: [ 'broadcast'\n ]\n },\n broadcast: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n channel: {\n $ref: '#/$defs/broadcast_channel'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n messageType: {\n $ref: '#/$defs/broadcast_message_type'\n },\n name: {\n type: 'string'\n },\n status: {\n $ref: '#/$defs/broadcast_status'\n },\n totalContacts: {\n type: 'integer',\n description: 'Total number of contacts in the broadcast.'\n },\n actualCost: {\n type: 'number',\n description: 'Actual cost so far in USD.'\n },\n completedAt: {\n type: 'string',\n format: 'date-time'\n },\n content: {\n $ref: '#/$defs/broadcast_content'\n },\n deliveredCount: {\n type: 'integer'\n },\n emailSubject: {\n type: 'string'\n },\n estimatedCost: {\n type: 'number',\n description: 'Estimated total cost in USD.'\n },\n failedCount: {\n type: 'integer'\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n pendingCount: {\n type: 'integer'\n },\n reservedAmount: {\n type: 'number',\n description: 'Amount reserved from balance in USD.'\n },\n scheduledAt: {\n type: 'string',\n format: 'date-time'\n },\n senderId: {\n type: 'string'\n },\n sendingCount: {\n type: 'integer'\n },\n startedAt: {\n type: 'string',\n format: 'date-time'\n },\n text: {\n type: 'string'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'id',\n 'channel',\n 'createdAt',\n 'messageType',\n 'name',\n 'status',\n 'totalContacts'\n ]\n },\n broadcast_channel: {\n type: 'string',\n description: 'Broadcast delivery channel.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n broadcast_message_type: {\n type: 'string',\n description: 'Type of message for broadcast.',\n enum: [ 'text',\n 'image',\n 'video',\n 'audio',\n 'document',\n 'template'\n ]\n },\n broadcast_status: {\n type: 'string',\n description: 'Current status of the broadcast.',\n enum: [ 'draft',\n 'scheduled',\n 'sending',\n 'paused',\n 'completed',\n 'cancelled',\n 'failed'\n ]\n },\n broadcast_content: {\n type: 'object',\n description: 'Content for non-text broadcast message types.',\n properties: {\n filename: {\n type: 'string',\n description: 'Filename for documents.'\n },\n mediaId: {\n type: 'string',\n description: 'Media ID if already uploaded.'\n },\n mediaUrl: {\n type: 'string',\n description: 'URL of the media file.'\n },\n mimeType: {\n type: 'string',\n description: 'MIME type of the media.'\n },\n templateId: {\n type: 'string',\n description: 'Template ID for template messages.'\n },\n templateVariables: {\n type: 'object',\n description: 'Default template variables (can be overridden per contact).',\n additionalProperties: true\n }\n }\n }\n }\n}\n```",
22
- inputSchema: {
23
- type: 'object',
24
- properties: {
25
- broadcastId: {
26
- type: 'string',
27
- },
28
- jq_filter: {
29
- type: 'string',
30
- title: 'jq Filter',
31
- description:
32
- 'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
33
- },
34
- },
35
- required: ['broadcastId'],
36
- },
37
- annotations: {
38
- readOnlyHint: true,
39
- },
40
- };
41
-
42
- export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
43
- const { broadcastId, jq_filter, ...body } = args as any;
44
- try {
45
- return asTextContentResult(await maybeFilter(jq_filter, await client.broadcasts.retrieve(broadcastId)));
46
- } catch (error) {
47
- if (error instanceof Zavudev.APIError || isJqError(error)) {
48
- return asErrorResult(error.message);
49
- }
50
- throw error;
51
- }
52
- };
53
-
54
- export default { metadata, tool, handler };
@@ -1,57 +0,0 @@
1
- // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
-
3
- import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
4
- import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
5
-
6
- import { Tool } from '@modelcontextprotocol/sdk/types.js';
7
- import Zavudev from '@zavudev/sdk';
8
-
9
- export const metadata: Metadata = {
10
- resource: 'broadcasts',
11
- operation: 'write',
12
- tags: [],
13
- httpMethod: 'post',
14
- httpPath: '/v1/broadcasts/{broadcastId}/send',
15
- operationId: 'sendBroadcast',
16
- };
17
-
18
- export const tool: Tool = {
19
- name: 'send_broadcasts',
20
- description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nStart sending the broadcast immediately or schedule for later. Reserves the estimated cost from your balance.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/broadcast_send_response',\n $defs: {\n broadcast_send_response: {\n type: 'object',\n properties: {\n broadcast: {\n $ref: '#/$defs/broadcast'\n }\n },\n required: [ 'broadcast'\n ]\n },\n broadcast: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n channel: {\n $ref: '#/$defs/broadcast_channel'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n messageType: {\n $ref: '#/$defs/broadcast_message_type'\n },\n name: {\n type: 'string'\n },\n status: {\n $ref: '#/$defs/broadcast_status'\n },\n totalContacts: {\n type: 'integer',\n description: 'Total number of contacts in the broadcast.'\n },\n actualCost: {\n type: 'number',\n description: 'Actual cost so far in USD.'\n },\n completedAt: {\n type: 'string',\n format: 'date-time'\n },\n content: {\n $ref: '#/$defs/broadcast_content'\n },\n deliveredCount: {\n type: 'integer'\n },\n emailSubject: {\n type: 'string'\n },\n estimatedCost: {\n type: 'number',\n description: 'Estimated total cost in USD.'\n },\n failedCount: {\n type: 'integer'\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n pendingCount: {\n type: 'integer'\n },\n reservedAmount: {\n type: 'number',\n description: 'Amount reserved from balance in USD.'\n },\n scheduledAt: {\n type: 'string',\n format: 'date-time'\n },\n senderId: {\n type: 'string'\n },\n sendingCount: {\n type: 'integer'\n },\n startedAt: {\n type: 'string',\n format: 'date-time'\n },\n text: {\n type: 'string'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'id',\n 'channel',\n 'createdAt',\n 'messageType',\n 'name',\n 'status',\n 'totalContacts'\n ]\n },\n broadcast_channel: {\n type: 'string',\n description: 'Broadcast delivery channel.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n broadcast_message_type: {\n type: 'string',\n description: 'Type of message for broadcast.',\n enum: [ 'text',\n 'image',\n 'video',\n 'audio',\n 'document',\n 'template'\n ]\n },\n broadcast_status: {\n type: 'string',\n description: 'Current status of the broadcast.',\n enum: [ 'draft',\n 'scheduled',\n 'sending',\n 'paused',\n 'completed',\n 'cancelled',\n 'failed'\n ]\n },\n broadcast_content: {\n type: 'object',\n description: 'Content for non-text broadcast message types.',\n properties: {\n filename: {\n type: 'string',\n description: 'Filename for documents.'\n },\n mediaId: {\n type: 'string',\n description: 'Media ID if already uploaded.'\n },\n mediaUrl: {\n type: 'string',\n description: 'URL of the media file.'\n },\n mimeType: {\n type: 'string',\n description: 'MIME type of the media.'\n },\n templateId: {\n type: 'string',\n description: 'Template ID for template messages.'\n },\n templateVariables: {\n type: 'object',\n description: 'Default template variables (can be overridden per contact).',\n additionalProperties: true\n }\n }\n }\n }\n}\n```",
22
- inputSchema: {
23
- type: 'object',
24
- properties: {
25
- broadcastId: {
26
- type: 'string',
27
- },
28
- scheduledAt: {
29
- type: 'string',
30
- description: 'Schedule for future delivery. Omit to send immediately.',
31
- format: 'date-time',
32
- },
33
- jq_filter: {
34
- type: 'string',
35
- title: 'jq Filter',
36
- description:
37
- 'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
38
- },
39
- },
40
- required: ['broadcastId'],
41
- },
42
- annotations: {},
43
- };
44
-
45
- export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
46
- const { broadcastId, jq_filter, ...body } = args as any;
47
- try {
48
- return asTextContentResult(await maybeFilter(jq_filter, await client.broadcasts.send(broadcastId, body)));
49
- } catch (error) {
50
- if (error instanceof Zavudev.APIError || isJqError(error)) {
51
- return asErrorResult(error.message);
52
- }
53
- throw error;
54
- }
55
- };
56
-
57
- export default { metadata, tool, handler };
@@ -1,106 +0,0 @@
1
- // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
-
3
- import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
4
- import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
5
-
6
- import { Tool } from '@modelcontextprotocol/sdk/types.js';
7
- import Zavudev from '@zavudev/sdk';
8
-
9
- export const metadata: Metadata = {
10
- resource: 'broadcasts',
11
- operation: 'write',
12
- tags: [],
13
- httpMethod: 'patch',
14
- httpPath: '/v1/broadcasts/{broadcastId}',
15
- operationId: 'updateBroadcast',
16
- };
17
-
18
- export const tool: Tool = {
19
- name: 'update_broadcasts',
20
- description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nUpdate a broadcast in draft status.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/broadcast_update_response',\n $defs: {\n broadcast_update_response: {\n type: 'object',\n properties: {\n broadcast: {\n $ref: '#/$defs/broadcast'\n }\n },\n required: [ 'broadcast'\n ]\n },\n broadcast: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n channel: {\n $ref: '#/$defs/broadcast_channel'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n messageType: {\n $ref: '#/$defs/broadcast_message_type'\n },\n name: {\n type: 'string'\n },\n status: {\n $ref: '#/$defs/broadcast_status'\n },\n totalContacts: {\n type: 'integer',\n description: 'Total number of contacts in the broadcast.'\n },\n actualCost: {\n type: 'number',\n description: 'Actual cost so far in USD.'\n },\n completedAt: {\n type: 'string',\n format: 'date-time'\n },\n content: {\n $ref: '#/$defs/broadcast_content'\n },\n deliveredCount: {\n type: 'integer'\n },\n emailSubject: {\n type: 'string'\n },\n estimatedCost: {\n type: 'number',\n description: 'Estimated total cost in USD.'\n },\n failedCount: {\n type: 'integer'\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n pendingCount: {\n type: 'integer'\n },\n reservedAmount: {\n type: 'number',\n description: 'Amount reserved from balance in USD.'\n },\n scheduledAt: {\n type: 'string',\n format: 'date-time'\n },\n senderId: {\n type: 'string'\n },\n sendingCount: {\n type: 'integer'\n },\n startedAt: {\n type: 'string',\n format: 'date-time'\n },\n text: {\n type: 'string'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'id',\n 'channel',\n 'createdAt',\n 'messageType',\n 'name',\n 'status',\n 'totalContacts'\n ]\n },\n broadcast_channel: {\n type: 'string',\n description: 'Broadcast delivery channel.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n broadcast_message_type: {\n type: 'string',\n description: 'Type of message for broadcast.',\n enum: [ 'text',\n 'image',\n 'video',\n 'audio',\n 'document',\n 'template'\n ]\n },\n broadcast_status: {\n type: 'string',\n description: 'Current status of the broadcast.',\n enum: [ 'draft',\n 'scheduled',\n 'sending',\n 'paused',\n 'completed',\n 'cancelled',\n 'failed'\n ]\n },\n broadcast_content: {\n type: 'object',\n description: 'Content for non-text broadcast message types.',\n properties: {\n filename: {\n type: 'string',\n description: 'Filename for documents.'\n },\n mediaId: {\n type: 'string',\n description: 'Media ID if already uploaded.'\n },\n mediaUrl: {\n type: 'string',\n description: 'URL of the media file.'\n },\n mimeType: {\n type: 'string',\n description: 'MIME type of the media.'\n },\n templateId: {\n type: 'string',\n description: 'Template ID for template messages.'\n },\n templateVariables: {\n type: 'object',\n description: 'Default template variables (can be overridden per contact).',\n additionalProperties: true\n }\n }\n }\n }\n}\n```",
22
- inputSchema: {
23
- type: 'object',
24
- properties: {
25
- broadcastId: {
26
- type: 'string',
27
- },
28
- content: {
29
- $ref: '#/$defs/broadcast_content',
30
- },
31
- emailHtmlBody: {
32
- type: 'string',
33
- },
34
- emailSubject: {
35
- type: 'string',
36
- },
37
- metadata: {
38
- type: 'object',
39
- additionalProperties: true,
40
- },
41
- name: {
42
- type: 'string',
43
- },
44
- text: {
45
- type: 'string',
46
- },
47
- jq_filter: {
48
- type: 'string',
49
- title: 'jq Filter',
50
- description:
51
- 'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
52
- },
53
- },
54
- required: ['broadcastId'],
55
- $defs: {
56
- broadcast_content: {
57
- type: 'object',
58
- description: 'Content for non-text broadcast message types.',
59
- properties: {
60
- filename: {
61
- type: 'string',
62
- description: 'Filename for documents.',
63
- },
64
- mediaId: {
65
- type: 'string',
66
- description: 'Media ID if already uploaded.',
67
- },
68
- mediaUrl: {
69
- type: 'string',
70
- description: 'URL of the media file.',
71
- },
72
- mimeType: {
73
- type: 'string',
74
- description: 'MIME type of the media.',
75
- },
76
- templateId: {
77
- type: 'string',
78
- description: 'Template ID for template messages.',
79
- },
80
- templateVariables: {
81
- type: 'object',
82
- description: 'Default template variables (can be overridden per contact).',
83
- additionalProperties: true,
84
- },
85
- },
86
- },
87
- },
88
- },
89
- annotations: {},
90
- };
91
-
92
- export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
93
- const { broadcastId, jq_filter, ...body } = args as any;
94
- try {
95
- return asTextContentResult(
96
- await maybeFilter(jq_filter, await client.broadcasts.update(broadcastId, body)),
97
- );
98
- } catch (error) {
99
- if (error instanceof Zavudev.APIError || isJqError(error)) {
100
- return asErrorResult(error.message);
101
- }
102
- throw error;
103
- }
104
- };
105
-
106
- export default { metadata, tool, handler };
@@ -1,61 +0,0 @@
1
- // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
-
3
- import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
4
- import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
5
-
6
- import { Tool } from '@modelcontextprotocol/sdk/types.js';
7
- import Zavudev from '@zavudev/sdk';
8
-
9
- export const metadata: Metadata = {
10
- resource: 'contacts',
11
- operation: 'read',
12
- tags: [],
13
- httpMethod: 'get',
14
- httpPath: '/v1/contacts',
15
- operationId: 'listContacts',
16
- };
17
-
18
- export const tool: Tool = {
19
- name: 'list_contacts',
20
- description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nList contacts\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n items: {\n type: 'array',\n items: {\n $ref: '#/$defs/contact'\n }\n },\n nextCursor: {\n type: 'string'\n }\n },\n required: [ 'items'\n ],\n $defs: {\n contact: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n phoneNumber: {\n type: 'string',\n description: 'E.164 phone number.'\n },\n availableChannels: {\n type: 'array',\n description: 'List of available messaging channels for this contact.',\n items: {\n type: 'string'\n }\n },\n countryCode: {\n type: 'string'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n defaultChannel: {\n type: 'string',\n description: 'Preferred channel for this contact.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n profileName: {\n type: 'string',\n description: 'Contact\\'s WhatsApp profile name. Only available for WhatsApp contacts.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n },\n verified: {\n type: 'boolean',\n description: 'Whether this contact has been verified.'\n }\n },\n required: [ 'id',\n 'phoneNumber'\n ]\n }\n }\n}\n```",
22
- inputSchema: {
23
- type: 'object',
24
- properties: {
25
- cursor: {
26
- type: 'string',
27
- },
28
- limit: {
29
- type: 'integer',
30
- },
31
- phoneNumber: {
32
- type: 'string',
33
- },
34
- jq_filter: {
35
- type: 'string',
36
- title: 'jq Filter',
37
- description:
38
- 'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
39
- },
40
- },
41
- required: [],
42
- },
43
- annotations: {
44
- readOnlyHint: true,
45
- },
46
- };
47
-
48
- export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
49
- const { jq_filter, ...body } = args as any;
50
- const response = await client.contacts.list(body).asResponse();
51
- try {
52
- return asTextContentResult(await maybeFilter(jq_filter, await response.json()));
53
- } catch (error) {
54
- if (error instanceof Zavudev.APIError || isJqError(error)) {
55
- return asErrorResult(error.message);
56
- }
57
- throw error;
58
- }
59
- };
60
-
61
- export default { metadata, tool, handler };
@@ -1,56 +0,0 @@
1
- // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
-
3
- import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
4
- import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
5
-
6
- import { Tool } from '@modelcontextprotocol/sdk/types.js';
7
- import Zavudev from '@zavudev/sdk';
8
-
9
- export const metadata: Metadata = {
10
- resource: 'contacts',
11
- operation: 'read',
12
- tags: [],
13
- httpMethod: 'get',
14
- httpPath: '/v1/contacts/phone/{phoneNumber}',
15
- operationId: 'getContactByPhone',
16
- };
17
-
18
- export const tool: Tool = {
19
- name: 'retrieve_by_phone_contacts',
20
- description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nGet contact by phone number\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/contact',\n $defs: {\n contact: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n phoneNumber: {\n type: 'string',\n description: 'E.164 phone number.'\n },\n availableChannels: {\n type: 'array',\n description: 'List of available messaging channels for this contact.',\n items: {\n type: 'string'\n }\n },\n countryCode: {\n type: 'string'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n defaultChannel: {\n type: 'string',\n description: 'Preferred channel for this contact.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n profileName: {\n type: 'string',\n description: 'Contact\\'s WhatsApp profile name. Only available for WhatsApp contacts.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n },\n verified: {\n type: 'boolean',\n description: 'Whether this contact has been verified.'\n }\n },\n required: [ 'id',\n 'phoneNumber'\n ]\n }\n }\n}\n```",
22
- inputSchema: {
23
- type: 'object',
24
- properties: {
25
- phoneNumber: {
26
- type: 'string',
27
- },
28
- jq_filter: {
29
- type: 'string',
30
- title: 'jq Filter',
31
- description:
32
- 'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
33
- },
34
- },
35
- required: ['phoneNumber'],
36
- },
37
- annotations: {
38
- readOnlyHint: true,
39
- },
40
- };
41
-
42
- export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
43
- const { phoneNumber, jq_filter, ...body } = args as any;
44
- try {
45
- return asTextContentResult(
46
- await maybeFilter(jq_filter, await client.contacts.retrieveByPhone(phoneNumber)),
47
- );
48
- } catch (error) {
49
- if (error instanceof Zavudev.APIError || isJqError(error)) {
50
- return asErrorResult(error.message);
51
- }
52
- throw error;
53
- }
54
- };
55
-
56
- export default { metadata, tool, handler };
@@ -1,54 +0,0 @@
1
- // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
-
3
- import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
4
- import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
5
-
6
- import { Tool } from '@modelcontextprotocol/sdk/types.js';
7
- import Zavudev from '@zavudev/sdk';
8
-
9
- export const metadata: Metadata = {
10
- resource: 'contacts',
11
- operation: 'read',
12
- tags: [],
13
- httpMethod: 'get',
14
- httpPath: '/v1/contacts/{contactId}',
15
- operationId: 'getContact',
16
- };
17
-
18
- export const tool: Tool = {
19
- name: 'retrieve_contacts',
20
- description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nGet contact\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/contact',\n $defs: {\n contact: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n phoneNumber: {\n type: 'string',\n description: 'E.164 phone number.'\n },\n availableChannels: {\n type: 'array',\n description: 'List of available messaging channels for this contact.',\n items: {\n type: 'string'\n }\n },\n countryCode: {\n type: 'string'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n defaultChannel: {\n type: 'string',\n description: 'Preferred channel for this contact.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n profileName: {\n type: 'string',\n description: 'Contact\\'s WhatsApp profile name. Only available for WhatsApp contacts.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n },\n verified: {\n type: 'boolean',\n description: 'Whether this contact has been verified.'\n }\n },\n required: [ 'id',\n 'phoneNumber'\n ]\n }\n }\n}\n```",
22
- inputSchema: {
23
- type: 'object',
24
- properties: {
25
- contactId: {
26
- type: 'string',
27
- },
28
- jq_filter: {
29
- type: 'string',
30
- title: 'jq Filter',
31
- description:
32
- 'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
33
- },
34
- },
35
- required: ['contactId'],
36
- },
37
- annotations: {
38
- readOnlyHint: true,
39
- },
40
- };
41
-
42
- export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
43
- const { contactId, jq_filter, ...body } = args as any;
44
- try {
45
- return asTextContentResult(await maybeFilter(jq_filter, await client.contacts.retrieve(contactId)));
46
- } catch (error) {
47
- if (error instanceof Zavudev.APIError || isJqError(error)) {
48
- return asErrorResult(error.message);
49
- }
50
- throw error;
51
- }
52
- };
53
-
54
- export default { metadata, tool, handler };
@@ -1,61 +0,0 @@
1
- // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
-
3
- import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
4
- import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
5
-
6
- import { Tool } from '@modelcontextprotocol/sdk/types.js';
7
- import Zavudev from '@zavudev/sdk';
8
-
9
- export const metadata: Metadata = {
10
- resource: 'contacts',
11
- operation: 'write',
12
- tags: [],
13
- httpMethod: 'patch',
14
- httpPath: '/v1/contacts/{contactId}',
15
- operationId: 'updateContact',
16
- };
17
-
18
- export const tool: Tool = {
19
- name: 'update_contacts',
20
- description:
21
- "When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nUpdate contact\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/contact',\n $defs: {\n contact: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n phoneNumber: {\n type: 'string',\n description: 'E.164 phone number.'\n },\n availableChannels: {\n type: 'array',\n description: 'List of available messaging channels for this contact.',\n items: {\n type: 'string'\n }\n },\n countryCode: {\n type: 'string'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n defaultChannel: {\n type: 'string',\n description: 'Preferred channel for this contact.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n profileName: {\n type: 'string',\n description: 'Contact\\'s WhatsApp profile name. Only available for WhatsApp contacts.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n },\n verified: {\n type: 'boolean',\n description: 'Whether this contact has been verified.'\n }\n },\n required: [ 'id',\n 'phoneNumber'\n ]\n }\n }\n}\n```",
22
- inputSchema: {
23
- type: 'object',
24
- properties: {
25
- contactId: {
26
- type: 'string',
27
- },
28
- defaultChannel: {
29
- type: 'string',
30
- description: 'Preferred channel for this contact. Set to null to clear.',
31
- enum: ['sms', 'whatsapp', 'email'],
32
- },
33
- metadata: {
34
- type: 'object',
35
- additionalProperties: true,
36
- },
37
- jq_filter: {
38
- type: 'string',
39
- title: 'jq Filter',
40
- description:
41
- 'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
42
- },
43
- },
44
- required: ['contactId'],
45
- },
46
- annotations: {},
47
- };
48
-
49
- export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
50
- const { contactId, jq_filter, ...body } = args as any;
51
- try {
52
- return asTextContentResult(await maybeFilter(jq_filter, await client.contacts.update(contactId, body)));
53
- } catch (error) {
54
- if (error instanceof Zavudev.APIError || isJqError(error)) {
55
- return asErrorResult(error.message);
56
- }
57
- throw error;
58
- }
59
- };
60
-
61
- export default { metadata, tool, handler };