@commandable/integration-data 0.4.0 → 0.4.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/dist/credentials-index.d.ts +7 -2
- package/dist/credentials-index.d.ts.map +1 -1
- package/dist/credentials-index.js +677 -11
- package/dist/credentials-index.js.map +1 -1
- package/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/loader.d.ts +119 -1
- package/dist/loader.d.ts.map +1 -1
- package/dist/loader.js +178 -63
- package/dist/loader.js.map +1 -1
- package/dist/tools.d.ts +1 -1
- package/dist/tools.d.ts.map +1 -1
- package/integrations/README.md +52 -0
- package/integrations/__tests__/liveHarness.ts +97 -0
- package/integrations/__tests__/usageParity.ts +54 -0
- package/integrations/airtable/.env.test.example +11 -0
- package/integrations/airtable/README.md +27 -0
- package/integrations/airtable/__tests__/get_handlers.test.ts +187 -0
- package/integrations/airtable/__tests__/usage_parity.test.ts +9 -0
- package/integrations/airtable/__tests__/write_and_admin_handlers.test.ts +116 -0
- package/integrations/airtable/credentials.json +26 -0
- package/integrations/airtable/credentials_hint.md +4 -0
- package/integrations/airtable/handlers/create_record.js +12 -0
- package/integrations/airtable/handlers/delete_record.js +7 -0
- package/integrations/airtable/handlers/get_record.js +4 -0
- package/integrations/airtable/handlers/get_table_schema.js +6 -0
- package/integrations/airtable/handlers/list_bases.js +4 -0
- package/integrations/airtable/handlers/list_records.js +25 -0
- package/integrations/airtable/handlers/list_table_fields.js +6 -0
- package/integrations/airtable/handlers/list_tables.js +4 -0
- package/integrations/airtable/handlers/list_views.js +6 -0
- package/integrations/airtable/handlers/search_records.js +6 -0
- package/integrations/airtable/handlers/update_record.js +11 -0
- package/integrations/airtable/manifest.json +84 -0
- package/integrations/airtable/schemas/create_record.json +12 -0
- package/integrations/airtable/schemas/delete_record.json +11 -0
- package/integrations/airtable/schemas/empty.json +6 -0
- package/integrations/airtable/schemas/get_record.json +11 -0
- package/integrations/airtable/schemas/id_base.json +9 -0
- package/integrations/airtable/schemas/id_base_table.json +10 -0
- package/integrations/airtable/schemas/list_records.json +26 -0
- package/integrations/airtable/schemas/search_records.json +12 -0
- package/integrations/airtable/schemas/update_record.json +13 -0
- package/integrations/confluence/.env.test.example +36 -0
- package/integrations/confluence/README.md +28 -0
- package/integrations/confluence/__tests__/get_handlers.test.ts +121 -0
- package/integrations/confluence/__tests__/usage_parity.test.ts +14 -0
- package/integrations/confluence/__tests__/write_handlers.test.ts +131 -0
- package/integrations/confluence/credentials.json +39 -0
- package/integrations/confluence/credentials_hint.md +4 -0
- package/integrations/confluence/credentials_hint_api_token.md +9 -0
- package/integrations/confluence/credentials_hint_oauth_token.md +8 -0
- package/integrations/confluence/handlers/add_comment.js +19 -0
- package/integrations/confluence/handlers/add_label.js +16 -0
- package/integrations/confluence/handlers/create_page.js +22 -0
- package/integrations/confluence/handlers/delete_page.js +17 -0
- package/integrations/confluence/handlers/get_comments.js +33 -0
- package/integrations/confluence/handlers/get_page_children.js +30 -0
- package/integrations/confluence/handlers/get_space.js +22 -0
- package/integrations/confluence/handlers/list_spaces.js +39 -0
- package/integrations/confluence/handlers/read_page.js +49 -0
- package/integrations/confluence/handlers/search_pages.js +42 -0
- package/integrations/confluence/handlers/update_page.js +42 -0
- package/integrations/confluence/manifest.json +85 -0
- package/integrations/confluence/prompt.md +55 -0
- package/integrations/confluence/schemas/add_comment.json +22 -0
- package/integrations/confluence/schemas/add_label.json +19 -0
- package/integrations/confluence/schemas/create_page.json +33 -0
- package/integrations/confluence/schemas/delete_page.json +23 -0
- package/integrations/confluence/schemas/empty.json +6 -0
- package/integrations/confluence/schemas/get_comments.json +24 -0
- package/integrations/confluence/schemas/get_page_children.json +28 -0
- package/integrations/confluence/schemas/get_space.json +18 -0
- package/integrations/confluence/schemas/list_spaces.json +36 -0
- package/integrations/confluence/schemas/read_page.json +28 -0
- package/integrations/confluence/schemas/search_pages.json +26 -0
- package/integrations/confluence/schemas/update_page.json +31 -0
- package/integrations/github/.env.test.example +17 -0
- package/integrations/github/README.md +75 -0
- package/integrations/github/__tests__/get_handlers.test.ts +305 -0
- package/integrations/github/__tests__/usage_parity.test.ts +22 -0
- package/integrations/github/__tests__/write_handlers.test.ts +496 -0
- package/integrations/github/credentials.json +47 -0
- package/integrations/github/credentials_hint.md +7 -0
- package/integrations/github/credentials_hint_classic_pat.md +8 -0
- package/integrations/github/credentials_hint_fine_grained_pat.md +9 -0
- package/integrations/github/handlers/add_labels_to_issue.js +12 -0
- package/integrations/github/handlers/close_issue.js +5 -0
- package/integrations/github/handlers/comment_on_issue.js +5 -0
- package/integrations/github/handlers/create_branch.js +33 -0
- package/integrations/github/handlers/create_commit.js +84 -0
- package/integrations/github/handlers/create_file.js +46 -0
- package/integrations/github/handlers/create_issue.js +10 -0
- package/integrations/github/handlers/create_or_update_file.js +21 -0
- package/integrations/github/handlers/create_pull_request.js +16 -0
- package/integrations/github/handlers/create_pull_request_review.js +10 -0
- package/integrations/github/handlers/create_release.js +14 -0
- package/integrations/github/handlers/create_repo.js +11 -0
- package/integrations/github/handlers/delete_branch.js +8 -0
- package/integrations/github/handlers/delete_file.js +22 -0
- package/integrations/github/handlers/delete_repo.js +6 -0
- package/integrations/github/handlers/edit_file.js +52 -0
- package/integrations/github/handlers/edit_files.js +107 -0
- package/integrations/github/handlers/fork_repo.js +10 -0
- package/integrations/github/handlers/get_commit.js +8 -0
- package/integrations/github/handlers/get_file_contents.js +21 -0
- package/integrations/github/handlers/get_issue.js +4 -0
- package/integrations/github/handlers/get_job_logs.js +6 -0
- package/integrations/github/handlers/get_latest_release.js +4 -0
- package/integrations/github/handlers/get_me.js +4 -0
- package/integrations/github/handlers/get_pull_request.js +4 -0
- package/integrations/github/handlers/get_pull_request_diff.js +8 -0
- package/integrations/github/handlers/get_repo.js +4 -0
- package/integrations/github/handlers/get_repo_tree.js +12 -0
- package/integrations/github/handlers/get_workflow_run.js +4 -0
- package/integrations/github/handlers/list_branches.js +9 -0
- package/integrations/github/handlers/list_commits.js +11 -0
- package/integrations/github/handlers/list_issue_comments.js +8 -0
- package/integrations/github/handlers/list_issues.js +11 -0
- package/integrations/github/handlers/list_labels.js +8 -0
- package/integrations/github/handlers/list_pull_request_comments.js +8 -0
- package/integrations/github/handlers/list_pull_request_files.js +8 -0
- package/integrations/github/handlers/list_pull_requests.js +13 -0
- package/integrations/github/handlers/list_releases.js +8 -0
- package/integrations/github/handlers/list_repos_install.js +4 -0
- package/integrations/github/handlers/list_repos_user.js +16 -0
- package/integrations/github/handlers/list_tags.js +8 -0
- package/integrations/github/handlers/list_workflow_runs.js +11 -0
- package/integrations/github/handlers/merge_pull_request.js +14 -0
- package/integrations/github/handlers/request_pull_request_reviewers.js +10 -0
- package/integrations/github/handlers/search_code.js +8 -0
- package/integrations/github/handlers/search_issues.js +8 -0
- package/integrations/github/handlers/search_pull_requests.js +8 -0
- package/integrations/github/handlers/search_repos.js +10 -0
- package/integrations/github/handlers/update_issue.js +15 -0
- package/integrations/github/handlers/update_pull_request.js +13 -0
- package/integrations/github/manifest.json +92 -0
- package/integrations/github/prompt.md +36 -0
- package/integrations/github/schemas/add_labels_to_issue.json +12 -0
- package/integrations/github/schemas/close_issue.json +10 -0
- package/integrations/github/schemas/comment_on_issue.json +11 -0
- package/integrations/github/schemas/create_branch.json +12 -0
- package/integrations/github/schemas/create_commit.json +25 -0
- package/integrations/github/schemas/create_file.json +13 -0
- package/integrations/github/schemas/create_issue.json +13 -0
- package/integrations/github/schemas/create_or_update_file.json +15 -0
- package/integrations/github/schemas/create_pull_request.json +15 -0
- package/integrations/github/schemas/create_pull_request_review.json +17 -0
- package/integrations/github/schemas/create_release.json +16 -0
- package/integrations/github/schemas/create_repo.json +12 -0
- package/integrations/github/schemas/delete_branch.json +10 -0
- package/integrations/github/schemas/delete_file.json +13 -0
- package/integrations/github/schemas/delete_repo.json +10 -0
- package/integrations/github/schemas/edit_file.json +26 -0
- package/integrations/github/schemas/edit_files.json +39 -0
- package/integrations/github/schemas/empty.json +5 -0
- package/integrations/github/schemas/fork_repo.json +11 -0
- package/integrations/github/schemas/get_commit.json +12 -0
- package/integrations/github/schemas/get_file_contents.json +11 -0
- package/integrations/github/schemas/get_issue.json +10 -0
- package/integrations/github/schemas/get_job_logs.json +10 -0
- package/integrations/github/schemas/get_pull_request.json +10 -0
- package/integrations/github/schemas/get_pull_request_diff.json +10 -0
- package/integrations/github/schemas/get_repo.json +9 -0
- package/integrations/github/schemas/get_repo_tree.json +12 -0
- package/integrations/github/schemas/get_workflow_run.json +10 -0
- package/integrations/github/schemas/list_branches.json +12 -0
- package/integrations/github/schemas/list_commits.json +14 -0
- package/integrations/github/schemas/list_issue_comments.json +12 -0
- package/integrations/github/schemas/list_issues.json +14 -0
- package/integrations/github/schemas/list_labels.json +11 -0
- package/integrations/github/schemas/list_pull_request_comments.json +12 -0
- package/integrations/github/schemas/list_pull_request_files.json +12 -0
- package/integrations/github/schemas/list_pull_requests.json +16 -0
- package/integrations/github/schemas/list_releases.json +11 -0
- package/integrations/github/schemas/list_tags.json +11 -0
- package/integrations/github/schemas/list_workflow_runs.json +18 -0
- package/integrations/github/schemas/merge_pull_request.json +14 -0
- package/integrations/github/schemas/owner_repo.json +9 -0
- package/integrations/github/schemas/request_pull_request_reviewers.json +20 -0
- package/integrations/github/schemas/search_code.json +10 -0
- package/integrations/github/schemas/search_issues.json +10 -0
- package/integrations/github/schemas/search_pull_requests.json +10 -0
- package/integrations/github/schemas/search_repos.json +12 -0
- package/integrations/github/schemas/update_issue.json +15 -0
- package/integrations/github/schemas/update_pull_request.json +15 -0
- package/integrations/google-calendar/.env.test.example +11 -0
- package/integrations/google-calendar/README.md +41 -0
- package/integrations/google-calendar/__tests__/get_handlers.test.ts +120 -0
- package/integrations/google-calendar/__tests__/usage_parity.test.ts +9 -0
- package/integrations/google-calendar/__tests__/write_and_admin_handlers.test.ts +155 -0
- package/integrations/google-calendar/credentials.json +59 -0
- package/integrations/google-calendar/credentials_hint.md +9 -0
- package/integrations/google-calendar/credentials_hint_oauth_token.md +8 -0
- package/integrations/google-calendar/credentials_hint_service_account.md +10 -0
- package/integrations/google-calendar/handlers/create_event.js +6 -0
- package/integrations/google-calendar/handlers/delete_acl.js +6 -0
- package/integrations/google-calendar/handlers/delete_event.js +7 -0
- package/integrations/google-calendar/handlers/freebusy_query.js +4 -0
- package/integrations/google-calendar/handlers/get_acl.js +5 -0
- package/integrations/google-calendar/handlers/get_calendar.js +4 -0
- package/integrations/google-calendar/handlers/get_event.js +9 -0
- package/integrations/google-calendar/handlers/insert_acl.js +6 -0
- package/integrations/google-calendar/handlers/list_acl.js +5 -0
- package/integrations/google-calendar/handlers/list_calendars.js +4 -0
- package/integrations/google-calendar/handlers/list_colors.js +4 -0
- package/integrations/google-calendar/handlers/list_events.js +23 -0
- package/integrations/google-calendar/handlers/list_settings.js +4 -0
- package/integrations/google-calendar/handlers/move_event.js +6 -0
- package/integrations/google-calendar/handlers/patch_event.js +5 -0
- package/integrations/google-calendar/handlers/quick_add.js +6 -0
- package/integrations/google-calendar/handlers/update_acl.js +7 -0
- package/integrations/google-calendar/manifest.json +36 -0
- package/integrations/google-calendar/prompt.md +68 -0
- package/integrations/google-calendar/schemas/create_event.json +34 -0
- package/integrations/google-calendar/schemas/delete_acl.json +9 -0
- package/integrations/google-calendar/schemas/empty.json +1 -0
- package/integrations/google-calendar/schemas/freebusy_query.json +13 -0
- package/integrations/google-calendar/schemas/get_acl.json +9 -0
- package/integrations/google-calendar/schemas/id_calendar.json +8 -0
- package/integrations/google-calendar/schemas/id_calendar_event.json +11 -0
- package/integrations/google-calendar/schemas/insert_acl.json +18 -0
- package/integrations/google-calendar/schemas/list_events.json +17 -0
- package/integrations/google-calendar/schemas/move_event.json +10 -0
- package/integrations/google-calendar/schemas/patch_event.json +10 -0
- package/integrations/google-calendar/schemas/quick_add.json +9 -0
- package/integrations/google-calendar/schemas/update_acl.json +10 -0
- package/integrations/google-docs/README.md +30 -0
- package/integrations/google-docs/__tests__/get_handlers.test.ts +83 -0
- package/integrations/google-docs/__tests__/usage_parity.test.ts +9 -0
- package/integrations/google-docs/__tests__/write_handlers.test.ts +238 -0
- package/integrations/google-docs/credentials.json +57 -0
- package/integrations/google-docs/credentials_hint.md +9 -0
- package/integrations/google-docs/credentials_hint_oauth_token.md +8 -0
- package/integrations/google-docs/credentials_hint_service_account.md +10 -0
- package/integrations/google-docs/handlers/append_text.js +12 -0
- package/integrations/google-docs/handlers/batch_update.js +13 -0
- package/integrations/google-docs/handlers/create_document.js +9 -0
- package/integrations/google-docs/handlers/delete_first_match.js +50 -0
- package/integrations/google-docs/handlers/insert_inline_image_after_first_match.js +41 -0
- package/integrations/google-docs/handlers/insert_page_break_after_first_match.js +49 -0
- package/integrations/google-docs/handlers/insert_table_after_first_match.js +49 -0
- package/integrations/google-docs/handlers/insert_text_after_first_match.js +51 -0
- package/integrations/google-docs/handlers/read_document.js +189 -0
- package/integrations/google-docs/handlers/replace_all_text.js +8 -0
- package/integrations/google-docs/handlers/style_first_match.js +42 -0
- package/integrations/google-docs/handlers/update_document_style.js +8 -0
- package/integrations/google-docs/handlers/update_paragraph_style_for_first_match.js +48 -0
- package/integrations/google-docs/manifest.json +44 -0
- package/integrations/google-docs/prompt.md +49 -0
- package/integrations/google-docs/schemas/append_text.json +10 -0
- package/integrations/google-docs/schemas/apply_text_style.json +13 -0
- package/integrations/google-docs/schemas/batch_update.json +16 -0
- package/integrations/google-docs/schemas/create_document.json +8 -0
- package/integrations/google-docs/schemas/delete_content_range.json +11 -0
- package/integrations/google-docs/schemas/delete_first_match.json +10 -0
- package/integrations/google-docs/schemas/insert_inline_image.json +12 -0
- package/integrations/google-docs/schemas/insert_inline_image_after_first_match.json +12 -0
- package/integrations/google-docs/schemas/insert_page_break.json +10 -0
- package/integrations/google-docs/schemas/insert_page_break_after_first_match.json +11 -0
- package/integrations/google-docs/schemas/insert_table.json +12 -0
- package/integrations/google-docs/schemas/insert_table_after_first_match.json +13 -0
- package/integrations/google-docs/schemas/insert_text_after_first_match.json +12 -0
- package/integrations/google-docs/schemas/insert_text_at.json +11 -0
- package/integrations/google-docs/schemas/read_document.json +12 -0
- package/integrations/google-docs/schemas/replace_all_text.json +12 -0
- package/integrations/google-docs/schemas/style_first_match.json +12 -0
- package/integrations/google-docs/schemas/update_document_style.json +11 -0
- package/integrations/google-docs/schemas/update_paragraph_style.json +13 -0
- package/integrations/google-docs/schemas/update_paragraph_style_for_first_match.json +12 -0
- package/integrations/google-docs/todo.md +18 -0
- package/integrations/google-drive/README.md +26 -0
- package/integrations/google-drive/__tests__/handlers.test.ts +145 -0
- package/integrations/google-drive/__tests__/usage_parity.test.ts +9 -0
- package/integrations/google-drive/credentials.json +59 -0
- package/integrations/google-drive/credentials_hint_oauth_token.md +8 -0
- package/integrations/google-drive/credentials_hint_service_account.md +10 -0
- package/integrations/google-drive/handlers/create_file.js +15 -0
- package/integrations/google-drive/handlers/create_folder.js +15 -0
- package/integrations/google-drive/handlers/delete_file.js +14 -0
- package/integrations/google-drive/handlers/get_file.js +5 -0
- package/integrations/google-drive/handlers/get_file_content.js +41 -0
- package/integrations/google-drive/handlers/list_files.js +15 -0
- package/integrations/google-drive/handlers/move_file.js +12 -0
- package/integrations/google-drive/handlers/search_files.js +20 -0
- package/integrations/google-drive/handlers/share_file.js +20 -0
- package/integrations/google-drive/manifest.json +70 -0
- package/integrations/google-drive/prompt.md +59 -0
- package/integrations/google-drive/schemas/create_file.json +12 -0
- package/integrations/google-drive/schemas/create_folder.json +11 -0
- package/integrations/google-drive/schemas/delete_file.json +10 -0
- package/integrations/google-drive/schemas/get_file.json +10 -0
- package/integrations/google-drive/schemas/get_file_content.json +11 -0
- package/integrations/google-drive/schemas/list_files.json +12 -0
- package/integrations/google-drive/schemas/move_file.json +12 -0
- package/integrations/google-drive/schemas/search_files.json +14 -0
- package/integrations/google-drive/schemas/share_file.json +23 -0
- package/integrations/google-gmail/.env.test.example +11 -0
- package/integrations/google-gmail/README.md +49 -0
- package/integrations/google-gmail/__tests__/get_handlers.test.ts +134 -0
- package/integrations/google-gmail/__tests__/usage_parity.test.ts +9 -0
- package/integrations/google-gmail/__tests__/write_and_admin_handlers.test.ts +211 -0
- package/integrations/google-gmail/credentials.json +59 -0
- package/integrations/google-gmail/credentials_hint_oauth_token.md +8 -0
- package/integrations/google-gmail/credentials_hint_service_account.md +10 -0
- package/integrations/google-gmail/handlers/create_draft_email.js +27 -0
- package/integrations/google-gmail/handlers/create_label.js +12 -0
- package/integrations/google-gmail/handlers/delete_draft.js +13 -0
- package/integrations/google-gmail/handlers/delete_label.js +13 -0
- package/integrations/google-gmail/handlers/delete_message.js +13 -0
- package/integrations/google-gmail/handlers/delete_thread.js +13 -0
- package/integrations/google-gmail/handlers/get_draft.js +6 -0
- package/integrations/google-gmail/handlers/get_label.js +6 -0
- package/integrations/google-gmail/handlers/get_message.js +14 -0
- package/integrations/google-gmail/handlers/get_profile.js +5 -0
- package/integrations/google-gmail/handlers/get_thread.js +14 -0
- package/integrations/google-gmail/handlers/list_drafts.js +15 -0
- package/integrations/google-gmail/handlers/list_labels.js +5 -0
- package/integrations/google-gmail/handlers/list_messages.js +19 -0
- package/integrations/google-gmail/handlers/list_threads.js +19 -0
- package/integrations/google-gmail/handlers/modify_message.js +11 -0
- package/integrations/google-gmail/handlers/modify_thread.js +11 -0
- package/integrations/google-gmail/handlers/read_email.js +56 -0
- package/integrations/google-gmail/handlers/send_draft.js +15 -0
- package/integrations/google-gmail/handlers/send_email.js +22 -0
- package/integrations/google-gmail/handlers/trash_message.js +6 -0
- package/integrations/google-gmail/handlers/trash_thread.js +6 -0
- package/integrations/google-gmail/handlers/untrash_message.js +6 -0
- package/integrations/google-gmail/handlers/untrash_thread.js +6 -0
- package/integrations/google-gmail/handlers/update_label.js +15 -0
- package/integrations/google-gmail/manifest.json +45 -0
- package/integrations/google-gmail/prompt.md +52 -0
- package/integrations/google-gmail/schemas/create_draft_email.json +16 -0
- package/integrations/google-gmail/schemas/create_label.json +26 -0
- package/integrations/google-gmail/schemas/get_message.json +20 -0
- package/integrations/google-gmail/schemas/get_profile.json +11 -0
- package/integrations/google-gmail/schemas/get_thread.json +20 -0
- package/integrations/google-gmail/schemas/id_draft.json +16 -0
- package/integrations/google-gmail/schemas/id_label.json +16 -0
- package/integrations/google-gmail/schemas/id_message.json +16 -0
- package/integrations/google-gmail/schemas/id_thread.json +16 -0
- package/integrations/google-gmail/schemas/list_drafts.json +30 -0
- package/integrations/google-gmail/schemas/list_labels.json +11 -0
- package/integrations/google-gmail/schemas/list_messages.json +35 -0
- package/integrations/google-gmail/schemas/list_threads.json +35 -0
- package/integrations/google-gmail/schemas/modify_message.json +24 -0
- package/integrations/google-gmail/schemas/modify_thread.json +24 -0
- package/integrations/google-gmail/schemas/read_email.json +10 -0
- package/integrations/google-gmail/schemas/send_draft.json +29 -0
- package/integrations/google-gmail/schemas/send_email.json +17 -0
- package/integrations/google-gmail/schemas/update_label.json +33 -0
- package/integrations/google-sheet/README.md +27 -0
- package/integrations/google-sheet/__tests__/get_handlers.test.ts +76 -0
- package/integrations/google-sheet/__tests__/usage_parity.test.ts +9 -0
- package/integrations/google-sheet/__tests__/write_handlers.test.ts +153 -0
- package/integrations/google-sheet/credentials.json +57 -0
- package/integrations/google-sheet/credentials_hint.md +9 -0
- package/integrations/google-sheet/credentials_hint_oauth_token.md +8 -0
- package/integrations/google-sheet/credentials_hint_service_account.md +10 -0
- package/integrations/google-sheet/handlers/append_values.js +18 -0
- package/integrations/google-sheet/handlers/batch_clear_values.js +6 -0
- package/integrations/google-sheet/handlers/batch_update.js +14 -0
- package/integrations/google-sheet/handlers/batch_update_values.js +16 -0
- package/integrations/google-sheet/handlers/clear_values.js +6 -0
- package/integrations/google-sheet/handlers/copy_to_spreadsheet.js +6 -0
- package/integrations/google-sheet/handlers/create_spreadsheet.js +5 -0
- package/integrations/google-sheet/handlers/get_spreadsheet.js +14 -0
- package/integrations/google-sheet/handlers/read_sheet.js +75 -0
- package/integrations/google-sheet/handlers/update_values.js +16 -0
- package/integrations/google-sheet/manifest.json +77 -0
- package/integrations/google-sheet/prompt.md +49 -0
- package/integrations/google-sheet/schemas/append_values.json +16 -0
- package/integrations/google-sheet/schemas/batch_clear_values.json +10 -0
- package/integrations/google-sheet/schemas/batch_update.json +13 -0
- package/integrations/google-sheet/schemas/batch_update_values.json +25 -0
- package/integrations/google-sheet/schemas/clear_values.json +10 -0
- package/integrations/google-sheet/schemas/copy_to_spreadsheet.json +11 -0
- package/integrations/google-sheet/schemas/create_spreadsheet.json +11 -0
- package/integrations/google-sheet/schemas/get_spreadsheet.json +16 -0
- package/integrations/google-sheet/schemas/read_sheet.json +21 -0
- package/integrations/google-sheet/schemas/update_values.json +15 -0
- package/integrations/google-slides/README.md +28 -0
- package/integrations/google-slides/__tests__/get_handlers.test.ts +74 -0
- package/integrations/google-slides/__tests__/usage_parity.test.ts +9 -0
- package/integrations/google-slides/__tests__/write_handlers.test.ts +131 -0
- package/integrations/google-slides/credentials.json +57 -0
- package/integrations/google-slides/credentials_hint.md +9 -0
- package/integrations/google-slides/credentials_hint_oauth_token.md +8 -0
- package/integrations/google-slides/credentials_hint_service_account.md +10 -0
- package/integrations/google-slides/handlers/append_text_to_title_of_first_slide.js +17 -0
- package/integrations/google-slides/handlers/batch_update.js +15 -0
- package/integrations/google-slides/handlers/create_presentation.js +8 -0
- package/integrations/google-slides/handlers/create_slide_after_first_match.js +20 -0
- package/integrations/google-slides/handlers/get_page_thumbnail.js +12 -0
- package/integrations/google-slides/handlers/insert_image_after_first_match.js +19 -0
- package/integrations/google-slides/handlers/insert_shape_after_first_match.js +21 -0
- package/integrations/google-slides/handlers/read_presentation.js +51 -0
- package/integrations/google-slides/handlers/replace_text_first_match.js +9 -0
- package/integrations/google-slides/handlers/set_background_color_for_slide_index.js +15 -0
- package/integrations/google-slides/handlers/style_text_first_match.js +48 -0
- package/integrations/google-slides/manifest.json +42 -0
- package/integrations/google-slides/prompt.md +56 -0
- package/integrations/google-slides/schemas/append_text_to_title_of_first_slide.json +11 -0
- package/integrations/google-slides/schemas/batch_update.json +13 -0
- package/integrations/google-slides/schemas/create_presentation.json +8 -0
- package/integrations/google-slides/schemas/create_slide_after_first_match.json +11 -0
- package/integrations/google-slides/schemas/get_page_thumbnail.json +12 -0
- package/integrations/google-slides/schemas/get_presentation.json +9 -0
- package/integrations/google-slides/schemas/insert_image_after_first_match.json +13 -0
- package/integrations/google-slides/schemas/insert_shape_after_first_match.json +13 -0
- package/integrations/google-slides/schemas/replace_text_first_match.json +12 -0
- package/integrations/google-slides/schemas/set_background_color_for_slide_index.json +11 -0
- package/integrations/google-slides/schemas/style_text_first_match.json +12 -0
- package/integrations/hubspot/.env.test.example +20 -0
- package/integrations/hubspot/README.md +48 -0
- package/integrations/hubspot/__tests__/get_handlers.test.ts +151 -0
- package/integrations/hubspot/__tests__/usage_parity.test.ts +10 -0
- package/integrations/hubspot/__tests__/write_handlers.test.ts +244 -0
- package/integrations/hubspot/credentials.json +50 -0
- package/integrations/hubspot/credentials_hint.md +20 -0
- package/integrations/hubspot/credentials_hint_oauth_token.md +16 -0
- package/integrations/hubspot/handlers/archive_company.js +13 -0
- package/integrations/hubspot/handlers/archive_contact.js +13 -0
- package/integrations/hubspot/handlers/archive_deal.js +13 -0
- package/integrations/hubspot/handlers/archive_ticket.js +13 -0
- package/integrations/hubspot/handlers/create_association.js +18 -0
- package/integrations/hubspot/handlers/create_company.js +13 -0
- package/integrations/hubspot/handlers/create_contact.js +14 -0
- package/integrations/hubspot/handlers/create_deal.js +16 -0
- package/integrations/hubspot/handlers/create_note.js +44 -0
- package/integrations/hubspot/handlers/create_task.js +48 -0
- package/integrations/hubspot/handlers/create_ticket.js +15 -0
- package/integrations/hubspot/handlers/get_associations.js +14 -0
- package/integrations/hubspot/handlers/get_company.js +18 -0
- package/integrations/hubspot/handlers/get_contact.js +18 -0
- package/integrations/hubspot/handlers/get_deal.js +18 -0
- package/integrations/hubspot/handlers/get_ticket.js +20 -0
- package/integrations/hubspot/handlers/list_owners.js +12 -0
- package/integrations/hubspot/handlers/list_pipelines.js +5 -0
- package/integrations/hubspot/handlers/list_properties.js +11 -0
- package/integrations/hubspot/handlers/remove_association.js +22 -0
- package/integrations/hubspot/handlers/search_companies.js +43 -0
- package/integrations/hubspot/handlers/search_contacts.js +43 -0
- package/integrations/hubspot/handlers/search_deals.js +43 -0
- package/integrations/hubspot/handlers/search_notes.js +43 -0
- package/integrations/hubspot/handlers/search_tasks.js +43 -0
- package/integrations/hubspot/handlers/search_tickets.js +43 -0
- package/integrations/hubspot/handlers/update_company.js +13 -0
- package/integrations/hubspot/handlers/update_contact.js +14 -0
- package/integrations/hubspot/handlers/update_deal.js +16 -0
- package/integrations/hubspot/handlers/update_task.js +17 -0
- package/integrations/hubspot/handlers/update_ticket.js +15 -0
- package/integrations/hubspot/manifest.json +231 -0
- package/integrations/hubspot/prompt.md +69 -0
- package/integrations/hubspot/schemas/archive_company.json +13 -0
- package/integrations/hubspot/schemas/archive_contact.json +13 -0
- package/integrations/hubspot/schemas/archive_deal.json +9 -0
- package/integrations/hubspot/schemas/archive_ticket.json +9 -0
- package/integrations/hubspot/schemas/create_association.json +24 -0
- package/integrations/hubspot/schemas/create_company.json +14 -0
- package/integrations/hubspot/schemas/create_contact.json +15 -0
- package/integrations/hubspot/schemas/create_deal.json +20 -0
- package/integrations/hubspot/schemas/create_note.json +37 -0
- package/integrations/hubspot/schemas/create_task.json +51 -0
- package/integrations/hubspot/schemas/create_ticket.json +16 -0
- package/integrations/hubspot/schemas/empty.json +6 -0
- package/integrations/hubspot/schemas/get_associations.json +30 -0
- package/integrations/hubspot/schemas/get_company.json +27 -0
- package/integrations/hubspot/schemas/get_contact.json +27 -0
- package/integrations/hubspot/schemas/get_deal.json +20 -0
- package/integrations/hubspot/schemas/get_ticket.json +20 -0
- package/integrations/hubspot/schemas/list_owners.json +25 -0
- package/integrations/hubspot/schemas/list_pipelines.json +13 -0
- package/integrations/hubspot/schemas/list_properties.json +17 -0
- package/integrations/hubspot/schemas/remove_association.json +24 -0
- package/integrations/hubspot/schemas/search_companies.json +56 -0
- package/integrations/hubspot/schemas/search_contacts.json +56 -0
- package/integrations/hubspot/schemas/search_deals.json +43 -0
- package/integrations/hubspot/schemas/search_notes.json +43 -0
- package/integrations/hubspot/schemas/search_tasks.json +43 -0
- package/integrations/hubspot/schemas/search_tickets.json +43 -0
- package/integrations/hubspot/schemas/update_company.json +20 -0
- package/integrations/hubspot/schemas/update_contact.json +21 -0
- package/integrations/hubspot/schemas/update_deal.json +19 -0
- package/integrations/hubspot/schemas/update_task.json +31 -0
- package/integrations/hubspot/schemas/update_ticket.json +18 -0
- package/integrations/jira/.env.test.example +41 -0
- package/integrations/jira/README.md +46 -0
- package/integrations/jira/__tests__/get_handlers.test.ts +193 -0
- package/integrations/jira/__tests__/usage_parity.test.ts +14 -0
- package/integrations/jira/__tests__/write_handlers.test.ts +157 -0
- package/integrations/jira/credentials.json +39 -0
- package/integrations/jira/credentials_hint.md +4 -0
- package/integrations/jira/credentials_hint_api_token.md +6 -0
- package/integrations/jira/credentials_hint_oauth_token.md +6 -0
- package/integrations/jira/handlers/add_comment.js +9 -0
- package/integrations/jira/handlers/assign_issue.js +11 -0
- package/integrations/jira/handlers/create_issue.js +37 -0
- package/integrations/jira/handlers/create_sprint.js +19 -0
- package/integrations/jira/handlers/delete_issue.js +10 -0
- package/integrations/jira/handlers/get_backlog_issues.js +13 -0
- package/integrations/jira/handlers/get_board.js +6 -0
- package/integrations/jira/handlers/get_issue.js +63 -0
- package/integrations/jira/handlers/get_issue_comments.js +31 -0
- package/integrations/jira/handlers/get_myself.js +14 -0
- package/integrations/jira/handlers/get_project.js +28 -0
- package/integrations/jira/handlers/get_sprint.js +5 -0
- package/integrations/jira/handlers/get_sprint_issues.js +13 -0
- package/integrations/jira/handlers/get_transitions.js +23 -0
- package/integrations/jira/handlers/list_boards.js +34 -0
- package/integrations/jira/handlers/list_projects.js +29 -0
- package/integrations/jira/handlers/list_sprints.js +29 -0
- package/integrations/jira/handlers/move_issues_to_sprint.js +11 -0
- package/integrations/jira/handlers/search_issues.js +43 -0
- package/integrations/jira/handlers/search_users.js +21 -0
- package/integrations/jira/handlers/transition_issue.js +44 -0
- package/integrations/jira/handlers/update_issue.js +40 -0
- package/integrations/jira/handlers/update_sprint.js +20 -0
- package/integrations/jira/manifest.json +204 -0
- package/integrations/jira/prompt.md +80 -0
- package/integrations/jira/schemas/add_comment.json +16 -0
- package/integrations/jira/schemas/assign_issue.json +16 -0
- package/integrations/jira/schemas/create_issue.json +49 -0
- package/integrations/jira/schemas/create_sprint.json +29 -0
- package/integrations/jira/schemas/delete_issue.json +12 -0
- package/integrations/jira/schemas/empty.json +6 -0
- package/integrations/jira/schemas/get_backlog_issues.json +33 -0
- package/integrations/jira/schemas/get_board.json +13 -0
- package/integrations/jira/schemas/get_issue.json +23 -0
- package/integrations/jira/schemas/get_issue_comments.json +23 -0
- package/integrations/jira/schemas/get_project.json +17 -0
- package/integrations/jira/schemas/get_sprint.json +13 -0
- package/integrations/jira/schemas/get_sprint_issues.json +33 -0
- package/integrations/jira/schemas/get_transitions.json +12 -0
- package/integrations/jira/schemas/list_boards.json +27 -0
- package/integrations/jira/schemas/list_projects.json +22 -0
- package/integrations/jira/schemas/list_sprints.json +29 -0
- package/integrations/jira/schemas/move_issues_to_sprint.json +19 -0
- package/integrations/jira/schemas/search_issues.json +28 -0
- package/integrations/jira/schemas/search_users.json +18 -0
- package/integrations/jira/schemas/transition_issue.json +38 -0
- package/integrations/jira/schemas/update_issue.json +47 -0
- package/integrations/jira/schemas/update_sprint.json +33 -0
- package/integrations/new_integration_prompt.md +216 -0
- package/integrations/notion/.env.test.example +13 -0
- package/integrations/notion/README.md +42 -0
- package/integrations/notion/__tests__/get_handlers.test.ts +156 -0
- package/integrations/notion/__tests__/usage_parity.test.ts +9 -0
- package/integrations/notion/__tests__/write_and_admin_handlers.test.ts +186 -0
- package/integrations/notion/credentials.json +27 -0
- package/integrations/notion/credentials_hint.md +5 -0
- package/integrations/notion/handlers/append_block_children.js +7 -0
- package/integrations/notion/handlers/create_comment.js +10 -0
- package/integrations/notion/handlers/create_database.js +11 -0
- package/integrations/notion/handlers/create_page.js +13 -0
- package/integrations/notion/handlers/delete_block.js +8 -0
- package/integrations/notion/handlers/get_me.js +4 -0
- package/integrations/notion/handlers/list_block_children.js +10 -0
- package/integrations/notion/handlers/list_comments.js +14 -0
- package/integrations/notion/handlers/list_users.js +10 -0
- package/integrations/notion/handlers/query_database.js +10 -0
- package/integrations/notion/handlers/retrieve_block.js +4 -0
- package/integrations/notion/handlers/retrieve_database.js +4 -0
- package/integrations/notion/handlers/retrieve_page.js +4 -0
- package/integrations/notion/handlers/retrieve_page_property_item.js +10 -0
- package/integrations/notion/handlers/retrieve_user.js +4 -0
- package/integrations/notion/handlers/search.js +11 -0
- package/integrations/notion/handlers/update_block.js +7 -0
- package/integrations/notion/handlers/update_database.js +10 -0
- package/integrations/notion/handlers/update_page_properties.js +10 -0
- package/integrations/notion/manifest.json +169 -0
- package/integrations/notion/prompt.md +26 -0
- package/integrations/notion/schemas/append_block_children.json +10 -0
- package/integrations/notion/schemas/create_comment.json +18 -0
- package/integrations/notion/schemas/create_database.json +18 -0
- package/integrations/notion/schemas/create_page.json +22 -0
- package/integrations/notion/schemas/delete_block.json +9 -0
- package/integrations/notion/schemas/empty.json +6 -0
- package/integrations/notion/schemas/id_block.json +9 -0
- package/integrations/notion/schemas/id_database.json +9 -0
- package/integrations/notion/schemas/id_page.json +9 -0
- package/integrations/notion/schemas/id_user.json +9 -0
- package/integrations/notion/schemas/list_block_children.json +11 -0
- package/integrations/notion/schemas/list_comments.json +15 -0
- package/integrations/notion/schemas/list_users.json +9 -0
- package/integrations/notion/schemas/query_database.json +13 -0
- package/integrations/notion/schemas/retrieve_page_property_item.json +12 -0
- package/integrations/notion/schemas/search.json +27 -0
- package/integrations/notion/schemas/update_block.json +10 -0
- package/integrations/notion/schemas/update_database.json +13 -0
- package/integrations/notion/schemas/update_page_properties.json +13 -0
- package/integrations/trello/.env.test.example +9 -0
- package/integrations/trello/README.md +50 -0
- package/integrations/trello/__tests__/get_handlers.test.ts +225 -0
- package/integrations/trello/__tests__/usage_parity.test.ts +9 -0
- package/integrations/trello/__tests__/write_and_admin_handlers.test.ts +171 -0
- package/integrations/trello/credentials.json +32 -0
- package/integrations/trello/credentials_hint.md +4 -0
- package/integrations/trello/handlers/add_checklist_to_card.js +5 -0
- package/integrations/trello/handlers/add_member_to_card.js +5 -0
- package/integrations/trello/handlers/archive_list.js +5 -0
- package/integrations/trello/handlers/close_board.js +6 -0
- package/integrations/trello/handlers/create_board.js +11 -0
- package/integrations/trello/handlers/create_card.js +13 -0
- package/integrations/trello/handlers/create_list.js +7 -0
- package/integrations/trello/handlers/delete_board.js +13 -0
- package/integrations/trello/handlers/delete_card.js +9 -0
- package/integrations/trello/handlers/get_board.js +4 -0
- package/integrations/trello/handlers/get_board_cards.js +4 -0
- package/integrations/trello/handlers/get_board_custom_fields.js +4 -0
- package/integrations/trello/handlers/get_board_labels.js +4 -0
- package/integrations/trello/handlers/get_board_lists.js +4 -0
- package/integrations/trello/handlers/get_board_members.js +4 -0
- package/integrations/trello/handlers/get_board_memberships.js +4 -0
- package/integrations/trello/handlers/get_card.js +4 -0
- package/integrations/trello/handlers/get_card_actions.js +4 -0
- package/integrations/trello/handlers/get_card_attachments.js +4 -0
- package/integrations/trello/handlers/get_card_checklists.js +4 -0
- package/integrations/trello/handlers/get_card_custom_field_items.js +4 -0
- package/integrations/trello/handlers/get_card_members.js +4 -0
- package/integrations/trello/handlers/get_list.js +4 -0
- package/integrations/trello/handlers/get_list_cards.js +4 -0
- package/integrations/trello/handlers/get_member.js +4 -0
- package/integrations/trello/handlers/get_member_boards.js +4 -0
- package/integrations/trello/handlers/get_member_organizations.js +4 -0
- package/integrations/trello/handlers/get_organization.js +4 -0
- package/integrations/trello/handlers/get_organization_boards.js +4 -0
- package/integrations/trello/handlers/move_card_to_list.js +5 -0
- package/integrations/trello/handlers/remove_member_from_card.js +9 -0
- package/integrations/trello/handlers/search.js +5 -0
- package/integrations/trello/handlers/update_card.js +19 -0
- package/integrations/trello/handlers/update_list.js +11 -0
- package/integrations/trello/manifest.json +245 -0
- package/integrations/trello/schemas/add_checklist_to_card.json +10 -0
- package/integrations/trello/schemas/add_member_to_card.json +10 -0
- package/integrations/trello/schemas/archive_list.json +9 -0
- package/integrations/trello/schemas/close_board.json +10 -0
- package/integrations/trello/schemas/create_board.json +12 -0
- package/integrations/trello/schemas/create_card.json +13 -0
- package/integrations/trello/schemas/create_list.json +11 -0
- package/integrations/trello/schemas/delete_board.json +10 -0
- package/integrations/trello/schemas/delete_card.json +9 -0
- package/integrations/trello/schemas/display_trello_cards.json +45 -0
- package/integrations/trello/schemas/empty.json +5 -0
- package/integrations/trello/schemas/get_member.json +5 -0
- package/integrations/trello/schemas/id_board.json +8 -0
- package/integrations/trello/schemas/id_card.json +8 -0
- package/integrations/trello/schemas/id_list.json +8 -0
- package/integrations/trello/schemas/id_org.json +8 -0
- package/integrations/trello/schemas/move_card_to_list.json +10 -0
- package/integrations/trello/schemas/remove_member_from_card.json +10 -0
- package/integrations/trello/schemas/search.json +8 -0
- package/integrations/trello/schemas/update_card.json +16 -0
- package/integrations/trello/schemas/update_list.json +12 -0
- package/package.json +4 -3
- package/dist/generated/registry.d.ts +0 -3
- package/dist/generated/registry.d.ts.map +0 -1
- package/dist/generated/registry.js +0 -11889
- package/dist/generated/registry.js.map +0 -1
- package/dist/types.d.ts +0 -88
- package/dist/types.d.ts.map +0 -1
- package/dist/types.js +0 -2
- package/dist/types.js.map +0 -1
|
@@ -0,0 +1,16 @@
|
|
|
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
|
+
"insertDataOption": { "type": "string", "enum": ["OVERWRITE", "INSERT_ROWS"] },
|
|
11
|
+
"includeValuesInResponse": { "type": "boolean" },
|
|
12
|
+
"responseValueRenderOption": { "type": "string", "enum": ["FORMATTED_VALUE", "UNFORMATTED_VALUE", "FORMULA"] },
|
|
13
|
+
"responseDateTimeRenderOption": { "type": "string", "enum": ["SERIAL_NUMBER", "FORMATTED_STRING"] }
|
|
14
|
+
},
|
|
15
|
+
"additionalProperties": false
|
|
16
|
+
}
|
|
@@ -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,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,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,16 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string", "description": "Spreadsheet ID. Found in the spreadsheet URL: https://docs.google.com/spreadsheets/d/{spreadsheetId}/." },
|
|
7
|
+
"includeGridData": { "type": "boolean", "description": "Whether to include cell grid data. Defaults to false. Set to true only when you need cell values -- use get_values or batch_get_values for targeted range reads instead." },
|
|
8
|
+
"ranges": {
|
|
9
|
+
"type": "array",
|
|
10
|
+
"items": { "type": "string" },
|
|
11
|
+
"description": "Optional A1 notation ranges to include when includeGridData is true. Example: ['Sheet1!A1:D10', 'Sheet2!A:A']."
|
|
12
|
+
},
|
|
13
|
+
"fields": { "type": "string", "description": "Partial response fields selector to reduce response size. Example: 'sheets.properties' to get only sheet names and IDs without cell data. See Sheets API fields reference." }
|
|
14
|
+
},
|
|
15
|
+
"additionalProperties": false
|
|
16
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": {
|
|
7
|
+
"type": "string",
|
|
8
|
+
"description": "Spreadsheet ID from URL: https://docs.google.com/spreadsheets/d/{spreadsheetId}/edit"
|
|
9
|
+
},
|
|
10
|
+
"range": {
|
|
11
|
+
"type": "string",
|
|
12
|
+
"description": "A1 notation range to read, e.g. 'Sheet1!A1:D20'. Defaults to 'A1:Z1000'."
|
|
13
|
+
},
|
|
14
|
+
"valueRenderOption": {
|
|
15
|
+
"type": "string",
|
|
16
|
+
"enum": ["FORMATTED_VALUE", "UNFORMATTED_VALUE", "FORMULA"],
|
|
17
|
+
"description": "How values should be represented in the output."
|
|
18
|
+
}
|
|
19
|
+
},
|
|
20
|
+
"additionalProperties": false
|
|
21
|
+
}
|
|
@@ -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,28 @@
|
|
|
1
|
+
# Google Slides
|
|
2
|
+
|
|
3
|
+
**11 tools**
|
|
4
|
+
|
|
5
|
+

