@zavudev/sdk-mcp 0.15.1 → 0.16.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/README.md +13 -228
- package/code-tool.d.mts +2 -44
- package/code-tool.d.mts.map +1 -1
- package/code-tool.d.ts +2 -44
- package/code-tool.d.ts.map +1 -1
- package/code-tool.js +2 -2
- package/code-tool.js.map +1 -1
- package/code-tool.mjs +2 -2
- package/code-tool.mjs.map +1 -1
- package/docs-search-tool.d.mts +3 -3
- package/docs-search-tool.d.mts.map +1 -1
- package/docs-search-tool.d.ts +3 -3
- package/docs-search-tool.d.ts.map +1 -1
- package/docs-search-tool.js +1 -1
- package/docs-search-tool.js.map +1 -1
- package/docs-search-tool.mjs +1 -1
- package/http.d.mts.map +1 -1
- package/http.d.ts.map +1 -1
- package/http.js +1 -18
- package/http.js.map +1 -1
- package/http.mjs +1 -18
- package/http.mjs.map +1 -1
- package/index.js +4 -40
- package/index.js.map +1 -1
- package/index.mjs +4 -40
- package/index.mjs.map +1 -1
- package/options.d.mts +0 -9
- package/options.d.mts.map +1 -1
- package/options.d.ts +0 -9
- package/options.d.ts.map +1 -1
- package/options.js +4 -359
- package/options.js.map +1 -1
- package/options.mjs +4 -359
- package/options.mjs.map +1 -1
- package/package.json +9 -49
- package/server.d.mts +3 -8
- package/server.d.mts.map +1 -1
- package/server.d.ts +3 -8
- package/server.d.ts.map +1 -1
- package/server.js +12 -65
- package/server.js.map +1 -1
- package/server.mjs +11 -62
- package/server.mjs.map +1 -1
- package/src/code-tool.ts +2 -2
- package/src/docs-search-tool.ts +1 -1
- package/src/http.ts +1 -19
- package/src/index.ts +5 -52
- package/src/options.ts +5 -386
- package/src/server.ts +12 -72
- package/src/stdio.ts +2 -3
- package/src/{tools/types.ts → types.ts} +1 -1
- package/stdio.d.mts +1 -2
- package/stdio.d.mts.map +1 -1
- package/stdio.d.ts +1 -2
- package/stdio.d.ts.map +1 -1
- package/stdio.js +2 -2
- package/stdio.js.map +1 -1
- package/stdio.mjs +2 -2
- package/stdio.mjs.map +1 -1
- package/{tools/types.d.mts → types.d.mts} +1 -1
- package/types.d.mts.map +1 -0
- package/{tools/types.d.ts → types.d.ts} +1 -1
- package/types.d.ts.map +1 -0
- package/types.js.map +1 -0
- package/types.mjs.map +1 -0
- package/compat.d.mts +0 -58
- package/compat.d.mts.map +0 -1
- package/compat.d.ts +0 -58
- package/compat.d.ts.map +0 -1
- package/compat.js +0 -387
- package/compat.js.map +0 -1
- package/compat.mjs +0 -378
- package/compat.mjs.map +0 -1
- package/dynamic-tools.d.mts +0 -12
- package/dynamic-tools.d.mts.map +0 -1
- package/dynamic-tools.d.ts +0 -12
- package/dynamic-tools.d.ts.map +0 -1
- package/dynamic-tools.js +0 -135
- package/dynamic-tools.js.map +0 -1
- package/dynamic-tools.mjs +0 -132
- package/dynamic-tools.mjs.map +0 -1
- package/filtering.d.mts +0 -3
- package/filtering.d.mts.map +0 -1
- package/filtering.d.ts +0 -3
- package/filtering.d.ts.map +0 -1
- package/filtering.js +0 -24
- package/filtering.js.map +0 -1
- package/filtering.mjs +0 -16
- package/filtering.mjs.map +0 -1
- package/src/compat.ts +0 -483
- package/src/dynamic-tools.ts +0 -153
- package/src/filtering.ts +0 -18
- package/src/tools/broadcasts/cancel-broadcasts.ts +0 -52
- package/src/tools/broadcasts/contacts/add-broadcasts-contacts.ts +0 -73
- package/src/tools/broadcasts/contacts/list-broadcasts-contacts.ts +0 -71
- package/src/tools/broadcasts/contacts/remove-broadcasts-contacts.ts +0 -43
- package/src/tools/broadcasts/create-broadcasts.ts +0 -134
- package/src/tools/broadcasts/delete-broadcasts.ts +0 -40
- package/src/tools/broadcasts/list-broadcasts.ts +0 -68
- package/src/tools/broadcasts/progress-broadcasts.ts +0 -54
- package/src/tools/broadcasts/retrieve-broadcasts.ts +0 -54
- package/src/tools/broadcasts/send-broadcasts.ts +0 -57
- package/src/tools/broadcasts/update-broadcasts.ts +0 -106
- package/src/tools/contacts/list-contacts.ts +0 -61
- package/src/tools/contacts/retrieve-by-phone-contacts.ts +0 -56
- package/src/tools/contacts/retrieve-contacts.ts +0 -54
- package/src/tools/contacts/update-contacts.ts +0 -61
- package/src/tools/index.ts +0 -149
- package/src/tools/introspect/validate-phone-introspect.ts +0 -52
- package/src/tools/messages/list-messages.ts +0 -78
- package/src/tools/messages/react-messages.ts +0 -59
- package/src/tools/messages/retrieve-messages.ts +0 -54
- package/src/tools/messages/send-messages.ts +0 -233
- package/src/tools/phone-numbers/list-phone-numbers.ts +0 -68
- package/src/tools/phone-numbers/purchase-phone-numbers.ts +0 -57
- package/src/tools/phone-numbers/release-phone-numbers.ts +0 -40
- package/src/tools/phone-numbers/retrieve-phone-numbers.ts +0 -56
- package/src/tools/phone-numbers/search-available-phone-numbers.ts +0 -72
- package/src/tools/phone-numbers/update-phone-numbers.ts +0 -62
- package/src/tools/senders/create-senders.ts +0 -86
- package/src/tools/senders/delete-senders.ts +0 -40
- package/src/tools/senders/get-profile-senders.ts +0 -54
- package/src/tools/senders/list-senders.ts +0 -58
- package/src/tools/senders/regenerate-webhook-secret-senders.ts +0 -54
- package/src/tools/senders/retrieve-senders.ts +0 -54
- package/src/tools/senders/update-profile-senders.ts +0 -107
- package/src/tools/senders/update-senders.ts +0 -90
- package/src/tools/senders/upload-profile-picture-senders.ts +0 -63
- package/src/tools/templates/create-templates.ts +0 -74
- package/src/tools/templates/delete-templates.ts +0 -40
- package/src/tools/templates/list-templates.ts +0 -58
- package/src/tools/templates/retrieve-templates.ts +0 -54
- package/src/tools/templates/submit-templates.ts +0 -66
- package/src/tools.ts +0 -1
- package/tools/broadcasts/cancel-broadcasts.d.mts +0 -51
- package/tools/broadcasts/cancel-broadcasts.d.mts.map +0 -1
- package/tools/broadcasts/cancel-broadcasts.d.ts +0 -51
- package/tools/broadcasts/cancel-broadcasts.d.ts.map +0 -1
- package/tools/broadcasts/cancel-broadcasts.js +0 -52
- package/tools/broadcasts/cancel-broadcasts.js.map +0 -1
- package/tools/broadcasts/cancel-broadcasts.mjs +0 -45
- package/tools/broadcasts/cancel-broadcasts.mjs.map +0 -1
- package/tools/broadcasts/contacts/add-broadcasts-contacts.d.mts +0 -51
- package/tools/broadcasts/contacts/add-broadcasts-contacts.d.mts.map +0 -1
- package/tools/broadcasts/contacts/add-broadcasts-contacts.d.ts +0 -51
- package/tools/broadcasts/contacts/add-broadcasts-contacts.d.ts.map +0 -1
- package/tools/broadcasts/contacts/add-broadcasts-contacts.js +0 -71
- package/tools/broadcasts/contacts/add-broadcasts-contacts.js.map +0 -1
- package/tools/broadcasts/contacts/add-broadcasts-contacts.mjs +0 -64
- package/tools/broadcasts/contacts/add-broadcasts-contacts.mjs.map +0 -1
- package/tools/broadcasts/contacts/list-broadcasts-contacts.d.mts +0 -51
- package/tools/broadcasts/contacts/list-broadcasts-contacts.d.mts.map +0 -1
- package/tools/broadcasts/contacts/list-broadcasts-contacts.d.ts +0 -51
- package/tools/broadcasts/contacts/list-broadcasts-contacts.d.ts.map +0 -1
- package/tools/broadcasts/contacts/list-broadcasts-contacts.js +0 -71
- package/tools/broadcasts/contacts/list-broadcasts-contacts.js.map +0 -1
- package/tools/broadcasts/contacts/list-broadcasts-contacts.mjs +0 -64
- package/tools/broadcasts/contacts/list-broadcasts-contacts.mjs.map +0 -1
- package/tools/broadcasts/contacts/remove-broadcasts-contacts.d.mts +0 -51
- package/tools/broadcasts/contacts/remove-broadcasts-contacts.d.mts.map +0 -1
- package/tools/broadcasts/contacts/remove-broadcasts-contacts.d.ts +0 -51
- package/tools/broadcasts/contacts/remove-broadcasts-contacts.d.ts.map +0 -1
- package/tools/broadcasts/contacts/remove-broadcasts-contacts.js +0 -40
- package/tools/broadcasts/contacts/remove-broadcasts-contacts.js.map +0 -1
- package/tools/broadcasts/contacts/remove-broadcasts-contacts.mjs +0 -36
- package/tools/broadcasts/contacts/remove-broadcasts-contacts.mjs.map +0 -1
- package/tools/broadcasts/create-broadcasts.d.mts +0 -51
- package/tools/broadcasts/create-broadcasts.d.mts.map +0 -1
- package/tools/broadcasts/create-broadcasts.d.ts +0 -51
- package/tools/broadcasts/create-broadcasts.d.ts.map +0 -1
- package/tools/broadcasts/create-broadcasts.js +0 -134
- package/tools/broadcasts/create-broadcasts.js.map +0 -1
- package/tools/broadcasts/create-broadcasts.mjs +0 -127
- package/tools/broadcasts/create-broadcasts.mjs.map +0 -1
- package/tools/broadcasts/delete-broadcasts.d.mts +0 -51
- package/tools/broadcasts/delete-broadcasts.d.mts.map +0 -1
- package/tools/broadcasts/delete-broadcasts.d.ts +0 -51
- package/tools/broadcasts/delete-broadcasts.d.ts.map +0 -1
- package/tools/broadcasts/delete-broadcasts.js +0 -37
- package/tools/broadcasts/delete-broadcasts.js.map +0 -1
- package/tools/broadcasts/delete-broadcasts.mjs +0 -33
- package/tools/broadcasts/delete-broadcasts.mjs.map +0 -1
- package/tools/broadcasts/list-broadcasts.d.mts +0 -51
- package/tools/broadcasts/list-broadcasts.d.mts.map +0 -1
- package/tools/broadcasts/list-broadcasts.d.ts +0 -51
- package/tools/broadcasts/list-broadcasts.d.ts.map +0 -1
- package/tools/broadcasts/list-broadcasts.js +0 -68
- package/tools/broadcasts/list-broadcasts.js.map +0 -1
- package/tools/broadcasts/list-broadcasts.mjs +0 -61
- package/tools/broadcasts/list-broadcasts.mjs.map +0 -1
- package/tools/broadcasts/progress-broadcasts.d.mts +0 -51
- package/tools/broadcasts/progress-broadcasts.d.mts.map +0 -1
- package/tools/broadcasts/progress-broadcasts.d.ts +0 -51
- package/tools/broadcasts/progress-broadcasts.d.ts.map +0 -1
- package/tools/broadcasts/progress-broadcasts.js +0 -54
- package/tools/broadcasts/progress-broadcasts.js.map +0 -1
- package/tools/broadcasts/progress-broadcasts.mjs +0 -47
- package/tools/broadcasts/progress-broadcasts.mjs.map +0 -1
- package/tools/broadcasts/retrieve-broadcasts.d.mts +0 -51
- package/tools/broadcasts/retrieve-broadcasts.d.mts.map +0 -1
- package/tools/broadcasts/retrieve-broadcasts.d.ts +0 -51
- package/tools/broadcasts/retrieve-broadcasts.d.ts.map +0 -1
- package/tools/broadcasts/retrieve-broadcasts.js +0 -54
- package/tools/broadcasts/retrieve-broadcasts.js.map +0 -1
- package/tools/broadcasts/retrieve-broadcasts.mjs +0 -47
- package/tools/broadcasts/retrieve-broadcasts.mjs.map +0 -1
- package/tools/broadcasts/send-broadcasts.d.mts +0 -51
- package/tools/broadcasts/send-broadcasts.d.mts.map +0 -1
- package/tools/broadcasts/send-broadcasts.d.ts +0 -51
- package/tools/broadcasts/send-broadcasts.d.ts.map +0 -1
- package/tools/broadcasts/send-broadcasts.js +0 -57
- package/tools/broadcasts/send-broadcasts.js.map +0 -1
- package/tools/broadcasts/send-broadcasts.mjs +0 -50
- package/tools/broadcasts/send-broadcasts.mjs.map +0 -1
- package/tools/broadcasts/update-broadcasts.d.mts +0 -51
- package/tools/broadcasts/update-broadcasts.d.mts.map +0 -1
- package/tools/broadcasts/update-broadcasts.d.ts +0 -51
- package/tools/broadcasts/update-broadcasts.d.ts.map +0 -1
- package/tools/broadcasts/update-broadcasts.js +0 -104
- package/tools/broadcasts/update-broadcasts.js.map +0 -1
- package/tools/broadcasts/update-broadcasts.mjs +0 -97
- package/tools/broadcasts/update-broadcasts.mjs.map +0 -1
- package/tools/contacts/list-contacts.d.mts +0 -51
- package/tools/contacts/list-contacts.d.mts.map +0 -1
- package/tools/contacts/list-contacts.d.ts +0 -51
- package/tools/contacts/list-contacts.d.ts.map +0 -1
- package/tools/contacts/list-contacts.js +0 -61
- package/tools/contacts/list-contacts.js.map +0 -1
- package/tools/contacts/list-contacts.mjs +0 -54
- package/tools/contacts/list-contacts.mjs.map +0 -1
- package/tools/contacts/retrieve-by-phone-contacts.d.mts +0 -51
- package/tools/contacts/retrieve-by-phone-contacts.d.mts.map +0 -1
- package/tools/contacts/retrieve-by-phone-contacts.d.ts +0 -51
- package/tools/contacts/retrieve-by-phone-contacts.d.ts.map +0 -1
- package/tools/contacts/retrieve-by-phone-contacts.js +0 -54
- package/tools/contacts/retrieve-by-phone-contacts.js.map +0 -1
- package/tools/contacts/retrieve-by-phone-contacts.mjs +0 -47
- package/tools/contacts/retrieve-by-phone-contacts.mjs.map +0 -1
- package/tools/contacts/retrieve-contacts.d.mts +0 -51
- package/tools/contacts/retrieve-contacts.d.mts.map +0 -1
- package/tools/contacts/retrieve-contacts.d.ts +0 -51
- package/tools/contacts/retrieve-contacts.d.ts.map +0 -1
- package/tools/contacts/retrieve-contacts.js +0 -54
- package/tools/contacts/retrieve-contacts.js.map +0 -1
- package/tools/contacts/retrieve-contacts.mjs +0 -47
- package/tools/contacts/retrieve-contacts.mjs.map +0 -1
- package/tools/contacts/update-contacts.d.mts +0 -51
- package/tools/contacts/update-contacts.d.mts.map +0 -1
- package/tools/contacts/update-contacts.d.ts +0 -51
- package/tools/contacts/update-contacts.d.ts.map +0 -1
- package/tools/contacts/update-contacts.js +0 -61
- package/tools/contacts/update-contacts.js.map +0 -1
- package/tools/contacts/update-contacts.mjs +0 -54
- package/tools/contacts/update-contacts.mjs.map +0 -1
- package/tools/index.d.mts +0 -10
- package/tools/index.d.mts.map +0 -1
- package/tools/index.d.ts +0 -10
- package/tools/index.d.ts.map +0 -1
- package/tools/index.js +0 -133
- package/tools/index.js.map +0 -1
- package/tools/index.mjs +0 -126
- package/tools/index.mjs.map +0 -1
- package/tools/introspect/validate-phone-introspect.d.mts +0 -51
- package/tools/introspect/validate-phone-introspect.d.mts.map +0 -1
- package/tools/introspect/validate-phone-introspect.d.ts +0 -51
- package/tools/introspect/validate-phone-introspect.d.ts.map +0 -1
- package/tools/introspect/validate-phone-introspect.js +0 -52
- package/tools/introspect/validate-phone-introspect.js.map +0 -1
- package/tools/introspect/validate-phone-introspect.mjs +0 -45
- package/tools/introspect/validate-phone-introspect.mjs.map +0 -1
- package/tools/messages/list-messages.d.mts +0 -51
- package/tools/messages/list-messages.d.mts.map +0 -1
- package/tools/messages/list-messages.d.ts +0 -51
- package/tools/messages/list-messages.d.ts.map +0 -1
- package/tools/messages/list-messages.js +0 -78
- package/tools/messages/list-messages.js.map +0 -1
- package/tools/messages/list-messages.mjs +0 -71
- package/tools/messages/list-messages.mjs.map +0 -1
- package/tools/messages/react-messages.d.mts +0 -51
- package/tools/messages/react-messages.d.mts.map +0 -1
- package/tools/messages/react-messages.d.ts +0 -51
- package/tools/messages/react-messages.d.ts.map +0 -1
- package/tools/messages/react-messages.js +0 -59
- package/tools/messages/react-messages.js.map +0 -1
- package/tools/messages/react-messages.mjs +0 -52
- package/tools/messages/react-messages.mjs.map +0 -1
- package/tools/messages/retrieve-messages.d.mts +0 -51
- package/tools/messages/retrieve-messages.d.mts.map +0 -1
- package/tools/messages/retrieve-messages.d.ts +0 -51
- package/tools/messages/retrieve-messages.d.ts.map +0 -1
- package/tools/messages/retrieve-messages.js +0 -54
- package/tools/messages/retrieve-messages.js.map +0 -1
- package/tools/messages/retrieve-messages.mjs +0 -47
- package/tools/messages/retrieve-messages.mjs.map +0 -1
- package/tools/messages/send-messages.d.mts +0 -51
- package/tools/messages/send-messages.d.mts.map +0 -1
- package/tools/messages/send-messages.d.ts +0 -51
- package/tools/messages/send-messages.d.ts.map +0 -1
- package/tools/messages/send-messages.js +0 -233
- package/tools/messages/send-messages.js.map +0 -1
- package/tools/messages/send-messages.mjs +0 -226
- package/tools/messages/send-messages.mjs.map +0 -1
- package/tools/phone-numbers/list-phone-numbers.d.mts +0 -51
- package/tools/phone-numbers/list-phone-numbers.d.mts.map +0 -1
- package/tools/phone-numbers/list-phone-numbers.d.ts +0 -51
- package/tools/phone-numbers/list-phone-numbers.d.ts.map +0 -1
- package/tools/phone-numbers/list-phone-numbers.js +0 -68
- package/tools/phone-numbers/list-phone-numbers.js.map +0 -1
- package/tools/phone-numbers/list-phone-numbers.mjs +0 -61
- package/tools/phone-numbers/list-phone-numbers.mjs.map +0 -1
- package/tools/phone-numbers/purchase-phone-numbers.d.mts +0 -51
- package/tools/phone-numbers/purchase-phone-numbers.d.mts.map +0 -1
- package/tools/phone-numbers/purchase-phone-numbers.d.ts +0 -51
- package/tools/phone-numbers/purchase-phone-numbers.d.ts.map +0 -1
- package/tools/phone-numbers/purchase-phone-numbers.js +0 -57
- package/tools/phone-numbers/purchase-phone-numbers.js.map +0 -1
- package/tools/phone-numbers/purchase-phone-numbers.mjs +0 -50
- package/tools/phone-numbers/purchase-phone-numbers.mjs.map +0 -1
- package/tools/phone-numbers/release-phone-numbers.d.mts +0 -51
- package/tools/phone-numbers/release-phone-numbers.d.mts.map +0 -1
- package/tools/phone-numbers/release-phone-numbers.d.ts +0 -51
- package/tools/phone-numbers/release-phone-numbers.d.ts.map +0 -1
- package/tools/phone-numbers/release-phone-numbers.js +0 -37
- package/tools/phone-numbers/release-phone-numbers.js.map +0 -1
- package/tools/phone-numbers/release-phone-numbers.mjs +0 -33
- package/tools/phone-numbers/release-phone-numbers.mjs.map +0 -1
- package/tools/phone-numbers/retrieve-phone-numbers.d.mts +0 -51
- package/tools/phone-numbers/retrieve-phone-numbers.d.mts.map +0 -1
- package/tools/phone-numbers/retrieve-phone-numbers.d.ts +0 -51
- package/tools/phone-numbers/retrieve-phone-numbers.d.ts.map +0 -1
- package/tools/phone-numbers/retrieve-phone-numbers.js +0 -54
- package/tools/phone-numbers/retrieve-phone-numbers.js.map +0 -1
- package/tools/phone-numbers/retrieve-phone-numbers.mjs +0 -47
- package/tools/phone-numbers/retrieve-phone-numbers.mjs.map +0 -1
- package/tools/phone-numbers/search-available-phone-numbers.d.mts +0 -51
- package/tools/phone-numbers/search-available-phone-numbers.d.mts.map +0 -1
- package/tools/phone-numbers/search-available-phone-numbers.d.ts +0 -51
- package/tools/phone-numbers/search-available-phone-numbers.d.ts.map +0 -1
- package/tools/phone-numbers/search-available-phone-numbers.js +0 -72
- package/tools/phone-numbers/search-available-phone-numbers.js.map +0 -1
- package/tools/phone-numbers/search-available-phone-numbers.mjs +0 -65
- package/tools/phone-numbers/search-available-phone-numbers.mjs.map +0 -1
- package/tools/phone-numbers/update-phone-numbers.d.mts +0 -51
- package/tools/phone-numbers/update-phone-numbers.d.mts.map +0 -1
- package/tools/phone-numbers/update-phone-numbers.d.ts +0 -51
- package/tools/phone-numbers/update-phone-numbers.d.ts.map +0 -1
- package/tools/phone-numbers/update-phone-numbers.js +0 -60
- package/tools/phone-numbers/update-phone-numbers.js.map +0 -1
- package/tools/phone-numbers/update-phone-numbers.mjs +0 -53
- package/tools/phone-numbers/update-phone-numbers.mjs.map +0 -1
- package/tools/senders/create-senders.d.mts +0 -51
- package/tools/senders/create-senders.d.mts.map +0 -1
- package/tools/senders/create-senders.d.ts +0 -51
- package/tools/senders/create-senders.d.ts.map +0 -1
- package/tools/senders/create-senders.js +0 -85
- package/tools/senders/create-senders.js.map +0 -1
- package/tools/senders/create-senders.mjs +0 -78
- package/tools/senders/create-senders.mjs.map +0 -1
- package/tools/senders/delete-senders.d.mts +0 -51
- package/tools/senders/delete-senders.d.mts.map +0 -1
- package/tools/senders/delete-senders.d.ts +0 -51
- package/tools/senders/delete-senders.d.ts.map +0 -1
- package/tools/senders/delete-senders.js +0 -37
- package/tools/senders/delete-senders.js.map +0 -1
- package/tools/senders/delete-senders.mjs +0 -33
- package/tools/senders/delete-senders.mjs.map +0 -1
- package/tools/senders/get-profile-senders.d.mts +0 -51
- package/tools/senders/get-profile-senders.d.mts.map +0 -1
- package/tools/senders/get-profile-senders.d.ts +0 -51
- package/tools/senders/get-profile-senders.d.ts.map +0 -1
- package/tools/senders/get-profile-senders.js +0 -54
- package/tools/senders/get-profile-senders.js.map +0 -1
- package/tools/senders/get-profile-senders.mjs +0 -47
- package/tools/senders/get-profile-senders.mjs.map +0 -1
- package/tools/senders/list-senders.d.mts +0 -51
- package/tools/senders/list-senders.d.mts.map +0 -1
- package/tools/senders/list-senders.d.ts +0 -51
- package/tools/senders/list-senders.d.ts.map +0 -1
- package/tools/senders/list-senders.js +0 -58
- package/tools/senders/list-senders.js.map +0 -1
- package/tools/senders/list-senders.mjs +0 -51
- package/tools/senders/list-senders.mjs.map +0 -1
- package/tools/senders/regenerate-webhook-secret-senders.d.mts +0 -51
- package/tools/senders/regenerate-webhook-secret-senders.d.mts.map +0 -1
- package/tools/senders/regenerate-webhook-secret-senders.d.ts +0 -51
- package/tools/senders/regenerate-webhook-secret-senders.d.ts.map +0 -1
- package/tools/senders/regenerate-webhook-secret-senders.js +0 -52
- package/tools/senders/regenerate-webhook-secret-senders.js.map +0 -1
- package/tools/senders/regenerate-webhook-secret-senders.mjs +0 -45
- package/tools/senders/regenerate-webhook-secret-senders.mjs.map +0 -1
- package/tools/senders/retrieve-senders.d.mts +0 -51
- package/tools/senders/retrieve-senders.d.mts.map +0 -1
- package/tools/senders/retrieve-senders.d.ts +0 -51
- package/tools/senders/retrieve-senders.d.ts.map +0 -1
- package/tools/senders/retrieve-senders.js +0 -54
- package/tools/senders/retrieve-senders.js.map +0 -1
- package/tools/senders/retrieve-senders.mjs +0 -47
- package/tools/senders/retrieve-senders.mjs.map +0 -1
- package/tools/senders/update-profile-senders.d.mts +0 -51
- package/tools/senders/update-profile-senders.d.mts.map +0 -1
- package/tools/senders/update-profile-senders.d.ts +0 -51
- package/tools/senders/update-profile-senders.d.ts.map +0 -1
- package/tools/senders/update-profile-senders.js +0 -105
- package/tools/senders/update-profile-senders.js.map +0 -1
- package/tools/senders/update-profile-senders.mjs +0 -98
- package/tools/senders/update-profile-senders.mjs.map +0 -1
- package/tools/senders/update-senders.d.mts +0 -51
- package/tools/senders/update-senders.d.mts.map +0 -1
- package/tools/senders/update-senders.d.ts +0 -51
- package/tools/senders/update-senders.d.ts.map +0 -1
- package/tools/senders/update-senders.js +0 -89
- package/tools/senders/update-senders.js.map +0 -1
- package/tools/senders/update-senders.mjs +0 -82
- package/tools/senders/update-senders.mjs.map +0 -1
- package/tools/senders/upload-profile-picture-senders.d.mts +0 -51
- package/tools/senders/upload-profile-picture-senders.d.mts.map +0 -1
- package/tools/senders/upload-profile-picture-senders.d.ts +0 -51
- package/tools/senders/upload-profile-picture-senders.d.ts.map +0 -1
- package/tools/senders/upload-profile-picture-senders.js +0 -61
- package/tools/senders/upload-profile-picture-senders.js.map +0 -1
- package/tools/senders/upload-profile-picture-senders.mjs +0 -54
- package/tools/senders/upload-profile-picture-senders.mjs.map +0 -1
- package/tools/templates/create-templates.d.mts +0 -51
- package/tools/templates/create-templates.d.mts.map +0 -1
- package/tools/templates/create-templates.d.ts +0 -51
- package/tools/templates/create-templates.d.ts.map +0 -1
- package/tools/templates/create-templates.js +0 -74
- package/tools/templates/create-templates.js.map +0 -1
- package/tools/templates/create-templates.mjs +0 -67
- package/tools/templates/create-templates.mjs.map +0 -1
- package/tools/templates/delete-templates.d.mts +0 -51
- package/tools/templates/delete-templates.d.mts.map +0 -1
- package/tools/templates/delete-templates.d.ts +0 -51
- package/tools/templates/delete-templates.d.ts.map +0 -1
- package/tools/templates/delete-templates.js +0 -37
- package/tools/templates/delete-templates.js.map +0 -1
- package/tools/templates/delete-templates.mjs +0 -33
- package/tools/templates/delete-templates.mjs.map +0 -1
- package/tools/templates/list-templates.d.mts +0 -51
- package/tools/templates/list-templates.d.mts.map +0 -1
- package/tools/templates/list-templates.d.ts +0 -51
- package/tools/templates/list-templates.d.ts.map +0 -1
- package/tools/templates/list-templates.js +0 -58
- package/tools/templates/list-templates.js.map +0 -1
- package/tools/templates/list-templates.mjs +0 -51
- package/tools/templates/list-templates.mjs.map +0 -1
- package/tools/templates/retrieve-templates.d.mts +0 -51
- package/tools/templates/retrieve-templates.d.mts.map +0 -1
- package/tools/templates/retrieve-templates.d.ts +0 -51
- package/tools/templates/retrieve-templates.d.ts.map +0 -1
- package/tools/templates/retrieve-templates.js +0 -54
- package/tools/templates/retrieve-templates.js.map +0 -1
- package/tools/templates/retrieve-templates.mjs +0 -47
- package/tools/templates/retrieve-templates.mjs.map +0 -1
- package/tools/templates/submit-templates.d.mts +0 -51
- package/tools/templates/submit-templates.d.mts.map +0 -1
- package/tools/templates/submit-templates.d.ts +0 -51
- package/tools/templates/submit-templates.d.ts.map +0 -1
- package/tools/templates/submit-templates.js +0 -66
- package/tools/templates/submit-templates.js.map +0 -1
- package/tools/templates/submit-templates.mjs +0 -59
- package/tools/templates/submit-templates.mjs.map +0 -1
- package/tools/types.d.mts.map +0 -1
- package/tools/types.d.ts.map +0 -1
- package/tools/types.js.map +0 -1
- package/tools/types.mjs.map +0 -1
- package/tools.d.mts +0 -2
- package/tools.d.mts.map +0 -1
- package/tools.d.ts +0 -2
- package/tools.d.ts.map +0 -1
- package/tools.js +0 -18
- package/tools.js.map +0 -1
- package/tools.mjs +0 -2
- package/tools.mjs.map +0 -1
- /package/{tools/types.js → types.js} +0 -0
- /package/{tools/types.mjs → types.mjs} +0 -0
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
-
|
|
3
|
-
import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
|
|
4
|
-
import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
|
|
5
|
-
|
|
6
|
-
import { Tool } from '@modelcontextprotocol/sdk/types.js';
|
|
7
|
-
import Zavudev from '@zavudev/sdk';
|
|
8
|
-
|
|
9
|
-
export const metadata: Metadata = {
|
|
10
|
-
resource: 'broadcasts',
|
|
11
|
-
operation: 'read',
|
|
12
|
-
tags: [],
|
|
13
|
-
httpMethod: 'get',
|
|
14
|
-
httpPath: '/v1/broadcasts',
|
|
15
|
-
operationId: 'listBroadcasts',
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
export const tool: Tool = {
|
|
19
|
-
name: 'list_broadcasts',
|
|
20
|
-
description:
|
|
21
|
-
"When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nList broadcasts for this project.\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n items: {\n type: 'array',\n items: {\n $ref: '#/$defs/broadcast'\n }\n },\n nextCursor: {\n type: 'string'\n }\n },\n required: [ 'items'\n ],\n $defs: {\n broadcast: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n channel: {\n $ref: '#/$defs/broadcast_channel'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n messageType: {\n $ref: '#/$defs/broadcast_message_type'\n },\n name: {\n type: 'string'\n },\n status: {\n $ref: '#/$defs/broadcast_status'\n },\n totalContacts: {\n type: 'integer',\n description: 'Total number of contacts in the broadcast.'\n },\n actualCost: {\n type: 'number',\n description: 'Actual cost so far in USD.'\n },\n completedAt: {\n type: 'string',\n format: 'date-time'\n },\n content: {\n $ref: '#/$defs/broadcast_content'\n },\n deliveredCount: {\n type: 'integer'\n },\n emailSubject: {\n type: 'string'\n },\n estimatedCost: {\n type: 'number',\n description: 'Estimated total cost in USD.'\n },\n failedCount: {\n type: 'integer'\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n pendingCount: {\n type: 'integer'\n },\n reservedAmount: {\n type: 'number',\n description: 'Amount reserved from balance in USD.'\n },\n scheduledAt: {\n type: 'string',\n format: 'date-time'\n },\n senderId: {\n type: 'string'\n },\n sendingCount: {\n type: 'integer'\n },\n startedAt: {\n type: 'string',\n format: 'date-time'\n },\n text: {\n type: 'string'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'id',\n 'channel',\n 'createdAt',\n 'messageType',\n 'name',\n 'status',\n 'totalContacts'\n ]\n },\n broadcast_channel: {\n type: 'string',\n description: 'Broadcast delivery channel.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n broadcast_message_type: {\n type: 'string',\n description: 'Type of message for broadcast.',\n enum: [ 'text',\n 'image',\n 'video',\n 'audio',\n 'document',\n 'template'\n ]\n },\n broadcast_status: {\n type: 'string',\n description: 'Current status of the broadcast.',\n enum: [ 'draft',\n 'scheduled',\n 'sending',\n 'paused',\n 'completed',\n 'cancelled',\n 'failed'\n ]\n },\n broadcast_content: {\n type: 'object',\n description: 'Content for non-text broadcast message types.',\n properties: {\n filename: {\n type: 'string',\n description: 'Filename for documents.'\n },\n mediaId: {\n type: 'string',\n description: 'Media ID if already uploaded.'\n },\n mediaUrl: {\n type: 'string',\n description: 'URL of the media file.'\n },\n mimeType: {\n type: 'string',\n description: 'MIME type of the media.'\n },\n templateId: {\n type: 'string',\n description: 'Template ID for template messages.'\n },\n templateVariables: {\n type: 'object',\n description: 'Default template variables (can be overridden per contact).',\n additionalProperties: true\n }\n }\n }\n }\n}\n```",
|
|
22
|
-
inputSchema: {
|
|
23
|
-
type: 'object',
|
|
24
|
-
properties: {
|
|
25
|
-
cursor: {
|
|
26
|
-
type: 'string',
|
|
27
|
-
},
|
|
28
|
-
limit: {
|
|
29
|
-
type: 'integer',
|
|
30
|
-
},
|
|
31
|
-
status: {
|
|
32
|
-
$ref: '#/$defs/broadcast_status',
|
|
33
|
-
},
|
|
34
|
-
jq_filter: {
|
|
35
|
-
type: 'string',
|
|
36
|
-
title: 'jq Filter',
|
|
37
|
-
description:
|
|
38
|
-
'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
|
|
39
|
-
},
|
|
40
|
-
},
|
|
41
|
-
required: [],
|
|
42
|
-
$defs: {
|
|
43
|
-
broadcast_status: {
|
|
44
|
-
type: 'string',
|
|
45
|
-
description: 'Current status of the broadcast.',
|
|
46
|
-
enum: ['draft', 'scheduled', 'sending', 'paused', 'completed', 'cancelled', 'failed'],
|
|
47
|
-
},
|
|
48
|
-
},
|
|
49
|
-
},
|
|
50
|
-
annotations: {
|
|
51
|
-
readOnlyHint: true,
|
|
52
|
-
},
|
|
53
|
-
};
|
|
54
|
-
|
|
55
|
-
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
56
|
-
const { jq_filter, ...body } = args as any;
|
|
57
|
-
const response = await client.broadcasts.list(body).asResponse();
|
|
58
|
-
try {
|
|
59
|
-
return asTextContentResult(await maybeFilter(jq_filter, await response.json()));
|
|
60
|
-
} catch (error) {
|
|
61
|
-
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
62
|
-
return asErrorResult(error.message);
|
|
63
|
-
}
|
|
64
|
-
throw error;
|
|
65
|
-
}
|
|
66
|
-
};
|
|
67
|
-
|
|
68
|
-
export default { metadata, tool, handler };
|
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
-
|
|
3
|
-
import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
|
|
4
|
-
import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
|
|
5
|
-
|
|
6
|
-
import { Tool } from '@modelcontextprotocol/sdk/types.js';
|
|
7
|
-
import Zavudev from '@zavudev/sdk';
|
|
8
|
-
|
|
9
|
-
export const metadata: Metadata = {
|
|
10
|
-
resource: 'broadcasts',
|
|
11
|
-
operation: 'read',
|
|
12
|
-
tags: [],
|
|
13
|
-
httpMethod: 'get',
|
|
14
|
-
httpPath: '/v1/broadcasts/{broadcastId}/progress',
|
|
15
|
-
operationId: 'getBroadcastProgress',
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
export const tool: Tool = {
|
|
19
|
-
name: 'progress_broadcasts',
|
|
20
|
-
description:
|
|
21
|
-
"When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nGet real-time progress of a broadcast including delivery counts and estimated completion time.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/broadcast_progress',\n $defs: {\n broadcast_progress: {\n type: 'object',\n properties: {\n broadcastId: {\n type: 'string'\n },\n delivered: {\n type: 'integer',\n description: 'Successfully delivered.'\n },\n failed: {\n type: 'integer',\n description: 'Failed to deliver.'\n },\n pending: {\n type: 'integer',\n description: 'Not yet queued for sending.'\n },\n percentComplete: {\n type: 'number',\n description: 'Percentage complete (0-100).'\n },\n sending: {\n type: 'integer',\n description: 'Currently being sent.'\n },\n skipped: {\n type: 'integer',\n description: 'Skipped (broadcast cancelled).'\n },\n status: {\n $ref: '#/$defs/broadcast_status'\n },\n total: {\n type: 'integer',\n description: 'Total contacts in broadcast.'\n },\n actualCost: {\n type: 'number',\n description: 'Actual cost so far in USD.'\n },\n estimatedCompletionAt: {\n type: 'string',\n format: 'date-time'\n },\n estimatedCost: {\n type: 'number',\n description: 'Estimated total cost in USD.'\n },\n reservedAmount: {\n type: 'number',\n description: 'Amount reserved from balance in USD.'\n },\n startedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'broadcastId',\n 'delivered',\n 'failed',\n 'pending',\n 'percentComplete',\n 'sending',\n 'skipped',\n 'status',\n 'total'\n ]\n },\n broadcast_status: {\n type: 'string',\n description: 'Current status of the broadcast.',\n enum: [ 'draft',\n 'scheduled',\n 'sending',\n 'paused',\n 'completed',\n 'cancelled',\n 'failed'\n ]\n }\n }\n}\n```",
|
|
22
|
-
inputSchema: {
|
|
23
|
-
type: 'object',
|
|
24
|
-
properties: {
|
|
25
|
-
broadcastId: {
|
|
26
|
-
type: 'string',
|
|
27
|
-
},
|
|
28
|
-
jq_filter: {
|
|
29
|
-
type: 'string',
|
|
30
|
-
title: 'jq Filter',
|
|
31
|
-
description:
|
|
32
|
-
'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
|
|
33
|
-
},
|
|
34
|
-
},
|
|
35
|
-
required: ['broadcastId'],
|
|
36
|
-
},
|
|
37
|
-
annotations: {
|
|
38
|
-
readOnlyHint: true,
|
|
39
|
-
},
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
43
|
-
const { broadcastId, jq_filter, ...body } = args as any;
|
|
44
|
-
try {
|
|
45
|
-
return asTextContentResult(await maybeFilter(jq_filter, await client.broadcasts.progress(broadcastId)));
|
|
46
|
-
} catch (error) {
|
|
47
|
-
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
48
|
-
return asErrorResult(error.message);
|
|
49
|
-
}
|
|
50
|
-
throw error;
|
|
51
|
-
}
|
|
52
|
-
};
|
|
53
|
-
|
|
54
|
-
export default { metadata, tool, handler };
|
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
-
|
|
3
|
-
import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
|
|
4
|
-
import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
|
|
5
|
-
|
|
6
|
-
import { Tool } from '@modelcontextprotocol/sdk/types.js';
|
|
7
|
-
import Zavudev from '@zavudev/sdk';
|
|
8
|
-
|
|
9
|
-
export const metadata: Metadata = {
|
|
10
|
-
resource: 'broadcasts',
|
|
11
|
-
operation: 'read',
|
|
12
|
-
tags: [],
|
|
13
|
-
httpMethod: 'get',
|
|
14
|
-
httpPath: '/v1/broadcasts/{broadcastId}',
|
|
15
|
-
operationId: 'getBroadcast',
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
export const tool: Tool = {
|
|
19
|
-
name: 'retrieve_broadcasts',
|
|
20
|
-
description:
|
|
21
|
-
"When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nGet broadcast\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/broadcast_retrieve_response',\n $defs: {\n broadcast_retrieve_response: {\n type: 'object',\n properties: {\n broadcast: {\n $ref: '#/$defs/broadcast'\n }\n },\n required: [ 'broadcast'\n ]\n },\n broadcast: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n channel: {\n $ref: '#/$defs/broadcast_channel'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n messageType: {\n $ref: '#/$defs/broadcast_message_type'\n },\n name: {\n type: 'string'\n },\n status: {\n $ref: '#/$defs/broadcast_status'\n },\n totalContacts: {\n type: 'integer',\n description: 'Total number of contacts in the broadcast.'\n },\n actualCost: {\n type: 'number',\n description: 'Actual cost so far in USD.'\n },\n completedAt: {\n type: 'string',\n format: 'date-time'\n },\n content: {\n $ref: '#/$defs/broadcast_content'\n },\n deliveredCount: {\n type: 'integer'\n },\n emailSubject: {\n type: 'string'\n },\n estimatedCost: {\n type: 'number',\n description: 'Estimated total cost in USD.'\n },\n failedCount: {\n type: 'integer'\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n pendingCount: {\n type: 'integer'\n },\n reservedAmount: {\n type: 'number',\n description: 'Amount reserved from balance in USD.'\n },\n scheduledAt: {\n type: 'string',\n format: 'date-time'\n },\n senderId: {\n type: 'string'\n },\n sendingCount: {\n type: 'integer'\n },\n startedAt: {\n type: 'string',\n format: 'date-time'\n },\n text: {\n type: 'string'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'id',\n 'channel',\n 'createdAt',\n 'messageType',\n 'name',\n 'status',\n 'totalContacts'\n ]\n },\n broadcast_channel: {\n type: 'string',\n description: 'Broadcast delivery channel.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n broadcast_message_type: {\n type: 'string',\n description: 'Type of message for broadcast.',\n enum: [ 'text',\n 'image',\n 'video',\n 'audio',\n 'document',\n 'template'\n ]\n },\n broadcast_status: {\n type: 'string',\n description: 'Current status of the broadcast.',\n enum: [ 'draft',\n 'scheduled',\n 'sending',\n 'paused',\n 'completed',\n 'cancelled',\n 'failed'\n ]\n },\n broadcast_content: {\n type: 'object',\n description: 'Content for non-text broadcast message types.',\n properties: {\n filename: {\n type: 'string',\n description: 'Filename for documents.'\n },\n mediaId: {\n type: 'string',\n description: 'Media ID if already uploaded.'\n },\n mediaUrl: {\n type: 'string',\n description: 'URL of the media file.'\n },\n mimeType: {\n type: 'string',\n description: 'MIME type of the media.'\n },\n templateId: {\n type: 'string',\n description: 'Template ID for template messages.'\n },\n templateVariables: {\n type: 'object',\n description: 'Default template variables (can be overridden per contact).',\n additionalProperties: true\n }\n }\n }\n }\n}\n```",
|
|
22
|
-
inputSchema: {
|
|
23
|
-
type: 'object',
|
|
24
|
-
properties: {
|
|
25
|
-
broadcastId: {
|
|
26
|
-
type: 'string',
|
|
27
|
-
},
|
|
28
|
-
jq_filter: {
|
|
29
|
-
type: 'string',
|
|
30
|
-
title: 'jq Filter',
|
|
31
|
-
description:
|
|
32
|
-
'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
|
|
33
|
-
},
|
|
34
|
-
},
|
|
35
|
-
required: ['broadcastId'],
|
|
36
|
-
},
|
|
37
|
-
annotations: {
|
|
38
|
-
readOnlyHint: true,
|
|
39
|
-
},
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
43
|
-
const { broadcastId, jq_filter, ...body } = args as any;
|
|
44
|
-
try {
|
|
45
|
-
return asTextContentResult(await maybeFilter(jq_filter, await client.broadcasts.retrieve(broadcastId)));
|
|
46
|
-
} catch (error) {
|
|
47
|
-
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
48
|
-
return asErrorResult(error.message);
|
|
49
|
-
}
|
|
50
|
-
throw error;
|
|
51
|
-
}
|
|
52
|
-
};
|
|
53
|
-
|
|
54
|
-
export default { metadata, tool, handler };
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
-
|
|
3
|
-
import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
|
|
4
|
-
import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
|
|
5
|
-
|
|
6
|
-
import { Tool } from '@modelcontextprotocol/sdk/types.js';
|
|
7
|
-
import Zavudev from '@zavudev/sdk';
|
|
8
|
-
|
|
9
|
-
export const metadata: Metadata = {
|
|
10
|
-
resource: 'broadcasts',
|
|
11
|
-
operation: 'write',
|
|
12
|
-
tags: [],
|
|
13
|
-
httpMethod: 'post',
|
|
14
|
-
httpPath: '/v1/broadcasts/{broadcastId}/send',
|
|
15
|
-
operationId: 'sendBroadcast',
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
export const tool: Tool = {
|
|
19
|
-
name: 'send_broadcasts',
|
|
20
|
-
description:
|
|
21
|
-
"When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nStart sending the broadcast immediately or schedule for later. Reserves the estimated cost from your balance.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/broadcast_send_response',\n $defs: {\n broadcast_send_response: {\n type: 'object',\n properties: {\n broadcast: {\n $ref: '#/$defs/broadcast'\n }\n },\n required: [ 'broadcast'\n ]\n },\n broadcast: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n channel: {\n $ref: '#/$defs/broadcast_channel'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n messageType: {\n $ref: '#/$defs/broadcast_message_type'\n },\n name: {\n type: 'string'\n },\n status: {\n $ref: '#/$defs/broadcast_status'\n },\n totalContacts: {\n type: 'integer',\n description: 'Total number of contacts in the broadcast.'\n },\n actualCost: {\n type: 'number',\n description: 'Actual cost so far in USD.'\n },\n completedAt: {\n type: 'string',\n format: 'date-time'\n },\n content: {\n $ref: '#/$defs/broadcast_content'\n },\n deliveredCount: {\n type: 'integer'\n },\n emailSubject: {\n type: 'string'\n },\n estimatedCost: {\n type: 'number',\n description: 'Estimated total cost in USD.'\n },\n failedCount: {\n type: 'integer'\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n pendingCount: {\n type: 'integer'\n },\n reservedAmount: {\n type: 'number',\n description: 'Amount reserved from balance in USD.'\n },\n scheduledAt: {\n type: 'string',\n format: 'date-time'\n },\n senderId: {\n type: 'string'\n },\n sendingCount: {\n type: 'integer'\n },\n startedAt: {\n type: 'string',\n format: 'date-time'\n },\n text: {\n type: 'string'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'id',\n 'channel',\n 'createdAt',\n 'messageType',\n 'name',\n 'status',\n 'totalContacts'\n ]\n },\n broadcast_channel: {\n type: 'string',\n description: 'Broadcast delivery channel.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n broadcast_message_type: {\n type: 'string',\n description: 'Type of message for broadcast.',\n enum: [ 'text',\n 'image',\n 'video',\n 'audio',\n 'document',\n 'template'\n ]\n },\n broadcast_status: {\n type: 'string',\n description: 'Current status of the broadcast.',\n enum: [ 'draft',\n 'scheduled',\n 'sending',\n 'paused',\n 'completed',\n 'cancelled',\n 'failed'\n ]\n },\n broadcast_content: {\n type: 'object',\n description: 'Content for non-text broadcast message types.',\n properties: {\n filename: {\n type: 'string',\n description: 'Filename for documents.'\n },\n mediaId: {\n type: 'string',\n description: 'Media ID if already uploaded.'\n },\n mediaUrl: {\n type: 'string',\n description: 'URL of the media file.'\n },\n mimeType: {\n type: 'string',\n description: 'MIME type of the media.'\n },\n templateId: {\n type: 'string',\n description: 'Template ID for template messages.'\n },\n templateVariables: {\n type: 'object',\n description: 'Default template variables (can be overridden per contact).',\n additionalProperties: true\n }\n }\n }\n }\n}\n```",
|
|
22
|
-
inputSchema: {
|
|
23
|
-
type: 'object',
|
|
24
|
-
properties: {
|
|
25
|
-
broadcastId: {
|
|
26
|
-
type: 'string',
|
|
27
|
-
},
|
|
28
|
-
scheduledAt: {
|
|
29
|
-
type: 'string',
|
|
30
|
-
description: 'Schedule for future delivery. Omit to send immediately.',
|
|
31
|
-
format: 'date-time',
|
|
32
|
-
},
|
|
33
|
-
jq_filter: {
|
|
34
|
-
type: 'string',
|
|
35
|
-
title: 'jq Filter',
|
|
36
|
-
description:
|
|
37
|
-
'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
|
|
38
|
-
},
|
|
39
|
-
},
|
|
40
|
-
required: ['broadcastId'],
|
|
41
|
-
},
|
|
42
|
-
annotations: {},
|
|
43
|
-
};
|
|
44
|
-
|
|
45
|
-
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
46
|
-
const { broadcastId, jq_filter, ...body } = args as any;
|
|
47
|
-
try {
|
|
48
|
-
return asTextContentResult(await maybeFilter(jq_filter, await client.broadcasts.send(broadcastId, body)));
|
|
49
|
-
} catch (error) {
|
|
50
|
-
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
51
|
-
return asErrorResult(error.message);
|
|
52
|
-
}
|
|
53
|
-
throw error;
|
|
54
|
-
}
|
|
55
|
-
};
|
|
56
|
-
|
|
57
|
-
export default { metadata, tool, handler };
|
|
@@ -1,106 +0,0 @@
|
|
|
1
|
-
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
-
|
|
3
|
-
import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
|
|
4
|
-
import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
|
|
5
|
-
|
|
6
|
-
import { Tool } from '@modelcontextprotocol/sdk/types.js';
|
|
7
|
-
import Zavudev from '@zavudev/sdk';
|
|
8
|
-
|
|
9
|
-
export const metadata: Metadata = {
|
|
10
|
-
resource: 'broadcasts',
|
|
11
|
-
operation: 'write',
|
|
12
|
-
tags: [],
|
|
13
|
-
httpMethod: 'patch',
|
|
14
|
-
httpPath: '/v1/broadcasts/{broadcastId}',
|
|
15
|
-
operationId: 'updateBroadcast',
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
export const tool: Tool = {
|
|
19
|
-
name: 'update_broadcasts',
|
|
20
|
-
description:
|
|
21
|
-
"When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nUpdate a broadcast in draft status.\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/broadcast_update_response',\n $defs: {\n broadcast_update_response: {\n type: 'object',\n properties: {\n broadcast: {\n $ref: '#/$defs/broadcast'\n }\n },\n required: [ 'broadcast'\n ]\n },\n broadcast: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n channel: {\n $ref: '#/$defs/broadcast_channel'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n messageType: {\n $ref: '#/$defs/broadcast_message_type'\n },\n name: {\n type: 'string'\n },\n status: {\n $ref: '#/$defs/broadcast_status'\n },\n totalContacts: {\n type: 'integer',\n description: 'Total number of contacts in the broadcast.'\n },\n actualCost: {\n type: 'number',\n description: 'Actual cost so far in USD.'\n },\n completedAt: {\n type: 'string',\n format: 'date-time'\n },\n content: {\n $ref: '#/$defs/broadcast_content'\n },\n deliveredCount: {\n type: 'integer'\n },\n emailSubject: {\n type: 'string'\n },\n estimatedCost: {\n type: 'number',\n description: 'Estimated total cost in USD.'\n },\n failedCount: {\n type: 'integer'\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n pendingCount: {\n type: 'integer'\n },\n reservedAmount: {\n type: 'number',\n description: 'Amount reserved from balance in USD.'\n },\n scheduledAt: {\n type: 'string',\n format: 'date-time'\n },\n senderId: {\n type: 'string'\n },\n sendingCount: {\n type: 'integer'\n },\n startedAt: {\n type: 'string',\n format: 'date-time'\n },\n text: {\n type: 'string'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n }\n },\n required: [ 'id',\n 'channel',\n 'createdAt',\n 'messageType',\n 'name',\n 'status',\n 'totalContacts'\n ]\n },\n broadcast_channel: {\n type: 'string',\n description: 'Broadcast delivery channel.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n broadcast_message_type: {\n type: 'string',\n description: 'Type of message for broadcast.',\n enum: [ 'text',\n 'image',\n 'video',\n 'audio',\n 'document',\n 'template'\n ]\n },\n broadcast_status: {\n type: 'string',\n description: 'Current status of the broadcast.',\n enum: [ 'draft',\n 'scheduled',\n 'sending',\n 'paused',\n 'completed',\n 'cancelled',\n 'failed'\n ]\n },\n broadcast_content: {\n type: 'object',\n description: 'Content for non-text broadcast message types.',\n properties: {\n filename: {\n type: 'string',\n description: 'Filename for documents.'\n },\n mediaId: {\n type: 'string',\n description: 'Media ID if already uploaded.'\n },\n mediaUrl: {\n type: 'string',\n description: 'URL of the media file.'\n },\n mimeType: {\n type: 'string',\n description: 'MIME type of the media.'\n },\n templateId: {\n type: 'string',\n description: 'Template ID for template messages.'\n },\n templateVariables: {\n type: 'object',\n description: 'Default template variables (can be overridden per contact).',\n additionalProperties: true\n }\n }\n }\n }\n}\n```",
|
|
22
|
-
inputSchema: {
|
|
23
|
-
type: 'object',
|
|
24
|
-
properties: {
|
|
25
|
-
broadcastId: {
|
|
26
|
-
type: 'string',
|
|
27
|
-
},
|
|
28
|
-
content: {
|
|
29
|
-
$ref: '#/$defs/broadcast_content',
|
|
30
|
-
},
|
|
31
|
-
emailHtmlBody: {
|
|
32
|
-
type: 'string',
|
|
33
|
-
},
|
|
34
|
-
emailSubject: {
|
|
35
|
-
type: 'string',
|
|
36
|
-
},
|
|
37
|
-
metadata: {
|
|
38
|
-
type: 'object',
|
|
39
|
-
additionalProperties: true,
|
|
40
|
-
},
|
|
41
|
-
name: {
|
|
42
|
-
type: 'string',
|
|
43
|
-
},
|
|
44
|
-
text: {
|
|
45
|
-
type: 'string',
|
|
46
|
-
},
|
|
47
|
-
jq_filter: {
|
|
48
|
-
type: 'string',
|
|
49
|
-
title: 'jq Filter',
|
|
50
|
-
description:
|
|
51
|
-
'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
|
|
52
|
-
},
|
|
53
|
-
},
|
|
54
|
-
required: ['broadcastId'],
|
|
55
|
-
$defs: {
|
|
56
|
-
broadcast_content: {
|
|
57
|
-
type: 'object',
|
|
58
|
-
description: 'Content for non-text broadcast message types.',
|
|
59
|
-
properties: {
|
|
60
|
-
filename: {
|
|
61
|
-
type: 'string',
|
|
62
|
-
description: 'Filename for documents.',
|
|
63
|
-
},
|
|
64
|
-
mediaId: {
|
|
65
|
-
type: 'string',
|
|
66
|
-
description: 'Media ID if already uploaded.',
|
|
67
|
-
},
|
|
68
|
-
mediaUrl: {
|
|
69
|
-
type: 'string',
|
|
70
|
-
description: 'URL of the media file.',
|
|
71
|
-
},
|
|
72
|
-
mimeType: {
|
|
73
|
-
type: 'string',
|
|
74
|
-
description: 'MIME type of the media.',
|
|
75
|
-
},
|
|
76
|
-
templateId: {
|
|
77
|
-
type: 'string',
|
|
78
|
-
description: 'Template ID for template messages.',
|
|
79
|
-
},
|
|
80
|
-
templateVariables: {
|
|
81
|
-
type: 'object',
|
|
82
|
-
description: 'Default template variables (can be overridden per contact).',
|
|
83
|
-
additionalProperties: true,
|
|
84
|
-
},
|
|
85
|
-
},
|
|
86
|
-
},
|
|
87
|
-
},
|
|
88
|
-
},
|
|
89
|
-
annotations: {},
|
|
90
|
-
};
|
|
91
|
-
|
|
92
|
-
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
93
|
-
const { broadcastId, jq_filter, ...body } = args as any;
|
|
94
|
-
try {
|
|
95
|
-
return asTextContentResult(
|
|
96
|
-
await maybeFilter(jq_filter, await client.broadcasts.update(broadcastId, body)),
|
|
97
|
-
);
|
|
98
|
-
} catch (error) {
|
|
99
|
-
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
100
|
-
return asErrorResult(error.message);
|
|
101
|
-
}
|
|
102
|
-
throw error;
|
|
103
|
-
}
|
|
104
|
-
};
|
|
105
|
-
|
|
106
|
-
export default { metadata, tool, handler };
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
-
|
|
3
|
-
import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
|
|
4
|
-
import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
|
|
5
|
-
|
|
6
|
-
import { Tool } from '@modelcontextprotocol/sdk/types.js';
|
|
7
|
-
import Zavudev from '@zavudev/sdk';
|
|
8
|
-
|
|
9
|
-
export const metadata: Metadata = {
|
|
10
|
-
resource: 'contacts',
|
|
11
|
-
operation: 'read',
|
|
12
|
-
tags: [],
|
|
13
|
-
httpMethod: 'get',
|
|
14
|
-
httpPath: '/v1/contacts',
|
|
15
|
-
operationId: 'listContacts',
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
export const tool: Tool = {
|
|
19
|
-
name: 'list_contacts',
|
|
20
|
-
description:
|
|
21
|
-
"When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nList contacts\n\n# Response Schema\n```json\n{\n type: 'object',\n properties: {\n items: {\n type: 'array',\n items: {\n $ref: '#/$defs/contact'\n }\n },\n nextCursor: {\n type: 'string'\n }\n },\n required: [ 'items'\n ],\n $defs: {\n contact: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n phoneNumber: {\n type: 'string',\n description: 'E.164 phone number.'\n },\n availableChannels: {\n type: 'array',\n description: 'List of available messaging channels for this contact.',\n items: {\n type: 'string'\n }\n },\n countryCode: {\n type: 'string'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n defaultChannel: {\n type: 'string',\n description: 'Preferred channel for this contact.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n profileName: {\n type: 'string',\n description: 'Contact\\'s WhatsApp profile name. Only available for WhatsApp contacts.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n },\n verified: {\n type: 'boolean',\n description: 'Whether this contact has been verified.'\n }\n },\n required: [ 'id',\n 'phoneNumber'\n ]\n }\n }\n}\n```",
|
|
22
|
-
inputSchema: {
|
|
23
|
-
type: 'object',
|
|
24
|
-
properties: {
|
|
25
|
-
cursor: {
|
|
26
|
-
type: 'string',
|
|
27
|
-
},
|
|
28
|
-
limit: {
|
|
29
|
-
type: 'integer',
|
|
30
|
-
},
|
|
31
|
-
phoneNumber: {
|
|
32
|
-
type: 'string',
|
|
33
|
-
},
|
|
34
|
-
jq_filter: {
|
|
35
|
-
type: 'string',
|
|
36
|
-
title: 'jq Filter',
|
|
37
|
-
description:
|
|
38
|
-
'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
|
|
39
|
-
},
|
|
40
|
-
},
|
|
41
|
-
required: [],
|
|
42
|
-
},
|
|
43
|
-
annotations: {
|
|
44
|
-
readOnlyHint: true,
|
|
45
|
-
},
|
|
46
|
-
};
|
|
47
|
-
|
|
48
|
-
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
49
|
-
const { jq_filter, ...body } = args as any;
|
|
50
|
-
const response = await client.contacts.list(body).asResponse();
|
|
51
|
-
try {
|
|
52
|
-
return asTextContentResult(await maybeFilter(jq_filter, await response.json()));
|
|
53
|
-
} catch (error) {
|
|
54
|
-
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
55
|
-
return asErrorResult(error.message);
|
|
56
|
-
}
|
|
57
|
-
throw error;
|
|
58
|
-
}
|
|
59
|
-
};
|
|
60
|
-
|
|
61
|
-
export default { metadata, tool, handler };
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
-
|
|
3
|
-
import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
|
|
4
|
-
import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
|
|
5
|
-
|
|
6
|
-
import { Tool } from '@modelcontextprotocol/sdk/types.js';
|
|
7
|
-
import Zavudev from '@zavudev/sdk';
|
|
8
|
-
|
|
9
|
-
export const metadata: Metadata = {
|
|
10
|
-
resource: 'contacts',
|
|
11
|
-
operation: 'read',
|
|
12
|
-
tags: [],
|
|
13
|
-
httpMethod: 'get',
|
|
14
|
-
httpPath: '/v1/contacts/phone/{phoneNumber}',
|
|
15
|
-
operationId: 'getContactByPhone',
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
export const tool: Tool = {
|
|
19
|
-
name: 'retrieve_by_phone_contacts',
|
|
20
|
-
description:
|
|
21
|
-
"When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nGet contact by phone number\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/contact',\n $defs: {\n contact: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n phoneNumber: {\n type: 'string',\n description: 'E.164 phone number.'\n },\n availableChannels: {\n type: 'array',\n description: 'List of available messaging channels for this contact.',\n items: {\n type: 'string'\n }\n },\n countryCode: {\n type: 'string'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n defaultChannel: {\n type: 'string',\n description: 'Preferred channel for this contact.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n profileName: {\n type: 'string',\n description: 'Contact\\'s WhatsApp profile name. Only available for WhatsApp contacts.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n },\n verified: {\n type: 'boolean',\n description: 'Whether this contact has been verified.'\n }\n },\n required: [ 'id',\n 'phoneNumber'\n ]\n }\n }\n}\n```",
|
|
22
|
-
inputSchema: {
|
|
23
|
-
type: 'object',
|
|
24
|
-
properties: {
|
|
25
|
-
phoneNumber: {
|
|
26
|
-
type: 'string',
|
|
27
|
-
},
|
|
28
|
-
jq_filter: {
|
|
29
|
-
type: 'string',
|
|
30
|
-
title: 'jq Filter',
|
|
31
|
-
description:
|
|
32
|
-
'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
|
|
33
|
-
},
|
|
34
|
-
},
|
|
35
|
-
required: ['phoneNumber'],
|
|
36
|
-
},
|
|
37
|
-
annotations: {
|
|
38
|
-
readOnlyHint: true,
|
|
39
|
-
},
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
43
|
-
const { phoneNumber, jq_filter, ...body } = args as any;
|
|
44
|
-
try {
|
|
45
|
-
return asTextContentResult(
|
|
46
|
-
await maybeFilter(jq_filter, await client.contacts.retrieveByPhone(phoneNumber)),
|
|
47
|
-
);
|
|
48
|
-
} catch (error) {
|
|
49
|
-
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
50
|
-
return asErrorResult(error.message);
|
|
51
|
-
}
|
|
52
|
-
throw error;
|
|
53
|
-
}
|
|
54
|
-
};
|
|
55
|
-
|
|
56
|
-
export default { metadata, tool, handler };
|
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
-
|
|
3
|
-
import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
|
|
4
|
-
import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
|
|
5
|
-
|
|
6
|
-
import { Tool } from '@modelcontextprotocol/sdk/types.js';
|
|
7
|
-
import Zavudev from '@zavudev/sdk';
|
|
8
|
-
|
|
9
|
-
export const metadata: Metadata = {
|
|
10
|
-
resource: 'contacts',
|
|
11
|
-
operation: 'read',
|
|
12
|
-
tags: [],
|
|
13
|
-
httpMethod: 'get',
|
|
14
|
-
httpPath: '/v1/contacts/{contactId}',
|
|
15
|
-
operationId: 'getContact',
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
export const tool: Tool = {
|
|
19
|
-
name: 'retrieve_contacts',
|
|
20
|
-
description:
|
|
21
|
-
"When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nGet contact\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/contact',\n $defs: {\n contact: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n phoneNumber: {\n type: 'string',\n description: 'E.164 phone number.'\n },\n availableChannels: {\n type: 'array',\n description: 'List of available messaging channels for this contact.',\n items: {\n type: 'string'\n }\n },\n countryCode: {\n type: 'string'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n defaultChannel: {\n type: 'string',\n description: 'Preferred channel for this contact.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n profileName: {\n type: 'string',\n description: 'Contact\\'s WhatsApp profile name. Only available for WhatsApp contacts.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n },\n verified: {\n type: 'boolean',\n description: 'Whether this contact has been verified.'\n }\n },\n required: [ 'id',\n 'phoneNumber'\n ]\n }\n }\n}\n```",
|
|
22
|
-
inputSchema: {
|
|
23
|
-
type: 'object',
|
|
24
|
-
properties: {
|
|
25
|
-
contactId: {
|
|
26
|
-
type: 'string',
|
|
27
|
-
},
|
|
28
|
-
jq_filter: {
|
|
29
|
-
type: 'string',
|
|
30
|
-
title: 'jq Filter',
|
|
31
|
-
description:
|
|
32
|
-
'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
|
|
33
|
-
},
|
|
34
|
-
},
|
|
35
|
-
required: ['contactId'],
|
|
36
|
-
},
|
|
37
|
-
annotations: {
|
|
38
|
-
readOnlyHint: true,
|
|
39
|
-
},
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
43
|
-
const { contactId, jq_filter, ...body } = args as any;
|
|
44
|
-
try {
|
|
45
|
-
return asTextContentResult(await maybeFilter(jq_filter, await client.contacts.retrieve(contactId)));
|
|
46
|
-
} catch (error) {
|
|
47
|
-
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
48
|
-
return asErrorResult(error.message);
|
|
49
|
-
}
|
|
50
|
-
throw error;
|
|
51
|
-
}
|
|
52
|
-
};
|
|
53
|
-
|
|
54
|
-
export default { metadata, tool, handler };
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
-
|
|
3
|
-
import { isJqError, maybeFilter } from '@zavudev/sdk-mcp/filtering';
|
|
4
|
-
import { Metadata, asErrorResult, asTextContentResult } from '@zavudev/sdk-mcp/tools/types';
|
|
5
|
-
|
|
6
|
-
import { Tool } from '@modelcontextprotocol/sdk/types.js';
|
|
7
|
-
import Zavudev from '@zavudev/sdk';
|
|
8
|
-
|
|
9
|
-
export const metadata: Metadata = {
|
|
10
|
-
resource: 'contacts',
|
|
11
|
-
operation: 'write',
|
|
12
|
-
tags: [],
|
|
13
|
-
httpMethod: 'patch',
|
|
14
|
-
httpPath: '/v1/contacts/{contactId}',
|
|
15
|
-
operationId: 'updateContact',
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
export const tool: Tool = {
|
|
19
|
-
name: 'update_contacts',
|
|
20
|
-
description:
|
|
21
|
-
"When using this tool, always use the `jq_filter` parameter to reduce the response size and improve performance.\n\nOnly omit if you're sure you don't need the data.\n\nUpdate contact\n\n# Response Schema\n```json\n{\n $ref: '#/$defs/contact',\n $defs: {\n contact: {\n type: 'object',\n properties: {\n id: {\n type: 'string'\n },\n phoneNumber: {\n type: 'string',\n description: 'E.164 phone number.'\n },\n availableChannels: {\n type: 'array',\n description: 'List of available messaging channels for this contact.',\n items: {\n type: 'string'\n }\n },\n countryCode: {\n type: 'string'\n },\n createdAt: {\n type: 'string',\n format: 'date-time'\n },\n defaultChannel: {\n type: 'string',\n description: 'Preferred channel for this contact.',\n enum: [ 'sms',\n 'whatsapp',\n 'email'\n ]\n },\n metadata: {\n type: 'object',\n additionalProperties: true\n },\n profileName: {\n type: 'string',\n description: 'Contact\\'s WhatsApp profile name. Only available for WhatsApp contacts.'\n },\n updatedAt: {\n type: 'string',\n format: 'date-time'\n },\n verified: {\n type: 'boolean',\n description: 'Whether this contact has been verified.'\n }\n },\n required: [ 'id',\n 'phoneNumber'\n ]\n }\n }\n}\n```",
|
|
22
|
-
inputSchema: {
|
|
23
|
-
type: 'object',
|
|
24
|
-
properties: {
|
|
25
|
-
contactId: {
|
|
26
|
-
type: 'string',
|
|
27
|
-
},
|
|
28
|
-
defaultChannel: {
|
|
29
|
-
type: 'string',
|
|
30
|
-
description: 'Preferred channel for this contact. Set to null to clear.',
|
|
31
|
-
enum: ['sms', 'whatsapp', 'email'],
|
|
32
|
-
},
|
|
33
|
-
metadata: {
|
|
34
|
-
type: 'object',
|
|
35
|
-
additionalProperties: true,
|
|
36
|
-
},
|
|
37
|
-
jq_filter: {
|
|
38
|
-
type: 'string',
|
|
39
|
-
title: 'jq Filter',
|
|
40
|
-
description:
|
|
41
|
-
'A jq filter to apply to the response to include certain fields. Consult the output schema in the tool description to see the fields that are available.\n\nFor example: to include only the `name` field in every object of a results array, you can provide ".results[].name".\n\nFor more information, see the [jq documentation](https://jqlang.org/manual/).',
|
|
42
|
-
},
|
|
43
|
-
},
|
|
44
|
-
required: ['contactId'],
|
|
45
|
-
},
|
|
46
|
-
annotations: {},
|
|
47
|
-
};
|
|
48
|
-
|
|
49
|
-
export const handler = async (client: Zavudev, args: Record<string, unknown> | undefined) => {
|
|
50
|
-
const { contactId, jq_filter, ...body } = args as any;
|
|
51
|
-
try {
|
|
52
|
-
return asTextContentResult(await maybeFilter(jq_filter, await client.contacts.update(contactId, body)));
|
|
53
|
-
} catch (error) {
|
|
54
|
-
if (error instanceof Zavudev.APIError || isJqError(error)) {
|
|
55
|
-
return asErrorResult(error.message);
|
|
56
|
-
}
|
|
57
|
-
throw error;
|
|
58
|
-
}
|
|
59
|
-
};
|
|
60
|
-
|
|
61
|
-
export default { metadata, tool, handler };
|