@zavudev/sdk-mcp 0.14.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 (472) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +313 -0
  3. package/code-tool-types.d.mts +16 -0
  4. package/code-tool-types.d.mts.map +1 -0
  5. package/code-tool-types.d.ts +16 -0
  6. package/code-tool-types.d.ts.map +1 -0
  7. package/code-tool-types.js +4 -0
  8. package/code-tool-types.js.map +1 -0
  9. package/code-tool-types.mjs +3 -0
  10. package/code-tool-types.mjs.map +1 -0
  11. package/code-tool.d.mts +54 -0
  12. package/code-tool.d.mts.map +1 -0
  13. package/code-tool.d.ts +54 -0
  14. package/code-tool.d.ts.map +1 -0
  15. package/code-tool.js +49 -0
  16. package/code-tool.js.map +1 -0
  17. package/code-tool.mjs +46 -0
  18. package/code-tool.mjs.map +1 -0
  19. package/compat.d.mts +58 -0
  20. package/compat.d.mts.map +1 -0
  21. package/compat.d.ts +58 -0
  22. package/compat.d.ts.map +1 -0
  23. package/compat.js +387 -0
  24. package/compat.js.map +1 -0
  25. package/compat.mjs +378 -0
  26. package/compat.mjs.map +1 -0
  27. package/docs-search-tool.d.mts +50 -0
  28. package/docs-search-tool.d.mts.map +1 -0
  29. package/docs-search-tool.d.ts +50 -0
  30. package/docs-search-tool.d.ts.map +1 -0
  31. package/docs-search-tool.js +51 -0
  32. package/docs-search-tool.js.map +1 -0
  33. package/docs-search-tool.mjs +47 -0
  34. package/docs-search-tool.mjs.map +1 -0
  35. package/dynamic-tools.d.mts +12 -0
  36. package/dynamic-tools.d.mts.map +1 -0
  37. package/dynamic-tools.d.ts +12 -0
  38. package/dynamic-tools.d.ts.map +1 -0
  39. package/dynamic-tools.js +135 -0
  40. package/dynamic-tools.js.map +1 -0
  41. package/dynamic-tools.mjs +132 -0
  42. package/dynamic-tools.mjs.map +1 -0
  43. package/filtering.d.mts +3 -0
  44. package/filtering.d.mts.map +1 -0
  45. package/filtering.d.ts +3 -0
  46. package/filtering.d.ts.map +1 -0
  47. package/filtering.js +24 -0
  48. package/filtering.js.map +1 -0
  49. package/filtering.mjs +16 -0
  50. package/filtering.mjs.map +1 -0
  51. package/headers.d.mts +4 -0
  52. package/headers.d.mts.map +1 -0
  53. package/headers.d.ts +4 -0
  54. package/headers.d.ts.map +1 -0
  55. package/headers.js +22 -0
  56. package/headers.js.map +1 -0
  57. package/headers.mjs +18 -0
  58. package/headers.mjs.map +1 -0
  59. package/http.d.mts +9 -0
  60. package/http.d.mts.map +1 -0
  61. package/http.d.ts +9 -0
  62. package/http.d.ts.map +1 -0
  63. package/http.js +108 -0
  64. package/http.js.map +1 -0
  65. package/http.mjs +100 -0
  66. package/http.mjs.map +1 -0
  67. package/index.d.mts +3 -0
  68. package/index.d.mts.map +1 -0
  69. package/index.d.ts +3 -0
  70. package/index.d.ts.map +1 -0
  71. package/index.js +91 -0
  72. package/index.js.map +1 -0
  73. package/index.mjs +89 -0
  74. package/index.mjs.map +1 -0
  75. package/options.d.mts +20 -0
  76. package/options.d.mts.map +1 -0
  77. package/options.d.ts +20 -0
  78. package/options.d.ts.map +1 -0
  79. package/options.js +427 -0
  80. package/options.js.map +1 -0
  81. package/options.mjs +420 -0
  82. package/options.mjs.map +1 -0
  83. package/package.json +201 -0
  84. package/server.d.mts +35 -0
  85. package/server.d.mts.map +1 -0
  86. package/server.d.ts +35 -0
  87. package/server.d.ts.map +1 -0
  88. package/server.js +174 -0
  89. package/server.js.map +1 -0
  90. package/server.mjs +160 -0
  91. package/server.mjs.map +1 -0
  92. package/src/code-tool-types.ts +18 -0
  93. package/src/code-tool.ts +59 -0
  94. package/src/compat.ts +483 -0
  95. package/src/docs-search-tool.ts +59 -0
  96. package/src/dynamic-tools.ts +153 -0
  97. package/src/filtering.ts +18 -0
  98. package/src/headers.ts +25 -0
  99. package/src/http.ts +127 -0
  100. package/src/index.ts +108 -0
  101. package/src/options.ts +473 -0
  102. package/src/server.ts +207 -0
  103. package/src/stdio.ts +13 -0
  104. package/src/tools/broadcasts/cancel-broadcasts.ts +52 -0
  105. package/src/tools/broadcasts/contacts/add-broadcasts-contacts.ts +73 -0
  106. package/src/tools/broadcasts/contacts/list-broadcasts-contacts.ts +71 -0
  107. package/src/tools/broadcasts/contacts/remove-broadcasts-contacts.ts +43 -0
  108. package/src/tools/broadcasts/create-broadcasts.ts +134 -0
  109. package/src/tools/broadcasts/delete-broadcasts.ts +40 -0
  110. package/src/tools/broadcasts/list-broadcasts.ts +68 -0
  111. package/src/tools/broadcasts/progress-broadcasts.ts +54 -0
  112. package/src/tools/broadcasts/retrieve-broadcasts.ts +54 -0
  113. package/src/tools/broadcasts/send-broadcasts.ts +57 -0
  114. package/src/tools/broadcasts/update-broadcasts.ts +106 -0
  115. package/src/tools/contacts/list-contacts.ts +61 -0
  116. package/src/tools/contacts/retrieve-by-phone-contacts.ts +56 -0
  117. package/src/tools/contacts/retrieve-contacts.ts +54 -0
  118. package/src/tools/contacts/update-contacts.ts +61 -0
  119. package/src/tools/index.ts +143 -0
  120. package/src/tools/introspect/validate-phone-introspect.ts +52 -0
  121. package/src/tools/messages/list-messages.ts +78 -0
  122. package/src/tools/messages/react-messages.ts +59 -0
  123. package/src/tools/messages/retrieve-messages.ts +54 -0
  124. package/src/tools/messages/send-messages.ts +233 -0
  125. package/src/tools/phone-numbers/list-phone-numbers.ts +68 -0
  126. package/src/tools/phone-numbers/purchase-phone-numbers.ts +57 -0
  127. package/src/tools/phone-numbers/release-phone-numbers.ts +40 -0
  128. package/src/tools/phone-numbers/retrieve-phone-numbers.ts +56 -0
  129. package/src/tools/phone-numbers/search-available-phone-numbers.ts +72 -0
  130. package/src/tools/phone-numbers/update-phone-numbers.ts +62 -0
  131. package/src/tools/senders/create-senders.ts +86 -0
  132. package/src/tools/senders/delete-senders.ts +40 -0
  133. package/src/tools/senders/list-senders.ts +58 -0
  134. package/src/tools/senders/regenerate-webhook-secret-senders.ts +54 -0
  135. package/src/tools/senders/retrieve-senders.ts +54 -0
  136. package/src/tools/senders/update-senders.ts +90 -0
  137. package/src/tools/templates/create-templates.ts +74 -0
  138. package/src/tools/templates/delete-templates.ts +40 -0
  139. package/src/tools/templates/list-templates.ts +58 -0
  140. package/src/tools/templates/retrieve-templates.ts +54 -0
  141. package/src/tools/templates/submit-templates.ts +66 -0
  142. package/src/tools/types.ts +115 -0
  143. package/src/tools.ts +1 -0
  144. package/src/tsconfig.json +11 -0
  145. package/stdio.d.mts +3 -0
  146. package/stdio.d.mts.map +1 -0
  147. package/stdio.d.ts +3 -0
  148. package/stdio.d.ts.map +1 -0
  149. package/stdio.js +14 -0
  150. package/stdio.js.map +1 -0
  151. package/stdio.mjs +10 -0
  152. package/stdio.mjs.map +1 -0
  153. package/tools/broadcasts/cancel-broadcasts.d.mts +51 -0
  154. package/tools/broadcasts/cancel-broadcasts.d.mts.map +1 -0
  155. package/tools/broadcasts/cancel-broadcasts.d.ts +51 -0
  156. package/tools/broadcasts/cancel-broadcasts.d.ts.map +1 -0
  157. package/tools/broadcasts/cancel-broadcasts.js +52 -0
  158. package/tools/broadcasts/cancel-broadcasts.js.map +1 -0
  159. package/tools/broadcasts/cancel-broadcasts.mjs +45 -0
  160. package/tools/broadcasts/cancel-broadcasts.mjs.map +1 -0
  161. package/tools/broadcasts/contacts/add-broadcasts-contacts.d.mts +51 -0
  162. package/tools/broadcasts/contacts/add-broadcasts-contacts.d.mts.map +1 -0
  163. package/tools/broadcasts/contacts/add-broadcasts-contacts.d.ts +51 -0
  164. package/tools/broadcasts/contacts/add-broadcasts-contacts.d.ts.map +1 -0
  165. package/tools/broadcasts/contacts/add-broadcasts-contacts.js +71 -0
  166. package/tools/broadcasts/contacts/add-broadcasts-contacts.js.map +1 -0
  167. package/tools/broadcasts/contacts/add-broadcasts-contacts.mjs +64 -0
  168. package/tools/broadcasts/contacts/add-broadcasts-contacts.mjs.map +1 -0
  169. package/tools/broadcasts/contacts/list-broadcasts-contacts.d.mts +51 -0
  170. package/tools/broadcasts/contacts/list-broadcasts-contacts.d.mts.map +1 -0
  171. package/tools/broadcasts/contacts/list-broadcasts-contacts.d.ts +51 -0
  172. package/tools/broadcasts/contacts/list-broadcasts-contacts.d.ts.map +1 -0
  173. package/tools/broadcasts/contacts/list-broadcasts-contacts.js +71 -0
  174. package/tools/broadcasts/contacts/list-broadcasts-contacts.js.map +1 -0
  175. package/tools/broadcasts/contacts/list-broadcasts-contacts.mjs +64 -0
  176. package/tools/broadcasts/contacts/list-broadcasts-contacts.mjs.map +1 -0
  177. package/tools/broadcasts/contacts/remove-broadcasts-contacts.d.mts +51 -0
  178. package/tools/broadcasts/contacts/remove-broadcasts-contacts.d.mts.map +1 -0
  179. package/tools/broadcasts/contacts/remove-broadcasts-contacts.d.ts +51 -0
  180. package/tools/broadcasts/contacts/remove-broadcasts-contacts.d.ts.map +1 -0
  181. package/tools/broadcasts/contacts/remove-broadcasts-contacts.js +40 -0
  182. package/tools/broadcasts/contacts/remove-broadcasts-contacts.js.map +1 -0
  183. package/tools/broadcasts/contacts/remove-broadcasts-contacts.mjs +36 -0
  184. package/tools/broadcasts/contacts/remove-broadcasts-contacts.mjs.map +1 -0
  185. package/tools/broadcasts/create-broadcasts.d.mts +51 -0
  186. package/tools/broadcasts/create-broadcasts.d.mts.map +1 -0
  187. package/tools/broadcasts/create-broadcasts.d.ts +51 -0
  188. package/tools/broadcasts/create-broadcasts.d.ts.map +1 -0
  189. package/tools/broadcasts/create-broadcasts.js +134 -0
  190. package/tools/broadcasts/create-broadcasts.js.map +1 -0
  191. package/tools/broadcasts/create-broadcasts.mjs +127 -0
  192. package/tools/broadcasts/create-broadcasts.mjs.map +1 -0
  193. package/tools/broadcasts/delete-broadcasts.d.mts +51 -0
  194. package/tools/broadcasts/delete-broadcasts.d.mts.map +1 -0
  195. package/tools/broadcasts/delete-broadcasts.d.ts +51 -0
  196. package/tools/broadcasts/delete-broadcasts.d.ts.map +1 -0
  197. package/tools/broadcasts/delete-broadcasts.js +37 -0
  198. package/tools/broadcasts/delete-broadcasts.js.map +1 -0
  199. package/tools/broadcasts/delete-broadcasts.mjs +33 -0
  200. package/tools/broadcasts/delete-broadcasts.mjs.map +1 -0
  201. package/tools/broadcasts/list-broadcasts.d.mts +51 -0
  202. package/tools/broadcasts/list-broadcasts.d.mts.map +1 -0
  203. package/tools/broadcasts/list-broadcasts.d.ts +51 -0
  204. package/tools/broadcasts/list-broadcasts.d.ts.map +1 -0
  205. package/tools/broadcasts/list-broadcasts.js +68 -0
  206. package/tools/broadcasts/list-broadcasts.js.map +1 -0
  207. package/tools/broadcasts/list-broadcasts.mjs +61 -0
  208. package/tools/broadcasts/list-broadcasts.mjs.map +1 -0
  209. package/tools/broadcasts/progress-broadcasts.d.mts +51 -0
  210. package/tools/broadcasts/progress-broadcasts.d.mts.map +1 -0
  211. package/tools/broadcasts/progress-broadcasts.d.ts +51 -0
  212. package/tools/broadcasts/progress-broadcasts.d.ts.map +1 -0
  213. package/tools/broadcasts/progress-broadcasts.js +54 -0
  214. package/tools/broadcasts/progress-broadcasts.js.map +1 -0
  215. package/tools/broadcasts/progress-broadcasts.mjs +47 -0
  216. package/tools/broadcasts/progress-broadcasts.mjs.map +1 -0
  217. package/tools/broadcasts/retrieve-broadcasts.d.mts +51 -0
  218. package/tools/broadcasts/retrieve-broadcasts.d.mts.map +1 -0
  219. package/tools/broadcasts/retrieve-broadcasts.d.ts +51 -0
  220. package/tools/broadcasts/retrieve-broadcasts.d.ts.map +1 -0
  221. package/tools/broadcasts/retrieve-broadcasts.js +54 -0
  222. package/tools/broadcasts/retrieve-broadcasts.js.map +1 -0
  223. package/tools/broadcasts/retrieve-broadcasts.mjs +47 -0
  224. package/tools/broadcasts/retrieve-broadcasts.mjs.map +1 -0
  225. package/tools/broadcasts/send-broadcasts.d.mts +51 -0
  226. package/tools/broadcasts/send-broadcasts.d.mts.map +1 -0
  227. package/tools/broadcasts/send-broadcasts.d.ts +51 -0
  228. package/tools/broadcasts/send-broadcasts.d.ts.map +1 -0
  229. package/tools/broadcasts/send-broadcasts.js +57 -0
  230. package/tools/broadcasts/send-broadcasts.js.map +1 -0
  231. package/tools/broadcasts/send-broadcasts.mjs +50 -0
  232. package/tools/broadcasts/send-broadcasts.mjs.map +1 -0
  233. package/tools/broadcasts/update-broadcasts.d.mts +51 -0
  234. package/tools/broadcasts/update-broadcasts.d.mts.map +1 -0
  235. package/tools/broadcasts/update-broadcasts.d.ts +51 -0
  236. package/tools/broadcasts/update-broadcasts.d.ts.map +1 -0
  237. package/tools/broadcasts/update-broadcasts.js +104 -0
  238. package/tools/broadcasts/update-broadcasts.js.map +1 -0
  239. package/tools/broadcasts/update-broadcasts.mjs +97 -0
  240. package/tools/broadcasts/update-broadcasts.mjs.map +1 -0
  241. package/tools/contacts/list-contacts.d.mts +51 -0
  242. package/tools/contacts/list-contacts.d.mts.map +1 -0
  243. package/tools/contacts/list-contacts.d.ts +51 -0
  244. package/tools/contacts/list-contacts.d.ts.map +1 -0
  245. package/tools/contacts/list-contacts.js +61 -0
  246. package/tools/contacts/list-contacts.js.map +1 -0
  247. package/tools/contacts/list-contacts.mjs +54 -0
  248. package/tools/contacts/list-contacts.mjs.map +1 -0
  249. package/tools/contacts/retrieve-by-phone-contacts.d.mts +51 -0
  250. package/tools/contacts/retrieve-by-phone-contacts.d.mts.map +1 -0
  251. package/tools/contacts/retrieve-by-phone-contacts.d.ts +51 -0
  252. package/tools/contacts/retrieve-by-phone-contacts.d.ts.map +1 -0
  253. package/tools/contacts/retrieve-by-phone-contacts.js +54 -0
  254. package/tools/contacts/retrieve-by-phone-contacts.js.map +1 -0
  255. package/tools/contacts/retrieve-by-phone-contacts.mjs +47 -0
  256. package/tools/contacts/retrieve-by-phone-contacts.mjs.map +1 -0
  257. package/tools/contacts/retrieve-contacts.d.mts +51 -0
  258. package/tools/contacts/retrieve-contacts.d.mts.map +1 -0
  259. package/tools/contacts/retrieve-contacts.d.ts +51 -0
  260. package/tools/contacts/retrieve-contacts.d.ts.map +1 -0
  261. package/tools/contacts/retrieve-contacts.js +54 -0
  262. package/tools/contacts/retrieve-contacts.js.map +1 -0
  263. package/tools/contacts/retrieve-contacts.mjs +47 -0
  264. package/tools/contacts/retrieve-contacts.mjs.map +1 -0
  265. package/tools/contacts/update-contacts.d.mts +51 -0
  266. package/tools/contacts/update-contacts.d.mts.map +1 -0
  267. package/tools/contacts/update-contacts.d.ts +51 -0
  268. package/tools/contacts/update-contacts.d.ts.map +1 -0
  269. package/tools/contacts/update-contacts.js +61 -0
  270. package/tools/contacts/update-contacts.js.map +1 -0
  271. package/tools/contacts/update-contacts.mjs +54 -0
  272. package/tools/contacts/update-contacts.mjs.map +1 -0
  273. package/tools/index.d.mts +10 -0
  274. package/tools/index.d.mts.map +1 -0
  275. package/tools/index.d.ts +10 -0
  276. package/tools/index.d.ts.map +1 -0
  277. package/tools/index.js +127 -0
  278. package/tools/index.js.map +1 -0
  279. package/tools/index.mjs +120 -0
  280. package/tools/index.mjs.map +1 -0
  281. package/tools/introspect/validate-phone-introspect.d.mts +51 -0
  282. package/tools/introspect/validate-phone-introspect.d.mts.map +1 -0
  283. package/tools/introspect/validate-phone-introspect.d.ts +51 -0
  284. package/tools/introspect/validate-phone-introspect.d.ts.map +1 -0
  285. package/tools/introspect/validate-phone-introspect.js +52 -0
  286. package/tools/introspect/validate-phone-introspect.js.map +1 -0
  287. package/tools/introspect/validate-phone-introspect.mjs +45 -0
  288. package/tools/introspect/validate-phone-introspect.mjs.map +1 -0
  289. package/tools/messages/list-messages.d.mts +51 -0
  290. package/tools/messages/list-messages.d.mts.map +1 -0
  291. package/tools/messages/list-messages.d.ts +51 -0
  292. package/tools/messages/list-messages.d.ts.map +1 -0
  293. package/tools/messages/list-messages.js +78 -0
  294. package/tools/messages/list-messages.js.map +1 -0
  295. package/tools/messages/list-messages.mjs +71 -0
  296. package/tools/messages/list-messages.mjs.map +1 -0
  297. package/tools/messages/react-messages.d.mts +51 -0
  298. package/tools/messages/react-messages.d.mts.map +1 -0
  299. package/tools/messages/react-messages.d.ts +51 -0
  300. package/tools/messages/react-messages.d.ts.map +1 -0
  301. package/tools/messages/react-messages.js +59 -0
  302. package/tools/messages/react-messages.js.map +1 -0
  303. package/tools/messages/react-messages.mjs +52 -0
  304. package/tools/messages/react-messages.mjs.map +1 -0
  305. package/tools/messages/retrieve-messages.d.mts +51 -0
  306. package/tools/messages/retrieve-messages.d.mts.map +1 -0
  307. package/tools/messages/retrieve-messages.d.ts +51 -0
  308. package/tools/messages/retrieve-messages.d.ts.map +1 -0
  309. package/tools/messages/retrieve-messages.js +54 -0
  310. package/tools/messages/retrieve-messages.js.map +1 -0
  311. package/tools/messages/retrieve-messages.mjs +47 -0
  312. package/tools/messages/retrieve-messages.mjs.map +1 -0
  313. package/tools/messages/send-messages.d.mts +51 -0
  314. package/tools/messages/send-messages.d.mts.map +1 -0
  315. package/tools/messages/send-messages.d.ts +51 -0
  316. package/tools/messages/send-messages.d.ts.map +1 -0
  317. package/tools/messages/send-messages.js +233 -0
  318. package/tools/messages/send-messages.js.map +1 -0
  319. package/tools/messages/send-messages.mjs +226 -0
  320. package/tools/messages/send-messages.mjs.map +1 -0
  321. package/tools/phone-numbers/list-phone-numbers.d.mts +51 -0
  322. package/tools/phone-numbers/list-phone-numbers.d.mts.map +1 -0
  323. package/tools/phone-numbers/list-phone-numbers.d.ts +51 -0
  324. package/tools/phone-numbers/list-phone-numbers.d.ts.map +1 -0
  325. package/tools/phone-numbers/list-phone-numbers.js +68 -0
  326. package/tools/phone-numbers/list-phone-numbers.js.map +1 -0
  327. package/tools/phone-numbers/list-phone-numbers.mjs +61 -0
  328. package/tools/phone-numbers/list-phone-numbers.mjs.map +1 -0
  329. package/tools/phone-numbers/purchase-phone-numbers.d.mts +51 -0
  330. package/tools/phone-numbers/purchase-phone-numbers.d.mts.map +1 -0
  331. package/tools/phone-numbers/purchase-phone-numbers.d.ts +51 -0
  332. package/tools/phone-numbers/purchase-phone-numbers.d.ts.map +1 -0
  333. package/tools/phone-numbers/purchase-phone-numbers.js +57 -0
  334. package/tools/phone-numbers/purchase-phone-numbers.js.map +1 -0
  335. package/tools/phone-numbers/purchase-phone-numbers.mjs +50 -0
  336. package/tools/phone-numbers/purchase-phone-numbers.mjs.map +1 -0
  337. package/tools/phone-numbers/release-phone-numbers.d.mts +51 -0
  338. package/tools/phone-numbers/release-phone-numbers.d.mts.map +1 -0
  339. package/tools/phone-numbers/release-phone-numbers.d.ts +51 -0
  340. package/tools/phone-numbers/release-phone-numbers.d.ts.map +1 -0
  341. package/tools/phone-numbers/release-phone-numbers.js +37 -0
  342. package/tools/phone-numbers/release-phone-numbers.js.map +1 -0
  343. package/tools/phone-numbers/release-phone-numbers.mjs +33 -0
  344. package/tools/phone-numbers/release-phone-numbers.mjs.map +1 -0
  345. package/tools/phone-numbers/retrieve-phone-numbers.d.mts +51 -0
  346. package/tools/phone-numbers/retrieve-phone-numbers.d.mts.map +1 -0
  347. package/tools/phone-numbers/retrieve-phone-numbers.d.ts +51 -0
  348. package/tools/phone-numbers/retrieve-phone-numbers.d.ts.map +1 -0
  349. package/tools/phone-numbers/retrieve-phone-numbers.js +54 -0
  350. package/tools/phone-numbers/retrieve-phone-numbers.js.map +1 -0
  351. package/tools/phone-numbers/retrieve-phone-numbers.mjs +47 -0
  352. package/tools/phone-numbers/retrieve-phone-numbers.mjs.map +1 -0
  353. package/tools/phone-numbers/search-available-phone-numbers.d.mts +51 -0
  354. package/tools/phone-numbers/search-available-phone-numbers.d.mts.map +1 -0
  355. package/tools/phone-numbers/search-available-phone-numbers.d.ts +51 -0
  356. package/tools/phone-numbers/search-available-phone-numbers.d.ts.map +1 -0
  357. package/tools/phone-numbers/search-available-phone-numbers.js +72 -0
  358. package/tools/phone-numbers/search-available-phone-numbers.js.map +1 -0
  359. package/tools/phone-numbers/search-available-phone-numbers.mjs +65 -0
  360. package/tools/phone-numbers/search-available-phone-numbers.mjs.map +1 -0
  361. package/tools/phone-numbers/update-phone-numbers.d.mts +51 -0
  362. package/tools/phone-numbers/update-phone-numbers.d.mts.map +1 -0
  363. package/tools/phone-numbers/update-phone-numbers.d.ts +51 -0
  364. package/tools/phone-numbers/update-phone-numbers.d.ts.map +1 -0
  365. package/tools/phone-numbers/update-phone-numbers.js +60 -0
  366. package/tools/phone-numbers/update-phone-numbers.js.map +1 -0
  367. package/tools/phone-numbers/update-phone-numbers.mjs +53 -0
  368. package/tools/phone-numbers/update-phone-numbers.mjs.map +1 -0
  369. package/tools/senders/create-senders.d.mts +51 -0
  370. package/tools/senders/create-senders.d.mts.map +1 -0
  371. package/tools/senders/create-senders.d.ts +51 -0
  372. package/tools/senders/create-senders.d.ts.map +1 -0
  373. package/tools/senders/create-senders.js +85 -0
  374. package/tools/senders/create-senders.js.map +1 -0
  375. package/tools/senders/create-senders.mjs +78 -0
  376. package/tools/senders/create-senders.mjs.map +1 -0
  377. package/tools/senders/delete-senders.d.mts +51 -0
  378. package/tools/senders/delete-senders.d.mts.map +1 -0
  379. package/tools/senders/delete-senders.d.ts +51 -0
  380. package/tools/senders/delete-senders.d.ts.map +1 -0
  381. package/tools/senders/delete-senders.js +37 -0
  382. package/tools/senders/delete-senders.js.map +1 -0
  383. package/tools/senders/delete-senders.mjs +33 -0
  384. package/tools/senders/delete-senders.mjs.map +1 -0
  385. package/tools/senders/list-senders.d.mts +51 -0
  386. package/tools/senders/list-senders.d.mts.map +1 -0
  387. package/tools/senders/list-senders.d.ts +51 -0
  388. package/tools/senders/list-senders.d.ts.map +1 -0
  389. package/tools/senders/list-senders.js +58 -0
  390. package/tools/senders/list-senders.js.map +1 -0
  391. package/tools/senders/list-senders.mjs +51 -0
  392. package/tools/senders/list-senders.mjs.map +1 -0
  393. package/tools/senders/regenerate-webhook-secret-senders.d.mts +51 -0
  394. package/tools/senders/regenerate-webhook-secret-senders.d.mts.map +1 -0
  395. package/tools/senders/regenerate-webhook-secret-senders.d.ts +51 -0
  396. package/tools/senders/regenerate-webhook-secret-senders.d.ts.map +1 -0
  397. package/tools/senders/regenerate-webhook-secret-senders.js +52 -0
  398. package/tools/senders/regenerate-webhook-secret-senders.js.map +1 -0
  399. package/tools/senders/regenerate-webhook-secret-senders.mjs +45 -0
  400. package/tools/senders/regenerate-webhook-secret-senders.mjs.map +1 -0
  401. package/tools/senders/retrieve-senders.d.mts +51 -0
  402. package/tools/senders/retrieve-senders.d.mts.map +1 -0
  403. package/tools/senders/retrieve-senders.d.ts +51 -0
  404. package/tools/senders/retrieve-senders.d.ts.map +1 -0
  405. package/tools/senders/retrieve-senders.js +54 -0
  406. package/tools/senders/retrieve-senders.js.map +1 -0
  407. package/tools/senders/retrieve-senders.mjs +47 -0
  408. package/tools/senders/retrieve-senders.mjs.map +1 -0
  409. package/tools/senders/update-senders.d.mts +51 -0
  410. package/tools/senders/update-senders.d.mts.map +1 -0
  411. package/tools/senders/update-senders.d.ts +51 -0
  412. package/tools/senders/update-senders.d.ts.map +1 -0
  413. package/tools/senders/update-senders.js +89 -0
  414. package/tools/senders/update-senders.js.map +1 -0
  415. package/tools/senders/update-senders.mjs +82 -0
  416. package/tools/senders/update-senders.mjs.map +1 -0
  417. package/tools/templates/create-templates.d.mts +51 -0
  418. package/tools/templates/create-templates.d.mts.map +1 -0
  419. package/tools/templates/create-templates.d.ts +51 -0
  420. package/tools/templates/create-templates.d.ts.map +1 -0
  421. package/tools/templates/create-templates.js +74 -0
  422. package/tools/templates/create-templates.js.map +1 -0
  423. package/tools/templates/create-templates.mjs +67 -0
  424. package/tools/templates/create-templates.mjs.map +1 -0
  425. package/tools/templates/delete-templates.d.mts +51 -0
  426. package/tools/templates/delete-templates.d.mts.map +1 -0
  427. package/tools/templates/delete-templates.d.ts +51 -0
  428. package/tools/templates/delete-templates.d.ts.map +1 -0
  429. package/tools/templates/delete-templates.js +37 -0
  430. package/tools/templates/delete-templates.js.map +1 -0
  431. package/tools/templates/delete-templates.mjs +33 -0
  432. package/tools/templates/delete-templates.mjs.map +1 -0
  433. package/tools/templates/list-templates.d.mts +51 -0
  434. package/tools/templates/list-templates.d.mts.map +1 -0
  435. package/tools/templates/list-templates.d.ts +51 -0
  436. package/tools/templates/list-templates.d.ts.map +1 -0
  437. package/tools/templates/list-templates.js +58 -0
  438. package/tools/templates/list-templates.js.map +1 -0
  439. package/tools/templates/list-templates.mjs +51 -0
  440. package/tools/templates/list-templates.mjs.map +1 -0
  441. package/tools/templates/retrieve-templates.d.mts +51 -0
  442. package/tools/templates/retrieve-templates.d.mts.map +1 -0
  443. package/tools/templates/retrieve-templates.d.ts +51 -0
  444. package/tools/templates/retrieve-templates.d.ts.map +1 -0
  445. package/tools/templates/retrieve-templates.js +54 -0
  446. package/tools/templates/retrieve-templates.js.map +1 -0
  447. package/tools/templates/retrieve-templates.mjs +47 -0
  448. package/tools/templates/retrieve-templates.mjs.map +1 -0
  449. package/tools/templates/submit-templates.d.mts +51 -0
  450. package/tools/templates/submit-templates.d.mts.map +1 -0
  451. package/tools/templates/submit-templates.d.ts +51 -0
  452. package/tools/templates/submit-templates.d.ts.map +1 -0
  453. package/tools/templates/submit-templates.js +66 -0
  454. package/tools/templates/submit-templates.js.map +1 -0
  455. package/tools/templates/submit-templates.mjs +59 -0
  456. package/tools/templates/submit-templates.mjs.map +1 -0
  457. package/tools/types.d.mts +52 -0
  458. package/tools/types.d.mts.map +1 -0
  459. package/tools/types.d.ts +52 -0
  460. package/tools/types.d.ts.map +1 -0
  461. package/tools/types.js +58 -0
  462. package/tools/types.js.map +1 -0
  463. package/tools/types.mjs +53 -0
  464. package/tools/types.mjs.map +1 -0
  465. package/tools.d.mts +2 -0
  466. package/tools.d.mts.map +1 -0
  467. package/tools.d.ts +2 -0
  468. package/tools.d.ts.map +1 -0
  469. package/tools.js +18 -0
  470. package/tools.js.map +1 -0
  471. package/tools.mjs +2 -0
  472. package/tools.mjs.map +1 -0
