@commandable/mcp 0.0.1
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 +10 -0
- package/README.md +34 -0
- package/dist/cli/bin.d.ts +3 -0
- package/dist/cli/bin.d.ts.map +1 -0
- package/dist/cli/bin.js +7 -0
- package/dist/cli/bin.js.map +1 -0
- package/dist/cli/credentialManager.d.ts +19 -0
- package/dist/cli/credentialManager.d.ts.map +1 -0
- package/dist/cli/credentialManager.js +81 -0
- package/dist/cli/credentialManager.js.map +1 -0
- package/dist/cli/index.d.ts +2 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +77 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/setup.d.ts +3 -0
- package/dist/cli/setup.d.ts.map +1 -0
- package/dist/cli/setup.js +194 -0
- package/dist/cli/setup.js.map +1 -0
- package/dist/crypto/encryption.d.ts +3 -0
- package/dist/crypto/encryption.d.ts.map +1 -0
- package/dist/crypto/encryption.js +29 -0
- package/dist/crypto/encryption.js.map +1 -0
- package/dist/db/client.d.ts +22 -0
- package/dist/db/client.d.ts.map +1 -0
- package/dist/db/client.js +43 -0
- package/dist/db/client.js.map +1 -0
- package/dist/db/credentialStore.d.ts +13 -0
- package/dist/db/credentialStore.d.ts.map +1 -0
- package/dist/db/credentialStore.js +57 -0
- package/dist/db/credentialStore.js.map +1 -0
- package/dist/db/integrationStore.d.ts +5 -0
- package/dist/db/integrationStore.d.ts.map +1 -0
- package/dist/db/integrationStore.js +65 -0
- package/dist/db/integrationStore.js.map +1 -0
- package/dist/db/migrate.d.ts +3 -0
- package/dist/db/migrate.d.ts.map +1 -0
- package/dist/db/migrate.js +88 -0
- package/dist/db/migrate.js.map +1 -0
- package/dist/db/schema.d.ts +911 -0
- package/dist/db/schema.d.ts.map +1 -0
- package/dist/db/schema.js +73 -0
- package/dist/db/schema.js.map +1 -0
- package/dist/errors/httpError.d.ts +6 -0
- package/dist/errors/httpError.d.ts.map +1 -0
- package/dist/errors/httpError.js +11 -0
- package/dist/errors/httpError.js.map +1 -0
- package/dist/index.d.ts +21 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +21 -0
- package/dist/index.js.map +1 -0
- package/dist/integrations/actionsFactory.d.ts +12 -0
- package/dist/integrations/actionsFactory.d.ts.map +1 -0
- package/dist/integrations/actionsFactory.js +68 -0
- package/dist/integrations/actionsFactory.js.map +1 -0
- package/dist/integrations/catalog.d.ts +9 -0
- package/dist/integrations/catalog.d.ts.map +1 -0
- package/dist/integrations/catalog.js +80 -0
- package/dist/integrations/catalog.js.map +1 -0
- package/dist/integrations/dataLoader.d.ts +47 -0
- package/dist/integrations/dataLoader.d.ts.map +1 -0
- package/dist/integrations/dataLoader.js +126 -0
- package/dist/integrations/dataLoader.js.map +1 -0
- package/dist/integrations/getIntegration.d.ts +11 -0
- package/dist/integrations/getIntegration.d.ts.map +1 -0
- package/dist/integrations/getIntegration.js +22 -0
- package/dist/integrations/getIntegration.js.map +1 -0
- package/dist/integrations/googleServiceAccount.d.ts +6 -0
- package/dist/integrations/googleServiceAccount.d.ts.map +1 -0
- package/dist/integrations/googleServiceAccount.js +54 -0
- package/dist/integrations/googleServiceAccount.js.map +1 -0
- package/dist/integrations/providerRegistry.d.ts +2 -0
- package/dist/integrations/providerRegistry.d.ts.map +1 -0
- package/dist/integrations/providerRegistry.js +50 -0
- package/dist/integrations/providerRegistry.js.map +1 -0
- package/dist/integrations/proxy.d.ts +16 -0
- package/dist/integrations/proxy.d.ts.map +1 -0
- package/dist/integrations/proxy.js +331 -0
- package/dist/integrations/proxy.js.map +1 -0
- package/dist/integrations/sandbox.d.ts +7 -0
- package/dist/integrations/sandbox.d.ts.map +1 -0
- package/dist/integrations/sandbox.js +210 -0
- package/dist/integrations/sandbox.js.map +1 -0
- package/dist/integrations/tools.d.ts +3 -0
- package/dist/integrations/tools.d.ts.map +1 -0
- package/dist/integrations/tools.js +70 -0
- package/dist/integrations/tools.js.map +1 -0
- package/dist/mcp/server.d.ts +15 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +50 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/toolAdapter.d.ts +17 -0
- package/dist/mcp/toolAdapter.d.ts.map +1 -0
- package/dist/mcp/toolAdapter.js +18 -0
- package/dist/mcp/toolAdapter.js.map +1 -0
- package/dist/types.d.ts +34 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/integration-data/README.md +52 -0
- package/integration-data/airtable/credentials.json +20 -0
- package/integration-data/airtable/credentials_hint.md +4 -0
- package/integration-data/airtable/handlers/create_record.js +12 -0
- package/integration-data/airtable/handlers/delete_record.js +7 -0
- package/integration-data/airtable/handlers/get_record.js +4 -0
- package/integration-data/airtable/handlers/get_table_schema.js +6 -0
- package/integration-data/airtable/handlers/list_bases.js +4 -0
- package/integration-data/airtable/handlers/list_records.js +25 -0
- package/integration-data/airtable/handlers/list_table_fields.js +6 -0
- package/integration-data/airtable/handlers/list_tables.js +4 -0
- package/integration-data/airtable/handlers/list_views.js +6 -0
- package/integration-data/airtable/handlers/search_records.js +6 -0
- package/integration-data/airtable/handlers/update_record.js +11 -0
- package/integration-data/airtable/manifest.json +83 -0
- package/integration-data/airtable/schemas/create_record.json +12 -0
- package/integration-data/airtable/schemas/delete_record.json +11 -0
- package/integration-data/airtable/schemas/empty.json +6 -0
- package/integration-data/airtable/schemas/get_record.json +11 -0
- package/integration-data/airtable/schemas/id_base.json +9 -0
- package/integration-data/airtable/schemas/id_base_table.json +10 -0
- package/integration-data/airtable/schemas/list_records.json +26 -0
- package/integration-data/airtable/schemas/search_records.json +12 -0
- package/integration-data/airtable/schemas/update_record.json +13 -0
- package/integration-data/github/credentials.json +20 -0
- package/integration-data/github/credentials_hint.md +7 -0
- package/integration-data/github/handlers/add_labels_to_issue.js +12 -0
- package/integration-data/github/handlers/close_issue.js +5 -0
- package/integration-data/github/handlers/comment_on_issue.js +5 -0
- package/integration-data/github/handlers/create_branch.js +33 -0
- package/integration-data/github/handlers/create_commit.js +91 -0
- package/integration-data/github/handlers/create_issue.js +10 -0
- package/integration-data/github/handlers/create_or_update_file.js +21 -0
- package/integration-data/github/handlers/create_pull_request.js +16 -0
- package/integration-data/github/handlers/create_repo.js +11 -0
- package/integration-data/github/handlers/delete_repo.js +6 -0
- package/integration-data/github/handlers/get_issue.js +4 -0
- package/integration-data/github/handlers/get_repo.js +4 -0
- package/integration-data/github/handlers/list_branches.js +4 -0
- package/integration-data/github/handlers/list_commits.js +12 -0
- package/integration-data/github/handlers/list_issues.js +12 -0
- package/integration-data/github/handlers/list_pull_requests.js +8 -0
- package/integration-data/github/handlers/list_repos_install.js +4 -0
- package/integration-data/github/handlers/list_repos_user.js +4 -0
- package/integration-data/github/handlers/merge_pull_request.js +14 -0
- package/integration-data/github/handlers/update_issue.js +15 -0
- package/integration-data/github/manifest.json +26 -0
- package/integration-data/github/schemas/add_labels_to_issue.json +12 -0
- package/integration-data/github/schemas/close_issue.json +10 -0
- package/integration-data/github/schemas/comment_on_issue.json +11 -0
- package/integration-data/github/schemas/create_branch.json +12 -0
- package/integration-data/github/schemas/create_commit.json +25 -0
- package/integration-data/github/schemas/create_issue.json +13 -0
- package/integration-data/github/schemas/create_or_update_file.json +15 -0
- package/integration-data/github/schemas/create_pull_request.json +15 -0
- package/integration-data/github/schemas/create_repo.json +12 -0
- package/integration-data/github/schemas/delete_repo.json +10 -0
- package/integration-data/github/schemas/empty.json +5 -0
- package/integration-data/github/schemas/get_issue.json +10 -0
- package/integration-data/github/schemas/get_repo.json +9 -0
- package/integration-data/github/schemas/list_commits.json +12 -0
- package/integration-data/github/schemas/list_issues.json +12 -0
- package/integration-data/github/schemas/list_pull_requests.json +10 -0
- package/integration-data/github/schemas/merge_pull_request.json +14 -0
- package/integration-data/github/schemas/owner_repo.json +9 -0
- package/integration-data/github/schemas/update_issue.json +15 -0
- package/integration-data/google-calendar/credentials.json +36 -0
- package/integration-data/google-calendar/credentials_hint.md +9 -0
- package/integration-data/google-calendar/handlers/create_event.js +6 -0
- package/integration-data/google-calendar/handlers/delete_acl.js +6 -0
- package/integration-data/google-calendar/handlers/delete_event.js +7 -0
- package/integration-data/google-calendar/handlers/freebusy_query.js +4 -0
- package/integration-data/google-calendar/handlers/get_acl.js +5 -0
- package/integration-data/google-calendar/handlers/get_calendar.js +4 -0
- package/integration-data/google-calendar/handlers/get_event.js +5 -0
- package/integration-data/google-calendar/handlers/insert_acl.js +6 -0
- package/integration-data/google-calendar/handlers/list_acl.js +5 -0
- package/integration-data/google-calendar/handlers/list_calendars.js +4 -0
- package/integration-data/google-calendar/handlers/list_colors.js +4 -0
- package/integration-data/google-calendar/handlers/list_events.js +21 -0
- package/integration-data/google-calendar/handlers/list_settings.js +4 -0
- package/integration-data/google-calendar/handlers/move_event.js +6 -0
- package/integration-data/google-calendar/handlers/patch_event.js +5 -0
- package/integration-data/google-calendar/handlers/quick_add.js +6 -0
- package/integration-data/google-calendar/handlers/update_acl.js +7 -0
- package/integration-data/google-calendar/handlers/update_event.js +5 -0
- package/integration-data/google-calendar/manifest.json +26 -0
- package/integration-data/google-calendar/schemas/create_event.json +34 -0
- package/integration-data/google-calendar/schemas/delete_acl.json +9 -0
- package/integration-data/google-calendar/schemas/empty.json +1 -0
- package/integration-data/google-calendar/schemas/freebusy_query.json +13 -0
- package/integration-data/google-calendar/schemas/get_acl.json +9 -0
- package/integration-data/google-calendar/schemas/id_calendar.json +8 -0
- package/integration-data/google-calendar/schemas/id_calendar_event.json +9 -0
- package/integration-data/google-calendar/schemas/insert_acl.json +18 -0
- package/integration-data/google-calendar/schemas/list_events.json +15 -0
- package/integration-data/google-calendar/schemas/move_event.json +10 -0
- package/integration-data/google-calendar/schemas/patch_event.json +10 -0
- package/integration-data/google-calendar/schemas/quick_add.json +9 -0
- package/integration-data/google-calendar/schemas/update_acl.json +10 -0
- package/integration-data/google-calendar/schemas/update_event.json +10 -0
- package/integration-data/google-docs/credentials.json +36 -0
- package/integration-data/google-docs/credentials_hint.md +9 -0
- package/integration-data/google-docs/handlers/append_text.js +12 -0
- package/integration-data/google-docs/handlers/batch_update.js +13 -0
- package/integration-data/google-docs/handlers/create_document.js +9 -0
- package/integration-data/google-docs/handlers/delete_first_match.js +50 -0
- package/integration-data/google-docs/handlers/get_document.js +12 -0
- package/integration-data/google-docs/handlers/get_document_structured.js +6 -0
- package/integration-data/google-docs/handlers/get_document_text.js +17 -0
- package/integration-data/google-docs/handlers/insert_inline_image_after_first_match.js +41 -0
- package/integration-data/google-docs/handlers/insert_page_break_after_first_match.js +49 -0
- package/integration-data/google-docs/handlers/insert_table_after_first_match.js +49 -0
- package/integration-data/google-docs/handlers/insert_text_after_first_match.js +51 -0
- package/integration-data/google-docs/handlers/replace_all_text.js +8 -0
- package/integration-data/google-docs/handlers/style_first_match.js +42 -0
- package/integration-data/google-docs/handlers/update_document_style.js +8 -0
- package/integration-data/google-docs/handlers/update_paragraph_style_for_first_match.js +48 -0
- package/integration-data/google-docs/manifest.json +58 -0
- package/integration-data/google-docs/schemas/append_text.json +10 -0
- package/integration-data/google-docs/schemas/apply_text_style.json +13 -0
- package/integration-data/google-docs/schemas/batch_update.json +16 -0
- package/integration-data/google-docs/schemas/create_document.json +8 -0
- package/integration-data/google-docs/schemas/delete_content_range.json +11 -0
- package/integration-data/google-docs/schemas/delete_first_match.json +10 -0
- package/integration-data/google-docs/schemas/get_document.json +11 -0
- package/integration-data/google-docs/schemas/get_document_structured.json +9 -0
- package/integration-data/google-docs/schemas/get_document_text.json +9 -0
- package/integration-data/google-docs/schemas/insert_inline_image.json +12 -0
- package/integration-data/google-docs/schemas/insert_inline_image_after_first_match.json +13 -0
- package/integration-data/google-docs/schemas/insert_page_break.json +10 -0
- package/integration-data/google-docs/schemas/insert_page_break_after_first_match.json +11 -0
- package/integration-data/google-docs/schemas/insert_table.json +12 -0
- package/integration-data/google-docs/schemas/insert_table_after_first_match.json +13 -0
- package/integration-data/google-docs/schemas/insert_text_after_first_match.json +12 -0
- package/integration-data/google-docs/schemas/insert_text_at.json +11 -0
- package/integration-data/google-docs/schemas/replace_all_text.json +12 -0
- package/integration-data/google-docs/schemas/style_first_match.json +12 -0
- package/integration-data/google-docs/schemas/update_document_style.json +11 -0
- package/integration-data/google-docs/schemas/update_paragraph_style.json +13 -0
- package/integration-data/google-docs/schemas/update_paragraph_style_for_first_match.json +12 -0
- package/integration-data/google-sheet/credentials.json +36 -0
- package/integration-data/google-sheet/credentials_hint.md +9 -0
- package/integration-data/google-sheet/handlers/append_values.js +18 -0
- package/integration-data/google-sheet/handlers/batch_clear_values.js +6 -0
- package/integration-data/google-sheet/handlers/batch_clear_values_by_data_filter.js +6 -0
- package/integration-data/google-sheet/handlers/batch_get_values.js +16 -0
- package/integration-data/google-sheet/handlers/batch_update.js +14 -0
- package/integration-data/google-sheet/handlers/batch_update_values.js +16 -0
- package/integration-data/google-sheet/handlers/batch_update_values_by_data_filter.js +16 -0
- package/integration-data/google-sheet/handlers/clear_values.js +6 -0
- package/integration-data/google-sheet/handlers/copy_to_spreadsheet.js +6 -0
- package/integration-data/google-sheet/handlers/create_spreadsheet.js +5 -0
- package/integration-data/google-sheet/handlers/get_developer_metadata.js +6 -0
- package/integration-data/google-sheet/handlers/get_spreadsheet.js +12 -0
- package/integration-data/google-sheet/handlers/get_spreadsheet_by_data_filter.js +10 -0
- package/integration-data/google-sheet/handlers/get_values.js +14 -0
- package/integration-data/google-sheet/handlers/get_values_by_data_filter.js +14 -0
- package/integration-data/google-sheet/handlers/search_developer_metadata.js +7 -0
- package/integration-data/google-sheet/handlers/update_values.js +16 -0
- package/integration-data/google-sheet/manifest.json +125 -0
- package/integration-data/google-sheet/schemas/append_values.json +16 -0
- package/integration-data/google-sheet/schemas/batch_clear_values.json +10 -0
- package/integration-data/google-sheet/schemas/batch_clear_values_by_data_filter.json +10 -0
- package/integration-data/google-sheet/schemas/batch_get_values.json +13 -0
- package/integration-data/google-sheet/schemas/batch_update.json +13 -0
- package/integration-data/google-sheet/schemas/batch_update_values.json +25 -0
- package/integration-data/google-sheet/schemas/batch_update_values_by_data_filter.json +25 -0
- package/integration-data/google-sheet/schemas/clear_values.json +10 -0
- package/integration-data/google-sheet/schemas/copy_to_spreadsheet.json +11 -0
- package/integration-data/google-sheet/schemas/create_spreadsheet.json +11 -0
- package/integration-data/google-sheet/schemas/get_developer_metadata.json +10 -0
- package/integration-data/google-sheet/schemas/get_spreadsheet.json +15 -0
- package/integration-data/google-sheet/schemas/get_spreadsheet_by_data_filter.json +11 -0
- package/integration-data/google-sheet/schemas/get_values.json +13 -0
- package/integration-data/google-sheet/schemas/get_values_by_data_filter.json +17 -0
- package/integration-data/google-sheet/schemas/search_developer_metadata.json +14 -0
- package/integration-data/google-sheet/schemas/update_values.json +15 -0
- package/integration-data/google-slides/credentials.json +36 -0
- package/integration-data/google-slides/credentials_hint.md +9 -0
- package/integration-data/google-slides/handlers/append_text_to_title_of_first_slide.js +17 -0
- package/integration-data/google-slides/handlers/batch_update.js +15 -0
- package/integration-data/google-slides/handlers/create_presentation.js +8 -0
- package/integration-data/google-slides/handlers/create_slide_after_first_match.js +20 -0
- package/integration-data/google-slides/handlers/get_page_thumbnail.js +12 -0
- package/integration-data/google-slides/handlers/get_presentation.js +6 -0
- package/integration-data/google-slides/handlers/insert_image_after_first_match.js +19 -0
- package/integration-data/google-slides/handlers/insert_shape_after_first_match.js +21 -0
- package/integration-data/google-slides/handlers/replace_text_first_match.js +9 -0
- package/integration-data/google-slides/handlers/set_background_color_for_slide_index.js +15 -0
- package/integration-data/google-slides/handlers/style_text_first_match.js +48 -0
- package/integration-data/google-slides/manifest.json +41 -0
- package/integration-data/google-slides/schemas/append_text_to_title_of_first_slide.json +11 -0
- package/integration-data/google-slides/schemas/batch_update.json +13 -0
- package/integration-data/google-slides/schemas/create_presentation.json +8 -0
- package/integration-data/google-slides/schemas/create_slide_after_first_match.json +11 -0
- package/integration-data/google-slides/schemas/get_page_thumbnail.json +12 -0
- package/integration-data/google-slides/schemas/get_presentation.json +9 -0
- package/integration-data/google-slides/schemas/insert_image_after_first_match.json +13 -0
- package/integration-data/google-slides/schemas/insert_shape_after_first_match.json +13 -0
- package/integration-data/google-slides/schemas/replace_text_first_match.json +12 -0
- package/integration-data/google-slides/schemas/set_background_color_for_slide_index.json +11 -0
- package/integration-data/google-slides/schemas/style_text_first_match.json +12 -0
- package/integration-data/new_integration_prompt.md +41 -0
- package/integration-data/notion/credentials.json +21 -0
- package/integration-data/notion/credentials_hint.md +5 -0
- package/integration-data/notion/handlers/append_block_children.js +7 -0
- package/integration-data/notion/handlers/create_comment.js +10 -0
- package/integration-data/notion/handlers/create_database.js +11 -0
- package/integration-data/notion/handlers/create_page.js +13 -0
- package/integration-data/notion/handlers/delete_block.js +8 -0
- package/integration-data/notion/handlers/get_me.js +4 -0
- package/integration-data/notion/handlers/list_block_children.js +10 -0
- package/integration-data/notion/handlers/list_comments.js +14 -0
- package/integration-data/notion/handlers/list_users.js +10 -0
- package/integration-data/notion/handlers/query_database.js +10 -0
- package/integration-data/notion/handlers/retrieve_block.js +4 -0
- package/integration-data/notion/handlers/retrieve_database.js +4 -0
- package/integration-data/notion/handlers/retrieve_page.js +4 -0
- package/integration-data/notion/handlers/retrieve_page_property_item.js +10 -0
- package/integration-data/notion/handlers/retrieve_user.js +4 -0
- package/integration-data/notion/handlers/search.js +11 -0
- package/integration-data/notion/handlers/update_block.js +7 -0
- package/integration-data/notion/handlers/update_database.js +10 -0
- package/integration-data/notion/handlers/update_page_properties.js +10 -0
- package/integration-data/notion/manifest.json +139 -0
- package/integration-data/notion/prompt.md +26 -0
- package/integration-data/notion/schemas/append_block_children.json +10 -0
- package/integration-data/notion/schemas/create_comment.json +18 -0
- package/integration-data/notion/schemas/create_database.json +18 -0
- package/integration-data/notion/schemas/create_page.json +22 -0
- package/integration-data/notion/schemas/delete_block.json +9 -0
- package/integration-data/notion/schemas/empty.json +6 -0
- package/integration-data/notion/schemas/id_block.json +9 -0
- package/integration-data/notion/schemas/id_database.json +9 -0
- package/integration-data/notion/schemas/id_page.json +9 -0
- package/integration-data/notion/schemas/id_user.json +9 -0
- package/integration-data/notion/schemas/list_block_children.json +11 -0
- package/integration-data/notion/schemas/list_comments.json +15 -0
- package/integration-data/notion/schemas/list_users.json +9 -0
- package/integration-data/notion/schemas/query_database.json +13 -0
- package/integration-data/notion/schemas/retrieve_page_property_item.json +12 -0
- package/integration-data/notion/schemas/search.json +27 -0
- package/integration-data/notion/schemas/update_block.json +10 -0
- package/integration-data/notion/schemas/update_database.json +13 -0
- package/integration-data/notion/schemas/update_page_properties.json +13 -0
- package/integration-data/trello/credentials.json +26 -0
- package/integration-data/trello/credentials_hint.md +4 -0
- package/integration-data/trello/handlers/add_checklist_to_card.js +5 -0
- package/integration-data/trello/handlers/add_member_to_card.js +5 -0
- package/integration-data/trello/handlers/archive_list.js +5 -0
- package/integration-data/trello/handlers/create_card.js +13 -0
- package/integration-data/trello/handlers/create_list.js +7 -0
- package/integration-data/trello/handlers/delete_card.js +9 -0
- package/integration-data/trello/handlers/get_board.js +4 -0
- package/integration-data/trello/handlers/get_board_cards.js +4 -0
- package/integration-data/trello/handlers/get_board_custom_fields.js +4 -0
- package/integration-data/trello/handlers/get_board_labels.js +4 -0
- package/integration-data/trello/handlers/get_board_lists.js +4 -0
- package/integration-data/trello/handlers/get_board_members.js +4 -0
- package/integration-data/trello/handlers/get_board_memberships.js +4 -0
- package/integration-data/trello/handlers/get_card.js +4 -0
- package/integration-data/trello/handlers/get_card_actions.js +4 -0
- package/integration-data/trello/handlers/get_card_attachments.js +4 -0
- package/integration-data/trello/handlers/get_card_checklists.js +4 -0
- package/integration-data/trello/handlers/get_card_custom_field_items.js +4 -0
- package/integration-data/trello/handlers/get_card_members.js +4 -0
- package/integration-data/trello/handlers/get_list.js +4 -0
- package/integration-data/trello/handlers/get_list_cards.js +4 -0
- package/integration-data/trello/handlers/get_member.js +4 -0
- package/integration-data/trello/handlers/get_member_boards.js +4 -0
- package/integration-data/trello/handlers/get_member_organizations.js +4 -0
- package/integration-data/trello/handlers/get_organization.js +4 -0
- package/integration-data/trello/handlers/get_organization_boards.js +4 -0
- package/integration-data/trello/handlers/move_card_to_list.js +5 -0
- package/integration-data/trello/handlers/remove_member_from_card.js +9 -0
- package/integration-data/trello/handlers/search.js +5 -0
- package/integration-data/trello/handlers/update_card.js +19 -0
- package/integration-data/trello/handlers/update_list.js +11 -0
- package/integration-data/trello/manifest.json +231 -0
- package/integration-data/trello/schemas/add_checklist_to_card.json +10 -0
- package/integration-data/trello/schemas/add_member_to_card.json +10 -0
- package/integration-data/trello/schemas/archive_list.json +9 -0
- package/integration-data/trello/schemas/create_card.json +13 -0
- package/integration-data/trello/schemas/create_list.json +11 -0
- package/integration-data/trello/schemas/delete_card.json +9 -0
- package/integration-data/trello/schemas/display_trello_cards.json +45 -0
- package/integration-data/trello/schemas/empty.json +5 -0
- package/integration-data/trello/schemas/get_member.json +5 -0
- package/integration-data/trello/schemas/id_board.json +8 -0
- package/integration-data/trello/schemas/id_card.json +8 -0
- package/integration-data/trello/schemas/id_list.json +8 -0
- package/integration-data/trello/schemas/id_org.json +8 -0
- package/integration-data/trello/schemas/move_card_to_list.json +10 -0
- package/integration-data/trello/schemas/remove_member_from_card.json +10 -0
- package/integration-data/trello/schemas/search.json +8 -0
- package/integration-data/trello/schemas/update_card.json +16 -0
- package/integration-data/trello/schemas/update_list.json +12 -0
- package/package.json +61 -0
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "ranges"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"ranges": { "type": "array", "items": { "type": "string" } }
|
|
8
|
+
},
|
|
9
|
+
"additionalProperties": false
|
|
10
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "dataFilters"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"dataFilters": { "type": "array", "items": { "type": "object" } }
|
|
8
|
+
},
|
|
9
|
+
"additionalProperties": false
|
|
10
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "ranges"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"ranges": { "type": "array", "items": { "type": "string" } },
|
|
8
|
+
"majorDimension": { "type": "string", "enum": ["ROWS", "COLUMNS"] },
|
|
9
|
+
"valueRenderOption": { "type": "string", "enum": ["FORMATTED_VALUE", "UNFORMATTED_VALUE", "FORMULA"] },
|
|
10
|
+
"dateTimeRenderOption": { "type": "string", "enum": ["SERIAL_NUMBER", "FORMATTED_STRING"] }
|
|
11
|
+
},
|
|
12
|
+
"additionalProperties": false
|
|
13
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "requests"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"requests": { "type": "array", "items": { "type": "object" } },
|
|
8
|
+
"includeSpreadsheetInResponse": { "type": "boolean" },
|
|
9
|
+
"responseRanges": { "type": "array", "items": { "type": "string" } },
|
|
10
|
+
"responseIncludeGridData": { "type": "boolean" }
|
|
11
|
+
},
|
|
12
|
+
"additionalProperties": true
|
|
13
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "data"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"data": {
|
|
8
|
+
"type": "array",
|
|
9
|
+
"items": {
|
|
10
|
+
"type": "object",
|
|
11
|
+
"required": ["range", "values"],
|
|
12
|
+
"properties": {
|
|
13
|
+
"range": { "type": "string" },
|
|
14
|
+
"values": { "type": "array", "items": { "type": "array", "items": {} } },
|
|
15
|
+
"majorDimension": { "type": "string", "enum": ["ROWS", "COLUMNS"] }
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
"valueInputOption": { "type": "string", "enum": ["RAW", "USER_ENTERED"] },
|
|
20
|
+
"includeValuesInResponse": { "type": "boolean" },
|
|
21
|
+
"responseValueRenderOption": { "type": "string", "enum": ["FORMATTED_VALUE", "UNFORMATTED_VALUE", "FORMULA"] },
|
|
22
|
+
"responseDateTimeRenderOption": { "type": "string", "enum": ["SERIAL_NUMBER", "FORMATTED_STRING"] }
|
|
23
|
+
},
|
|
24
|
+
"additionalProperties": false
|
|
25
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "data"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"data": {
|
|
8
|
+
"type": "array",
|
|
9
|
+
"items": {
|
|
10
|
+
"type": "object",
|
|
11
|
+
"required": ["dataFilter", "values"],
|
|
12
|
+
"properties": {
|
|
13
|
+
"dataFilter": { "type": "object" },
|
|
14
|
+
"values": { "type": "array", "items": { "type": "array", "items": {} } },
|
|
15
|
+
"majorDimension": { "type": "string", "enum": ["ROWS", "COLUMNS"] }
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
"valueInputOption": { "type": "string", "enum": ["RAW", "USER_ENTERED"] },
|
|
20
|
+
"includeValuesInResponse": { "type": "boolean" },
|
|
21
|
+
"responseValueRenderOption": { "type": "string", "enum": ["FORMATTED_VALUE", "UNFORMATTED_VALUE", "FORMULA"] },
|
|
22
|
+
"responseDateTimeRenderOption": { "type": "string", "enum": ["SERIAL_NUMBER", "FORMATTED_STRING"] }
|
|
23
|
+
},
|
|
24
|
+
"additionalProperties": false
|
|
25
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "sheetId", "destinationSpreadsheetId"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string", "description": "Source spreadsheet ID" },
|
|
7
|
+
"sheetId": { "type": "integer", "description": "Source sheet numeric ID" },
|
|
8
|
+
"destinationSpreadsheetId": { "type": "string", "description": "Destination spreadsheet ID" }
|
|
9
|
+
},
|
|
10
|
+
"additionalProperties": false
|
|
11
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"properties": {
|
|
5
|
+
"properties": { "type": "object", "description": "Spreadsheet properties" },
|
|
6
|
+
"sheets": { "type": "array", "items": { "type": "object" } },
|
|
7
|
+
"namedRanges": { "type": "array", "items": { "type": "object" } },
|
|
8
|
+
"dataSources": { "type": "array", "items": { "type": "object" } }
|
|
9
|
+
},
|
|
10
|
+
"additionalProperties": true
|
|
11
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "metadataId"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"metadataId": { "type": "integer" }
|
|
8
|
+
},
|
|
9
|
+
"additionalProperties": false
|
|
10
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string", "description": "ID of the spreadsheet" },
|
|
7
|
+
"includeGridData": { "type": "boolean", "description": "Whether to include grid data" },
|
|
8
|
+
"ranges": {
|
|
9
|
+
"type": "array",
|
|
10
|
+
"items": { "type": "string" },
|
|
11
|
+
"description": "Optional A1 ranges to include"
|
|
12
|
+
}
|
|
13
|
+
},
|
|
14
|
+
"additionalProperties": false
|
|
15
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"dataFilters": { "type": "array", "items": { "type": "object" } },
|
|
8
|
+
"includeGridData": { "type": "boolean" }
|
|
9
|
+
},
|
|
10
|
+
"additionalProperties": true
|
|
11
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "range"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"range": { "type": "string", "description": "A1 notation range" },
|
|
8
|
+
"majorDimension": { "type": "string", "enum": ["ROWS", "COLUMNS"], "description": "Return values by rows or columns" },
|
|
9
|
+
"valueRenderOption": { "type": "string", "enum": ["FORMATTED_VALUE", "UNFORMATTED_VALUE", "FORMULA"] },
|
|
10
|
+
"dateTimeRenderOption": { "type": "string", "enum": ["SERIAL_NUMBER", "FORMATTED_STRING"] }
|
|
11
|
+
},
|
|
12
|
+
"additionalProperties": false
|
|
13
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "dataFilters"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"dataFilters": {
|
|
8
|
+
"type": "array",
|
|
9
|
+
"items": { "type": "object" },
|
|
10
|
+
"description": "Array of DataFilter objects per Sheets API"
|
|
11
|
+
},
|
|
12
|
+
"majorDimension": { "type": "string", "enum": ["ROWS", "COLUMNS"] },
|
|
13
|
+
"valueRenderOption": { "type": "string", "enum": ["FORMATTED_VALUE", "UNFORMATTED_VALUE", "FORMULA"] },
|
|
14
|
+
"dateTimeRenderOption": { "type": "string", "enum": ["SERIAL_NUMBER", "FORMATTED_STRING"] }
|
|
15
|
+
},
|
|
16
|
+
"additionalProperties": false
|
|
17
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "dataFilters"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"dataFilters": {
|
|
8
|
+
"type": "array",
|
|
9
|
+
"items": { "type": "object" },
|
|
10
|
+
"description": "DeveloperMetadataLookup wrapped in DataFilter objects"
|
|
11
|
+
}
|
|
12
|
+
},
|
|
13
|
+
"additionalProperties": false
|
|
14
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "range", "values"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"range": { "type": "string" },
|
|
8
|
+
"values": { "type": "array", "items": { "type": "array", "items": {} } },
|
|
9
|
+
"valueInputOption": { "type": "string", "enum": ["RAW", "USER_ENTERED"] },
|
|
10
|
+
"includeValuesInResponse": { "type": "boolean" },
|
|
11
|
+
"responseValueRenderOption": { "type": "string", "enum": ["FORMATTED_VALUE", "UNFORMATTED_VALUE", "FORMULA"] },
|
|
12
|
+
"responseDateTimeRenderOption": { "type": "string", "enum": ["SERIAL_NUMBER", "FORMATTED_STRING"] }
|
|
13
|
+
},
|
|
14
|
+
"additionalProperties": false
|
|
15
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
{
|
|
2
|
+
"schema": {
|
|
3
|
+
"type": "object",
|
|
4
|
+
"properties": {
|
|
5
|
+
"token": {
|
|
6
|
+
"type": "string",
|
|
7
|
+
"title": "OAuth Access Token (optional)",
|
|
8
|
+
"description": "Google OAuth access token to use as a Bearer token (typically short-lived)."
|
|
9
|
+
},
|
|
10
|
+
"serviceAccountJson": {
|
|
11
|
+
"type": "string",
|
|
12
|
+
"title": "Service Account JSON (recommended)",
|
|
13
|
+
"description": "Full service account key JSON (contents of the downloaded JSON file)."
|
|
14
|
+
},
|
|
15
|
+
"subject": {
|
|
16
|
+
"type": "string",
|
|
17
|
+
"title": "Subject / impersonated user (optional)",
|
|
18
|
+
"description": "Optional user email to impersonate when using Google Workspace domain-wide delegation."
|
|
19
|
+
},
|
|
20
|
+
"scopes": {
|
|
21
|
+
"type": "array",
|
|
22
|
+
"title": "OAuth scopes (optional)",
|
|
23
|
+
"description": "Optional override for OAuth scopes.",
|
|
24
|
+
"items": { "type": "string" }
|
|
25
|
+
}
|
|
26
|
+
},
|
|
27
|
+
"required": [],
|
|
28
|
+
"additionalProperties": false
|
|
29
|
+
},
|
|
30
|
+
"injection": {
|
|
31
|
+
"headers": {
|
|
32
|
+
"Authorization": "Bearer {{token}}"
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
Recommended: use a Google service account.
|
|
2
|
+
|
|
3
|
+
- Create a service account in Google Cloud
|
|
4
|
+
- Download a JSON key
|
|
5
|
+
- Paste the JSON into `serviceAccountJson` (or use `env:GOOGLE_SERVICE_ACCOUNT_JSON`)
|
|
6
|
+
- Share your test presentation with the service account `client_email`
|
|
7
|
+
|
|
8
|
+
You can also paste a short-lived OAuth access token into `token`, but it will expire.
|
|
9
|
+
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
async (input) => {
|
|
2
|
+
const { presentationId, text, slideIndex = 0 } = input
|
|
3
|
+
const presRes = await integration.fetch(`/presentations/${encodeURIComponent(presentationId)}`)
|
|
4
|
+
const pres = await presRes.json()
|
|
5
|
+
const slide = (pres?.slides || [])[slideIndex]
|
|
6
|
+
if (!slide)
|
|
7
|
+
return { presentationId, applied: false, replies: [] }
|
|
8
|
+
const titleShape = (slide.pageElements || []).find(el => el.shape?.placeholder?.type === 'TITLE')
|
|
9
|
+
if (!titleShape?.objectId)
|
|
10
|
+
return { presentationId, applied: false, replies: [] }
|
|
11
|
+
const res = await integration.fetch(`/presentations/${encodeURIComponent(presentationId)}:batchUpdate`, {
|
|
12
|
+
method: 'POST',
|
|
13
|
+
body: { requests: [{ insertText: { objectId: titleShape.objectId, insertionIndex: -1, text } }] },
|
|
14
|
+
})
|
|
15
|
+
const out = await res.json()
|
|
16
|
+
return out?.presentationId ? { ...out, applied: true } : { presentationId, applied: true, replies: out?.replies || [] }
|
|
17
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
async (input) => {
|
|
2
|
+
const { presentationId, requests, includePresentationInResponse, responsePageObjectIds, writeControl } = input
|
|
3
|
+
const params = new URLSearchParams()
|
|
4
|
+
if (includePresentationInResponse !== undefined)
|
|
5
|
+
params.set('includePresentationInResponse', String(includePresentationInResponse))
|
|
6
|
+
if (Array.isArray(responsePageObjectIds))
|
|
7
|
+
responsePageObjectIds.forEach(id => params.append('responsePageObjectIds', String(id)))
|
|
8
|
+
const qs = params.toString()
|
|
9
|
+
const path = `/presentations/${encodeURIComponent(presentationId)}:batchUpdate${qs ? `?${qs}` : ''}`
|
|
10
|
+
const body = { requests }
|
|
11
|
+
if (writeControl)
|
|
12
|
+
body.writeControl = writeControl
|
|
13
|
+
const res = await integration.fetch(path, { method: 'POST', body })
|
|
14
|
+
return await res.json()
|
|
15
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
async (input) => {
|
|
2
|
+
const { presentationId, findText, layout = 'BLANK' } = input
|
|
3
|
+
const presRes = await integration.fetch(`/presentations/${encodeURIComponent(presentationId)}`)
|
|
4
|
+
const pres = await presRes.json()
|
|
5
|
+
let targetSlideId = null
|
|
6
|
+
for (const slide of (pres?.slides || [])) {
|
|
7
|
+
const text = JSON.stringify(slide)
|
|
8
|
+
if (text && text.includes(findText)) { targetSlideId = slide.objectId; break }
|
|
9
|
+
}
|
|
10
|
+
if (!targetSlideId)
|
|
11
|
+
return { presentationId, applied: false, replies: [] }
|
|
12
|
+
const newSlideId = `slide_${Date.now()}`
|
|
13
|
+
const currentIndex = (pres?.slides || []).findIndex(s => s.objectId === targetSlideId)
|
|
14
|
+
const requests = [
|
|
15
|
+
{ createSlide: { objectId: newSlideId, insertionIndex: currentIndex >= 0 ? currentIndex + 1 : (pres?.slides?.length || 0), slideLayoutReference: { predefinedLayout: layout } } },
|
|
16
|
+
]
|
|
17
|
+
const res = await integration.fetch(`/presentations/${encodeURIComponent(presentationId)}:batchUpdate`, { method: 'POST', body: { requests } })
|
|
18
|
+
const out = await res.json()
|
|
19
|
+
return out?.presentationId ? { ...out, applied: true } : { presentationId, applied: true, replies: out?.replies || [] }
|
|
20
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
async (input) => {
|
|
2
|
+
const { presentationId, pageObjectId } = input
|
|
3
|
+
const params = new URLSearchParams()
|
|
4
|
+
if (input['thumbnailProperties.thumbnailSize'])
|
|
5
|
+
params.set('thumbnailProperties.thumbnailSize', String(input['thumbnailProperties.thumbnailSize']))
|
|
6
|
+
if (input['thumbnailProperties.mimeType'])
|
|
7
|
+
params.set('thumbnailProperties.mimeType', String(input['thumbnailProperties.mimeType']))
|
|
8
|
+
const qs = params.toString()
|
|
9
|
+
const path = `/presentations/${encodeURIComponent(presentationId)}/pages/${encodeURIComponent(pageObjectId)}/thumbnail${qs ? `?${qs}` : ''}`
|
|
10
|
+
const res = await integration.fetch(path)
|
|
11
|
+
return await res.json()
|
|
12
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
async (input) => {
|
|
2
|
+
const { presentationId, findText, uri, width = 2000000, height = 2000000 } = input
|
|
3
|
+
const presRes = await integration.fetch(`/presentations/${encodeURIComponent(presentationId)}`)
|
|
4
|
+
const pres = await presRes.json()
|
|
5
|
+
let targetSlideId = null
|
|
6
|
+
for (const slide of (pres?.slides || [])) {
|
|
7
|
+
const text = JSON.stringify(slide)
|
|
8
|
+
if (text && text.includes(findText)) { targetSlideId = slide.objectId; break }
|
|
9
|
+
}
|
|
10
|
+
if (!targetSlideId)
|
|
11
|
+
return { presentationId, applied: false, replies: [] }
|
|
12
|
+
const elementId = `image_${Date.now()}`
|
|
13
|
+
const requests = [
|
|
14
|
+
{ createImage: { objectId: elementId, url: uri, elementProperties: { pageObjectId: targetSlideId, size: { width: { magnitude: width, unit: 'EMU' }, height: { magnitude: height, unit: 'EMU' } }, transform: { scaleX: 1, scaleY: 1, translateX: 1000000, translateY: 1000000, unit: 'EMU' } } } },
|
|
15
|
+
]
|
|
16
|
+
const res = await integration.fetch(`/presentations/${encodeURIComponent(presentationId)}:batchUpdate`, { method: 'POST', body: { requests } })
|
|
17
|
+
const out = await res.json()
|
|
18
|
+
return out?.presentationId ? { ...out, applied: true } : { presentationId, applied: true, replies: out?.replies || [] }
|
|
19
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
async (input) => {
|
|
2
|
+
const { presentationId, findText, shapeType = 'RECTANGLE', width = 2000000, height = 1000000 } = input
|
|
3
|
+
const presRes = await integration.fetch(`/presentations/${encodeURIComponent(presentationId)}`)
|
|
4
|
+
const pres = await presRes.json()
|
|
5
|
+
// Find slide with first text match
|
|
6
|
+
let targetSlideId = null
|
|
7
|
+
for (const slide of (pres?.slides || [])) {
|
|
8
|
+
const text = JSON.stringify(slide)
|
|
9
|
+
if (text && text.includes(findText)) { targetSlideId = slide.objectId; break }
|
|
10
|
+
}
|
|
11
|
+
if (!targetSlideId)
|
|
12
|
+
return { presentationId, applied: false, replies: [] }
|
|
13
|
+
// Insert a shape at a default position near center
|
|
14
|
+
const elementId = `shape_${Date.now()}`
|
|
15
|
+
const requests = [
|
|
16
|
+
{ createShape: { objectId: elementId, shapeType, elementProperties: { pageObjectId: targetSlideId, size: { width: { magnitude: width, unit: 'EMU' }, height: { magnitude: height, unit: 'EMU' } }, transform: { scaleX: 1, scaleY: 1, translateX: 1000000, translateY: 1000000, unit: 'EMU' } } } },
|
|
17
|
+
]
|
|
18
|
+
const res = await integration.fetch(`/presentations/${encodeURIComponent(presentationId)}:batchUpdate`, { method: 'POST', body: { requests } })
|
|
19
|
+
const out = await res.json()
|
|
20
|
+
return out?.presentationId ? { ...out, applied: true } : { presentationId, applied: true, replies: out?.replies || [] }
|
|
21
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
async (input) => {
|
|
2
|
+
const { presentationId, findText, replaceText, matchCase } = input
|
|
3
|
+
const res = await integration.fetch(`/presentations/${encodeURIComponent(presentationId)}:batchUpdate`, {
|
|
4
|
+
method: 'POST',
|
|
5
|
+
body: { requests: [{ replaceAllText: { containsText: { text: findText, matchCase: Boolean(matchCase) }, replaceText } }] },
|
|
6
|
+
})
|
|
7
|
+
const out = await res.json()
|
|
8
|
+
return out?.presentationId ? { ...out, applied: true } : { presentationId, applied: true, replies: out?.replies || [] }
|
|
9
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
async (input) => {
|
|
2
|
+
const { presentationId, slideIndex, rgbColor } = input
|
|
3
|
+
const presRes = await integration.fetch(`/presentations/${encodeURIComponent(presentationId)}`)
|
|
4
|
+
const pres = await presRes.json()
|
|
5
|
+
const slide = (pres?.slides || [])[slideIndex]
|
|
6
|
+
if (!slide?.objectId)
|
|
7
|
+
return { presentationId, applied: false, replies: [] }
|
|
8
|
+
const color = { color: { rgbColor } }
|
|
9
|
+
const res = await integration.fetch(`/presentations/${encodeURIComponent(presentationId)}:batchUpdate`, {
|
|
10
|
+
method: 'POST',
|
|
11
|
+
body: { requests: [{ updatePageProperties: { objectId: slide.objectId, pageProperties: { pageBackgroundFill: { solidFill: color } }, fields: 'pageBackgroundFill.solidFill.color' } }] },
|
|
12
|
+
})
|
|
13
|
+
const out = await res.json()
|
|
14
|
+
return out?.presentationId ? { ...out, applied: true } : { presentationId, applied: true, replies: out?.replies || [] }
|
|
15
|
+
}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
async (input) => {
|
|
2
|
+
const { presentationId, findText, textStyle, fields } = input
|
|
3
|
+
// Replace first match with a marker to derive objectId/range
|
|
4
|
+
const marker = `__CMD_MARK_${Date.now()}__`
|
|
5
|
+
const rep = await integration.fetch(`/presentations/${encodeURIComponent(presentationId)}:batchUpdate`, {
|
|
6
|
+
method: 'POST',
|
|
7
|
+
body: { requests: [{ replaceAllText: { containsText: { text: findText, matchCase: false }, replaceText: marker } }] },
|
|
8
|
+
})
|
|
9
|
+
await rep.json()
|
|
10
|
+
// Scan pages for marker and apply style to that range on the text element
|
|
11
|
+
const presRes = await integration.fetch(`/presentations/${encodeURIComponent(presentationId)}`)
|
|
12
|
+
const pres = await presRes.json()
|
|
13
|
+
let targetObjectId = null
|
|
14
|
+
let startIndex = -1
|
|
15
|
+
let endIndex = -1
|
|
16
|
+
for (const slide of (pres?.slides || [])) {
|
|
17
|
+
for (const el of (slide.pageElements || [])) {
|
|
18
|
+
const text = el.shape?.text
|
|
19
|
+
if (!text)
|
|
20
|
+
continue
|
|
21
|
+
for (const pe of (text.textElements || [])) {
|
|
22
|
+
const t = pe.textRun?.content
|
|
23
|
+
if (!t)
|
|
24
|
+
continue
|
|
25
|
+
const idx = t.indexOf(marker)
|
|
26
|
+
if (idx >= 0) {
|
|
27
|
+
targetObjectId = el.objectId
|
|
28
|
+
startIndex = (pe.startIndex || 0) + idx
|
|
29
|
+
endIndex = startIndex + marker.length
|
|
30
|
+
break
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
if (targetObjectId)
|
|
34
|
+
break
|
|
35
|
+
}
|
|
36
|
+
if (targetObjectId)
|
|
37
|
+
break
|
|
38
|
+
}
|
|
39
|
+
if (!targetObjectId)
|
|
40
|
+
return { presentationId, applied: false, replies: [] }
|
|
41
|
+
const requests = [
|
|
42
|
+
{ updateTextStyle: { objectId: targetObjectId, style: textStyle, textRange: { type: 'FIXED_RANGE', startIndex, endIndex }, fields: fields || Object.keys(textStyle || {}).join(',') } },
|
|
43
|
+
{ replaceAllText: { containsText: { text: marker, matchCase: true }, replaceText: findText } },
|
|
44
|
+
]
|
|
45
|
+
const res = await integration.fetch(`/presentations/${encodeURIComponent(presentationId)}:batchUpdate`, { method: 'POST', body: { requests } })
|
|
46
|
+
const out = await res.json()
|
|
47
|
+
return out?.presentationId ? { ...out, applied: true } : { presentationId, applied: true, replies: out?.replies || [] }
|
|
48
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "google-slides",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"tools": [
|
|
5
|
+
{
|
|
6
|
+
"name": "get_presentation",
|
|
7
|
+
"description": "Retrieve presentation metadata, including slides/pages and elements.",
|
|
8
|
+
"inputSchema": "schemas/get_presentation.json",
|
|
9
|
+
"handler": "handlers/get_presentation.js",
|
|
10
|
+
"scope": "read"
|
|
11
|
+
},
|
|
12
|
+
{
|
|
13
|
+
"name": "get_page_thumbnail",
|
|
14
|
+
"description": "Get a thumbnail image for a page (slide) in a presentation.",
|
|
15
|
+
"inputSchema": "schemas/get_page_thumbnail.json",
|
|
16
|
+
"handler": "handlers/get_page_thumbnail.js",
|
|
17
|
+
"scope": "read"
|
|
18
|
+
},
|
|
19
|
+
{
|
|
20
|
+
"name": "create_presentation",
|
|
21
|
+
"description": "Create a new presentation with optional initial title.",
|
|
22
|
+
"inputSchema": "schemas/create_presentation.json",
|
|
23
|
+
"handler": "handlers/create_presentation.js",
|
|
24
|
+
"scope": "write"
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
"name": "batch_update",
|
|
28
|
+
"description": "Send a batchUpdate request to modify presentation structure and content.",
|
|
29
|
+
"inputSchema": "schemas/batch_update.json",
|
|
30
|
+
"handler": "handlers/batch_update.js",
|
|
31
|
+
"scope": "write"
|
|
32
|
+
},
|
|
33
|
+
{ "name": "append_text_to_title_of_slide_index", "description": "Append text to the title shape of the specified slide (slideIndex, default 0).", "inputSchema": "schemas/append_text_to_title_of_first_slide.json", "handler": "handlers/append_text_to_title_of_first_slide.js", "scope": "write" },
|
|
34
|
+
{ "name": "replace_text_first_match", "description": "Replace text for the first match anywhere in the presentation.", "inputSchema": "schemas/replace_text_first_match.json", "handler": "handlers/replace_text_first_match.js", "scope": "write" },
|
|
35
|
+
{ "name": "style_text_first_match", "description": "Apply text style to the first match of given text.", "inputSchema": "schemas/style_text_first_match.json", "handler": "handlers/style_text_first_match.js", "scope": "write" },
|
|
36
|
+
{ "name": "insert_shape_after_first_match", "description": "Insert a rectangle shape near the first match of text on a slide.", "inputSchema": "schemas/insert_shape_after_first_match.json", "handler": "handlers/insert_shape_after_first_match.js", "scope": "write" },
|
|
37
|
+
{ "name": "insert_image_after_first_match", "description": "Insert an image near the first match of text on a slide.", "inputSchema": "schemas/insert_image_after_first_match.json", "handler": "handlers/insert_image_after_first_match.js", "scope": "write" },
|
|
38
|
+
{ "name": "create_slide_after_first_match", "description": "Create a new slide after the slide that contains the first text match.", "inputSchema": "schemas/create_slide_after_first_match.json", "handler": "handlers/create_slide_after_first_match.js", "scope": "write" },
|
|
39
|
+
{ "name": "set_background_color_for_slide_index", "description": "Set background color for a slide by index.", "inputSchema": "schemas/set_background_color_for_slide_index.json", "handler": "handlers/set_background_color_for_slide_index.js", "scope": "write" }
|
|
40
|
+
]
|
|
41
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"properties": {
|
|
5
|
+
"presentationId": { "type": "string" },
|
|
6
|
+
"text": { "type": "string" },
|
|
7
|
+
"slideIndex": { "type": "number", "minimum": 0, "description": "Zero-based slide index to target (default 0)." }
|
|
8
|
+
},
|
|
9
|
+
"required": ["presentationId", "text"],
|
|
10
|
+
"additionalProperties": false
|
|
11
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["presentationId", "requests"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"presentationId": { "type": "string", "description": "ID of the presentation." },
|
|
7
|
+
"requests": { "type": "array", "items": { "type": "object" }, "description": "Array of Slides API requests." },
|
|
8
|
+
"writeControl": { "type": "object", "description": "Optional write control object." },
|
|
9
|
+
"includePresentationInResponse": { "type": "boolean" },
|
|
10
|
+
"responsePageObjectIds": { "type": "array", "items": { "type": "string" } }
|
|
11
|
+
},
|
|
12
|
+
"additionalProperties": false
|
|
13
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"properties": {
|
|
5
|
+
"presentationId": { "type": "string" },
|
|
6
|
+
"findText": { "type": "string" },
|
|
7
|
+
"layout": { "type": "string", "default": "BLANK" }
|
|
8
|
+
},
|
|
9
|
+
"required": ["presentationId", "findText"],
|
|
10
|
+
"additionalProperties": false
|
|
11
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["presentationId", "pageObjectId"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"presentationId": { "type": "string", "description": "ID of the presentation." },
|
|
7
|
+
"pageObjectId": { "type": "string", "description": "Object ID of the page (slide)." },
|
|
8
|
+
"thumbnailProperties.thumbnailSize": { "type": "string", "enum": ["THUMBNAIL_SIZE_UNSPECIFIED", "LARGE", "MEDIUM", "SMALL"], "description": "Requested size hint for the thumbnail." },
|
|
9
|
+
"thumbnailProperties.mimeType": { "type": "string", "enum": ["PNG", "JPEG"], "description": "Requested image MIME type." }
|
|
10
|
+
},
|
|
11
|
+
"additionalProperties": false
|
|
12
|
+
}
|