|
|
6
|
+
|
|
7
|
+
## Credential variants
|
|
8
|
+
|
|
9
|
+
| Variant | Label |
|
|
10
|
+
|---|---|
|
|
11
|
+
| `service_account` | Service Account (recommended) _(default)_ |
|
|
12
|
+
| `oauth_token` | OAuth Access Token (short-lived) |
|
|
13
|
+
|
|
14
|
+
## Tools
|
|
15
|
+
|
|
16
|
+
| Tool | Scope | Description |
|
|
17
|
+
|---|---|---|
|
|
18
|
+
| `read_presentation` | read | Read a Google Slides presentation and return a human-readable summary including the title… |
|
|
19
|
+
| `get_page_thumbnail` | read | Generate a thumbnail image URL for a specific slide (page) in a presentation. Requires th… |
|
|
20
|
+
| `create_presentation` | write | Create a new empty Google Slides presentation with an optional title. Returns the created… |
|
|
21
|
+
| `batch_update` | write | Send a presentations.batchUpdate request for low-level slide modifications. Accepts an ar… |
|
|
22
|
+
| `append_text_to_title_of_slide_index` | write | Append text to the title shape of a specific slide by its 0-based index (slideIndex=0 is … |
|
|
23
|
+
| `replace_text_first_match` | write | Replace the first occurrence of text anywhere in the presentation with new text. Note: th… |
|
|
24
|
+
| `style_text_first_match` | write | Find the first occurrence of text in the presentation and apply a text style to it (bold,… |
|
|
25
|
+
| `insert_shape_after_first_match` | write | Find the first slide containing a text match and insert a rectangle shape on that slide a… |
|
|
26
|
+
| `insert_image_after_first_match` | write | Find the first slide containing a text match and insert an image on that slide from a URL… |
|
|
27
|
+
| `create_slide_after_first_match` | write | Find the first slide containing a text match and create a new blank slide immediately aft… |
|
|
28
|
+
| `set_background_color_for_slide_index` | write | Set the background color for a specific slide by its 0-based index (slideIndex=0 is the f… |
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { afterAll, beforeAll, describe, expect, it } from 'vitest'
|
|
2
|
+
import { createCredentialStore, createIntegrationNode, createProxy, createToolbox, hasEnv, safeCleanup } from '../../__tests__/liveHarness.js'
|
|
3
|
+
|
|
4
|
+
// LIVE Google Slides read tests using credentials
|
|
5
|
+
// Required env vars:
|
|
6
|
+
// - Either GOOGLE_TOKEN, OR GOOGLE_SERVICE_ACCOUNT_JSON
|
|
7
|
+
|
|
8
|
+
const suite = (hasEnv('GOOGLE_TOKEN') || hasEnv('GOOGLE_SERVICE_ACCOUNT_JSON'))
|
|
9
|
+
? describe
|
|
10
|
+
: describe.skip
|
|
11
|
+
|
|
12
|
+
suite('google-slides read handlers (live)', () => {
|
|
13
|
+
let slides: ReturnType<typeof createToolbox>
|
|
14
|
+
let drive: ReturnType<typeof createToolbox>
|
|
15
|
+
let folderId: string | undefined
|
|
16
|
+
let presentationId: string | undefined
|
|
17
|
+
|
|
18
|
+
beforeAll(async () => {
|
|
19
|
+
const env = process.env as Record<string, string | undefined>
|
|
20
|
+
const credentialStore = createCredentialStore(async () => ({
|
|
21
|
+
token: env.GOOGLE_TOKEN || '',
|
|
22
|
+
serviceAccountJson: env.GOOGLE_SERVICE_ACCOUNT_JSON || '',
|
|
23
|
+
subject: env.GOOGLE_IMPERSONATE_SUBJECT || '',
|
|
24
|
+
}))
|
|
25
|
+
const proxy = createProxy(credentialStore)
|
|
26
|
+
slides = createToolbox('google-slides', proxy, createIntegrationNode('google-slides', { label: 'Google Slides', credentialId: 'google-slides-creds' }))
|
|
27
|
+
drive = createToolbox('google-drive', proxy, createIntegrationNode('google-drive', { label: 'Google Drive', credentialId: 'google-drive-creds' }))
|
|
28
|
+
|
|
29
|
+
// Create dedicated folder + presentation for this run
|
|
30
|
+
const folder = await drive.write('create_folder')({ name: `CmdTest Slides ${Date.now()}` })
|
|
31
|
+
folderId = folder?.id
|
|
32
|
+
expect(folderId).toBeTruthy()
|
|
33
|
+
|
|
34
|
+
const created = await drive.write('create_file')({
|
|
35
|
+
name: `CmdTest Slides ${Date.now()}`,
|
|
36
|
+
mimeType: 'application/vnd.google-apps.presentation',
|
|
37
|
+
parentId: folderId,
|
|
38
|
+
})
|
|
39
|
+
presentationId = created?.id
|
|
40
|
+
expect(presentationId).toBeTruthy()
|
|
41
|
+
}, 60000)
|
|
42
|
+
|
|
43
|
+
afterAll(async () => {
|
|
44
|
+
if (!folderId)
|
|
45
|
+
return
|
|
46
|
+
await safeCleanup(async () => presentationId ? drive.write('delete_file')({ fileId: presentationId }) : Promise.resolve())
|
|
47
|
+
await safeCleanup(async () => drive.write('delete_file')({ fileId: folderId }))
|
|
48
|
+
}, 60000)
|
|
49
|
+
|
|
50
|
+
it('read_presentation returns human-readable content', async () => {
|
|
51
|
+
if (!presentationId)
|
|
52
|
+
return expect(true).toBe(true)
|
|
53
|
+
const handler = slides.read('read_presentation')
|
|
54
|
+
const result = await handler({ presentationId })
|
|
55
|
+
expect(typeof result).toBe('string')
|
|
56
|
+
expect(String(result)).toContain('Presentation:')
|
|
57
|
+
}, 30000)
|
|
58
|
+
|
|
59
|
+
it('get_page_thumbnail returns URL data', async () => {
|
|
60
|
+
if (!presentationId)
|
|
61
|
+
return expect(true).toBe(true)
|
|
62
|
+
// Query the readable summary and parse "Slide 1: ID <objectId>, ..."
|
|
63
|
+
const readPresentation = slides.read('read_presentation')
|
|
64
|
+
const summary = await readPresentation({ presentationId })
|
|
65
|
+
const text = String(summary || '')
|
|
66
|
+
const match = text.match(/Slide 1: ID ([^,\n]+)/)
|
|
67
|
+
const firstSlideObjectId = match?.[1]
|
|
68
|
+
if (!firstSlideObjectId)
|
|
69
|
+
return expect(true).toBe(true)
|
|
70
|
+
const handler = slides.read('get_page_thumbnail')
|
|
71
|
+
const result = await handler({ presentationId, 'pageObjectId': firstSlideObjectId, 'thumbnailProperties.thumbnailSize': 'MEDIUM', 'thumbnailProperties.mimeType': 'PNG' })
|
|
72
|
+
expect(typeof result?.contentUrl === 'string' || typeof result?.thumbnailUrl === 'string').toBe(true)
|
|
73
|
+
}, 30000)
|
|
74
|
+
})
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest'
|
|
2
|
+
import { getMissingToolUsages } from '../../__tests__/usageParity.js'
|
|
3
|
+
|
|
4
|
+
describe('google-slides static usage parity', () => {
|
|
5
|
+
it('every manifest tool is referenced in tests', () => {
|
|
6
|
+
const missing = getMissingToolUsages({ integrationName: 'google-slides', importMetaUrl: import.meta.url })
|
|
7
|
+
expect(missing, `Missing handler usages in tests: ${missing.join(', ')}`).toEqual([])
|
|
8
|
+
})
|
|
9
|
+
})
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
import { afterAll, beforeAll, describe, expect, it } from 'vitest'
|
|
2
|
+
import { createCredentialStore, createIntegrationNode, createProxy, createToolbox, hasEnv, safeCleanup } from '../../__tests__/liveHarness.js'
|
|
3
|
+
|
|
4
|
+
// LIVE Google Slides write tests using credentials
|
|
5
|
+
// Required env vars:
|
|
6
|
+
// - Either GOOGLE_TOKEN, OR GOOGLE_SERVICE_ACCOUNT_JSON
|
|
7
|
+
|
|
8
|
+
interface Ctx { presentationId?: string, folderId?: string, anchorText?: string }
|
|
9
|
+
|
|
10
|
+
const suite = (hasEnv('GOOGLE_TOKEN') || hasEnv('GOOGLE_SERVICE_ACCOUNT_JSON'))
|
|
11
|
+
? describe
|
|
12
|
+
: describe.skip
|
|
13
|
+
|
|
14
|
+
suite('google-slides write handlers (live)', () => {
|
|
15
|
+
const ctx: Ctx = {}
|
|
16
|
+
let slides: ReturnType<typeof createToolbox>
|
|
17
|
+
let drive: ReturnType<typeof createToolbox>
|
|
18
|
+
|
|
19
|
+
beforeAll(async () => {
|
|
20
|
+
const env = process.env as Record<string, string | undefined>
|
|
21
|
+
const credentialStore = createCredentialStore(async () => ({
|
|
22
|
+
token: env.GOOGLE_TOKEN || '',
|
|
23
|
+
serviceAccountJson: env.GOOGLE_SERVICE_ACCOUNT_JSON || '',
|
|
24
|
+
subject: env.GOOGLE_IMPERSONATE_SUBJECT || '',
|
|
25
|
+
}))
|
|
26
|
+
const proxy = createProxy(credentialStore)
|
|
27
|
+
slides = createToolbox('google-slides', proxy, createIntegrationNode('google-slides', { label: 'Google Slides', credentialId: 'google-slides-creds' }))
|
|
28
|
+
drive = createToolbox('google-drive', proxy, createIntegrationNode('google-drive', { label: 'Google Drive', credentialId: 'google-drive-creds' }))
|
|
29
|
+
|
|
30
|
+
const folder = await drive.write('create_folder')({ name: `CmdTest Slides Write ${Date.now()}` })
|
|
31
|
+
ctx.folderId = folder?.id
|
|
32
|
+
expect(ctx.folderId).toBeTruthy()
|
|
33
|
+
|
|
34
|
+
const created = await drive.write('create_file')({
|
|
35
|
+
name: `CmdTest Slides ${Date.now()}`,
|
|
36
|
+
mimeType: 'application/vnd.google-apps.presentation',
|
|
37
|
+
parentId: ctx.folderId,
|
|
38
|
+
})
|
|
39
|
+
ctx.presentationId = created?.id
|
|
40
|
+
expect(ctx.presentationId).toBeTruthy()
|
|
41
|
+
|
|
42
|
+
ctx.anchorText = `CMD_ANCHOR_${Date.now()}`
|
|
43
|
+
const appendTitle = slides.write('append_text_to_title_of_slide_index')
|
|
44
|
+
await appendTitle({ presentationId: ctx.presentationId, slideIndex: 0, text: ` ${ctx.anchorText} ` })
|
|
45
|
+
}, 60000)
|
|
46
|
+
|
|
47
|
+
afterAll(async () => {
|
|
48
|
+
await safeCleanup(async () => ctx.presentationId ? drive.write('delete_file')({ fileId: ctx.presentationId }) : Promise.resolve())
|
|
49
|
+
await safeCleanup(async () => ctx.folderId ? drive.write('delete_file')({ fileId: ctx.folderId }) : Promise.resolve())
|
|
50
|
+
}, 60_000)
|
|
51
|
+
|
|
52
|
+
it('batch_update performs a trivial update (no-op replace)', async () => {
|
|
53
|
+
if (!ctx.presentationId)
|
|
54
|
+
return expect(true).toBe(true)
|
|
55
|
+
const handler = slides.write('batch_update')
|
|
56
|
+
const res = await handler({ presentationId: ctx.presentationId, requests: [
|
|
57
|
+
{ replaceAllText: { containsText: { text: '___unlikely___', matchCase: true }, replaceText: '___unlikely___' } },
|
|
58
|
+
] })
|
|
59
|
+
expect(res?.presentationId || Array.isArray(res?.replies) || res?.writeControl).toBeTruthy()
|
|
60
|
+
}, 60000)
|
|
61
|
+
|
|
62
|
+
it('append_text_to_title_of_slide_index appends to title', async () => {
|
|
63
|
+
if (!ctx.presentationId)
|
|
64
|
+
return expect(true).toBe(true)
|
|
65
|
+
const handler = slides.write('append_text_to_title_of_slide_index')
|
|
66
|
+
const res = await handler({ presentationId: ctx.presentationId, slideIndex: 0, text: ` CmdTest ${Date.now()}` })
|
|
67
|
+
expect(res?.presentationId || Array.isArray(res?.replies)).toBeTruthy()
|
|
68
|
+
}, 60000)
|
|
69
|
+
|
|
70
|
+
it('replace_text_first_match replaces text (no-op ok)', async () => {
|
|
71
|
+
if (!ctx.presentationId)
|
|
72
|
+
return expect(true).toBe(true)
|
|
73
|
+
const handler = slides.write('replace_text_first_match')
|
|
74
|
+
const res = await handler({ presentationId: ctx.presentationId, findText: '___unlikely___', replaceText: '___unlikely___' })
|
|
75
|
+
expect(res?.presentationId || Array.isArray(res?.replies)).toBeTruthy()
|
|
76
|
+
}, 60000)
|
|
77
|
+
|
|
78
|
+
it('style_text_first_match applies style', async () => {
|
|
79
|
+
if (!ctx.presentationId)
|
|
80
|
+
return expect(true).toBe(true)
|
|
81
|
+
if (!ctx.anchorText)
|
|
82
|
+
return expect(true).toBe(true)
|
|
83
|
+
const handler = slides.write('style_text_first_match')
|
|
84
|
+
const res = await handler({ presentationId: ctx.presentationId, findText: ctx.anchorText, textStyle: { bold: true } })
|
|
85
|
+
expect(res?.presentationId || Array.isArray(res?.replies)).toBeTruthy()
|
|
86
|
+
}, 60000)
|
|
87
|
+
|
|
88
|
+
it('insert_shape_after_first_match inserts a shape', async () => {
|
|
89
|
+
if (!ctx.presentationId)
|
|
90
|
+
return expect(true).toBe(true)
|
|
91
|
+
if (!ctx.anchorText)
|
|
92
|
+
return expect(true).toBe(true)
|
|
93
|
+
const handler = slides.write('insert_shape_after_first_match')
|
|
94
|
+
const res = await handler({ presentationId: ctx.presentationId, findText: ctx.anchorText, shapeType: 'RECTANGLE' })
|
|
95
|
+
expect(res?.presentationId || Array.isArray(res?.replies)).toBeTruthy()
|
|
96
|
+
}, 60000)
|
|
97
|
+
|
|
98
|
+
it('insert_image_after_first_match inserts an image when allowed', async () => {
|
|
99
|
+
if (!ctx.presentationId || !ctx.anchorText)
|
|
100
|
+
return expect(true).toBe(true)
|
|
101
|
+
const imageUri = 'https://www.google.com/images/branding/googlelogo/2x/googlelogo_color_272x92dp.png'
|
|
102
|
+
const handler = slides.write('insert_image_after_first_match')
|
|
103
|
+
const res = await handler({ presentationId: ctx.presentationId, findText: ctx.anchorText, uri: imageUri })
|
|
104
|
+
expect(res?.presentationId || Array.isArray(res?.replies)).toBeTruthy()
|
|
105
|
+
}, 60000)
|
|
106
|
+
|
|
107
|
+
it('create_slide_after_first_match creates a slide near anchor', async () => {
|
|
108
|
+
if (!ctx.presentationId)
|
|
109
|
+
return expect(true).toBe(true)
|
|
110
|
+
if (!ctx.anchorText)
|
|
111
|
+
return expect(true).toBe(true)
|
|
112
|
+
const handler = slides.write('create_slide_after_first_match')
|
|
113
|
+
const res = await handler({ presentationId: ctx.presentationId, findText: ctx.anchorText, layout: 'BLANK' })
|
|
114
|
+
expect(res?.presentationId || Array.isArray(res?.replies)).toBeTruthy()
|
|
115
|
+
}, 60000)
|
|
116
|
+
|
|
117
|
+
it('set_background_color_for_slide_index sets color', async () => {
|
|
118
|
+
if (!ctx.presentationId)
|
|
119
|
+
return expect(true).toBe(true)
|
|
120
|
+
const handler = slides.write('set_background_color_for_slide_index')
|
|
121
|
+
const res = await handler({ presentationId: ctx.presentationId, slideIndex: 0, rgbColor: { red: 0.9, green: 0.9, blue: 0.9 } })
|
|
122
|
+
expect(res?.presentationId || Array.isArray(res?.replies)).toBeTruthy()
|
|
123
|
+
}, 60000)
|
|
124
|
+
|
|
125
|
+
it('create_presentation creates a presentation (self-cleaning)', async () => {
|
|
126
|
+
const created = await slides.write('create_presentation')({ title: `CmdTest Slides Tool ${Date.now()}` })
|
|
127
|
+
const id = created?.presentationId
|
|
128
|
+
expect(typeof id).toBe('string')
|
|
129
|
+
await safeCleanup(async () => id ? drive.write('delete_file')({ fileId: id }) : Promise.resolve())
|
|
130
|
+
}, 60000)
|
|
131
|
+
})
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
{
|
|
2
|
+
"variants": {
|
|
3
|
+
"service_account": {
|
|
4
|
+
"label": "Service Account (recommended)",
|
|
5
|
+
"schema": {
|
|
6
|
+
"type": "object",
|
|
7
|
+
"properties": {
|
|
8
|
+
"serviceAccountJson": {
|
|
9
|
+
"type": "string",
|
|
10
|
+
"title": "Service Account JSON",
|
|
11
|
+
"description": "Full service account key JSON (contents of the downloaded JSON file from Google Cloud)."
|
|
12
|
+
},
|
|
13
|
+
"subject": {
|
|
14
|
+
"type": "string",
|
|
15
|
+
"title": "Subject / impersonated user (optional)",
|
|
16
|
+
"description": "Optional user email to impersonate when using Google Workspace domain-wide delegation."
|
|
17
|
+
},
|
|
18
|
+
"scopes": {
|
|
19
|
+
"type": "array",
|
|
20
|
+
"title": "OAuth scopes (optional)",
|
|
21
|
+
"description": "Optional override for OAuth scopes. Defaults to presentations + drive.",
|
|
22
|
+
"items": { "type": "string" }
|
|
23
|
+
}
|
|
24
|
+
},
|
|
25
|
+
"required": ["serviceAccountJson"],
|
|
26
|
+
"additionalProperties": false
|
|
27
|
+
},
|
|
28
|
+
"injection": {
|
|
29
|
+
"headers": {
|
|
30
|
+
"Authorization": "Bearer {{token}}"
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
"preprocess": "google_service_account"
|
|
34
|
+
},
|
|
35
|
+
"oauth_token": {
|
|
36
|
+
"label": "OAuth Access Token (short-lived)",
|
|
37
|
+
"schema": {
|
|
38
|
+
"type": "object",
|
|
39
|
+
"properties": {
|
|
40
|
+
"token": {
|
|
41
|
+
"type": "string",
|
|
42
|
+
"title": "OAuth Access Token",
|
|
43
|
+
"description": "Short-lived Google OAuth access token with presentations and drive scopes."
|
|
44
|
+
}
|
|
45
|
+
},
|
|
46
|
+
"required": ["token"],
|
|
47
|
+
"additionalProperties": false
|
|
48
|
+
},
|
|
49
|
+
"injection": {
|
|
50
|
+
"headers": {
|
|
51
|
+
"Authorization": "Bearer {{token}}"
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
},
|
|
56
|
+
"default": "service_account"
|
|
57
|
+
}
|
|
@@ -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`
|
|
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,8 @@
|
|
|
1
|
+
Obtain a short-lived Google OAuth access token:
|
|
2
|
+
|
|
3
|
+
1. Use the Google OAuth 2.0 Playground (`https://developers.google.com/oauthplayground/`) or your own OAuth flow
|
|
4
|
+
2. Select the scopes: `https://www.googleapis.com/auth/presentations` and `https://www.googleapis.com/auth/drive`
|
|
5
|
+
3. Exchange the authorization code for an access token
|
|
6
|
+
4. Paste the access token here
|
|
7
|
+
|
|
8
|
+
Note: OAuth access tokens are short-lived (typically 1 hour). For long-running use, prefer the Service Account variant.
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
Set up a Google Cloud Service Account:
|
|
2
|
+
|
|
3
|
+
1. Open the [Google Cloud Console](https://console.cloud.google.com/)
|
|
4
|
+
2. Enable the **Google Slides API** and **Google Drive API** for your project
|
|
5
|
+
3. Go to **IAM & Admin → Service Accounts** and create a new service account
|
|
6
|
+
4. Under **Keys**, click **Add Key → Create new key → JSON** and download the file
|
|
7
|
+
5. Paste the full contents of the JSON file here
|
|
8
|
+
6. Share your target presentations with the service account's `client_email`
|
|
9
|
+
|
|
10
|
+
For Google Workspace users: optionally configure domain-wide delegation and set `subject` to the user's email.
|
|
@@ -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
|
+
}
|