@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.
- package/LICENSE +201 -0
- package/README.md +313 -0
- package/code-tool-types.d.mts +16 -0
- package/code-tool-types.d.mts.map +1 -0
- package/code-tool-types.d.ts +16 -0
- package/code-tool-types.d.ts.map +1 -0
- package/code-tool-types.js +4 -0
- package/code-tool-types.js.map +1 -0
- package/code-tool-types.mjs +3 -0
- package/code-tool-types.mjs.map +1 -0
- package/code-tool.d.mts +54 -0
- package/code-tool.d.mts.map +1 -0
- package/code-tool.d.ts +54 -0
- package/code-tool.d.ts.map +1 -0
- package/code-tool.js +49 -0
- package/code-tool.js.map +1 -0
- package/code-tool.mjs +46 -0
- package/code-tool.mjs.map +1 -0
- package/compat.d.mts +58 -0
- package/compat.d.mts.map +1 -0
- package/compat.d.ts +58 -0
- package/compat.d.ts.map +1 -0
- package/compat.js +387 -0
- package/compat.js.map +1 -0
- package/compat.mjs +378 -0
- package/compat.mjs.map +1 -0
- package/docs-search-tool.d.mts +50 -0
- package/docs-search-tool.d.mts.map +1 -0
- package/docs-search-tool.d.ts +50 -0
- package/docs-search-tool.d.ts.map +1 -0
- package/docs-search-tool.js +51 -0
- package/docs-search-tool.js.map +1 -0
- package/docs-search-tool.mjs +47 -0
- package/docs-search-tool.mjs.map +1 -0
- package/dynamic-tools.d.mts +12 -0
- package/dynamic-tools.d.mts.map +1 -0
- package/dynamic-tools.d.ts +12 -0
- package/dynamic-tools.d.ts.map +1 -0
- package/dynamic-tools.js +135 -0
- package/dynamic-tools.js.map +1 -0
- package/dynamic-tools.mjs +132 -0
- package/dynamic-tools.mjs.map +1 -0
- package/filtering.d.mts +3 -0
- package/filtering.d.mts.map +1 -0
- package/filtering.d.ts +3 -0
- package/filtering.d.ts.map +1 -0
- package/filtering.js +24 -0
- package/filtering.js.map +1 -0
- package/filtering.mjs +16 -0
- package/filtering.mjs.map +1 -0
- package/headers.d.mts +4 -0
- package/headers.d.mts.map +1 -0
- package/headers.d.ts +4 -0
- package/headers.d.ts.map +1 -0
- package/headers.js +22 -0
- package/headers.js.map +1 -0
- package/headers.mjs +18 -0
- package/headers.mjs.map +1 -0
- package/http.d.mts +9 -0
- package/http.d.mts.map +1 -0
- package/http.d.ts +9 -0
- package/http.d.ts.map +1 -0
- package/http.js +108 -0
- package/http.js.map +1 -0
- package/http.mjs +100 -0
- package/http.mjs.map +1 -0
- package/index.d.mts +3 -0
- package/index.d.mts.map +1 -0
- package/index.d.ts +3 -0
- package/index.d.ts.map +1 -0
- package/index.js +91 -0
- package/index.js.map +1 -0
- package/index.mjs +89 -0
- package/index.mjs.map +1 -0
- package/options.d.mts +20 -0
- package/options.d.mts.map +1 -0
- package/options.d.ts +20 -0
- package/options.d.ts.map +1 -0
- package/options.js +427 -0
- package/options.js.map +1 -0
- package/options.mjs +420 -0
- package/options.mjs.map +1 -0
- package/package.json +201 -0
- package/server.d.mts +35 -0
- package/server.d.mts.map +1 -0
- package/server.d.ts +35 -0
- package/server.d.ts.map +1 -0
- package/server.js +174 -0
- package/server.js.map +1 -0
- package/server.mjs +160 -0
- package/server.mjs.map +1 -0
- package/src/code-tool-types.ts +18 -0
- package/src/code-tool.ts +59 -0
- package/src/compat.ts +483 -0
- package/src/docs-search-tool.ts +59 -0
- package/src/dynamic-tools.ts +153 -0
- package/src/filtering.ts +18 -0
- package/src/headers.ts +25 -0
- package/src/http.ts +127 -0
- package/src/index.ts +108 -0
- package/src/options.ts +473 -0
- package/src/server.ts +207 -0
- package/src/stdio.ts +13 -0
- package/src/tools/broadcasts/cancel-broadcasts.ts +52 -0
- package/src/tools/broadcasts/contacts/add-broadcasts-contacts.ts +73 -0
- package/src/tools/broadcasts/contacts/list-broadcasts-contacts.ts +71 -0
- package/src/tools/broadcasts/contacts/remove-broadcasts-contacts.ts +43 -0
- package/src/tools/broadcasts/create-broadcasts.ts +134 -0
- package/src/tools/broadcasts/delete-broadcasts.ts +40 -0
- package/src/tools/broadcasts/list-broadcasts.ts +68 -0
- package/src/tools/broadcasts/progress-broadcasts.ts +54 -0
- package/src/tools/broadcasts/retrieve-broadcasts.ts +54 -0
- package/src/tools/broadcasts/send-broadcasts.ts +57 -0
- package/src/tools/broadcasts/update-broadcasts.ts +106 -0
- package/src/tools/contacts/list-contacts.ts +61 -0
- package/src/tools/contacts/retrieve-by-phone-contacts.ts +56 -0
- package/src/tools/contacts/retrieve-contacts.ts +54 -0
- package/src/tools/contacts/update-contacts.ts +61 -0
- package/src/tools/index.ts +143 -0
- package/src/tools/introspect/validate-phone-introspect.ts +52 -0
- package/src/tools/messages/list-messages.ts +78 -0
- package/src/tools/messages/react-messages.ts +59 -0
- package/src/tools/messages/retrieve-messages.ts +54 -0
- package/src/tools/messages/send-messages.ts +233 -0
- package/src/tools/phone-numbers/list-phone-numbers.ts +68 -0
- package/src/tools/phone-numbers/purchase-phone-numbers.ts +57 -0
- package/src/tools/phone-numbers/release-phone-numbers.ts +40 -0
- package/src/tools/phone-numbers/retrieve-phone-numbers.ts +56 -0
- package/src/tools/phone-numbers/search-available-phone-numbers.ts +72 -0
- package/src/tools/phone-numbers/update-phone-numbers.ts +62 -0
- package/src/tools/senders/create-senders.ts +86 -0
- package/src/tools/senders/delete-senders.ts +40 -0
- package/src/tools/senders/list-senders.ts +58 -0
- package/src/tools/senders/regenerate-webhook-secret-senders.ts +54 -0
- package/src/tools/senders/retrieve-senders.ts +54 -0
- package/src/tools/senders/update-senders.ts +90 -0
- package/src/tools/templates/create-templates.ts +74 -0
- package/src/tools/templates/delete-templates.ts +40 -0
- package/src/tools/templates/list-templates.ts +58 -0
- package/src/tools/templates/retrieve-templates.ts +54 -0
- package/src/tools/templates/submit-templates.ts +66 -0
- package/src/tools/types.ts +115 -0
- package/src/tools.ts +1 -0
- package/src/tsconfig.json +11 -0
- package/stdio.d.mts +3 -0
- package/stdio.d.mts.map +1 -0
- package/stdio.d.ts +3 -0
- package/stdio.d.ts.map +1 -0
- package/stdio.js +14 -0
- package/stdio.js.map +1 -0
- package/stdio.mjs +10 -0
- package/stdio.mjs.map +1 -0
- package/tools/broadcasts/cancel-broadcasts.d.mts +51 -0
- package/tools/broadcasts/cancel-broadcasts.d.mts.map +1 -0
- package/tools/broadcasts/cancel-broadcasts.d.ts +51 -0
- package/tools/broadcasts/cancel-broadcasts.d.ts.map +1 -0
- package/tools/broadcasts/cancel-broadcasts.js +52 -0
- package/tools/broadcasts/cancel-broadcasts.js.map +1 -0
- package/tools/broadcasts/cancel-broadcasts.mjs +45 -0
- package/tools/broadcasts/cancel-broadcasts.mjs.map +1 -0
- package/tools/broadcasts/contacts/add-broadcasts-contacts.d.mts +51 -0
- package/tools/broadcasts/contacts/add-broadcasts-contacts.d.mts.map +1 -0
- package/tools/broadcasts/contacts/add-broadcasts-contacts.d.ts +51 -0
- package/tools/broadcasts/contacts/add-broadcasts-contacts.d.ts.map +1 -0
- package/tools/broadcasts/contacts/add-broadcasts-contacts.js +71 -0
- package/tools/broadcasts/contacts/add-broadcasts-contacts.js.map +1 -0
- package/tools/broadcasts/contacts/add-broadcasts-contacts.mjs +64 -0
- package/tools/broadcasts/contacts/add-broadcasts-contacts.mjs.map +1 -0
- package/tools/broadcasts/contacts/list-broadcasts-contacts.d.mts +51 -0
- package/tools/broadcasts/contacts/list-broadcasts-contacts.d.mts.map +1 -0
- package/tools/broadcasts/contacts/list-broadcasts-contacts.d.ts +51 -0
- package/tools/broadcasts/contacts/list-broadcasts-contacts.d.ts.map +1 -0
- package/tools/broadcasts/contacts/list-broadcasts-contacts.js +71 -0
- package/tools/broadcasts/contacts/list-broadcasts-contacts.js.map +1 -0
- package/tools/broadcasts/contacts/list-broadcasts-contacts.mjs +64 -0
- package/tools/broadcasts/contacts/list-broadcasts-contacts.mjs.map +1 -0
- package/tools/broadcasts/contacts/remove-broadcasts-contacts.d.mts +51 -0
- package/tools/broadcasts/contacts/remove-broadcasts-contacts.d.mts.map +1 -0
- package/tools/broadcasts/contacts/remove-broadcasts-contacts.d.ts +51 -0
- package/tools/broadcasts/contacts/remove-broadcasts-contacts.d.ts.map +1 -0
- package/tools/broadcasts/contacts/remove-broadcasts-contacts.js +40 -0
- package/tools/broadcasts/contacts/remove-broadcasts-contacts.js.map +1 -0
- package/tools/broadcasts/contacts/remove-broadcasts-contacts.mjs +36 -0
- package/tools/broadcasts/contacts/remove-broadcasts-contacts.mjs.map +1 -0
- package/tools/broadcasts/create-broadcasts.d.mts +51 -0
- package/tools/broadcasts/create-broadcasts.d.mts.map +1 -0
- package/tools/broadcasts/create-broadcasts.d.ts +51 -0
- package/tools/broadcasts/create-broadcasts.d.ts.map +1 -0
- package/tools/broadcasts/create-broadcasts.js +134 -0
- package/tools/broadcasts/create-broadcasts.js.map +1 -0
- package/tools/broadcasts/create-broadcasts.mjs +127 -0
- package/tools/broadcasts/create-broadcasts.mjs.map +1 -0
- package/tools/broadcasts/delete-broadcasts.d.mts +51 -0
- package/tools/broadcasts/delete-broadcasts.d.mts.map +1 -0
- package/tools/broadcasts/delete-broadcasts.d.ts +51 -0
- package/tools/broadcasts/delete-broadcasts.d.ts.map +1 -0
- package/tools/broadcasts/delete-broadcasts.js +37 -0
- package/tools/broadcasts/delete-broadcasts.js.map +1 -0
- package/tools/broadcasts/delete-broadcasts.mjs +33 -0
- package/tools/broadcasts/delete-broadcasts.mjs.map +1 -0
- package/tools/broadcasts/list-broadcasts.d.mts +51 -0
- package/tools/broadcasts/list-broadcasts.d.mts.map +1 -0
- package/tools/broadcasts/list-broadcasts.d.ts +51 -0
- package/tools/broadcasts/list-broadcasts.d.ts.map +1 -0
- package/tools/broadcasts/list-broadcasts.js +68 -0
- package/tools/broadcasts/list-broadcasts.js.map +1 -0
- package/tools/broadcasts/list-broadcasts.mjs +61 -0
- package/tools/broadcasts/list-broadcasts.mjs.map +1 -0
- package/tools/broadcasts/progress-broadcasts.d.mts +51 -0
- package/tools/broadcasts/progress-broadcasts.d.mts.map +1 -0
- package/tools/broadcasts/progress-broadcasts.d.ts +51 -0
- package/tools/broadcasts/progress-broadcasts.d.ts.map +1 -0
- package/tools/broadcasts/progress-broadcasts.js +54 -0
- package/tools/broadcasts/progress-broadcasts.js.map +1 -0
- package/tools/broadcasts/progress-broadcasts.mjs +47 -0
- package/tools/broadcasts/progress-broadcasts.mjs.map +1 -0
- package/tools/broadcasts/retrieve-broadcasts.d.mts +51 -0
- package/tools/broadcasts/retrieve-broadcasts.d.mts.map +1 -0
- package/tools/broadcasts/retrieve-broadcasts.d.ts +51 -0
- package/tools/broadcasts/retrieve-broadcasts.d.ts.map +1 -0
- package/tools/broadcasts/retrieve-broadcasts.js +54 -0
- package/tools/broadcasts/retrieve-broadcasts.js.map +1 -0
- package/tools/broadcasts/retrieve-broadcasts.mjs +47 -0
- package/tools/broadcasts/retrieve-broadcasts.mjs.map +1 -0
- package/tools/broadcasts/send-broadcasts.d.mts +51 -0
- package/tools/broadcasts/send-broadcasts.d.mts.map +1 -0
- package/tools/broadcasts/send-broadcasts.d.ts +51 -0
- package/tools/broadcasts/send-broadcasts.d.ts.map +1 -0
- package/tools/broadcasts/send-broadcasts.js +57 -0
- package/tools/broadcasts/send-broadcasts.js.map +1 -0
- package/tools/broadcasts/send-broadcasts.mjs +50 -0
- package/tools/broadcasts/send-broadcasts.mjs.map +1 -0
- package/tools/broadcasts/update-broadcasts.d.mts +51 -0
- package/tools/broadcasts/update-broadcasts.d.mts.map +1 -0
- package/tools/broadcasts/update-broadcasts.d.ts +51 -0
- package/tools/broadcasts/update-broadcasts.d.ts.map +1 -0
- package/tools/broadcasts/update-broadcasts.js +104 -0
- package/tools/broadcasts/update-broadcasts.js.map +1 -0
- package/tools/broadcasts/update-broadcasts.mjs +97 -0
- package/tools/broadcasts/update-broadcasts.mjs.map +1 -0
- package/tools/contacts/list-contacts.d.mts +51 -0
- package/tools/contacts/list-contacts.d.mts.map +1 -0
- package/tools/contacts/list-contacts.d.ts +51 -0
- package/tools/contacts/list-contacts.d.ts.map +1 -0
- package/tools/contacts/list-contacts.js +61 -0
- package/tools/contacts/list-contacts.js.map +1 -0
- package/tools/contacts/list-contacts.mjs +54 -0
- package/tools/contacts/list-contacts.mjs.map +1 -0
- package/tools/contacts/retrieve-by-phone-contacts.d.mts +51 -0
- package/tools/contacts/retrieve-by-phone-contacts.d.mts.map +1 -0
- package/tools/contacts/retrieve-by-phone-contacts.d.ts +51 -0
- package/tools/contacts/retrieve-by-phone-contacts.d.ts.map +1 -0
- package/tools/contacts/retrieve-by-phone-contacts.js +54 -0
- package/tools/contacts/retrieve-by-phone-contacts.js.map +1 -0
- package/tools/contacts/retrieve-by-phone-contacts.mjs +47 -0
- package/tools/contacts/retrieve-by-phone-contacts.mjs.map +1 -0
- package/tools/contacts/retrieve-contacts.d.mts +51 -0
- package/tools/contacts/retrieve-contacts.d.mts.map +1 -0
- package/tools/contacts/retrieve-contacts.d.ts +51 -0
- package/tools/contacts/retrieve-contacts.d.ts.map +1 -0
- package/tools/contacts/retrieve-contacts.js +54 -0
- package/tools/contacts/retrieve-contacts.js.map +1 -0
- package/tools/contacts/retrieve-contacts.mjs +47 -0
- package/tools/contacts/retrieve-contacts.mjs.map +1 -0
- package/tools/contacts/update-contacts.d.mts +51 -0
- package/tools/contacts/update-contacts.d.mts.map +1 -0
- package/tools/contacts/update-contacts.d.ts +51 -0
- package/tools/contacts/update-contacts.d.ts.map +1 -0
- package/tools/contacts/update-contacts.js +61 -0
- package/tools/contacts/update-contacts.js.map +1 -0
- package/tools/contacts/update-contacts.mjs +54 -0
- package/tools/contacts/update-contacts.mjs.map +1 -0
- package/tools/index.d.mts +10 -0
- package/tools/index.d.mts.map +1 -0
- package/tools/index.d.ts +10 -0
- package/tools/index.d.ts.map +1 -0
- package/tools/index.js +127 -0
- package/tools/index.js.map +1 -0
- package/tools/index.mjs +120 -0
- package/tools/index.mjs.map +1 -0
- package/tools/introspect/validate-phone-introspect.d.mts +51 -0
- package/tools/introspect/validate-phone-introspect.d.mts.map +1 -0
- package/tools/introspect/validate-phone-introspect.d.ts +51 -0
- package/tools/introspect/validate-phone-introspect.d.ts.map +1 -0
- package/tools/introspect/validate-phone-introspect.js +52 -0
- package/tools/introspect/validate-phone-introspect.js.map +1 -0
- package/tools/introspect/validate-phone-introspect.mjs +45 -0
- package/tools/introspect/validate-phone-introspect.mjs.map +1 -0
- package/tools/messages/list-messages.d.mts +51 -0
- package/tools/messages/list-messages.d.mts.map +1 -0
- package/tools/messages/list-messages.d.ts +51 -0
- package/tools/messages/list-messages.d.ts.map +1 -0
- package/tools/messages/list-messages.js +78 -0
- package/tools/messages/list-messages.js.map +1 -0
- package/tools/messages/list-messages.mjs +71 -0
- package/tools/messages/list-messages.mjs.map +1 -0
- package/tools/messages/react-messages.d.mts +51 -0
- package/tools/messages/react-messages.d.mts.map +1 -0
- package/tools/messages/react-messages.d.ts +51 -0
- package/tools/messages/react-messages.d.ts.map +1 -0
- package/tools/messages/react-messages.js +59 -0
- package/tools/messages/react-messages.js.map +1 -0
- package/tools/messages/react-messages.mjs +52 -0
- package/tools/messages/react-messages.mjs.map +1 -0
- package/tools/messages/retrieve-messages.d.mts +51 -0
- package/tools/messages/retrieve-messages.d.mts.map +1 -0
- package/tools/messages/retrieve-messages.d.ts +51 -0
- package/tools/messages/retrieve-messages.d.ts.map +1 -0
- package/tools/messages/retrieve-messages.js +54 -0
- package/tools/messages/retrieve-messages.js.map +1 -0
- package/tools/messages/retrieve-messages.mjs +47 -0
- package/tools/messages/retrieve-messages.mjs.map +1 -0
- package/tools/messages/send-messages.d.mts +51 -0
- package/tools/messages/send-messages.d.mts.map +1 -0
- package/tools/messages/send-messages.d.ts +51 -0
- package/tools/messages/send-messages.d.ts.map +1 -0
- package/tools/messages/send-messages.js +233 -0
- package/tools/messages/send-messages.js.map +1 -0
- package/tools/messages/send-messages.mjs +226 -0
- package/tools/messages/send-messages.mjs.map +1 -0
- package/tools/phone-numbers/list-phone-numbers.d.mts +51 -0
- package/tools/phone-numbers/list-phone-numbers.d.mts.map +1 -0
- package/tools/phone-numbers/list-phone-numbers.d.ts +51 -0
- package/tools/phone-numbers/list-phone-numbers.d.ts.map +1 -0
- package/tools/phone-numbers/list-phone-numbers.js +68 -0
- package/tools/phone-numbers/list-phone-numbers.js.map +1 -0
- package/tools/phone-numbers/list-phone-numbers.mjs +61 -0
- package/tools/phone-numbers/list-phone-numbers.mjs.map +1 -0
- package/tools/phone-numbers/purchase-phone-numbers.d.mts +51 -0
- package/tools/phone-numbers/purchase-phone-numbers.d.mts.map +1 -0
- package/tools/phone-numbers/purchase-phone-numbers.d.ts +51 -0
- package/tools/phone-numbers/purchase-phone-numbers.d.ts.map +1 -0
- package/tools/phone-numbers/purchase-phone-numbers.js +57 -0
- package/tools/phone-numbers/purchase-phone-numbers.js.map +1 -0
- package/tools/phone-numbers/purchase-phone-numbers.mjs +50 -0
- package/tools/phone-numbers/purchase-phone-numbers.mjs.map +1 -0
- package/tools/phone-numbers/release-phone-numbers.d.mts +51 -0
- package/tools/phone-numbers/release-phone-numbers.d.mts.map +1 -0
- package/tools/phone-numbers/release-phone-numbers.d.ts +51 -0
- package/tools/phone-numbers/release-phone-numbers.d.ts.map +1 -0
- package/tools/phone-numbers/release-phone-numbers.js +37 -0
- package/tools/phone-numbers/release-phone-numbers.js.map +1 -0
- package/tools/phone-numbers/release-phone-numbers.mjs +33 -0
- package/tools/phone-numbers/release-phone-numbers.mjs.map +1 -0
- package/tools/phone-numbers/retrieve-phone-numbers.d.mts +51 -0
- package/tools/phone-numbers/retrieve-phone-numbers.d.mts.map +1 -0
- package/tools/phone-numbers/retrieve-phone-numbers.d.ts +51 -0
- package/tools/phone-numbers/retrieve-phone-numbers.d.ts.map +1 -0
- package/tools/phone-numbers/retrieve-phone-numbers.js +54 -0
- package/tools/phone-numbers/retrieve-phone-numbers.js.map +1 -0
- package/tools/phone-numbers/retrieve-phone-numbers.mjs +47 -0
- package/tools/phone-numbers/retrieve-phone-numbers.mjs.map +1 -0
- package/tools/phone-numbers/search-available-phone-numbers.d.mts +51 -0
- package/tools/phone-numbers/search-available-phone-numbers.d.mts.map +1 -0
- package/tools/phone-numbers/search-available-phone-numbers.d.ts +51 -0
- package/tools/phone-numbers/search-available-phone-numbers.d.ts.map +1 -0
- package/tools/phone-numbers/search-available-phone-numbers.js +72 -0
- package/tools/phone-numbers/search-available-phone-numbers.js.map +1 -0
- package/tools/phone-numbers/search-available-phone-numbers.mjs +65 -0
- package/tools/phone-numbers/search-available-phone-numbers.mjs.map +1 -0
- package/tools/phone-numbers/update-phone-numbers.d.mts +51 -0
- package/tools/phone-numbers/update-phone-numbers.d.mts.map +1 -0
- package/tools/phone-numbers/update-phone-numbers.d.ts +51 -0
- package/tools/phone-numbers/update-phone-numbers.d.ts.map +1 -0
- package/tools/phone-numbers/update-phone-numbers.js +60 -0
- package/tools/phone-numbers/update-phone-numbers.js.map +1 -0
- package/tools/phone-numbers/update-phone-numbers.mjs +53 -0
- package/tools/phone-numbers/update-phone-numbers.mjs.map +1 -0
- package/tools/senders/create-senders.d.mts +51 -0
- package/tools/senders/create-senders.d.mts.map +1 -0
- package/tools/senders/create-senders.d.ts +51 -0
- package/tools/senders/create-senders.d.ts.map +1 -0
- package/tools/senders/create-senders.js +85 -0
- package/tools/senders/create-senders.js.map +1 -0
- package/tools/senders/create-senders.mjs +78 -0
- package/tools/senders/create-senders.mjs.map +1 -0
- package/tools/senders/delete-senders.d.mts +51 -0
- package/tools/senders/delete-senders.d.mts.map +1 -0
- package/tools/senders/delete-senders.d.ts +51 -0
- package/tools/senders/delete-senders.d.ts.map +1 -0
- package/tools/senders/delete-senders.js +37 -0
- package/tools/senders/delete-senders.js.map +1 -0
- package/tools/senders/delete-senders.mjs +33 -0
- package/tools/senders/delete-senders.mjs.map +1 -0
- package/tools/senders/list-senders.d.mts +51 -0
- package/tools/senders/list-senders.d.mts.map +1 -0
- package/tools/senders/list-senders.d.ts +51 -0
- package/tools/senders/list-senders.d.ts.map +1 -0
- package/tools/senders/list-senders.js +58 -0
- package/tools/senders/list-senders.js.map +1 -0
- package/tools/senders/list-senders.mjs +51 -0
- package/tools/senders/list-senders.mjs.map +1 -0
- package/tools/senders/regenerate-webhook-secret-senders.d.mts +51 -0
- package/tools/senders/regenerate-webhook-secret-senders.d.mts.map +1 -0
- package/tools/senders/regenerate-webhook-secret-senders.d.ts +51 -0
- package/tools/senders/regenerate-webhook-secret-senders.d.ts.map +1 -0
- package/tools/senders/regenerate-webhook-secret-senders.js +52 -0
- package/tools/senders/regenerate-webhook-secret-senders.js.map +1 -0
- package/tools/senders/regenerate-webhook-secret-senders.mjs +45 -0
- package/tools/senders/regenerate-webhook-secret-senders.mjs.map +1 -0
- package/tools/senders/retrieve-senders.d.mts +51 -0
- package/tools/senders/retrieve-senders.d.mts.map +1 -0
- package/tools/senders/retrieve-senders.d.ts +51 -0
- package/tools/senders/retrieve-senders.d.ts.map +1 -0
- package/tools/senders/retrieve-senders.js +54 -0
- package/tools/senders/retrieve-senders.js.map +1 -0
- package/tools/senders/retrieve-senders.mjs +47 -0
- package/tools/senders/retrieve-senders.mjs.map +1 -0
- package/tools/senders/update-senders.d.mts +51 -0
- package/tools/senders/update-senders.d.mts.map +1 -0
- package/tools/senders/update-senders.d.ts +51 -0
- package/tools/senders/update-senders.d.ts.map +1 -0
- package/tools/senders/update-senders.js +89 -0
- package/tools/senders/update-senders.js.map +1 -0
- package/tools/senders/update-senders.mjs +82 -0
- package/tools/senders/update-senders.mjs.map +1 -0
- package/tools/templates/create-templates.d.mts +51 -0
- package/tools/templates/create-templates.d.mts.map +1 -0
- package/tools/templates/create-templates.d.ts +51 -0
- package/tools/templates/create-templates.d.ts.map +1 -0
- package/tools/templates/create-templates.js +74 -0
- package/tools/templates/create-templates.js.map +1 -0
- package/tools/templates/create-templates.mjs +67 -0
- package/tools/templates/create-templates.mjs.map +1 -0
- package/tools/templates/delete-templates.d.mts +51 -0
- package/tools/templates/delete-templates.d.mts.map +1 -0
- package/tools/templates/delete-templates.d.ts +51 -0
- package/tools/templates/delete-templates.d.ts.map +1 -0
- package/tools/templates/delete-templates.js +37 -0
- package/tools/templates/delete-templates.js.map +1 -0
- package/tools/templates/delete-templates.mjs +33 -0
- package/tools/templates/delete-templates.mjs.map +1 -0
- package/tools/templates/list-templates.d.mts +51 -0
- package/tools/templates/list-templates.d.mts.map +1 -0
- package/tools/templates/list-templates.d.ts +51 -0
- package/tools/templates/list-templates.d.ts.map +1 -0
- package/tools/templates/list-templates.js +58 -0
- package/tools/templates/list-templates.js.map +1 -0
- package/tools/templates/list-templates.mjs +51 -0
- package/tools/templates/list-templates.mjs.map +1 -0
- package/tools/templates/retrieve-templates.d.mts +51 -0
- package/tools/templates/retrieve-templates.d.mts.map +1 -0
- package/tools/templates/retrieve-templates.d.ts +51 -0
- package/tools/templates/retrieve-templates.d.ts.map +1 -0
- package/tools/templates/retrieve-templates.js +54 -0
- package/tools/templates/retrieve-templates.js.map +1 -0
- package/tools/templates/retrieve-templates.mjs +47 -0
- package/tools/templates/retrieve-templates.mjs.map +1 -0
- package/tools/templates/submit-templates.d.mts +51 -0
- package/tools/templates/submit-templates.d.mts.map +1 -0
- package/tools/templates/submit-templates.d.ts +51 -0
- package/tools/templates/submit-templates.d.ts.map +1 -0
- package/tools/templates/submit-templates.js +66 -0
- package/tools/templates/submit-templates.js.map +1 -0
- package/tools/templates/submit-templates.mjs +59 -0
- package/tools/templates/submit-templates.mjs.map +1 -0
- package/tools/types.d.mts +52 -0
- package/tools/types.d.mts.map +1 -0
- package/tools/types.d.ts +52 -0
- package/tools/types.d.ts.map +1 -0
- package/tools/types.js +58 -0
- package/tools/types.js.map +1 -0
- package/tools/types.mjs +53 -0
- package/tools/types.mjs.map +1 -0
- package/tools.d.mts +2 -0
- package/tools.d.mts.map +1 -0
- package/tools.d.ts +2 -0
- package/tools.d.ts.map +1 -0
- package/tools.js +18 -0
- package/tools.js.map +1 -0
- package/tools.mjs +2 -0
- package/tools.mjs.map +1 -0
|
@@ -0,0 +1,52 @@
|
|
|
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}/cancel',
|
|
15
|
+
operationId: 'cancelBroadcast',
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export const tool: Tool = {
|
|
19
|
+
name: 'cancel_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\nCancel a broadcast. Pending contacts will be skipped, but already queued messages may still be delivered.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/broadcast_cancel_response',\n $defs: {\n broadcast_cancel_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
|
+
};
|
|
39
|
+
|
|
40
|
+
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
41
|
+
const { broadcastId, jq_filter, ...body } = args as any;
|
|
42
|
+
try {
|
|
43
|
+
return asTextContentResult(await maybeFilter(jq_filter, await client.broadcasts.cancel(broadcastId)));
|
|
44
|
+
} catch (error) {
|
|
45
|
+
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
46
|
+
return asErrorResult(error.message);
|
|
47
|
+
}
|
|
48
|
+
throw error;
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
export default { metadata, tool, handler };
|
|
@@ -0,0 +1,73 @@
|
|
|
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.contacts',
|
|
11
|
+
operation: 'write',
|
|
12
|
+
tags: [],
|
|
13
|
+
httpMethod: 'post',
|
|
14
|
+
httpPath: '/v1/broadcasts/{broadcastId}/contacts',
|
|
15
|
+
operationId: 'addBroadcastContacts',
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export const tool: Tool = {
|
|
19
|
+
name: 'add_broadcasts_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\nAdd contacts to a broadcast in batch. Maximum 1000 contacts per request.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/contact_add_response',\n $defs: {\n contact_add_response: {\n type: 'object',\n properties: {\n added: {\n type: 'integer',\n description: 'Number of contacts successfully added.'\n },\n duplicates: {\n type: 'integer',\n description: 'Number of duplicate contacts skipped.'\n },\n invalid: {\n type: 'integer',\n description: 'Number of invalid contacts rejected.'\n },\n errors: {\n type: 'array',\n description: 'Details about invalid contacts.',\n items: {\n type: 'object',\n properties: {\n reason: {\n type: 'string'\n },\n recipient: {\n type: 'string'\n }\n }\n }\n }\n },\n required: [ 'added',\n 'duplicates',\n 'invalid'\n ]\n }\n }\n}\n```",
|
|
22
|
+
inputSchema: {
|
|
23
|
+
type: 'object',
|
|
24
|
+
properties: {
|
|
25
|
+
broadcastId: {
|
|
26
|
+
type: 'string',
|
|
27
|
+
},
|
|
28
|
+
contacts: {
|
|
29
|
+
type: 'array',
|
|
30
|
+
description: 'List of contacts to add (max 1000 per request).',
|
|
31
|
+
items: {
|
|
32
|
+
type: 'object',
|
|
33
|
+
properties: {
|
|
34
|
+
recipient: {
|
|
35
|
+
type: 'string',
|
|
36
|
+
description: 'Phone number (E.164) or email address.',
|
|
37
|
+
},
|
|
38
|
+
templateVariables: {
|
|
39
|
+
type: 'object',
|
|
40
|
+
description: 'Per-contact template variables to personalize the message.',
|
|
41
|
+
additionalProperties: true,
|
|
42
|
+
},
|
|
43
|
+
},
|
|
44
|
+
required: ['recipient'],
|
|
45
|
+
},
|
|
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', 'contacts'],
|
|
55
|
+
},
|
|
56
|
+
annotations: {},
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
60
|
+
const { broadcastId, jq_filter, ...body } = args as any;
|
|
61
|
+
try {
|
|
62
|
+
return asTextContentResult(
|
|
63
|
+
await maybeFilter(jq_filter, await client.broadcasts.contacts.add(broadcastId, body)),
|
|
64
|
+
);
|
|
65
|
+
} catch (error) {
|
|
66
|
+
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
67
|
+
return asErrorResult(error.message);
|
|
68
|
+
}
|
|
69
|
+
throw error;
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
export default { metadata, tool, handler };
|
|
@@ -0,0 +1,71 @@
|
|
|
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.contacts',
|
|
11
|
+
operation: 'read',
|
|
12
|
+
tags: [],
|
|
13
|
+
httpMethod: 'get',
|
|
14
|
+
httpPath: '/v1/broadcasts/{broadcastId}/contacts',
|
|
15
|
+
operationId: 'listBroadcastContacts',
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export const tool: Tool = {
|
|
19
|
+
name: 'list_broadcasts_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 in a broadcast with optional status filter.\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n items: {\n type: 'array',\n items: {\n $ref: '#/$defs/broadcast_contact'\n }\n },\n nextCursor: {\n type: 'string'\n }\n },\n required: [ 'items'\n ],\n $defs: {\n broadcast_contact: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n recipient: {\n type: 'string'\n },\n recipientType: {\n type: 'string',\n enum: [ 'phone',\n 'email'\n ]\n },\n status: {\n $ref: '#/$defs/broadcast_contact_status'\n },\n cost: {\n type: 'number'\n },\n errorCode: {\n type: 'string'\n },\n errorMessage: {\n type: 'string'\n },\n messageId: {\n type: 'string',\n description: 'Associated message ID after processing.'\n },\n processedAt: {\n type: 'string',\n format: 'date-time'\n },\n templateVariables: {\n type: 'object',\n additionalProperties: true\n }\n },\n required: [ 'id',\n 'createdAt',\n 'recipient',\n 'recipientType',\n 'status'\n ]\n },\n broadcast_contact_status: {\n type: 'string',\n description: 'Status of a contact within a broadcast.',\n enum: [ 'pending',\n 'queued',\n 'sending',\n 'delivered',\n 'failed',\n 'skipped'\n ]\n }\n }\n}\n```",
|
|
22
|
+
inputSchema: {
|
|
23
|
+
type: 'object',
|
|
24
|
+
properties: {
|
|
25
|
+
broadcastId: {
|
|
26
|
+
type: 'string',
|
|
27
|
+
},
|
|
28
|
+
cursor: {
|
|
29
|
+
type: 'string',
|
|
30
|
+
},
|
|
31
|
+
limit: {
|
|
32
|
+
type: 'integer',
|
|
33
|
+
},
|
|
34
|
+
status: {
|
|
35
|
+
$ref: '#/$defs/broadcast_contact_status',
|
|
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: ['broadcastId'],
|
|
45
|
+
$defs: {
|
|
46
|
+
broadcast_contact_status: {
|
|
47
|
+
type: 'string',
|
|
48
|
+
description: 'Status of a contact within a broadcast.',
|
|
49
|
+
enum: ['pending', 'queued', 'sending', 'delivered', 'failed', 'skipped'],
|
|
50
|
+
},
|
|
51
|
+
},
|
|
52
|
+
},
|
|
53
|
+
annotations: {
|
|
54
|
+
readOnlyHint: true,
|
|
55
|
+
},
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
59
|
+
const { broadcastId, jq_filter, ...body } = args as any;
|
|
60
|
+
const response = await client.broadcasts.contacts.list(broadcastId, body).asResponse();
|
|
61
|
+
try {
|
|
62
|
+
return asTextContentResult(await maybeFilter(jq_filter, await response.json()));
|
|
63
|
+
} catch (error) {
|
|
64
|
+
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
65
|
+
return asErrorResult(error.message);
|
|
66
|
+
}
|
|
67
|
+
throw error;
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
|
|
71
|
+
export default { metadata, tool, handler };
|
|
@@ -0,0 +1,43 @@
|
|
|
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: 'broadcasts.contacts',
|
|
10
|
+
operation: 'write',
|
|
11
|
+
tags: [],
|
|
12
|
+
httpMethod: 'delete',
|
|
13
|
+
httpPath: '/v1/broadcasts/{broadcastId}/contacts/{contactId}',
|
|
14
|
+
operationId: 'removeBroadcastContact',
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
export const tool: Tool = {
|
|
18
|
+
name: 'remove_broadcasts_contacts',
|
|
19
|
+
description: 'Remove a contact from a broadcast in draft status.',
|
|
20
|
+
inputSchema: {
|
|
21
|
+
type: 'object',
|
|
22
|
+
properties: {
|
|
23
|
+
broadcastId: {
|
|
24
|
+
type: 'string',
|
|
25
|
+
},
|
|
26
|
+
contactId: {
|
|
27
|
+
type: 'string',
|
|
28
|
+
},
|
|
29
|
+
},
|
|
30
|
+
required: ['broadcastId', 'contactId'],
|
|
31
|
+
},
|
|
32
|
+
annotations: {
|
|
33
|
+
idempotentHint: true,
|
|
34
|
+
},
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
38
|
+
const { contactId, ...body } = args as any;
|
|
39
|
+
const response = await client.broadcasts.contacts.remove(contactId, body).asResponse();
|
|
40
|
+
return asTextContentResult(await response.text());
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
export default { metadata, tool, handler };
|
|
@@ -0,0 +1,134 @@
|
|
|
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',
|
|
15
|
+
operationId: 'createBroadcast',
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export const tool: Tool = {
|
|
19
|
+
name: 'create_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\nCreate a new broadcast campaign. Add contacts after creation, then send.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/broadcast_create_response',\n $defs: {\n broadcast_create_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
|
+
channel: {
|
|
26
|
+
$ref: '#/$defs/broadcast_channel',
|
|
27
|
+
},
|
|
28
|
+
name: {
|
|
29
|
+
type: 'string',
|
|
30
|
+
description: 'Name of the broadcast campaign.',
|
|
31
|
+
},
|
|
32
|
+
content: {
|
|
33
|
+
$ref: '#/$defs/broadcast_content',
|
|
34
|
+
},
|
|
35
|
+
emailHtmlBody: {
|
|
36
|
+
type: 'string',
|
|
37
|
+
description: 'HTML body for email broadcasts.',
|
|
38
|
+
},
|
|
39
|
+
emailSubject: {
|
|
40
|
+
type: 'string',
|
|
41
|
+
description: 'Email subject line. Required for email broadcasts.',
|
|
42
|
+
},
|
|
43
|
+
idempotencyKey: {
|
|
44
|
+
type: 'string',
|
|
45
|
+
description: 'Idempotency key to prevent duplicate broadcasts.',
|
|
46
|
+
},
|
|
47
|
+
messageType: {
|
|
48
|
+
$ref: '#/$defs/broadcast_message_type',
|
|
49
|
+
},
|
|
50
|
+
metadata: {
|
|
51
|
+
type: 'object',
|
|
52
|
+
additionalProperties: true,
|
|
53
|
+
},
|
|
54
|
+
scheduledAt: {
|
|
55
|
+
type: 'string',
|
|
56
|
+
description: 'Schedule the broadcast for future delivery.',
|
|
57
|
+
format: 'date-time',
|
|
58
|
+
},
|
|
59
|
+
senderId: {
|
|
60
|
+
type: 'string',
|
|
61
|
+
description: 'Sender profile ID. Uses default sender if omitted.',
|
|
62
|
+
},
|
|
63
|
+
text: {
|
|
64
|
+
type: 'string',
|
|
65
|
+
description: 'Text content or caption. Supports template variables: {{name}}, {{1}}, etc.',
|
|
66
|
+
},
|
|
67
|
+
jq_filter: {
|
|
68
|
+
type: 'string',
|
|
69
|
+
title: 'jq Filter',
|
|
70
|
+
description:
|
|
71
|
+
'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/).',
|
|
72
|
+
},
|
|
73
|
+
},
|
|
74
|
+
required: ['channel', 'name'],
|
|
75
|
+
$defs: {
|
|
76
|
+
broadcast_channel: {
|
|
77
|
+
type: 'string',
|
|
78
|
+
description: 'Broadcast delivery channel.',
|
|
79
|
+
enum: ['sms', 'whatsapp', 'email'],
|
|
80
|
+
},
|
|
81
|
+
broadcast_content: {
|
|
82
|
+
type: 'object',
|
|
83
|
+
description: 'Content for non-text broadcast message types.',
|
|
84
|
+
properties: {
|
|
85
|
+
filename: {
|
|
86
|
+
type: 'string',
|
|
87
|
+
description: 'Filename for documents.',
|
|
88
|
+
},
|
|
89
|
+
mediaId: {
|
|
90
|
+
type: 'string',
|
|
91
|
+
description: 'Media ID if already uploaded.',
|
|
92
|
+
},
|
|
93
|
+
mediaUrl: {
|
|
94
|
+
type: 'string',
|
|
95
|
+
description: 'URL of the media file.',
|
|
96
|
+
},
|
|
97
|
+
mimeType: {
|
|
98
|
+
type: 'string',
|
|
99
|
+
description: 'MIME type of the media.',
|
|
100
|
+
},
|
|
101
|
+
templateId: {
|
|
102
|
+
type: 'string',
|
|
103
|
+
description: 'Template ID for template messages.',
|
|
104
|
+
},
|
|
105
|
+
templateVariables: {
|
|
106
|
+
type: 'object',
|
|
107
|
+
description: 'Default template variables (can be overridden per contact).',
|
|
108
|
+
additionalProperties: true,
|
|
109
|
+
},
|
|
110
|
+
},
|
|
111
|
+
},
|
|
112
|
+
broadcast_message_type: {
|
|
113
|
+
type: 'string',
|
|
114
|
+
description: 'Type of message for broadcast.',
|
|
115
|
+
enum: ['text', 'image', 'video', 'audio', 'document', 'template'],
|
|
116
|
+
},
|
|
117
|
+
},
|
|
118
|
+
},
|
|
119
|
+
annotations: {},
|
|
120
|
+
};
|
|
121
|
+
|
|
122
|
+
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
123
|
+
const { jq_filter, ...body } = args as any;
|
|
124
|
+
try {
|
|
125
|
+
return asTextContentResult(await maybeFilter(jq_filter, await client.broadcasts.create(body)));
|
|
126
|
+
} catch (error) {
|
|
127
|
+
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
128
|
+
return asErrorResult(error.message);
|
|
129
|
+
}
|
|
130
|
+
throw error;
|
|
131
|
+
}
|
|
132
|
+
};
|
|
133
|
+
|
|
134
|
+
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: 'broadcasts',
|
|
10
|
+
operation: 'write',
|
|
11
|
+
tags: [],
|
|
12
|
+
httpMethod: 'delete',
|
|
13
|
+
httpPath: '/v1/broadcasts/{broadcastId}',
|
|
14
|
+
operationId: 'deleteBroadcast',
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
export const tool: Tool = {
|
|
18
|
+
name: 'delete_broadcasts',
|
|
19
|
+
description: 'Delete a broadcast in draft status.',
|
|
20
|
+
inputSchema: {
|
|
21
|
+
type: 'object',
|
|
22
|
+
properties: {
|
|
23
|
+
broadcastId: {
|
|
24
|
+
type: 'string',
|
|
25
|
+
},
|
|
26
|
+
},
|
|
27
|
+
required: ['broadcastId'],
|
|
28
|
+
},
|
|
29
|
+
annotations: {
|
|
30
|
+
idempotentHint: true,
|
|
31
|
+
},
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
35
|
+
const { broadcastId, ...body } = args as any;
|
|
36
|
+
const response = await client.broadcasts.delete(broadcastId).asResponse();
|
|
37
|
+
return asTextContentResult(await response.text());
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
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: '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 };
|
|
@@ -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: '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 };
|
|
@@ -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: '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 };
|