@@ -0,0 +1,78 @@
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: 'messages',
11
+ operation: 'read',
12
+ tags: [],
13
+ httpMethod: 'get',
14
+ httpPath: '/v1/messages',
15
+ operationId: 'listMessages',
16
+ };
17
+
18
+ export const tool: Tool = {
19
+ name: 'list_messages',
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 messages previously sent by this project.\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n items: {\n type: 'array',\n items: {\n $ref: '#/$defs/message'\n }\n },\n nextCursor: {\n type: 'string'\n }\n },\n required: [ 'items'\n ],\n $defs: {\n message: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n channel: {\n $ref: '#/$defs/channel'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n messageType: {\n $ref: '#/$defs/message_type'\n },\n status: {\n $ref: '#/$defs/message_status'\n },\n to: {\n type: 'string'\n },\n content: {\n $ref: '#/$defs/message_content'\n },\n cost: {\n type: 'number',\n description: 'MAU cost in USD (charged for first contact of the month).'\n },\n costProvider: {\n type: 'number',\n description: 'Provider cost in USD (Telnyx, SES, etc.).'\n },\n costTotal: {\n type: 'number',\n description: 'Total cost in USD (MAU + provider cost).'\n },\n errorCode: {\n type: 'string'\n },\n errorMessage: {\n type: 'string'\n },\n from: {\n type: 'string'\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n providerMessageId: {\n type: 'string',\n description: 'Message ID from the delivery provider.'\n },\n senderId: {\n type: 'string'\n },\n text: {\n type: 'string',\n description: 'Text content or caption.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'id',\n 'channel',\n 'createdAt',\n 'messageType',\n 'status',\n 'to'\n ]\n },\n channel: {\n type: 'string',\n description: 'Delivery channel. Use \\'auto\\' for intelligent routing.',\n enum: [ 'auto',\n 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n message_type: {\n type: 'string',\n description: 'Type of message. Non-text types are WhatsApp only.',\n enum: [ 'text',\n 'image',\n 'video',\n 'audio',\n 'document',\n 'sticker',\n 'location',\n 'contact',\n 'buttons',\n 'list',\n 'reaction',\n 'template'\n ]\n },\n message_status: {\n type: 'string',\n enum: [ 'queued',\n 'sending',\n 'delivered',\n 'failed',\n 'received'\n ]\n },\n message_content: {\n type: 'object',\n description: 'Content for non-text message types (WhatsApp only).',\n properties: {\n buttons: {\n type: 'array',\n description: 'Interactive buttons (max 3).',\n items: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n title: {\n type: 'string'\n }\n },\n required: [ 'id',\n 'title'\n ]\n }\n },\n contacts: {\n type: 'array',\n description: 'Contact cards for contact messages.',\n items: {\n type: 'object',\n properties: {\n name: {\n type: 'string'\n },\n phones: {\n type: 'array',\n items: {\n type: 'string'\n }\n }\n }\n }\n },\n emoji: {\n type: 'string',\n description: 'Emoji for reaction messages.'\n },\n filename: {\n type: 'string',\n description: 'Filename for documents.'\n },\n latitude: {\n type: 'number',\n description: 'Latitude for location messages.'\n },\n listButton: {\n type: 'string',\n description: 'Button text for list messages.'\n },\n locationAddress: {\n type: 'string',\n description: 'Address of the location.'\n },\n locationName: {\n type: 'string',\n description: 'Name of the location.'\n },\n longitude: {\n type: 'number',\n description: 'Longitude for location messages.'\n },\n mediaId: {\n type: 'string',\n description: 'WhatsApp media ID if already uploaded.'\n },\n mediaUrl: {\n type: 'string',\n description: 'URL of the media file (for image, video, audio, document, sticker).'\n },\n mimeType: {\n type: 'string',\n description: 'MIME type of the media.'\n },\n reactToMessageId: {\n type: 'string',\n description: 'Message ID to react to.'\n },\n sections: {\n type: 'array',\n description: 'Sections for list messages.',\n items: {\n type: 'object',\n properties: {\n rows: {\n type: 'array',\n items: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n title: {\n type: 'string'\n },\n description: {\n type: 'string'\n }\n },\n required: [ 'id',\n 'title'\n ]\n }\n },\n title: {\n type: 'string'\n }\n },\n required: [ 'rows',\n 'title'\n ]\n }\n },\n templateId: {\n type: 'string',\n description: 'Template ID for template messages.'\n },\n templateVariables: {\n type: 'object',\n description: 'Variables for template rendering. Keys are variable positions (1, 2, 3...).',\n additionalProperties: true\n }\n }\n }\n }\n}\n```",
22
+ inputSchema: {
23
+ type: 'object',
24
+ properties: {
25
+ channel: {
26
+ $ref: '#/$defs/channel',
27
+ },
28
+ cursor: {
29
+ type: 'string',
30
+ },
31
+ limit: {
32
+ type: 'integer',
33
+ },
34
+ status: {
35
+ $ref: '#/$defs/message_status',
36
+ },
37
+ to: {
38
+ type: 'string',
39
+ },
40
+ jq_filter: {
41
+ type: 'string',
42
+ title: 'jq Filter',
43
+ description:
44
+ '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/).',
45
+ },
46
+ },
47
+ required: [],
48
+ $defs: {
49
+ channel: {
50
+ type: 'string',
51
+ description: "Delivery channel. Use 'auto' for intelligent routing.",
52
+ enum: ['auto', 'sms', 'whatsapp', 'email'],
53
+ },
54
+ message_status: {
55
+ type: 'string',
56
+ enum: ['queued', 'sending', 'delivered', 'failed', 'received'],
57
+ },
58
+ },
59
+ },
60
+ annotations: {
61
+ readOnlyHint: true,
62
+ },
63
+ };
64
+
65
+ export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
66
+ const { jq_filter, ...body } = args as any;
67
+ const response = await client.messages.list(body).asResponse();
68
+ try {
69
+ return asTextContentResult(await maybeFilter(jq_filter, await response.json()));
70
+ } catch (error) {
71
+ if (error instanceof Zavudev.APIError || isJqError(error)) {
72
+ return asErrorResult(error.message);
73
+ }
74
+ throw error;
75
+ }
76
+ };
77
+
78
+ export default { metadata, tool, handler };
@@ -0,0 +1,59 @@
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: 'messages',
11
+ operation: 'write',
12
+ tags: [],
13
+ httpMethod: 'post',
14
+ httpPath: '/v1/messages/{messageId}/reactions',
15
+ operationId: 'sendReaction',
16
+ };
17
+
18
+ export const tool: Tool = {
19
+ name: 'react_messages',
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\nSend an emoji reaction to an existing WhatsApp message. Reactions are only supported for WhatsApp messages.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/message_response',\n $defs: {\n message_response: {\n type: 'object',\n properties: {\n message: {\n $ref: '#/$defs/message'\n }\n },\n required: [ 'message'\n ]\n },\n message: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n channel: {\n $ref: '#/$defs/channel'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n messageType: {\n $ref: '#/$defs/message_type'\n },\n status: {\n $ref: '#/$defs/message_status'\n },\n to: {\n type: 'string'\n },\n content: {\n $ref: '#/$defs/message_content'\n },\n cost: {\n type: 'number',\n description: 'MAU cost in USD (charged for first contact of the month).'\n },\n costProvider: {\n type: 'number',\n description: 'Provider cost in USD (Telnyx, SES, etc.).'\n },\n costTotal: {\n type: 'number',\n description: 'Total cost in USD (MAU + provider cost).'\n },\n errorCode: {\n type: 'string'\n },\n errorMessage: {\n type: 'string'\n },\n from: {\n type: 'string'\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n providerMessageId: {\n type: 'string',\n description: 'Message ID from the delivery provider.'\n },\n senderId: {\n type: 'string'\n },\n text: {\n type: 'string',\n description: 'Text content or caption.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'id',\n 'channel',\n 'createdAt',\n 'messageType',\n 'status',\n 'to'\n ]\n },\n channel: {\n type: 'string',\n description: 'Delivery channel. Use \\'auto\\' for intelligent routing.',\n enum: [ 'auto',\n 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n message_type: {\n type: 'string',\n description: 'Type of message. Non-text types are WhatsApp only.',\n enum: [ 'text',\n 'image',\n 'video',\n 'audio',\n 'document',\n 'sticker',\n 'location',\n 'contact',\n 'buttons',\n 'list',\n 'reaction',\n 'template'\n ]\n },\n message_status: {\n type: 'string',\n enum: [ 'queued',\n 'sending',\n 'delivered',\n 'failed',\n 'received'\n ]\n },\n message_content: {\n type: 'object',\n description: 'Content for non-text message types (WhatsApp only).',\n properties: {\n buttons: {\n type: 'array',\n description: 'Interactive buttons (max 3).',\n items: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n title: {\n type: 'string'\n }\n },\n required: [ 'id',\n 'title'\n ]\n }\n },\n contacts: {\n type: 'array',\n description: 'Contact cards for contact messages.',\n items: {\n type: 'object',\n properties: {\n name: {\n type: 'string'\n },\n phones: {\n type: 'array',\n items: {\n type: 'string'\n }\n }\n }\n }\n },\n emoji: {\n type: 'string',\n description: 'Emoji for reaction messages.'\n },\n filename: {\n type: 'string',\n description: 'Filename for documents.'\n },\n latitude: {\n type: 'number',\n description: 'Latitude for location messages.'\n },\n listButton: {\n type: 'string',\n description: 'Button text for list messages.'\n },\n locationAddress: {\n type: 'string',\n description: 'Address of the location.'\n },\n locationName: {\n type: 'string',\n description: 'Name of the location.'\n },\n longitude: {\n type: 'number',\n description: 'Longitude for location messages.'\n },\n mediaId: {\n type: 'string',\n description: 'WhatsApp media ID if already uploaded.'\n },\n mediaUrl: {\n type: 'string',\n description: 'URL of the media file (for image, video, audio, document, sticker).'\n },\n mimeType: {\n type: 'string',\n description: 'MIME type of the media.'\n },\n reactToMessageId: {\n type: 'string',\n description: 'Message ID to react to.'\n },\n sections: {\n type: 'array',\n description: 'Sections for list messages.',\n items: {\n type: 'object',\n properties: {\n rows: {\n type: 'array',\n items: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n title: {\n type: 'string'\n },\n description: {\n type: 'string'\n }\n },\n required: [ 'id',\n 'title'\n ]\n }\n },\n title: {\n type: 'string'\n }\n },\n required: [ 'rows',\n 'title'\n ]\n }\n },\n templateId: {\n type: 'string',\n description: 'Template ID for template messages.'\n },\n templateVariables: {\n type: 'object',\n description: 'Variables for template rendering. Keys are variable positions (1, 2, 3...).',\n additionalProperties: true\n }\n }\n }\n }\n}\n```",
22
+ inputSchema: {
23
+ type: 'object',
24
+ properties: {
25
+ messageId: {
26
+ type: 'string',
27
+ },
28
+ emoji: {
29
+ type: 'string',
30
+ description: 'Single emoji character to react with.',
31
+ },
32
+ 'Zavu-Sender': {
33
+ type: 'string',
34
+ },
35
+ jq_filter: {
36
+ type: 'string',
37
+ title: 'jq Filter',
38
+ description:
39
+ '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/).',
40
+ },
41
+ },
42
+ required: ['messageId', 'emoji'],
43
+ },
44
+ annotations: {},
45
+ };
46
+
47
+ export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
48
+ const { messageId, jq_filter, ...body } = args as any;
49
+ try {
50
+ return asTextContentResult(await maybeFilter(jq_filter, await client.messages.react(messageId, body)));
51
+ } catch (error) {
52
+ if (error instanceof Zavudev.APIError || isJqError(error)) {
53
+ return asErrorResult(error.message);
54
+ }
55
+ throw error;
56
+ }
57
+ };
58
+
59
+ export default { metadata, tool, handler };
@@ -0,0 +1,54 @@
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: 'messages',
11
+ operation: 'read',
12
+ tags: [],
13
+ httpMethod: 'get',
14
+ httpPath: '/v1/messages/{messageId}',
15
+ operationId: 'getMessage',
16
+ };
17
+
18
+ export const tool: Tool = {
19
+ name: 'retrieve_messages',
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 message by ID\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/message_response',\n $defs: {\n message_response: {\n type: 'object',\n properties: {\n message: {\n $ref: '#/$defs/message'\n }\n },\n required: [ 'message'\n ]\n },\n message: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n channel: {\n $ref: '#/$defs/channel'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n messageType: {\n $ref: '#/$defs/message_type'\n },\n status: {\n $ref: '#/$defs/message_status'\n },\n to: {\n type: 'string'\n },\n content: {\n $ref: '#/$defs/message_content'\n },\n cost: {\n type: 'number',\n description: 'MAU cost in USD (charged for first contact of the month).'\n },\n costProvider: {\n type: 'number',\n description: 'Provider cost in USD (Telnyx, SES, etc.).'\n },\n costTotal: {\n type: 'number',\n description: 'Total cost in USD (MAU + provider cost).'\n },\n errorCode: {\n type: 'string'\n },\n errorMessage: {\n type: 'string'\n },\n from: {\n type: 'string'\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n providerMessageId: {\n type: 'string',\n description: 'Message ID from the delivery provider.'\n },\n senderId: {\n type: 'string'\n },\n text: {\n type: 'string',\n description: 'Text content or caption.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'id',\n 'channel',\n 'createdAt',\n 'messageType',\n 'status',\n 'to'\n ]\n },\n channel: {\n type: 'string',\n description: 'Delivery channel. Use \\'auto\\' for intelligent routing.',\n enum: [ 'auto',\n 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n message_type: {\n type: 'string',\n description: 'Type of message. Non-text types are WhatsApp only.',\n enum: [ 'text',\n 'image',\n 'video',\n 'audio',\n 'document',\n 'sticker',\n 'location',\n 'contact',\n 'buttons',\n 'list',\n 'reaction',\n 'template'\n ]\n },\n message_status: {\n type: 'string',\n enum: [ 'queued',\n 'sending',\n 'delivered',\n 'failed',\n 'received'\n ]\n },\n message_content: {\n type: 'object',\n description: 'Content for non-text message types (WhatsApp only).',\n properties: {\n buttons: {\n type: 'array',\n description: 'Interactive buttons (max 3).',\n items: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n title: {\n type: 'string'\n }\n },\n required: [ 'id',\n 'title'\n ]\n }\n },\n contacts: {\n type: 'array',\n description: 'Contact cards for contact messages.',\n items: {\n type: 'object',\n properties: {\n name: {\n type: 'string'\n },\n phones: {\n type: 'array',\n items: {\n type: 'string'\n }\n }\n }\n }\n },\n emoji: {\n type: 'string',\n description: 'Emoji for reaction messages.'\n },\n filename: {\n type: 'string',\n description: 'Filename for documents.'\n },\n latitude: {\n type: 'number',\n description: 'Latitude for location messages.'\n },\n listButton: {\n type: 'string',\n description: 'Button text for list messages.'\n },\n locationAddress: {\n type: 'string',\n description: 'Address of the location.'\n },\n locationName: {\n type: 'string',\n description: 'Name of the location.'\n },\n longitude: {\n type: 'number',\n description: 'Longitude for location messages.'\n },\n mediaId: {\n type: 'string',\n description: 'WhatsApp media ID if already uploaded.'\n },\n mediaUrl: {\n type: 'string',\n description: 'URL of the media file (for image, video, audio, document, sticker).'\n },\n mimeType: {\n type: 'string',\n description: 'MIME type of the media.'\n },\n reactToMessageId: {\n type: 'string',\n description: 'Message ID to react to.'\n },\n sections: {\n type: 'array',\n description: 'Sections for list messages.',\n items: {\n type: 'object',\n properties: {\n rows: {\n type: 'array',\n items: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n title: {\n type: 'string'\n },\n description: {\n type: 'string'\n }\n },\n required: [ 'id',\n 'title'\n ]\n }\n },\n title: {\n type: 'string'\n }\n },\n required: [ 'rows',\n 'title'\n ]\n }\n },\n templateId: {\n type: 'string',\n description: 'Template ID for template messages.'\n },\n templateVariables: {\n type: 'object',\n description: 'Variables for template rendering. Keys are variable positions (1, 2, 3...).',\n additionalProperties: true\n }\n }\n }\n }\n}\n```",
22
+ inputSchema: {
23
+ type: 'object',
24
+ properties: {
25
+ messageId: {
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: ['messageId'],
36
+ },
37
+ annotations: {
38
+ readOnlyHint: true,
39
+ },
40
+ };
41
+
42
+ export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
43
+ const { messageId, jq_filter, ...body } = args as any;
44
+ try {
45
+ return asTextContentResult(await maybeFilter(jq_filter, await client.messages.retrieve(messageId)));
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 };
@@ -0,0 +1,233 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
4
+
5
+ import { Tool } from '@modelcontextprotocol/sdk/types.js';
6
+ import Zavudev from '@zavudev/sdk';
7
+
8
+ export const metadata: Metadata = {
9
+ resource: 'messages',
10
+ operation: 'write',
11
+ tags: [],
12
+ httpMethod: 'post',
13
+ httpPath: '/v1/messages',
14
+ operationId: 'sendMessage',
15
+ };
16
+
17
+ export const tool: Tool = {
18
+ name: 'send_messages',
19
+ description:
20
+ 'Send a message to a recipient via SMS or WhatsApp.\n\n**Channel selection:**\n- If `channel` is omitted and `messageType` is `text`, defaults to SMS\n- If `messageType` is anything other than `text`, WhatsApp is used automatically\n\n**WhatsApp 24-hour window:**\n- Free-form messages (non-template) require an open 24h window\n- Window opens when the user messages you first\n- Use template messages to initiate conversations outside the window',
21
+ inputSchema: {
22
+ type: 'object',
23
+ properties: {
24
+ to: {
25
+ type: 'string',
26
+ description: 'Recipient phone number in E.164 format or email address.',
27
+ },
28
+ channel: {
29
+ $ref: '#/$defs/channel',
30
+ },
31
+ content: {
32
+ $ref: '#/$defs/message_content',
33
+ },
34
+ htmlBody: {
35
+ type: 'string',
36
+ description:
37
+ 'HTML body for email messages. If provided, email will be sent as multipart with both text and HTML.',
38
+ },
39
+ idempotencyKey: {
40
+ type: 'string',
41
+ description: 'Optional idempotency key to avoid duplicate sends.',
42
+ },
43
+ messageType: {
44
+ $ref: '#/$defs/message_type',
45
+ },
46
+ metadata: {
47
+ type: 'object',
48
+ description: 'Arbitrary metadata to associate with the message.',
49
+ additionalProperties: true,
50
+ },
51
+ replyTo: {
52
+ type: 'string',
53
+ description: 'Reply-To email address for email messages.',
54
+ },
55
+ subject: {
56
+ type: 'string',
57
+ description: "Email subject line. Required when channel is 'email' or recipient is an email address.",
58
+ },
59
+ text: {
60
+ type: 'string',
61
+ description: 'Text body for text messages or caption for media messages.',
62
+ },
63
+ 'Zavu-Sender': {
64
+ type: 'string',
65
+ },
66
+ },
67
+ required: ['to'],
68
+ $defs: {
69
+ channel: {
70
+ type: 'string',
71
+ description: "Delivery channel. Use 'auto' for intelligent routing.",
72
+ enum: ['auto', 'sms', 'whatsapp', 'email'],
73
+ },
74
+ message_content: {
75
+ type: 'object',
76
+ description: 'Content for non-text message types (WhatsApp only).',
77
+ properties: {
78
+ buttons: {
79
+ type: 'array',
80
+ description: 'Interactive buttons (max 3).',
81
+ items: {
82
+ type: 'object',
83
+ properties: {
84
+ id: {
85
+ type: 'string',
86
+ },
87
+ title: {
88
+ type: 'string',
89
+ },
90
+ },
91
+ required: ['id', 'title'],
92
+ },
93
+ },
94
+ contacts: {
95
+ type: 'array',
96
+ description: 'Contact cards for contact messages.',
97
+ items: {
98
+ type: 'object',
99
+ properties: {
100
+ name: {
101
+ type: 'string',
102
+ },
103
+ phones: {
104
+ type: 'array',
105
+ items: {
106
+ type: 'string',
107
+ },
108
+ },
109
+ },
110
+ },
111
+ },
112
+ emoji: {
113
+ type: 'string',
114
+ description: 'Emoji for reaction messages.',
115
+ },
116
+ filename: {
117
+ type: 'string',
118
+ description: 'Filename for documents.',
119
+ },
120
+ latitude: {
121
+ type: 'number',
122
+ description: 'Latitude for location messages.',
123
+ },
124
+ listButton: {
125
+ type: 'string',
126
+ description: 'Button text for list messages.',
127
+ },
128
+ locationAddress: {
129
+ type: 'string',
130
+ description: 'Address of the location.',
131
+ },
132
+ locationName: {
133
+ type: 'string',
134
+ description: 'Name of the location.',
135
+ },
136
+ longitude: {
137
+ type: 'number',
138
+ description: 'Longitude for location messages.',
139
+ },
140
+ mediaId: {
141
+ type: 'string',
142
+ description: 'WhatsApp media ID if already uploaded.',
143
+ },
144
+ mediaUrl: {
145
+ type: 'string',
146
+ description: 'URL of the media file (for image, video, audio, document, sticker).',
147
+ },
148
+ mimeType: {
149
+ type: 'string',
150
+ description: 'MIME type of the media.',
151
+ },
152
+ reactToMessageId: {
153
+ type: 'string',
154
+ description: 'Message ID to react to.',
155
+ },
156
+ sections: {
157
+ type: 'array',
158
+ description: 'Sections for list messages.',
159
+ items: {
160
+ type: 'object',
161
+ properties: {
162
+ rows: {
163
+ type: 'array',
164
+ items: {
165
+ type: 'object',
166
+ properties: {
167
+ id: {
168
+ type: 'string',
169
+ },
170
+ title: {
171
+ type: 'string',
172
+ },
173
+ description: {
174
+ type: 'string',
175
+ },
176
+ },
177
+ required: ['id', 'title'],
178
+ },
179
+ },
180
+ title: {
181
+ type: 'string',
182
+ },
183
+ },
184
+ required: ['rows', 'title'],
185
+ },
186
+ },
187
+ templateId: {
188
+ type: 'string',
189
+ description: 'Template ID for template messages.',
190
+ },
191
+ templateVariables: {
192
+ type: 'object',
193
+ description: 'Variables for template rendering. Keys are variable positions (1, 2, 3...).',
194
+ additionalProperties: true,
195
+ },
196
+ },
197
+ },
198
+ message_type: {
199
+ type: 'string',
200
+ description: 'Type of message. Non-text types are WhatsApp only.',
201
+ enum: [
202
+ 'text',
203
+ 'image',
204
+ 'video',
205
+ 'audio',
206
+ 'document',
207
+ 'sticker',
208
+ 'location',
209
+ 'contact',
210
+ 'buttons',
211
+ 'list',
212
+ 'reaction',
213
+ 'template',
214
+ ],
215
+ },
216
+ },
217
+ },
218
+ annotations: {},
219
+ };
220
+
221
+ export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
222
+ const body = args as any;
223
+ try {
224
+ return asTextContentResult(await client.messages.send(body));
225
+ } catch (error) {
226
+ if (error instanceof Zavudev.APIError) {
227
+ return asErrorResult(error.message);
228
+ }
229
+ throw error;
230
+ }
231
+ };
232
+
233
+ export default { metadata, tool, handler };
@@ -0,0 +1,68 @@
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: 'phone_numbers',
11
+ operation: 'read',
12
+ tags: [],
13
+ httpMethod: 'get',
14
+ httpPath: '/v1/phone-numbers',
15
+ operationId: 'listPhoneNumbers',
16
+ };
17
+
18
+ export const tool: Tool = {
19
+ name: 'list_phone_numbers',
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 all phone numbers owned by this project.\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n items: {\n type: 'array',\n items: {\n $ref: '#/$defs/owned_phone_number'\n }\n },\n nextCursor: {\n type: 'string'\n }\n },\n required: [ 'items'\n ],\n $defs: {\n owned_phone_number: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n capabilities: {\n type: 'array',\n items: {\n type: 'string'\n }\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n phoneNumber: {\n type: 'string'\n },\n pricing: {\n $ref: '#/$defs/owned_phone_number_pricing'\n },\n status: {\n $ref: '#/$defs/phone_number_status'\n },\n name: {\n type: 'string',\n description: 'Optional custom name for the phone number.'\n },\n nextRenewalDate: {\n type: 'string',\n format: 'date-time'\n },\n senderId: {\n type: 'string',\n description: 'Sender ID if the phone number is assigned to a sender.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'id',\n 'capabilities',\n 'createdAt',\n 'phoneNumber',\n 'pricing',\n 'status'\n ]\n },\n owned_phone_number_pricing: {\n type: 'object',\n properties: {\n isFreeNumber: {\n type: 'boolean',\n description: 'Whether this is a free number.'\n },\n monthlyCost: {\n type: 'number',\n description: 'Monthly cost in cents.'\n },\n monthlyPrice: {\n type: 'number',\n description: 'Monthly price in USD.'\n },\n upfrontCost: {\n type: 'number',\n description: 'One-time purchase cost in cents.'\n }\n }\n },\n phone_number_status: {\n type: 'string',\n enum: [ 'active',\n 'suspended',\n 'pending'\n ]\n }\n }\n}\n```",
22
+ inputSchema: {
23
+ type: 'object',
24
+ properties: {
25
+ cursor: {
26
+ type: 'string',
27
+ description: 'Pagination cursor.',
28
+ },
29
+ limit: {
30
+ type: 'integer',
31
+ },
32
+ status: {
33
+ $ref: '#/$defs/phone_number_status',
34
+ },
35
+ jq_filter: {
36
+ type: 'string',
37
+ title: 'jq Filter',
38
+ description:
39
+ '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/).',
40
+ },
41
+ },
42
+ required: [],
43
+ $defs: {
44
+ phone_number_status: {
45
+ type: 'string',
46
+ enum: ['active', 'suspended', 'pending'],
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.phoneNumbers.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 };
@@ -0,0 +1,57 @@
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: 'phone_numbers',
11
+ operation: 'write',
12
+ tags: [],
13
+ httpMethod: 'post',
14
+ httpPath: '/v1/phone-numbers',
15
+ operationId: 'purchasePhoneNumber',
16
+ };
17
+
18
+ export const tool: Tool = {
19
+ name: 'purchase_phone_numbers',
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\nPurchase an available phone number. The first US phone number is free for each team.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/phone_number_purchase_response',\n $defs: {\n phone_number_purchase_response: {\n type: 'object',\n properties: {\n phoneNumber: {\n $ref: '#/$defs/owned_phone_number'\n }\n },\n required: [ 'phoneNumber'\n ]\n },\n owned_phone_number: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n capabilities: {\n type: 'array',\n items: {\n type: 'string'\n }\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n phoneNumber: {\n type: 'string'\n },\n pricing: {\n $ref: '#/$defs/owned_phone_number_pricing'\n },\n status: {\n $ref: '#/$defs/phone_number_status'\n },\n name: {\n type: 'string',\n description: 'Optional custom name for the phone number.'\n },\n nextRenewalDate: {\n type: 'string',\n format: 'date-time'\n },\n senderId: {\n type: 'string',\n description: 'Sender ID if the phone number is assigned to a sender.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'id',\n 'capabilities',\n 'createdAt',\n 'phoneNumber',\n 'pricing',\n 'status'\n ]\n },\n owned_phone_number_pricing: {\n type: 'object',\n properties: {\n isFreeNumber: {\n type: 'boolean',\n description: 'Whether this is a free number.'\n },\n monthlyCost: {\n type: 'number',\n description: 'Monthly cost in cents.'\n },\n monthlyPrice: {\n type: 'number',\n description: 'Monthly price in USD.'\n },\n upfrontCost: {\n type: 'number',\n description: 'One-time purchase cost in cents.'\n }\n }\n },\n phone_number_status: {\n type: 'string',\n enum: [ 'active',\n 'suspended',\n 'pending'\n ]\n }\n }\n}\n```",
22
+ inputSchema: {
23
+ type: 'object',
24
+ properties: {
25
+ phoneNumber: {
26
+ type: 'string',
27
+ description: 'Phone number in E.164 format.',
28
+ },
29
+ name: {
30
+ type: 'string',
31
+ description: 'Optional custom name for the phone number.',
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: ['phoneNumber'],
41
+ },
42
+ annotations: {},
43
+ };
44
+
45
+ export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
46
+ const { jq_filter, ...body } = args as any;
47
+ try {
48
+ return asTextContentResult(await maybeFilter(jq_filter, await client.phoneNumbers.purchase(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 };
@@ -0,0 +1,40 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ import { Metadata, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
4
+
5
+ import { Tool } from '@modelcontextprotocol/sdk/types.js';
6
+ import Zavudev from '@zavudev/sdk';
7
+
8
+ export const metadata: Metadata = {
9
+ resource: 'phone_numbers',
10
+ operation: 'write',
11
+ tags: [],
12
+ httpMethod: 'delete',
13
+ httpPath: '/v1/phone-numbers/{phoneNumberId}',
14
+ operationId: 'releasePhoneNumber',
15
+ };
16
+
17
+ export const tool: Tool = {
18
+ name: 'release_phone_numbers',
19
+ description: 'Release a phone number. The phone number must not be assigned to a sender.',
20
+ inputSchema: {
21
+ type: 'object',
22
+ properties: {
23
+ phoneNumberId: {
24
+ type: 'string',
25
+ },
26
+ },
27
+ required: ['phoneNumberId'],
28
+ },
29
+ annotations: {
30
+ idempotentHint: true,
31
+ },
32
+ };
33
+
34
+ export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
35
+ const { phoneNumberId, ...body } = args as any;
36
+ const response = await client.phoneNumbers.release(phoneNumberId).asResponse();
37
+ return asTextContentResult(await response.text());
38
+ };
39
+
40
+ export default { metadata, tool, handler };