@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,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: 'broadcasts',
|
|
11
|
+
operation: 'write',
|
|
12
|
+
tags: [],
|
|
13
|
+
httpMethod: 'post',
|
|
14
|
+
httpPath: '/v1/broadcasts/{broadcastId}/send',
|
|
15
|
+
operationId: 'sendBroadcast',
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export const tool: Tool = {
|
|
19
|
+
name: 'send_broadcasts',
|
|
20
|
+
description:
|
|
21
|
+
"When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nStart sending the broadcast immediately or schedule for later. Reserves the estimated cost from your balance.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/broadcast_send_response',\n $defs: {\n broadcast_send_response: {\n type: 'object',\n properties: {\n broadcast: {\n $ref: '#/$defs/broadcast'\n }\n },\n required: [ 'broadcast'\n ]\n },\n broadcast: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n channel: {\n $ref: '#/$defs/broadcast_channel'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n messageType: {\n $ref: '#/$defs/broadcast_message_type'\n },\n name: {\n type: 'string'\n },\n status: {\n $ref: '#/$defs/broadcast_status'\n },\n totalContacts: {\n type: 'integer',\n description: 'Total number of contacts in the broadcast.'\n },\n actualCost: {\n type: 'number',\n description: 'Actual cost so far in USD.'\n },\n completedAt: {\n type: 'string',\n format: 'date-time'\n },\n content: {\n $ref: '#/$defs/broadcast_content'\n },\n deliveredCount: {\n type: 'integer'\n },\n emailSubject: {\n type: 'string'\n },\n estimatedCost: {\n type: 'number',\n description: 'Estimated total cost in USD.'\n },\n failedCount: {\n type: 'integer'\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n pendingCount: {\n type: 'integer'\n },\n reservedAmount: {\n type: 'number',\n description: 'Amount reserved from balance in USD.'\n },\n scheduledAt: {\n type: 'string',\n format: 'date-time'\n },\n senderId: {\n type: 'string'\n },\n sendingCount: {\n type: 'integer'\n },\n startedAt: {\n type: 'string',\n format: 'date-time'\n },\n text: {\n type: 'string'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'id',\n 'channel',\n 'createdAt',\n 'messageType',\n 'name',\n 'status',\n 'totalContacts'\n ]\n },\n broadcast_channel: {\n type: 'string',\n description: 'Broadcast delivery channel.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n broadcast_message_type: {\n type: 'string',\n description: 'Type of message for broadcast.',\n enum: [ 'text',\n 'image',\n 'video',\n 'audio',\n 'document',\n 'template'\n ]\n },\n broadcast_status: {\n type: 'string',\n description: 'Current status of the broadcast.',\n enum: [ 'draft',\n 'scheduled',\n 'sending',\n 'paused',\n 'completed',\n 'cancelled',\n 'failed'\n ]\n },\n broadcast_content: {\n type: 'object',\n description: 'Content for non-text broadcast message types.',\n properties: {\n filename: {\n type: 'string',\n description: 'Filename for documents.'\n },\n mediaId: {\n type: 'string',\n description: 'Media ID if already uploaded.'\n },\n mediaUrl: {\n type: 'string',\n description: 'URL of the media file.'\n },\n mimeType: {\n type: 'string',\n description: 'MIME type of the media.'\n },\n templateId: {\n type: 'string',\n description: 'Template ID for template messages.'\n },\n templateVariables: {\n type: 'object',\n description: 'Default template variables (can be overridden per contact).',\n additionalProperties: true\n }\n }\n }\n }\n}\n```",
|
|
22
|
+
inputSchema: {
|
|
23
|
+
type: 'object',
|
|
24
|
+
properties: {
|
|
25
|
+
broadcastId: {
|
|
26
|
+
type: 'string',
|
|
27
|
+
},
|
|
28
|
+
scheduledAt: {
|
|
29
|
+
type: 'string',
|
|
30
|
+
description: 'Schedule for future delivery. Omit to send immediately.',
|
|
31
|
+
format: 'date-time',
|
|
32
|
+
},
|
|
33
|
+
jq_filter: {
|
|
34
|
+
type: 'string',
|
|
35
|
+
title: 'jq Filter',
|
|
36
|
+
description:
|
|
37
|
+
'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
|
|
38
|
+
},
|
|
39
|
+
},
|
|
40
|
+
required: ['broadcastId'],
|
|
41
|
+
},
|
|
42
|
+
annotations: {},
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
46
|
+
const { broadcastId, jq_filter, ...body } = args as any;
|
|
47
|
+
try {
|
|
48
|
+
return asTextContentResult(await maybeFilter(jq_filter, await client.broadcasts.send(broadcastId, body)));
|
|
49
|
+
} catch (error) {
|
|
50
|
+
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
51
|
+
return asErrorResult(error.message);
|
|
52
|
+
}
|
|
53
|
+
throw error;
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
export default { metadata, tool, handler };
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
+
|
|
3
|
+
import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
|
|
4
|
+
import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
|
|
5
|
+
|
|
6
|
+
import { Tool } from '@modelcontextprotocol/sdk/types.js';
|
|
7
|
+
import Zavudev from '@zavudev/sdk';
|
|
8
|
+
|
|
9
|
+
export const metadata: Metadata = {
|
|
10
|
+
resource: 'broadcasts',
|
|
11
|
+
operation: 'write',
|
|
12
|
+
tags: [],
|
|
13
|
+
httpMethod: 'patch',
|
|
14
|
+
httpPath: '/v1/broadcasts/{broadcastId}',
|
|
15
|
+
operationId: 'updateBroadcast',
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export const tool: Tool = {
|
|
19
|
+
name: 'update_broadcasts',
|
|
20
|
+
description:
|
|
21
|
+
"When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nUpdate a broadcast in draft status.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/broadcast_update_response',\n $defs: {\n broadcast_update_response: {\n type: 'object',\n properties: {\n broadcast: {\n $ref: '#/$defs/broadcast'\n }\n },\n required: [ 'broadcast'\n ]\n },\n broadcast: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n channel: {\n $ref: '#/$defs/broadcast_channel'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n messageType: {\n $ref: '#/$defs/broadcast_message_type'\n },\n name: {\n type: 'string'\n },\n status: {\n $ref: '#/$defs/broadcast_status'\n },\n totalContacts: {\n type: 'integer',\n description: 'Total number of contacts in the broadcast.'\n },\n actualCost: {\n type: 'number',\n description: 'Actual cost so far in USD.'\n },\n completedAt: {\n type: 'string',\n format: 'date-time'\n },\n content: {\n $ref: '#/$defs/broadcast_content'\n },\n deliveredCount: {\n type: 'integer'\n },\n emailSubject: {\n type: 'string'\n },\n estimatedCost: {\n type: 'number',\n description: 'Estimated total cost in USD.'\n },\n failedCount: {\n type: 'integer'\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n pendingCount: {\n type: 'integer'\n },\n reservedAmount: {\n type: 'number',\n description: 'Amount reserved from balance in USD.'\n },\n scheduledAt: {\n type: 'string',\n format: 'date-time'\n },\n senderId: {\n type: 'string'\n },\n sendingCount: {\n type: 'integer'\n },\n startedAt: {\n type: 'string',\n format: 'date-time'\n },\n text: {\n type: 'string'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'id',\n 'channel',\n 'createdAt',\n 'messageType',\n 'name',\n 'status',\n 'totalContacts'\n ]\n },\n broadcast_channel: {\n type: 'string',\n description: 'Broadcast delivery channel.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n broadcast_message_type: {\n type: 'string',\n description: 'Type of message for broadcast.',\n enum: [ 'text',\n 'image',\n 'video',\n 'audio',\n 'document',\n 'template'\n ]\n },\n broadcast_status: {\n type: 'string',\n description: 'Current status of the broadcast.',\n enum: [ 'draft',\n 'scheduled',\n 'sending',\n 'paused',\n 'completed',\n 'cancelled',\n 'failed'\n ]\n },\n broadcast_content: {\n type: 'object',\n description: 'Content for non-text broadcast message types.',\n properties: {\n filename: {\n type: 'string',\n description: 'Filename for documents.'\n },\n mediaId: {\n type: 'string',\n description: 'Media ID if already uploaded.'\n },\n mediaUrl: {\n type: 'string',\n description: 'URL of the media file.'\n },\n mimeType: {\n type: 'string',\n description: 'MIME type of the media.'\n },\n templateId: {\n type: 'string',\n description: 'Template ID for template messages.'\n },\n templateVariables: {\n type: 'object',\n description: 'Default template variables (can be overridden per contact).',\n additionalProperties: true\n }\n }\n }\n }\n}\n```",
|
|
22
|
+
inputSchema: {
|
|
23
|
+
type: 'object',
|
|
24
|
+
properties: {
|
|
25
|
+
broadcastId: {
|
|
26
|
+
type: 'string',
|
|
27
|
+
},
|
|
28
|
+
content: {
|
|
29
|
+
$ref: '#/$defs/broadcast_content',
|
|
30
|
+
},
|
|
31
|
+
emailHtmlBody: {
|
|
32
|
+
type: 'string',
|
|
33
|
+
},
|
|
34
|
+
emailSubject: {
|
|
35
|
+
type: 'string',
|
|
36
|
+
},
|
|
37
|
+
metadata: {
|
|
38
|
+
type: 'object',
|
|
39
|
+
additionalProperties: true,
|
|
40
|
+
},
|
|
41
|
+
name: {
|
|
42
|
+
type: 'string',
|
|
43
|
+
},
|
|
44
|
+
text: {
|
|
45
|
+
type: 'string',
|
|
46
|
+
},
|
|
47
|
+
jq_filter: {
|
|
48
|
+
type: 'string',
|
|
49
|
+
title: 'jq Filter',
|
|
50
|
+
description:
|
|
51
|
+
'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
|
|
52
|
+
},
|
|
53
|
+
},
|
|
54
|
+
required: ['broadcastId'],
|
|
55
|
+
$defs: {
|
|
56
|
+
broadcast_content: {
|
|
57
|
+
type: 'object',
|
|
58
|
+
description: 'Content for non-text broadcast message types.',
|
|
59
|
+
properties: {
|
|
60
|
+
filename: {
|
|
61
|
+
type: 'string',
|
|
62
|
+
description: 'Filename for documents.',
|
|
63
|
+
},
|
|
64
|
+
mediaId: {
|
|
65
|
+
type: 'string',
|
|
66
|
+
description: 'Media ID if already uploaded.',
|
|
67
|
+
},
|
|
68
|
+
mediaUrl: {
|
|
69
|
+
type: 'string',
|
|
70
|
+
description: 'URL of the media file.',
|
|
71
|
+
},
|
|
72
|
+
mimeType: {
|
|
73
|
+
type: 'string',
|
|
74
|
+
description: 'MIME type of the media.',
|
|
75
|
+
},
|
|
76
|
+
templateId: {
|
|
77
|
+
type: 'string',
|
|
78
|
+
description: 'Template ID for template messages.',
|
|
79
|
+
},
|
|
80
|
+
templateVariables: {
|
|
81
|
+
type: 'object',
|
|
82
|
+
description: 'Default template variables (can be overridden per contact).',
|
|
83
|
+
additionalProperties: true,
|
|
84
|
+
},
|
|
85
|
+
},
|
|
86
|
+
},
|
|
87
|
+
},
|
|
88
|
+
},
|
|
89
|
+
annotations: {},
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
93
|
+
const { broadcastId, jq_filter, ...body } = args as any;
|
|
94
|
+
try {
|
|
95
|
+
return asTextContentResult(
|
|
96
|
+
await maybeFilter(jq_filter, await client.broadcasts.update(broadcastId, body)),
|
|
97
|
+
);
|
|
98
|
+
} catch (error) {
|
|
99
|
+
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
100
|
+
return asErrorResult(error.message);
|
|
101
|
+
}
|
|
102
|
+
throw error;
|
|
103
|
+
}
|
|
104
|
+
};
|
|
105
|
+
|
|
106
|
+
export default { metadata, tool, handler };
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
+
|
|
3
|
+
import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
|
|
4
|
+
import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
|
|
5
|
+
|
|
6
|
+
import { Tool } from '@modelcontextprotocol/sdk/types.js';
|
|
7
|
+
import Zavudev from '@zavudev/sdk';
|
|
8
|
+
|
|
9
|
+
export const metadata: Metadata = {
|
|
10
|
+
resource: 'contacts',
|
|
11
|
+
operation: 'read',
|
|
12
|
+
tags: [],
|
|
13
|
+
httpMethod: 'get',
|
|
14
|
+
httpPath: '/v1/contacts',
|
|
15
|
+
operationId: 'listContacts',
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export const tool: Tool = {
|
|
19
|
+
name: 'list_contacts',
|
|
20
|
+
description:
|
|
21
|
+
"When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nList contacts\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n items: {\n type: 'array',\n items: {\n $ref: '#/$defs/contact'\n }\n },\n nextCursor: {\n type: 'string'\n }\n },\n required: [ 'items'\n ],\n $defs: {\n contact: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n phoneNumber: {\n type: 'string',\n description: 'E.164 phone number.'\n },\n availableChannels: {\n type: 'array',\n description: 'List of available messaging channels for this contact.',\n items: {\n type: 'string'\n }\n },\n countryCode: {\n type: 'string'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n defaultChannel: {\n type: 'string',\n description: 'Preferred channel for this contact.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n profileName: {\n type: 'string',\n description: 'Contact\\'s WhatsApp profile name. Only available for WhatsApp contacts.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n },\n verified: {\n type: 'boolean',\n description: 'Whether this contact has been verified.'\n }\n },\n required: [ 'id',\n 'phoneNumber'\n ]\n }\n }\n}\n```",
|
|
22
|
+
inputSchema: {
|
|
23
|
+
type: 'object',
|
|
24
|
+
properties: {
|
|
25
|
+
cursor: {
|
|
26
|
+
type: 'string',
|
|
27
|
+
},
|
|
28
|
+
limit: {
|
|
29
|
+
type: 'integer',
|
|
30
|
+
},
|
|
31
|
+
phoneNumber: {
|
|
32
|
+
type: 'string',
|
|
33
|
+
},
|
|
34
|
+
jq_filter: {
|
|
35
|
+
type: 'string',
|
|
36
|
+
title: 'jq Filter',
|
|
37
|
+
description:
|
|
38
|
+
'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
|
|
39
|
+
},
|
|
40
|
+
},
|
|
41
|
+
required: [],
|
|
42
|
+
},
|
|
43
|
+
annotations: {
|
|
44
|
+
readOnlyHint: true,
|
|
45
|
+
},
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
49
|
+
const { jq_filter, ...body } = args as any;
|
|
50
|
+
const response = await client.contacts.list(body).asResponse();
|
|
51
|
+
try {
|
|
52
|
+
return asTextContentResult(await maybeFilter(jq_filter, await response.json()));
|
|
53
|
+
} catch (error) {
|
|
54
|
+
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
55
|
+
return asErrorResult(error.message);
|
|
56
|
+
}
|
|
57
|
+
throw error;
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
|
|
61
|
+
export default { metadata, tool, handler };
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
+
|
|
3
|
+
import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
|
|
4
|
+
import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
|
|
5
|
+
|
|
6
|
+
import { Tool } from '@modelcontextprotocol/sdk/types.js';
|
|
7
|
+
import Zavudev from '@zavudev/sdk';
|
|
8
|
+
|
|
9
|
+
export const metadata: Metadata = {
|
|
10
|
+
resource: 'contacts',
|
|
11
|
+
operation: 'read',
|
|
12
|
+
tags: [],
|
|
13
|
+
httpMethod: 'get',
|
|
14
|
+
httpPath: '/v1/contacts/phone/{phoneNumber}',
|
|
15
|
+
operationId: 'getContactByPhone',
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export const tool: Tool = {
|
|
19
|
+
name: 'retrieve_by_phone_contacts',
|
|
20
|
+
description:
|
|
21
|
+
"When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nGet contact by phone number\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/contact',\n $defs: {\n contact: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n phoneNumber: {\n type: 'string',\n description: 'E.164 phone number.'\n },\n availableChannels: {\n type: 'array',\n description: 'List of available messaging channels for this contact.',\n items: {\n type: 'string'\n }\n },\n countryCode: {\n type: 'string'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n defaultChannel: {\n type: 'string',\n description: 'Preferred channel for this contact.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n profileName: {\n type: 'string',\n description: 'Contact\\'s WhatsApp profile name. Only available for WhatsApp contacts.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n },\n verified: {\n type: 'boolean',\n description: 'Whether this contact has been verified.'\n }\n },\n required: [ 'id',\n 'phoneNumber'\n ]\n }\n }\n}\n```",
|
|
22
|
+
inputSchema: {
|
|
23
|
+
type: 'object',
|
|
24
|
+
properties: {
|
|
25
|
+
phoneNumber: {
|
|
26
|
+
type: 'string',
|
|
27
|
+
},
|
|
28
|
+
jq_filter: {
|
|
29
|
+
type: 'string',
|
|
30
|
+
title: 'jq Filter',
|
|
31
|
+
description:
|
|
32
|
+
'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
|
|
33
|
+
},
|
|
34
|
+
},
|
|
35
|
+
required: ['phoneNumber'],
|
|
36
|
+
},
|
|
37
|
+
annotations: {
|
|
38
|
+
readOnlyHint: true,
|
|
39
|
+
},
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
43
|
+
const { phoneNumber, jq_filter, ...body } = args as any;
|
|
44
|
+
try {
|
|
45
|
+
return asTextContentResult(
|
|
46
|
+
await maybeFilter(jq_filter, await client.contacts.retrieveByPhone(phoneNumber)),
|
|
47
|
+
);
|
|
48
|
+
} catch (error) {
|
|
49
|
+
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
50
|
+
return asErrorResult(error.message);
|
|
51
|
+
}
|
|
52
|
+
throw error;
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
export default { metadata, tool, handler };
|
|
@@ -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: 'contacts',
|
|
11
|
+
operation: 'read',
|
|
12
|
+
tags: [],
|
|
13
|
+
httpMethod: 'get',
|
|
14
|
+
httpPath: '/v1/contacts/{contactId}',
|
|
15
|
+
operationId: 'getContact',
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export const tool: Tool = {
|
|
19
|
+
name: 'retrieve_contacts',
|
|
20
|
+
description:
|
|
21
|
+
"When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nGet contact\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/contact',\n $defs: {\n contact: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n phoneNumber: {\n type: 'string',\n description: 'E.164 phone number.'\n },\n availableChannels: {\n type: 'array',\n description: 'List of available messaging channels for this contact.',\n items: {\n type: 'string'\n }\n },\n countryCode: {\n type: 'string'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n defaultChannel: {\n type: 'string',\n description: 'Preferred channel for this contact.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n profileName: {\n type: 'string',\n description: 'Contact\\'s WhatsApp profile name. Only available for WhatsApp contacts.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n },\n verified: {\n type: 'boolean',\n description: 'Whether this contact has been verified.'\n }\n },\n required: [ 'id',\n 'phoneNumber'\n ]\n }\n }\n}\n```",
|
|
22
|
+
inputSchema: {
|
|
23
|
+
type: 'object',
|
|
24
|
+
properties: {
|
|
25
|
+
contactId: {
|
|
26
|
+
type: 'string',
|
|
27
|
+
},
|
|
28
|
+
jq_filter: {
|
|
29
|
+
type: 'string',
|
|
30
|
+
title: 'jq Filter',
|
|
31
|
+
description:
|
|
32
|
+
'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
|
|
33
|
+
},
|
|
34
|
+
},
|
|
35
|
+
required: ['contactId'],
|
|
36
|
+
},
|
|
37
|
+
annotations: {
|
|
38
|
+
readOnlyHint: true,
|
|
39
|
+
},
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
43
|
+
const { contactId, jq_filter, ...body } = args as any;
|
|
44
|
+
try {
|
|
45
|
+
return asTextContentResult(await maybeFilter(jq_filter, await client.contacts.retrieve(contactId)));
|
|
46
|
+
} catch (error) {
|
|
47
|
+
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
48
|
+
return asErrorResult(error.message);
|
|
49
|
+
}
|
|
50
|
+
throw error;
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
export default { metadata, tool, handler };
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
+
|
|
3
|
+
import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
|
|
4
|
+
import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
|
|
5
|
+
|
|
6
|
+
import { Tool } from '@modelcontextprotocol/sdk/types.js';
|
|
7
|
+
import Zavudev from '@zavudev/sdk';
|
|
8
|
+
|
|
9
|
+
export const metadata: Metadata = {
|
|
10
|
+
resource: 'contacts',
|
|
11
|
+
operation: 'write',
|
|
12
|
+
tags: [],
|
|
13
|
+
httpMethod: 'patch',
|
|
14
|
+
httpPath: '/v1/contacts/{contactId}',
|
|
15
|
+
operationId: 'updateContact',
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export const tool: Tool = {
|
|
19
|
+
name: 'update_contacts',
|
|
20
|
+
description:
|
|
21
|
+
"When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nUpdate contact\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/contact',\n $defs: {\n contact: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n phoneNumber: {\n type: 'string',\n description: 'E.164 phone number.'\n },\n availableChannels: {\n type: 'array',\n description: 'List of available messaging channels for this contact.',\n items: {\n type: 'string'\n }\n },\n countryCode: {\n type: 'string'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n defaultChannel: {\n type: 'string',\n description: 'Preferred channel for this contact.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n profileName: {\n type: 'string',\n description: 'Contact\\'s WhatsApp profile name. Only available for WhatsApp contacts.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n },\n verified: {\n type: 'boolean',\n description: 'Whether this contact has been verified.'\n }\n },\n required: [ 'id',\n 'phoneNumber'\n ]\n }\n }\n}\n```",
|
|
22
|
+
inputSchema: {
|
|
23
|
+
type: 'object',
|
|
24
|
+
properties: {
|
|
25
|
+
contactId: {
|
|
26
|
+
type: 'string',
|
|
27
|
+
},
|
|
28
|
+
defaultChannel: {
|
|
29
|
+
type: 'string',
|
|
30
|
+
description: 'Preferred channel for this contact. Set to null to clear.',
|
|
31
|
+
enum: ['sms', 'whatsapp', 'email'],
|
|
32
|
+
},
|
|
33
|
+
metadata: {
|
|
34
|
+
type: 'object',
|
|
35
|
+
additionalProperties: true,
|
|
36
|
+
},
|
|
37
|
+
jq_filter: {
|
|
38
|
+
type: 'string',
|
|
39
|
+
title: 'jq Filter',
|
|
40
|
+
description:
|
|
41
|
+
'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
|
|
42
|
+
},
|
|
43
|
+
},
|
|
44
|
+
required: ['contactId'],
|
|
45
|
+
},
|
|
46
|
+
annotations: {},
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
50
|
+
const { contactId, jq_filter, ...body } = args as any;
|
|
51
|
+
try {
|
|
52
|
+
return asTextContentResult(await maybeFilter(jq_filter, await client.contacts.update(contactId, body)));
|
|
53
|
+
} catch (error) {
|
|
54
|
+
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
55
|
+
return asErrorResult(error.message);
|
|
56
|
+
}
|
|
57
|
+
throw error;
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
|
|
61
|
+
export default { metadata, tool, handler };
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
+
|
|
3
|
+
import { Metadata, Endpoint, HandlerFunction } from './types';
|
|
4
|
+
|
|
5
|
+
export { Metadata, Endpoint, HandlerFunction };
|
|
6
|
+
|
|
7
|
+
import retrieve_messages from './messages/retrieve-messages';
|
|
8
|
+
import list_messages from './messages/list-messages';
|
|
9
|
+
import react_messages from './messages/react-messages';
|
|
10
|
+
import send_messages from './messages/send-messages';
|
|
11
|
+
import create_templates from './templates/create-templates';
|
|
12
|
+
import retrieve_templates from './templates/retrieve-templates';
|
|
13
|
+
import list_templates from './templates/list-templates';
|
|
14
|
+
import delete_templates from './templates/delete-templates';
|
|
15
|
+
import submit_templates from './templates/submit-templates';
|
|
16
|
+
import create_senders from './senders/create-senders';
|
|
17
|
+
import retrieve_senders from './senders/retrieve-senders';
|
|
18
|
+
import update_senders from './senders/update-senders';
|
|
19
|
+
import list_senders from './senders/list-senders';
|
|
20
|
+
import delete_senders from './senders/delete-senders';
|
|
21
|
+
import regenerate_webhook_secret_senders from './senders/regenerate-webhook-secret-senders';
|
|
22
|
+
import retrieve_contacts from './contacts/retrieve-contacts';
|
|
23
|
+
import update_contacts from './contacts/update-contacts';
|
|
24
|
+
import list_contacts from './contacts/list-contacts';
|
|
25
|
+
import retrieve_by_phone_contacts from './contacts/retrieve-by-phone-contacts';
|
|
26
|
+
import create_broadcasts from './broadcasts/create-broadcasts';
|
|
27
|
+
import retrieve_broadcasts from './broadcasts/retrieve-broadcasts';
|
|
28
|
+
import update_broadcasts from './broadcasts/update-broadcasts';
|
|
29
|
+
import list_broadcasts from './broadcasts/list-broadcasts';
|
|
30
|
+
import delete_broadcasts from './broadcasts/delete-broadcasts';
|
|
31
|
+
import cancel_broadcasts from './broadcasts/cancel-broadcasts';
|
|
32
|
+
import progress_broadcasts from './broadcasts/progress-broadcasts';
|
|
33
|
+
import send_broadcasts from './broadcasts/send-broadcasts';
|
|
34
|
+
import list_broadcasts_contacts from './broadcasts/contacts/list-broadcasts-contacts';
|
|
35
|
+
import add_broadcasts_contacts from './broadcasts/contacts/add-broadcasts-contacts';
|
|
36
|
+
import remove_broadcasts_contacts from './broadcasts/contacts/remove-broadcasts-contacts';
|
|
37
|
+
import validate_phone_introspect from './introspect/validate-phone-introspect';
|
|
38
|
+
import retrieve_phone_numbers from './phone-numbers/retrieve-phone-numbers';
|
|
39
|
+
import update_phone_numbers from './phone-numbers/update-phone-numbers';
|
|
40
|
+
import list_phone_numbers from './phone-numbers/list-phone-numbers';
|
|
41
|
+
import purchase_phone_numbers from './phone-numbers/purchase-phone-numbers';
|
|
42
|
+
import release_phone_numbers from './phone-numbers/release-phone-numbers';
|
|
43
|
+
import search_available_phone_numbers from './phone-numbers/search-available-phone-numbers';
|
|
44
|
+
|
|
45
|
+
export const endpoints: Endpoint[] = [];
|
|
46
|
+
|
|
47
|
+
function addEndpoint(endpoint: Endpoint) {
|
|
48
|
+
endpoints.push(endpoint);
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
addEndpoint(retrieve_messages);
|
|
52
|
+
addEndpoint(list_messages);
|
|
53
|
+
addEndpoint(react_messages);
|
|
54
|
+
addEndpoint(send_messages);
|
|
55
|
+
addEndpoint(create_templates);
|
|
56
|
+
addEndpoint(retrieve_templates);
|
|
57
|
+
addEndpoint(list_templates);
|
|
58
|
+
addEndpoint(delete_templates);
|
|
59
|
+
addEndpoint(submit_templates);
|
|
60
|
+
addEndpoint(create_senders);
|
|
61
|
+
addEndpoint(retrieve_senders);
|
|
62
|
+
addEndpoint(update_senders);
|
|
63
|
+
addEndpoint(list_senders);
|
|
64
|
+
addEndpoint(delete_senders);
|
|
65
|
+
addEndpoint(regenerate_webhook_secret_senders);
|
|
66
|
+
addEndpoint(retrieve_contacts);
|
|
67
|
+
addEndpoint(update_contacts);
|
|
68
|
+
addEndpoint(list_contacts);
|
|
69
|
+
addEndpoint(retrieve_by_phone_contacts);
|
|
70
|
+
addEndpoint(create_broadcasts);
|
|
71
|
+
addEndpoint(retrieve_broadcasts);
|
|
72
|
+
addEndpoint(update_broadcasts);
|
|
73
|
+
addEndpoint(list_broadcasts);
|
|
74
|
+
addEndpoint(delete_broadcasts);
|
|
75
|
+
addEndpoint(cancel_broadcasts);
|
|
76
|
+
addEndpoint(progress_broadcasts);
|
|
77
|
+
addEndpoint(send_broadcasts);
|
|
78
|
+
addEndpoint(list_broadcasts_contacts);
|
|
79
|
+
addEndpoint(add_broadcasts_contacts);
|
|
80
|
+
addEndpoint(remove_broadcasts_contacts);
|
|
81
|
+
addEndpoint(validate_phone_introspect);
|
|
82
|
+
addEndpoint(retrieve_phone_numbers);
|
|
83
|
+
addEndpoint(update_phone_numbers);
|
|
84
|
+
addEndpoint(list_phone_numbers);
|
|
85
|
+
addEndpoint(purchase_phone_numbers);
|
|
86
|
+
addEndpoint(release_phone_numbers);
|
|
87
|
+
addEndpoint(search_available_phone_numbers);
|
|
88
|
+
|
|
89
|
+
export type Filter = {
|
|
90
|
+
type: 'resource' | 'operation' | 'tag' | 'tool';
|
|
91
|
+
op: 'include' | 'exclude';
|
|
92
|
+
value: string;
|
|
93
|
+
};
|
|
94
|
+
|
|
95
|
+
export function query(filters: Filter[], endpoints: Endpoint[]): Endpoint[] {
|
|
96
|
+
const allExcludes = filters.length > 0 && filters.every((filter) => filter.op === 'exclude');
|
|
97
|
+
const unmatchedFilters = new Set(filters);
|
|
98
|
+
|
|
99
|
+
const filtered = endpoints.filter((endpoint: Endpoint) => {
|
|
100
|
+
let included = false || allExcludes;
|
|
101
|
+
|
|
102
|
+
for (const filter of filters) {
|
|
103
|
+
if (match(filter, endpoint)) {
|
|
104
|
+
unmatchedFilters.delete(filter);
|
|
105
|
+
included = filter.op === 'include';
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
return included;
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
// Check if any filters didn't match
|
|
113
|
+
const unmatched = Array.from(unmatchedFilters).filter((f) => f.type === 'tool' || f.type === 'resource');
|
|
114
|
+
if (unmatched.length > 0) {
|
|
115
|
+
throw new Error(
|
|
116
|
+
`The following filters did not match any endpoints: ${unmatched
|
|
117
|
+
.map((f) => `${f.type}=${f.value}`)
|
|
118
|
+
.join(', ')}`,
|
|
119
|
+
);
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
return filtered;
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
function match({ type, value }: Filter, endpoint: Endpoint): boolean {
|
|
126
|
+
switch (type) {
|
|
127
|
+
case 'resource': {
|
|
128
|
+
const regexStr = '^' + normalizeResource(value).replace(/\*/g, '.*') + '$';
|
|
129
|
+
const regex = new RegExp(regexStr);
|
|
130
|
+
return regex.test(normalizeResource(endpoint.metadata.resource));
|
|
131
|
+
}
|
|
132
|
+
case 'operation':
|
|
133
|
+
return endpoint.metadata.operation === value;
|
|
134
|
+
case 'tag':
|
|
135
|
+
return endpoint.metadata.tags.includes(value);
|
|
136
|
+
case 'tool':
|
|
137
|
+
return endpoint.tool.name === value;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
function normalizeResource(resource: string): string {
|
|
142
|
+
return resource.toLowerCase().replace(/[^a-z.*\-_]*/g, '');
|
|
143
|
+
}
|
|
@@ -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: 'introspect',
|
|
11
|
+
operation: 'write',
|
|
12
|
+
tags: [],
|
|
13
|
+
httpMethod: 'post',
|
|
14
|
+
httpPath: '/v1/introspect/phone',
|
|
15
|
+
operationId: 'introspectPhone',
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export const tool: Tool = {
|
|
19
|
+
name: 'validate_phone_introspect',
|
|
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\nValidate a phone number and check if a WhatsApp conversation window is open.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/introspect_validate_phone_response',\n $defs: {\n introspect_validate_phone_response: {\n type: 'object',\n properties: {\n countryCode: {\n type: 'string'\n },\n phoneNumber: {\n type: 'string'\n },\n validNumber: {\n type: 'boolean'\n },\n availableChannels: {\n type: 'array',\n description: 'List of available messaging channels for this phone number.',\n items: {\n type: 'string'\n }\n },\n carrier: {\n type: 'object',\n description: 'Carrier information for the phone number.',\n properties: {\n name: {\n type: 'string',\n description: 'Carrier name.'\n },\n type: {\n $ref: '#/$defs/line_type'\n }\n }\n },\n lineType: {\n $ref: '#/$defs/line_type'\n },\n nationalFormat: {\n type: 'string',\n description: 'Phone number in national format.'\n }\n },\n required: [ 'countryCode',\n 'phoneNumber',\n 'validNumber'\n ]\n },\n line_type: {\n type: 'string',\n description: 'Type of phone line.',\n enum: [ 'mobile',\n 'landline',\n 'voip',\n 'toll_free',\n 'unknown'\n ]\n }\n }\n}\n```",
|
|
22
|
+
inputSchema: {
|
|
23
|
+
type: 'object',
|
|
24
|
+
properties: {
|
|
25
|
+
phoneNumber: {
|
|
26
|
+
type: 'string',
|
|
27
|
+
},
|
|
28
|
+
jq_filter: {
|
|
29
|
+
type: 'string',
|
|
30
|
+
title: 'jq Filter',
|
|
31
|
+
description:
|
|
32
|
+
'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
|
|
33
|
+
},
|
|
34
|
+
},
|
|
35
|
+
required: ['phoneNumber'],
|
|
36
|
+
},
|
|
37
|
+
annotations: {},
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
41
|
+
const { jq_filter, ...body } = args as any;
|
|
42
|
+
try {
|
|
43
|
+
return asTextContentResult(await maybeFilter(jq_filter, await client.introspect.validatePhone(body)));
|
|
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 };
|