@commandable/integration-data 0.4.1 → 0.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/credentials-index.d.ts +2 -7
- package/dist/credentials-index.d.ts.map +1 -1
- package/dist/credentials-index.js +11 -677
- package/dist/credentials-index.js.map +1 -1
- package/dist/generated/registry.d.ts +3 -0
- package/dist/generated/registry.d.ts.map +1 -0
- package/dist/generated/registry.js +11907 -0
- package/dist/generated/registry.js.map +1 -0
- 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 +1 -119
- package/dist/loader.d.ts.map +1 -1
- package/dist/loader.js +91 -177
- package/dist/loader.js.map +1 -1
- package/dist/tools.d.ts +1 -1
- package/dist/tools.d.ts.map +1 -1
- package/dist/types.d.ts +92 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/package.json +6 -4
- package/integrations/README.md +0 -52
- package/integrations/__tests__/liveHarness.ts +0 -97
- package/integrations/__tests__/usageParity.ts +0 -54
- package/integrations/airtable/.env.test.example +0 -11
- package/integrations/airtable/README.md +0 -27
- package/integrations/airtable/__tests__/get_handlers.test.ts +0 -187
- package/integrations/airtable/__tests__/usage_parity.test.ts +0 -9
- package/integrations/airtable/__tests__/write_and_admin_handlers.test.ts +0 -116
- package/integrations/airtable/credentials.json +0 -26
- package/integrations/airtable/credentials_hint.md +0 -4
- package/integrations/airtable/handlers/create_record.js +0 -12
- package/integrations/airtable/handlers/delete_record.js +0 -7
- package/integrations/airtable/handlers/get_record.js +0 -4
- package/integrations/airtable/handlers/get_table_schema.js +0 -6
- package/integrations/airtable/handlers/list_bases.js +0 -4
- package/integrations/airtable/handlers/list_records.js +0 -25
- package/integrations/airtable/handlers/list_table_fields.js +0 -6
- package/integrations/airtable/handlers/list_tables.js +0 -4
- package/integrations/airtable/handlers/list_views.js +0 -6
- package/integrations/airtable/handlers/search_records.js +0 -6
- package/integrations/airtable/handlers/update_record.js +0 -11
- package/integrations/airtable/manifest.json +0 -84
- package/integrations/airtable/schemas/create_record.json +0 -12
- package/integrations/airtable/schemas/delete_record.json +0 -11
- package/integrations/airtable/schemas/empty.json +0 -6
- package/integrations/airtable/schemas/get_record.json +0 -11
- package/integrations/airtable/schemas/id_base.json +0 -9
- package/integrations/airtable/schemas/id_base_table.json +0 -10
- package/integrations/airtable/schemas/list_records.json +0 -26
- package/integrations/airtable/schemas/search_records.json +0 -12
- package/integrations/airtable/schemas/update_record.json +0 -13
- package/integrations/confluence/.env.test.example +0 -36
- package/integrations/confluence/README.md +0 -28
- package/integrations/confluence/__tests__/get_handlers.test.ts +0 -121
- package/integrations/confluence/__tests__/usage_parity.test.ts +0 -14
- package/integrations/confluence/__tests__/write_handlers.test.ts +0 -131
- package/integrations/confluence/credentials.json +0 -39
- package/integrations/confluence/credentials_hint.md +0 -4
- package/integrations/confluence/credentials_hint_api_token.md +0 -9
- package/integrations/confluence/credentials_hint_oauth_token.md +0 -8
- package/integrations/confluence/handlers/add_comment.js +0 -19
- package/integrations/confluence/handlers/add_label.js +0 -16
- package/integrations/confluence/handlers/create_page.js +0 -22
- package/integrations/confluence/handlers/delete_page.js +0 -17
- package/integrations/confluence/handlers/get_comments.js +0 -33
- package/integrations/confluence/handlers/get_page_children.js +0 -30
- package/integrations/confluence/handlers/get_space.js +0 -22
- package/integrations/confluence/handlers/list_spaces.js +0 -39
- package/integrations/confluence/handlers/read_page.js +0 -49
- package/integrations/confluence/handlers/search_pages.js +0 -42
- package/integrations/confluence/handlers/update_page.js +0 -42
- package/integrations/confluence/manifest.json +0 -85
- package/integrations/confluence/prompt.md +0 -55
- package/integrations/confluence/schemas/add_comment.json +0 -22
- package/integrations/confluence/schemas/add_label.json +0 -19
- package/integrations/confluence/schemas/create_page.json +0 -33
- package/integrations/confluence/schemas/delete_page.json +0 -23
- package/integrations/confluence/schemas/empty.json +0 -6
- package/integrations/confluence/schemas/get_comments.json +0 -24
- package/integrations/confluence/schemas/get_page_children.json +0 -28
- package/integrations/confluence/schemas/get_space.json +0 -18
- package/integrations/confluence/schemas/list_spaces.json +0 -36
- package/integrations/confluence/schemas/read_page.json +0 -28
- package/integrations/confluence/schemas/search_pages.json +0 -26
- package/integrations/confluence/schemas/update_page.json +0 -31
- package/integrations/github/.env.test.example +0 -17
- package/integrations/github/README.md +0 -75
- package/integrations/github/__tests__/get_handlers.test.ts +0 -305
- package/integrations/github/__tests__/usage_parity.test.ts +0 -22
- package/integrations/github/__tests__/write_handlers.test.ts +0 -496
- package/integrations/github/credentials.json +0 -47
- package/integrations/github/credentials_hint.md +0 -7
- package/integrations/github/credentials_hint_classic_pat.md +0 -8
- package/integrations/github/credentials_hint_fine_grained_pat.md +0 -9
- package/integrations/github/handlers/add_labels_to_issue.js +0 -12
- package/integrations/github/handlers/close_issue.js +0 -5
- package/integrations/github/handlers/comment_on_issue.js +0 -5
- package/integrations/github/handlers/create_branch.js +0 -33
- package/integrations/github/handlers/create_commit.js +0 -84
- package/integrations/github/handlers/create_file.js +0 -46
- package/integrations/github/handlers/create_issue.js +0 -10
- package/integrations/github/handlers/create_or_update_file.js +0 -21
- package/integrations/github/handlers/create_pull_request.js +0 -16
- package/integrations/github/handlers/create_pull_request_review.js +0 -10
- package/integrations/github/handlers/create_release.js +0 -14
- package/integrations/github/handlers/create_repo.js +0 -11
- package/integrations/github/handlers/delete_branch.js +0 -8
- package/integrations/github/handlers/delete_file.js +0 -22
- package/integrations/github/handlers/delete_repo.js +0 -6
- package/integrations/github/handlers/edit_file.js +0 -52
- package/integrations/github/handlers/edit_files.js +0 -107
- package/integrations/github/handlers/fork_repo.js +0 -10
- package/integrations/github/handlers/get_commit.js +0 -8
- package/integrations/github/handlers/get_file_contents.js +0 -21
- package/integrations/github/handlers/get_issue.js +0 -4
- package/integrations/github/handlers/get_job_logs.js +0 -6
- package/integrations/github/handlers/get_latest_release.js +0 -4
- package/integrations/github/handlers/get_me.js +0 -4
- package/integrations/github/handlers/get_pull_request.js +0 -4
- package/integrations/github/handlers/get_pull_request_diff.js +0 -8
- package/integrations/github/handlers/get_repo.js +0 -4
- package/integrations/github/handlers/get_repo_tree.js +0 -12
- package/integrations/github/handlers/get_workflow_run.js +0 -4
- package/integrations/github/handlers/list_branches.js +0 -9
- package/integrations/github/handlers/list_commits.js +0 -11
- package/integrations/github/handlers/list_issue_comments.js +0 -8
- package/integrations/github/handlers/list_issues.js +0 -11
- package/integrations/github/handlers/list_labels.js +0 -8
- package/integrations/github/handlers/list_pull_request_comments.js +0 -8
- package/integrations/github/handlers/list_pull_request_files.js +0 -8
- package/integrations/github/handlers/list_pull_requests.js +0 -13
- package/integrations/github/handlers/list_releases.js +0 -8
- package/integrations/github/handlers/list_repos_install.js +0 -4
- package/integrations/github/handlers/list_repos_user.js +0 -16
- package/integrations/github/handlers/list_tags.js +0 -8
- package/integrations/github/handlers/list_workflow_runs.js +0 -11
- package/integrations/github/handlers/merge_pull_request.js +0 -14
- package/integrations/github/handlers/request_pull_request_reviewers.js +0 -10
- package/integrations/github/handlers/search_code.js +0 -8
- package/integrations/github/handlers/search_issues.js +0 -8
- package/integrations/github/handlers/search_pull_requests.js +0 -8
- package/integrations/github/handlers/search_repos.js +0 -10
- package/integrations/github/handlers/update_issue.js +0 -15
- package/integrations/github/handlers/update_pull_request.js +0 -13
- package/integrations/github/manifest.json +0 -92
- package/integrations/github/prompt.md +0 -36
- package/integrations/github/schemas/add_labels_to_issue.json +0 -12
- package/integrations/github/schemas/close_issue.json +0 -10
- package/integrations/github/schemas/comment_on_issue.json +0 -11
- package/integrations/github/schemas/create_branch.json +0 -12
- package/integrations/github/schemas/create_commit.json +0 -25
- package/integrations/github/schemas/create_file.json +0 -13
- package/integrations/github/schemas/create_issue.json +0 -13
- package/integrations/github/schemas/create_or_update_file.json +0 -15
- package/integrations/github/schemas/create_pull_request.json +0 -15
- package/integrations/github/schemas/create_pull_request_review.json +0 -17
- package/integrations/github/schemas/create_release.json +0 -16
- package/integrations/github/schemas/create_repo.json +0 -12
- package/integrations/github/schemas/delete_branch.json +0 -10
- package/integrations/github/schemas/delete_file.json +0 -13
- package/integrations/github/schemas/delete_repo.json +0 -10
- package/integrations/github/schemas/edit_file.json +0 -26
- package/integrations/github/schemas/edit_files.json +0 -39
- package/integrations/github/schemas/empty.json +0 -5
- package/integrations/github/schemas/fork_repo.json +0 -11
- package/integrations/github/schemas/get_commit.json +0 -12
- package/integrations/github/schemas/get_file_contents.json +0 -11
- package/integrations/github/schemas/get_issue.json +0 -10
- package/integrations/github/schemas/get_job_logs.json +0 -10
- package/integrations/github/schemas/get_pull_request.json +0 -10
- package/integrations/github/schemas/get_pull_request_diff.json +0 -10
- package/integrations/github/schemas/get_repo.json +0 -9
- package/integrations/github/schemas/get_repo_tree.json +0 -12
- package/integrations/github/schemas/get_workflow_run.json +0 -10
- package/integrations/github/schemas/list_branches.json +0 -12
- package/integrations/github/schemas/list_commits.json +0 -14
- package/integrations/github/schemas/list_issue_comments.json +0 -12
- package/integrations/github/schemas/list_issues.json +0 -14
- package/integrations/github/schemas/list_labels.json +0 -11
- package/integrations/github/schemas/list_pull_request_comments.json +0 -12
- package/integrations/github/schemas/list_pull_request_files.json +0 -12
- package/integrations/github/schemas/list_pull_requests.json +0 -16
- package/integrations/github/schemas/list_releases.json +0 -11
- package/integrations/github/schemas/list_tags.json +0 -11
- package/integrations/github/schemas/list_workflow_runs.json +0 -18
- package/integrations/github/schemas/merge_pull_request.json +0 -14
- package/integrations/github/schemas/owner_repo.json +0 -9
- package/integrations/github/schemas/request_pull_request_reviewers.json +0 -20
- package/integrations/github/schemas/search_code.json +0 -10
- package/integrations/github/schemas/search_issues.json +0 -10
- package/integrations/github/schemas/search_pull_requests.json +0 -10
- package/integrations/github/schemas/search_repos.json +0 -12
- package/integrations/github/schemas/update_issue.json +0 -15
- package/integrations/github/schemas/update_pull_request.json +0 -15
- package/integrations/google-calendar/.env.test.example +0 -11
- package/integrations/google-calendar/README.md +0 -41
- package/integrations/google-calendar/__tests__/get_handlers.test.ts +0 -120
- package/integrations/google-calendar/__tests__/usage_parity.test.ts +0 -9
- package/integrations/google-calendar/__tests__/write_and_admin_handlers.test.ts +0 -155
- package/integrations/google-calendar/credentials.json +0 -59
- package/integrations/google-calendar/credentials_hint.md +0 -9
- package/integrations/google-calendar/credentials_hint_oauth_token.md +0 -8
- package/integrations/google-calendar/credentials_hint_service_account.md +0 -10
- package/integrations/google-calendar/handlers/create_event.js +0 -6
- package/integrations/google-calendar/handlers/delete_acl.js +0 -6
- package/integrations/google-calendar/handlers/delete_event.js +0 -7
- package/integrations/google-calendar/handlers/freebusy_query.js +0 -4
- package/integrations/google-calendar/handlers/get_acl.js +0 -5
- package/integrations/google-calendar/handlers/get_calendar.js +0 -4
- package/integrations/google-calendar/handlers/get_event.js +0 -9
- package/integrations/google-calendar/handlers/insert_acl.js +0 -6
- package/integrations/google-calendar/handlers/list_acl.js +0 -5
- package/integrations/google-calendar/handlers/list_calendars.js +0 -4
- package/integrations/google-calendar/handlers/list_colors.js +0 -4
- package/integrations/google-calendar/handlers/list_events.js +0 -23
- package/integrations/google-calendar/handlers/list_settings.js +0 -4
- package/integrations/google-calendar/handlers/move_event.js +0 -6
- package/integrations/google-calendar/handlers/patch_event.js +0 -5
- package/integrations/google-calendar/handlers/quick_add.js +0 -6
- package/integrations/google-calendar/handlers/update_acl.js +0 -7
- package/integrations/google-calendar/manifest.json +0 -36
- package/integrations/google-calendar/prompt.md +0 -68
- package/integrations/google-calendar/schemas/create_event.json +0 -34
- package/integrations/google-calendar/schemas/delete_acl.json +0 -9
- package/integrations/google-calendar/schemas/empty.json +0 -1
- package/integrations/google-calendar/schemas/freebusy_query.json +0 -13
- package/integrations/google-calendar/schemas/get_acl.json +0 -9
- package/integrations/google-calendar/schemas/id_calendar.json +0 -8
- package/integrations/google-calendar/schemas/id_calendar_event.json +0 -11
- package/integrations/google-calendar/schemas/insert_acl.json +0 -18
- package/integrations/google-calendar/schemas/list_events.json +0 -17
- package/integrations/google-calendar/schemas/move_event.json +0 -10
- package/integrations/google-calendar/schemas/patch_event.json +0 -10
- package/integrations/google-calendar/schemas/quick_add.json +0 -9
- package/integrations/google-calendar/schemas/update_acl.json +0 -10
- package/integrations/google-docs/README.md +0 -30
- package/integrations/google-docs/__tests__/get_handlers.test.ts +0 -83
- package/integrations/google-docs/__tests__/usage_parity.test.ts +0 -9
- package/integrations/google-docs/__tests__/write_handlers.test.ts +0 -238
- package/integrations/google-docs/credentials.json +0 -57
- package/integrations/google-docs/credentials_hint.md +0 -9
- package/integrations/google-docs/credentials_hint_oauth_token.md +0 -8
- package/integrations/google-docs/credentials_hint_service_account.md +0 -10
- package/integrations/google-docs/handlers/append_text.js +0 -12
- package/integrations/google-docs/handlers/batch_update.js +0 -13
- package/integrations/google-docs/handlers/create_document.js +0 -9
- package/integrations/google-docs/handlers/delete_first_match.js +0 -50
- package/integrations/google-docs/handlers/insert_inline_image_after_first_match.js +0 -41
- package/integrations/google-docs/handlers/insert_page_break_after_first_match.js +0 -49
- package/integrations/google-docs/handlers/insert_table_after_first_match.js +0 -49
- package/integrations/google-docs/handlers/insert_text_after_first_match.js +0 -51
- package/integrations/google-docs/handlers/read_document.js +0 -189
- package/integrations/google-docs/handlers/replace_all_text.js +0 -8
- package/integrations/google-docs/handlers/style_first_match.js +0 -42
- package/integrations/google-docs/handlers/update_document_style.js +0 -8
- package/integrations/google-docs/handlers/update_paragraph_style_for_first_match.js +0 -48
- package/integrations/google-docs/manifest.json +0 -44
- package/integrations/google-docs/prompt.md +0 -49
- package/integrations/google-docs/schemas/append_text.json +0 -10
- package/integrations/google-docs/schemas/apply_text_style.json +0 -13
- package/integrations/google-docs/schemas/batch_update.json +0 -16
- package/integrations/google-docs/schemas/create_document.json +0 -8
- package/integrations/google-docs/schemas/delete_content_range.json +0 -11
- package/integrations/google-docs/schemas/delete_first_match.json +0 -10
- package/integrations/google-docs/schemas/insert_inline_image.json +0 -12
- package/integrations/google-docs/schemas/insert_inline_image_after_first_match.json +0 -12
- package/integrations/google-docs/schemas/insert_page_break.json +0 -10
- package/integrations/google-docs/schemas/insert_page_break_after_first_match.json +0 -11
- package/integrations/google-docs/schemas/insert_table.json +0 -12
- package/integrations/google-docs/schemas/insert_table_after_first_match.json +0 -13
- package/integrations/google-docs/schemas/insert_text_after_first_match.json +0 -12
- package/integrations/google-docs/schemas/insert_text_at.json +0 -11
- package/integrations/google-docs/schemas/read_document.json +0 -12
- package/integrations/google-docs/schemas/replace_all_text.json +0 -12
- package/integrations/google-docs/schemas/style_first_match.json +0 -12
- package/integrations/google-docs/schemas/update_document_style.json +0 -11
- package/integrations/google-docs/schemas/update_paragraph_style.json +0 -13
- package/integrations/google-docs/schemas/update_paragraph_style_for_first_match.json +0 -12
- package/integrations/google-docs/todo.md +0 -18
- package/integrations/google-drive/README.md +0 -26
- package/integrations/google-drive/__tests__/handlers.test.ts +0 -145
- package/integrations/google-drive/__tests__/usage_parity.test.ts +0 -9
- package/integrations/google-drive/credentials.json +0 -59
- package/integrations/google-drive/credentials_hint_oauth_token.md +0 -8
- package/integrations/google-drive/credentials_hint_service_account.md +0 -10
- package/integrations/google-drive/handlers/create_file.js +0 -15
- package/integrations/google-drive/handlers/create_folder.js +0 -15
- package/integrations/google-drive/handlers/delete_file.js +0 -14
- package/integrations/google-drive/handlers/get_file.js +0 -5
- package/integrations/google-drive/handlers/get_file_content.js +0 -41
- package/integrations/google-drive/handlers/list_files.js +0 -15
- package/integrations/google-drive/handlers/move_file.js +0 -12
- package/integrations/google-drive/handlers/search_files.js +0 -20
- package/integrations/google-drive/handlers/share_file.js +0 -20
- package/integrations/google-drive/manifest.json +0 -70
- package/integrations/google-drive/prompt.md +0 -59
- package/integrations/google-drive/schemas/create_file.json +0 -12
- package/integrations/google-drive/schemas/create_folder.json +0 -11
- package/integrations/google-drive/schemas/delete_file.json +0 -10
- package/integrations/google-drive/schemas/get_file.json +0 -10
- package/integrations/google-drive/schemas/get_file_content.json +0 -11
- package/integrations/google-drive/schemas/list_files.json +0 -12
- package/integrations/google-drive/schemas/move_file.json +0 -12
- package/integrations/google-drive/schemas/search_files.json +0 -14
- package/integrations/google-drive/schemas/share_file.json +0 -23
- package/integrations/google-gmail/.env.test.example +0 -11
- package/integrations/google-gmail/README.md +0 -49
- package/integrations/google-gmail/__tests__/get_handlers.test.ts +0 -134
- package/integrations/google-gmail/__tests__/usage_parity.test.ts +0 -9
- package/integrations/google-gmail/__tests__/write_and_admin_handlers.test.ts +0 -211
- package/integrations/google-gmail/credentials.json +0 -59
- package/integrations/google-gmail/credentials_hint_oauth_token.md +0 -8
- package/integrations/google-gmail/credentials_hint_service_account.md +0 -10
- package/integrations/google-gmail/handlers/create_draft_email.js +0 -27
- package/integrations/google-gmail/handlers/create_label.js +0 -12
- package/integrations/google-gmail/handlers/delete_draft.js +0 -13
- package/integrations/google-gmail/handlers/delete_label.js +0 -13
- package/integrations/google-gmail/handlers/delete_message.js +0 -13
- package/integrations/google-gmail/handlers/delete_thread.js +0 -13
- package/integrations/google-gmail/handlers/get_draft.js +0 -6
- package/integrations/google-gmail/handlers/get_label.js +0 -6
- package/integrations/google-gmail/handlers/get_message.js +0 -14
- package/integrations/google-gmail/handlers/get_profile.js +0 -5
- package/integrations/google-gmail/handlers/get_thread.js +0 -14
- package/integrations/google-gmail/handlers/list_drafts.js +0 -15
- package/integrations/google-gmail/handlers/list_labels.js +0 -5
- package/integrations/google-gmail/handlers/list_messages.js +0 -19
- package/integrations/google-gmail/handlers/list_threads.js +0 -19
- package/integrations/google-gmail/handlers/modify_message.js +0 -11
- package/integrations/google-gmail/handlers/modify_thread.js +0 -11
- package/integrations/google-gmail/handlers/read_email.js +0 -56
- package/integrations/google-gmail/handlers/send_draft.js +0 -15
- package/integrations/google-gmail/handlers/send_email.js +0 -22
- package/integrations/google-gmail/handlers/trash_message.js +0 -6
- package/integrations/google-gmail/handlers/trash_thread.js +0 -6
- package/integrations/google-gmail/handlers/untrash_message.js +0 -6
- package/integrations/google-gmail/handlers/untrash_thread.js +0 -6
- package/integrations/google-gmail/handlers/update_label.js +0 -15
- package/integrations/google-gmail/manifest.json +0 -45
- package/integrations/google-gmail/prompt.md +0 -52
- package/integrations/google-gmail/schemas/create_draft_email.json +0 -16
- package/integrations/google-gmail/schemas/create_label.json +0 -26
- package/integrations/google-gmail/schemas/get_message.json +0 -20
- package/integrations/google-gmail/schemas/get_profile.json +0 -11
- package/integrations/google-gmail/schemas/get_thread.json +0 -20
- package/integrations/google-gmail/schemas/id_draft.json +0 -16
- package/integrations/google-gmail/schemas/id_label.json +0 -16
- package/integrations/google-gmail/schemas/id_message.json +0 -16
- package/integrations/google-gmail/schemas/id_thread.json +0 -16
- package/integrations/google-gmail/schemas/list_drafts.json +0 -30
- package/integrations/google-gmail/schemas/list_labels.json +0 -11
- package/integrations/google-gmail/schemas/list_messages.json +0 -35
- package/integrations/google-gmail/schemas/list_threads.json +0 -35
- package/integrations/google-gmail/schemas/modify_message.json +0 -24
- package/integrations/google-gmail/schemas/modify_thread.json +0 -24
- package/integrations/google-gmail/schemas/read_email.json +0 -10
- package/integrations/google-gmail/schemas/send_draft.json +0 -29
- package/integrations/google-gmail/schemas/send_email.json +0 -17
- package/integrations/google-gmail/schemas/update_label.json +0 -33
- package/integrations/google-sheet/README.md +0 -27
- package/integrations/google-sheet/__tests__/get_handlers.test.ts +0 -76
- package/integrations/google-sheet/__tests__/usage_parity.test.ts +0 -9
- package/integrations/google-sheet/__tests__/write_handlers.test.ts +0 -153
- package/integrations/google-sheet/credentials.json +0 -57
- package/integrations/google-sheet/credentials_hint.md +0 -9
- package/integrations/google-sheet/credentials_hint_oauth_token.md +0 -8
- package/integrations/google-sheet/credentials_hint_service_account.md +0 -10
- package/integrations/google-sheet/handlers/append_values.js +0 -18
- package/integrations/google-sheet/handlers/batch_clear_values.js +0 -6
- package/integrations/google-sheet/handlers/batch_update.js +0 -14
- package/integrations/google-sheet/handlers/batch_update_values.js +0 -16
- package/integrations/google-sheet/handlers/clear_values.js +0 -6
- package/integrations/google-sheet/handlers/copy_to_spreadsheet.js +0 -6
- package/integrations/google-sheet/handlers/create_spreadsheet.js +0 -5
- package/integrations/google-sheet/handlers/get_spreadsheet.js +0 -14
- package/integrations/google-sheet/handlers/read_sheet.js +0 -75
- package/integrations/google-sheet/handlers/update_values.js +0 -16
- package/integrations/google-sheet/manifest.json +0 -77
- package/integrations/google-sheet/prompt.md +0 -49
- package/integrations/google-sheet/schemas/append_values.json +0 -16
- package/integrations/google-sheet/schemas/batch_clear_values.json +0 -10
- package/integrations/google-sheet/schemas/batch_update.json +0 -13
- package/integrations/google-sheet/schemas/batch_update_values.json +0 -25
- package/integrations/google-sheet/schemas/clear_values.json +0 -10
- package/integrations/google-sheet/schemas/copy_to_spreadsheet.json +0 -11
- package/integrations/google-sheet/schemas/create_spreadsheet.json +0 -11
- package/integrations/google-sheet/schemas/get_spreadsheet.json +0 -16
- package/integrations/google-sheet/schemas/read_sheet.json +0 -21
- package/integrations/google-sheet/schemas/update_values.json +0 -15
- package/integrations/google-slides/README.md +0 -28
- package/integrations/google-slides/__tests__/get_handlers.test.ts +0 -74
- package/integrations/google-slides/__tests__/usage_parity.test.ts +0 -9
- package/integrations/google-slides/__tests__/write_handlers.test.ts +0 -131
- package/integrations/google-slides/credentials.json +0 -57
- package/integrations/google-slides/credentials_hint.md +0 -9
- package/integrations/google-slides/credentials_hint_oauth_token.md +0 -8
- package/integrations/google-slides/credentials_hint_service_account.md +0 -10
- package/integrations/google-slides/handlers/append_text_to_title_of_first_slide.js +0 -17
- package/integrations/google-slides/handlers/batch_update.js +0 -15
- package/integrations/google-slides/handlers/create_presentation.js +0 -8
- package/integrations/google-slides/handlers/create_slide_after_first_match.js +0 -20
- package/integrations/google-slides/handlers/get_page_thumbnail.js +0 -12
- package/integrations/google-slides/handlers/insert_image_after_first_match.js +0 -19
- package/integrations/google-slides/handlers/insert_shape_after_first_match.js +0 -21
- package/integrations/google-slides/handlers/read_presentation.js +0 -51
- package/integrations/google-slides/handlers/replace_text_first_match.js +0 -9
- package/integrations/google-slides/handlers/set_background_color_for_slide_index.js +0 -15
- package/integrations/google-slides/handlers/style_text_first_match.js +0 -48
- package/integrations/google-slides/manifest.json +0 -42
- package/integrations/google-slides/prompt.md +0 -56
- package/integrations/google-slides/schemas/append_text_to_title_of_first_slide.json +0 -11
- package/integrations/google-slides/schemas/batch_update.json +0 -13
- package/integrations/google-slides/schemas/create_presentation.json +0 -8
- package/integrations/google-slides/schemas/create_slide_after_first_match.json +0 -11
- package/integrations/google-slides/schemas/get_page_thumbnail.json +0 -12
- package/integrations/google-slides/schemas/get_presentation.json +0 -9
- package/integrations/google-slides/schemas/insert_image_after_first_match.json +0 -13
- package/integrations/google-slides/schemas/insert_shape_after_first_match.json +0 -13
- package/integrations/google-slides/schemas/replace_text_first_match.json +0 -12
- package/integrations/google-slides/schemas/set_background_color_for_slide_index.json +0 -11
- package/integrations/google-slides/schemas/style_text_first_match.json +0 -12
- package/integrations/hubspot/.env.test.example +0 -20
- package/integrations/hubspot/README.md +0 -48
- package/integrations/hubspot/__tests__/get_handlers.test.ts +0 -151
- package/integrations/hubspot/__tests__/usage_parity.test.ts +0 -10
- package/integrations/hubspot/__tests__/write_handlers.test.ts +0 -244
- package/integrations/hubspot/credentials.json +0 -50
- package/integrations/hubspot/credentials_hint.md +0 -20
- package/integrations/hubspot/credentials_hint_oauth_token.md +0 -16
- package/integrations/hubspot/handlers/archive_company.js +0 -13
- package/integrations/hubspot/handlers/archive_contact.js +0 -13
- package/integrations/hubspot/handlers/archive_deal.js +0 -13
- package/integrations/hubspot/handlers/archive_ticket.js +0 -13
- package/integrations/hubspot/handlers/create_association.js +0 -18
- package/integrations/hubspot/handlers/create_company.js +0 -13
- package/integrations/hubspot/handlers/create_contact.js +0 -14
- package/integrations/hubspot/handlers/create_deal.js +0 -16
- package/integrations/hubspot/handlers/create_note.js +0 -44
- package/integrations/hubspot/handlers/create_task.js +0 -48
- package/integrations/hubspot/handlers/create_ticket.js +0 -15
- package/integrations/hubspot/handlers/get_associations.js +0 -14
- package/integrations/hubspot/handlers/get_company.js +0 -18
- package/integrations/hubspot/handlers/get_contact.js +0 -18
- package/integrations/hubspot/handlers/get_deal.js +0 -18
- package/integrations/hubspot/handlers/get_ticket.js +0 -20
- package/integrations/hubspot/handlers/list_owners.js +0 -12
- package/integrations/hubspot/handlers/list_pipelines.js +0 -5
- package/integrations/hubspot/handlers/list_properties.js +0 -11
- package/integrations/hubspot/handlers/remove_association.js +0 -22
- package/integrations/hubspot/handlers/search_companies.js +0 -43
- package/integrations/hubspot/handlers/search_contacts.js +0 -43
- package/integrations/hubspot/handlers/search_deals.js +0 -43
- package/integrations/hubspot/handlers/search_notes.js +0 -43
- package/integrations/hubspot/handlers/search_tasks.js +0 -43
- package/integrations/hubspot/handlers/search_tickets.js +0 -43
- package/integrations/hubspot/handlers/update_company.js +0 -13
- package/integrations/hubspot/handlers/update_contact.js +0 -14
- package/integrations/hubspot/handlers/update_deal.js +0 -16
- package/integrations/hubspot/handlers/update_task.js +0 -17
- package/integrations/hubspot/handlers/update_ticket.js +0 -15
- package/integrations/hubspot/manifest.json +0 -231
- package/integrations/hubspot/prompt.md +0 -69
- package/integrations/hubspot/schemas/archive_company.json +0 -13
- package/integrations/hubspot/schemas/archive_contact.json +0 -13
- package/integrations/hubspot/schemas/archive_deal.json +0 -9
- package/integrations/hubspot/schemas/archive_ticket.json +0 -9
- package/integrations/hubspot/schemas/create_association.json +0 -24
- package/integrations/hubspot/schemas/create_company.json +0 -14
- package/integrations/hubspot/schemas/create_contact.json +0 -15
- package/integrations/hubspot/schemas/create_deal.json +0 -20
- package/integrations/hubspot/schemas/create_note.json +0 -37
- package/integrations/hubspot/schemas/create_task.json +0 -51
- package/integrations/hubspot/schemas/create_ticket.json +0 -16
- package/integrations/hubspot/schemas/empty.json +0 -6
- package/integrations/hubspot/schemas/get_associations.json +0 -30
- package/integrations/hubspot/schemas/get_company.json +0 -27
- package/integrations/hubspot/schemas/get_contact.json +0 -27
- package/integrations/hubspot/schemas/get_deal.json +0 -20
- package/integrations/hubspot/schemas/get_ticket.json +0 -20
- package/integrations/hubspot/schemas/list_owners.json +0 -25
- package/integrations/hubspot/schemas/list_pipelines.json +0 -13
- package/integrations/hubspot/schemas/list_properties.json +0 -17
- package/integrations/hubspot/schemas/remove_association.json +0 -24
- package/integrations/hubspot/schemas/search_companies.json +0 -56
- package/integrations/hubspot/schemas/search_contacts.json +0 -56
- package/integrations/hubspot/schemas/search_deals.json +0 -43
- package/integrations/hubspot/schemas/search_notes.json +0 -43
- package/integrations/hubspot/schemas/search_tasks.json +0 -43
- package/integrations/hubspot/schemas/search_tickets.json +0 -43
- package/integrations/hubspot/schemas/update_company.json +0 -20
- package/integrations/hubspot/schemas/update_contact.json +0 -21
- package/integrations/hubspot/schemas/update_deal.json +0 -19
- package/integrations/hubspot/schemas/update_task.json +0 -31
- package/integrations/hubspot/schemas/update_ticket.json +0 -18
- package/integrations/jira/.env.test.example +0 -41
- package/integrations/jira/README.md +0 -46
- package/integrations/jira/__tests__/get_handlers.test.ts +0 -193
- package/integrations/jira/__tests__/usage_parity.test.ts +0 -14
- package/integrations/jira/__tests__/write_handlers.test.ts +0 -157
- package/integrations/jira/credentials.json +0 -39
- package/integrations/jira/credentials_hint.md +0 -4
- package/integrations/jira/credentials_hint_api_token.md +0 -6
- package/integrations/jira/credentials_hint_oauth_token.md +0 -6
- package/integrations/jira/handlers/add_comment.js +0 -9
- package/integrations/jira/handlers/assign_issue.js +0 -11
- package/integrations/jira/handlers/create_issue.js +0 -37
- package/integrations/jira/handlers/create_sprint.js +0 -19
- package/integrations/jira/handlers/delete_issue.js +0 -10
- package/integrations/jira/handlers/get_backlog_issues.js +0 -13
- package/integrations/jira/handlers/get_board.js +0 -6
- package/integrations/jira/handlers/get_issue.js +0 -63
- package/integrations/jira/handlers/get_issue_comments.js +0 -31
- package/integrations/jira/handlers/get_myself.js +0 -14
- package/integrations/jira/handlers/get_project.js +0 -28
- package/integrations/jira/handlers/get_sprint.js +0 -5
- package/integrations/jira/handlers/get_sprint_issues.js +0 -13
- package/integrations/jira/handlers/get_transitions.js +0 -23
- package/integrations/jira/handlers/list_boards.js +0 -34
- package/integrations/jira/handlers/list_projects.js +0 -29
- package/integrations/jira/handlers/list_sprints.js +0 -29
- package/integrations/jira/handlers/move_issues_to_sprint.js +0 -11
- package/integrations/jira/handlers/search_issues.js +0 -43
- package/integrations/jira/handlers/search_users.js +0 -21
- package/integrations/jira/handlers/transition_issue.js +0 -44
- package/integrations/jira/handlers/update_issue.js +0 -40
- package/integrations/jira/handlers/update_sprint.js +0 -20
- package/integrations/jira/manifest.json +0 -204
- package/integrations/jira/prompt.md +0 -80
- package/integrations/jira/schemas/add_comment.json +0 -16
- package/integrations/jira/schemas/assign_issue.json +0 -16
- package/integrations/jira/schemas/create_issue.json +0 -49
- package/integrations/jira/schemas/create_sprint.json +0 -29
- package/integrations/jira/schemas/delete_issue.json +0 -12
- package/integrations/jira/schemas/empty.json +0 -6
- package/integrations/jira/schemas/get_backlog_issues.json +0 -33
- package/integrations/jira/schemas/get_board.json +0 -13
- package/integrations/jira/schemas/get_issue.json +0 -23
- package/integrations/jira/schemas/get_issue_comments.json +0 -23
- package/integrations/jira/schemas/get_project.json +0 -17
- package/integrations/jira/schemas/get_sprint.json +0 -13
- package/integrations/jira/schemas/get_sprint_issues.json +0 -33
- package/integrations/jira/schemas/get_transitions.json +0 -12
- package/integrations/jira/schemas/list_boards.json +0 -27
- package/integrations/jira/schemas/list_projects.json +0 -22
- package/integrations/jira/schemas/list_sprints.json +0 -29
- package/integrations/jira/schemas/move_issues_to_sprint.json +0 -19
- package/integrations/jira/schemas/search_issues.json +0 -28
- package/integrations/jira/schemas/search_users.json +0 -18
- package/integrations/jira/schemas/transition_issue.json +0 -38
- package/integrations/jira/schemas/update_issue.json +0 -47
- package/integrations/jira/schemas/update_sprint.json +0 -33
- package/integrations/new_integration_prompt.md +0 -216
- package/integrations/notion/.env.test.example +0 -13
- package/integrations/notion/README.md +0 -42
- package/integrations/notion/__tests__/get_handlers.test.ts +0 -156
- package/integrations/notion/__tests__/usage_parity.test.ts +0 -9
- package/integrations/notion/__tests__/write_and_admin_handlers.test.ts +0 -186
- package/integrations/notion/credentials.json +0 -27
- package/integrations/notion/credentials_hint.md +0 -5
- package/integrations/notion/handlers/append_block_children.js +0 -7
- package/integrations/notion/handlers/create_comment.js +0 -10
- package/integrations/notion/handlers/create_database.js +0 -11
- package/integrations/notion/handlers/create_page.js +0 -13
- package/integrations/notion/handlers/delete_block.js +0 -8
- package/integrations/notion/handlers/get_me.js +0 -4
- package/integrations/notion/handlers/list_block_children.js +0 -10
- package/integrations/notion/handlers/list_comments.js +0 -14
- package/integrations/notion/handlers/list_users.js +0 -10
- package/integrations/notion/handlers/query_database.js +0 -10
- package/integrations/notion/handlers/retrieve_block.js +0 -4
- package/integrations/notion/handlers/retrieve_database.js +0 -4
- package/integrations/notion/handlers/retrieve_page.js +0 -4
- package/integrations/notion/handlers/retrieve_page_property_item.js +0 -10
- package/integrations/notion/handlers/retrieve_user.js +0 -4
- package/integrations/notion/handlers/search.js +0 -11
- package/integrations/notion/handlers/update_block.js +0 -7
- package/integrations/notion/handlers/update_database.js +0 -10
- package/integrations/notion/handlers/update_page_properties.js +0 -10
- package/integrations/notion/manifest.json +0 -169
- package/integrations/notion/prompt.md +0 -26
- package/integrations/notion/schemas/append_block_children.json +0 -10
- package/integrations/notion/schemas/create_comment.json +0 -18
- package/integrations/notion/schemas/create_database.json +0 -18
- package/integrations/notion/schemas/create_page.json +0 -22
- package/integrations/notion/schemas/delete_block.json +0 -9
- package/integrations/notion/schemas/empty.json +0 -6
- package/integrations/notion/schemas/id_block.json +0 -9
- package/integrations/notion/schemas/id_database.json +0 -9
- package/integrations/notion/schemas/id_page.json +0 -9
- package/integrations/notion/schemas/id_user.json +0 -9
- package/integrations/notion/schemas/list_block_children.json +0 -11
- package/integrations/notion/schemas/list_comments.json +0 -15
- package/integrations/notion/schemas/list_users.json +0 -9
- package/integrations/notion/schemas/query_database.json +0 -13
- package/integrations/notion/schemas/retrieve_page_property_item.json +0 -12
- package/integrations/notion/schemas/search.json +0 -27
- package/integrations/notion/schemas/update_block.json +0 -10
- package/integrations/notion/schemas/update_database.json +0 -13
- package/integrations/notion/schemas/update_page_properties.json +0 -13
- package/integrations/trello/.env.test.example +0 -9
- package/integrations/trello/README.md +0 -50
- package/integrations/trello/__tests__/get_handlers.test.ts +0 -225
- package/integrations/trello/__tests__/usage_parity.test.ts +0 -9
- package/integrations/trello/__tests__/write_and_admin_handlers.test.ts +0 -171
- package/integrations/trello/credentials.json +0 -32
- package/integrations/trello/credentials_hint.md +0 -4
- package/integrations/trello/handlers/add_checklist_to_card.js +0 -5
- package/integrations/trello/handlers/add_member_to_card.js +0 -5
- package/integrations/trello/handlers/archive_list.js +0 -5
- package/integrations/trello/handlers/close_board.js +0 -6
- package/integrations/trello/handlers/create_board.js +0 -11
- package/integrations/trello/handlers/create_card.js +0 -13
- package/integrations/trello/handlers/create_list.js +0 -7
- package/integrations/trello/handlers/delete_board.js +0 -13
- package/integrations/trello/handlers/delete_card.js +0 -9
- package/integrations/trello/handlers/get_board.js +0 -4
- package/integrations/trello/handlers/get_board_cards.js +0 -4
- package/integrations/trello/handlers/get_board_custom_fields.js +0 -4
- package/integrations/trello/handlers/get_board_labels.js +0 -4
- package/integrations/trello/handlers/get_board_lists.js +0 -4
- package/integrations/trello/handlers/get_board_members.js +0 -4
- package/integrations/trello/handlers/get_board_memberships.js +0 -4
- package/integrations/trello/handlers/get_card.js +0 -4
- package/integrations/trello/handlers/get_card_actions.js +0 -4
- package/integrations/trello/handlers/get_card_attachments.js +0 -4
- package/integrations/trello/handlers/get_card_checklists.js +0 -4
- package/integrations/trello/handlers/get_card_custom_field_items.js +0 -4
- package/integrations/trello/handlers/get_card_members.js +0 -4
- package/integrations/trello/handlers/get_list.js +0 -4
- package/integrations/trello/handlers/get_list_cards.js +0 -4
- package/integrations/trello/handlers/get_member.js +0 -4
- package/integrations/trello/handlers/get_member_boards.js +0 -4
- package/integrations/trello/handlers/get_member_organizations.js +0 -4
- package/integrations/trello/handlers/get_organization.js +0 -4
- package/integrations/trello/handlers/get_organization_boards.js +0 -4
- package/integrations/trello/handlers/move_card_to_list.js +0 -5
- package/integrations/trello/handlers/remove_member_from_card.js +0 -9
- package/integrations/trello/handlers/search.js +0 -5
- package/integrations/trello/handlers/update_card.js +0 -19
- package/integrations/trello/handlers/update_list.js +0 -11
- package/integrations/trello/manifest.json +0 -245
- package/integrations/trello/schemas/add_checklist_to_card.json +0 -10
- package/integrations/trello/schemas/add_member_to_card.json +0 -10
- package/integrations/trello/schemas/archive_list.json +0 -9
- package/integrations/trello/schemas/close_board.json +0 -10
- package/integrations/trello/schemas/create_board.json +0 -12
- package/integrations/trello/schemas/create_card.json +0 -13
- package/integrations/trello/schemas/create_list.json +0 -11
- package/integrations/trello/schemas/delete_board.json +0 -10
- package/integrations/trello/schemas/delete_card.json +0 -9
- package/integrations/trello/schemas/display_trello_cards.json +0 -45
- package/integrations/trello/schemas/empty.json +0 -5
- package/integrations/trello/schemas/get_member.json +0 -5
- package/integrations/trello/schemas/id_board.json +0 -8
- package/integrations/trello/schemas/id_card.json +0 -8
- package/integrations/trello/schemas/id_list.json +0 -8
- package/integrations/trello/schemas/id_org.json +0 -8
- package/integrations/trello/schemas/move_card_to_list.json +0 -10
- package/integrations/trello/schemas/remove_member_from_card.json +0 -10
- package/integrations/trello/schemas/search.json +0 -8
- package/integrations/trello/schemas/update_card.json +0 -16
- package/integrations/trello/schemas/update_list.json +0 -12
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const { documentId, findText, position } = input
|
|
3
|
-
const marker = `__CMD_MARK_${Date.now()}__`
|
|
4
|
-
const replaceRes = await integration.fetch(`/documents/${encodeURIComponent(documentId)}:batchUpdate`, {
|
|
5
|
-
method: 'POST',
|
|
6
|
-
body: { requests: [{ replaceAllText: { containsText: { text: findText, matchCase: false }, replaceText: marker } }] },
|
|
7
|
-
})
|
|
8
|
-
await replaceRes.json()
|
|
9
|
-
|
|
10
|
-
const getRes = await integration.fetch(`/documents/${encodeURIComponent(documentId)}`)
|
|
11
|
-
const doc = await getRes.json()
|
|
12
|
-
let baseIndex = -1
|
|
13
|
-
for (const el of (doc?.body?.content || [])) {
|
|
14
|
-
const p = el.paragraph
|
|
15
|
-
if (!p)
|
|
16
|
-
continue
|
|
17
|
-
for (const e of (p.elements || [])) {
|
|
18
|
-
const t = e?.textRun?.content
|
|
19
|
-
if (!t)
|
|
20
|
-
continue
|
|
21
|
-
const idx = t.indexOf(marker)
|
|
22
|
-
if (idx >= 0) {
|
|
23
|
-
const elStart = e.startIndex || 1
|
|
24
|
-
const startIndex = elStart + idx
|
|
25
|
-
const endIndex = startIndex + marker.length
|
|
26
|
-
baseIndex = position === 'before' ? startIndex : endIndex
|
|
27
|
-
break
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
if (baseIndex >= 0)
|
|
31
|
-
break
|
|
32
|
-
}
|
|
33
|
-
if (baseIndex < 0) {
|
|
34
|
-
const confirm = await integration.fetch(`/documents/${encodeURIComponent(documentId)}`)
|
|
35
|
-
const got = await confirm.json()
|
|
36
|
-
return { documentId: got?.documentId || documentId, applied: false, replies: [] }
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
const requests = []
|
|
40
|
-
requests.push({ insertPageBreak: { location: { index: baseIndex } } })
|
|
41
|
-
requests.push({ replaceAllText: { containsText: { text: marker, matchCase: true }, replaceText: findText } })
|
|
42
|
-
const res = await integration.fetch(`/documents/${encodeURIComponent(documentId)}:batchUpdate`, { method: 'POST', body: { requests } })
|
|
43
|
-
const out = await res.json()
|
|
44
|
-
if (out?.documentId || Array.isArray(out?.replies))
|
|
45
|
-
return { ...out, applied: true }
|
|
46
|
-
const confirm = await integration.fetch(`/documents/${encodeURIComponent(documentId)}`)
|
|
47
|
-
const got = await confirm.json()
|
|
48
|
-
return { documentId: got?.documentId || documentId, applied: true, replies: Array.isArray(out?.replies) ? out.replies : [] }
|
|
49
|
-
}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const { documentId, findText, rows, columns, position } = input
|
|
3
|
-
const marker = `__CMD_MARK_${Date.now()}__`
|
|
4
|
-
const replaceRes = await integration.fetch(`/documents/${encodeURIComponent(documentId)}:batchUpdate`, {
|
|
5
|
-
method: 'POST',
|
|
6
|
-
body: { requests: [{ replaceAllText: { containsText: { text: findText, matchCase: false }, replaceText: marker } }] },
|
|
7
|
-
})
|
|
8
|
-
await replaceRes.json()
|
|
9
|
-
|
|
10
|
-
const getRes = await integration.fetch(`/documents/${encodeURIComponent(documentId)}`)
|
|
11
|
-
const doc = await getRes.json()
|
|
12
|
-
let baseIndex = -1
|
|
13
|
-
for (const el of (doc?.body?.content || [])) {
|
|
14
|
-
const p = el.paragraph
|
|
15
|
-
if (!p)
|
|
16
|
-
continue
|
|
17
|
-
for (const e of (p.elements || [])) {
|
|
18
|
-
const t = e?.textRun?.content
|
|
19
|
-
if (!t)
|
|
20
|
-
continue
|
|
21
|
-
const idx = t.indexOf(marker)
|
|
22
|
-
if (idx >= 0) {
|
|
23
|
-
const elStart = e.startIndex || 1
|
|
24
|
-
const startIndex = elStart + idx
|
|
25
|
-
const endIndex = startIndex + marker.length
|
|
26
|
-
baseIndex = position === 'before' ? startIndex : endIndex
|
|
27
|
-
break
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
if (baseIndex >= 0)
|
|
31
|
-
break
|
|
32
|
-
}
|
|
33
|
-
if (baseIndex < 0) {
|
|
34
|
-
const confirm = await integration.fetch(`/documents/${encodeURIComponent(documentId)}`)
|
|
35
|
-
const got = await confirm.json()
|
|
36
|
-
return { documentId: got?.documentId || documentId, applied: false, replies: [] }
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
const requests = []
|
|
40
|
-
requests.push({ insertTable: { location: { index: baseIndex }, rows, columns } })
|
|
41
|
-
requests.push({ replaceAllText: { containsText: { text: marker, matchCase: true }, replaceText: findText } })
|
|
42
|
-
const res = await integration.fetch(`/documents/${encodeURIComponent(documentId)}:batchUpdate`, { method: 'POST', body: { requests } })
|
|
43
|
-
const out = await res.json()
|
|
44
|
-
if (out?.documentId || Array.isArray(out?.replies))
|
|
45
|
-
return { ...out, applied: true }
|
|
46
|
-
const confirm = await integration.fetch(`/documents/${encodeURIComponent(documentId)}`)
|
|
47
|
-
const got = await confirm.json()
|
|
48
|
-
return { documentId: got?.documentId || documentId, applied: true, replies: Array.isArray(out?.replies) ? out.replies : [] }
|
|
49
|
-
}
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const { documentId, findText, insertText, position } = input
|
|
3
|
-
const marker = `__CMD_MARK_${Date.now()}__`
|
|
4
|
-
// Replace first occurrence by marker only (simulate single by replacing all, then revert later to first span)
|
|
5
|
-
const replaceRes = await integration.fetch(`/documents/${encodeURIComponent(documentId)}:batchUpdate`, {
|
|
6
|
-
method: 'POST',
|
|
7
|
-
body: { requests: [{ replaceAllText: { containsText: { text: findText, matchCase: false }, replaceText: marker } }] },
|
|
8
|
-
})
|
|
9
|
-
await replaceRes.json()
|
|
10
|
-
|
|
11
|
-
const getRes = await integration.fetch(`/documents/${encodeURIComponent(documentId)}`)
|
|
12
|
-
const doc = await getRes.json()
|
|
13
|
-
let insertIndex = -1
|
|
14
|
-
for (const el of (doc?.body?.content || [])) {
|
|
15
|
-
const p = el.paragraph
|
|
16
|
-
if (!p)
|
|
17
|
-
continue
|
|
18
|
-
for (const e of (p.elements || [])) {
|
|
19
|
-
const t = e?.textRun?.content
|
|
20
|
-
if (!t)
|
|
21
|
-
continue
|
|
22
|
-
const idx = t.indexOf(marker)
|
|
23
|
-
if (idx >= 0) {
|
|
24
|
-
const elStart = e.startIndex || 1
|
|
25
|
-
const startIndex = elStart + idx
|
|
26
|
-
const endIndex = startIndex + marker.length
|
|
27
|
-
insertIndex = position === 'before' ? startIndex : endIndex
|
|
28
|
-
break
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
if (insertIndex >= 0)
|
|
32
|
-
break
|
|
33
|
-
}
|
|
34
|
-
if (insertIndex < 0) {
|
|
35
|
-
const confirm = await integration.fetch(`/documents/${encodeURIComponent(documentId)}`)
|
|
36
|
-
const got = await confirm.json()
|
|
37
|
-
return { documentId: got?.documentId || documentId, applied: false, replies: [] }
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
const requests = []
|
|
41
|
-
requests.push({ insertText: { text: insertText, location: { index: insertIndex } } })
|
|
42
|
-
// restore marker back to original findText everywhere
|
|
43
|
-
requests.push({ replaceAllText: { containsText: { text: marker, matchCase: true }, replaceText: findText } })
|
|
44
|
-
const res = await integration.fetch(`/documents/${encodeURIComponent(documentId)}:batchUpdate`, { method: 'POST', body: { requests } })
|
|
45
|
-
const out = await res.json()
|
|
46
|
-
if (out?.documentId || Array.isArray(out?.replies))
|
|
47
|
-
return { ...out, applied: true }
|
|
48
|
-
const confirm = await integration.fetch(`/documents/${encodeURIComponent(documentId)}`)
|
|
49
|
-
const got = await confirm.json()
|
|
50
|
-
return { documentId: got?.documentId || documentId, applied: true, replies: Array.isArray(out?.replies) ? out.replies : [] }
|
|
51
|
-
}
|
|
@@ -1,189 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const MONO_FONTS = new Set([
|
|
3
|
-
'Courier',
|
|
4
|
-
'Courier New',
|
|
5
|
-
'Consolas',
|
|
6
|
-
'Menlo',
|
|
7
|
-
'Monaco',
|
|
8
|
-
'Roboto Mono',
|
|
9
|
-
'Source Code Pro',
|
|
10
|
-
])
|
|
11
|
-
|
|
12
|
-
const HEADING_MAP = {
|
|
13
|
-
TITLE: '#',
|
|
14
|
-
SUBTITLE: '##',
|
|
15
|
-
HEADING_1: '#',
|
|
16
|
-
HEADING_2: '##',
|
|
17
|
-
HEADING_3: '###',
|
|
18
|
-
HEADING_4: '####',
|
|
19
|
-
HEADING_5: '#####',
|
|
20
|
-
HEADING_6: '######',
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
const BULLET_GLYPHS = new Set([
|
|
24
|
-
'BULLET_DISC_CIRCLE_SQUARE',
|
|
25
|
-
'BULLET_DIAMONDX_ARROW3D_SQUARE',
|
|
26
|
-
'BULLET_CHECKBOX',
|
|
27
|
-
'BULLET_ARROW_DIAMOND_DISC',
|
|
28
|
-
'BULLET_STAR_CIRCLE_SQUARE',
|
|
29
|
-
])
|
|
30
|
-
|
|
31
|
-
const LIST_NUMBER_GLYPHS = new Set([
|
|
32
|
-
'DECIMAL',
|
|
33
|
-
'ZERO_DECIMAL',
|
|
34
|
-
'UPPER_ALPHA',
|
|
35
|
-
'ALPHA',
|
|
36
|
-
'UPPER_ROMAN',
|
|
37
|
-
'ROMAN',
|
|
38
|
-
])
|
|
39
|
-
|
|
40
|
-
const trimEndWhitespace = (value) => (value || '').replace(/[ \t]+$/g, '')
|
|
41
|
-
|
|
42
|
-
const escapeCell = (value) =>
|
|
43
|
-
String(value ?? '')
|
|
44
|
-
.replace(/\|/g, '\\|')
|
|
45
|
-
.replace(/\r?\n/g, '<br>')
|
|
46
|
-
|
|
47
|
-
const extractPlainTextFromParagraph = (paragraph) => {
|
|
48
|
-
let text = ''
|
|
49
|
-
for (const element of paragraph?.elements || []) {
|
|
50
|
-
text += element?.textRun?.content || ''
|
|
51
|
-
}
|
|
52
|
-
return trimEndWhitespace(text)
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
const applyTextStyle = (text, textStyle = {}) => {
|
|
56
|
-
const raw = (text || '').replace(/\n/g, '')
|
|
57
|
-
if (!raw) return ''
|
|
58
|
-
|
|
59
|
-
let out = raw
|
|
60
|
-
if (textStyle.link?.url) out = `[${out}](${textStyle.link.url})`
|
|
61
|
-
|
|
62
|
-
const fontFamily = textStyle.weightedFontFamily?.fontFamily || ''
|
|
63
|
-
const isMono = textStyle.smallCaps || MONO_FONTS.has(fontFamily)
|
|
64
|
-
|
|
65
|
-
if (isMono) out = `\`${out}\``
|
|
66
|
-
if (textStyle.bold) out = `**${out}**`
|
|
67
|
-
if (textStyle.italic) out = `*${out}*`
|
|
68
|
-
if (textStyle.strikethrough) out = `~~${out}~~`
|
|
69
|
-
|
|
70
|
-
return out
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
const paragraphToMarkdown = (paragraph, docLists) => {
|
|
74
|
-
const styleType = paragraph?.paragraphStyle?.namedStyleType
|
|
75
|
-
const headingPrefix = HEADING_MAP[styleType] || ''
|
|
76
|
-
|
|
77
|
-
let line = ''
|
|
78
|
-
for (const element of paragraph?.elements || []) {
|
|
79
|
-
line += applyTextStyle(element?.textRun?.content || '', element?.textRun?.textStyle || {})
|
|
80
|
-
}
|
|
81
|
-
line = trimEndWhitespace(line)
|
|
82
|
-
|
|
83
|
-
if (!line) return ''
|
|
84
|
-
|
|
85
|
-
const bullet = paragraph?.bullet
|
|
86
|
-
if (bullet) {
|
|
87
|
-
const nestingLevel = bullet.nestingLevel || 0
|
|
88
|
-
const listMeta = docLists?.[bullet.listId]
|
|
89
|
-
const nesting = listMeta?.listProperties?.nestingLevels?.[nestingLevel]
|
|
90
|
-
const glyphType = nesting?.glyphType || ''
|
|
91
|
-
const isNumbered = LIST_NUMBER_GLYPHS.has(glyphType) && !BULLET_GLYPHS.has(glyphType)
|
|
92
|
-
const indent = ' '.repeat(Math.max(0, nestingLevel))
|
|
93
|
-
return `${indent}${isNumbered ? '1.' : '-'} ${line}`
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
if (headingPrefix) return `${headingPrefix} ${line}`
|
|
97
|
-
return line
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
const tableToMarkdown = (table, docLists) => {
|
|
101
|
-
const rows = table?.tableRows || []
|
|
102
|
-
if (!rows.length) return ''
|
|
103
|
-
|
|
104
|
-
const normalized = rows.map((row) =>
|
|
105
|
-
(row?.tableCells || []).map((cell) => {
|
|
106
|
-
const parts = []
|
|
107
|
-
for (const c of cell?.content || []) {
|
|
108
|
-
if (c?.paragraph) {
|
|
109
|
-
const p = paragraphToMarkdown(c.paragraph, docLists)
|
|
110
|
-
if (p) parts.push(p)
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
return escapeCell(parts.join('<br>'))
|
|
114
|
-
}),
|
|
115
|
-
)
|
|
116
|
-
|
|
117
|
-
const width = Math.max(...normalized.map((r) => r.length), 1)
|
|
118
|
-
const padded = normalized.map((r) => [...r, ...Array(width - r.length).fill('')])
|
|
119
|
-
const header = padded[0] || Array(width).fill('')
|
|
120
|
-
const separator = Array(width).fill('---')
|
|
121
|
-
const body = padded.slice(1)
|
|
122
|
-
|
|
123
|
-
const lines = [
|
|
124
|
-
`| ${header.join(' | ')} |`,
|
|
125
|
-
`| ${separator.join(' | ')} |`,
|
|
126
|
-
...body.map((r) => `| ${r.join(' | ')} |`),
|
|
127
|
-
]
|
|
128
|
-
return lines.join('\n')
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
const docToPlainText = (docBodyContent) => {
|
|
132
|
-
const lines = []
|
|
133
|
-
for (const item of docBodyContent || []) {
|
|
134
|
-
if (item?.paragraph) {
|
|
135
|
-
const text = extractPlainTextFromParagraph(item.paragraph)
|
|
136
|
-
if (text) lines.push(text)
|
|
137
|
-
} else if (item?.table) {
|
|
138
|
-
for (const row of item.table.tableRows || []) {
|
|
139
|
-
const cells = (row.tableCells || []).map((cell) => {
|
|
140
|
-
const pieces = []
|
|
141
|
-
for (const contentItem of cell.content || []) {
|
|
142
|
-
if (contentItem?.paragraph) {
|
|
143
|
-
const text = extractPlainTextFromParagraph(contentItem.paragraph)
|
|
144
|
-
if (text) pieces.push(text)
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
return pieces.join(' ')
|
|
148
|
-
})
|
|
149
|
-
if (cells.some(Boolean)) lines.push(cells.join(' | '))
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
return lines.join('\n\n').trim()
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
const { documentId } = input
|
|
157
|
-
const res = await integration.fetch(`/documents/${encodeURIComponent(documentId)}`)
|
|
158
|
-
const doc = await res.json()
|
|
159
|
-
|
|
160
|
-
const content = doc?.body?.content || []
|
|
161
|
-
const lists = doc?.lists || {}
|
|
162
|
-
|
|
163
|
-
const blocks = []
|
|
164
|
-
for (const item of content) {
|
|
165
|
-
if (item?.paragraph) {
|
|
166
|
-
const line = paragraphToMarkdown(item.paragraph, lists)
|
|
167
|
-
if (line) blocks.push(line)
|
|
168
|
-
} else if (item?.table) {
|
|
169
|
-
const table = tableToMarkdown(item.table, lists)
|
|
170
|
-
if (table) blocks.push(table)
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
const markdown = blocks.join('\n\n').trim()
|
|
175
|
-
if (markdown) {
|
|
176
|
-
return {
|
|
177
|
-
documentId: doc?.documentId || documentId,
|
|
178
|
-
title: doc?.title || '',
|
|
179
|
-
markdown,
|
|
180
|
-
}
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
// Escape hatch: return plain text if markdown conversion produced nothing.
|
|
184
|
-
return {
|
|
185
|
-
documentId: doc?.documentId || documentId,
|
|
186
|
-
title: doc?.title || '',
|
|
187
|
-
markdown: docToPlainText(content),
|
|
188
|
-
}
|
|
189
|
-
}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const { documentId, findText, replaceText, matchCase } = input
|
|
3
|
-
const res = await integration.fetch(`/documents/${encodeURIComponent(documentId)}:batchUpdate`, {
|
|
4
|
-
method: 'POST',
|
|
5
|
-
body: { requests: [{ replaceAllText: { containsText: { text: findText, matchCase: Boolean(matchCase) }, replaceText } }] },
|
|
6
|
-
})
|
|
7
|
-
return await res.json()
|
|
8
|
-
}
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const { documentId, findText, textStyle, fields } = input
|
|
3
|
-
// 1) Find first match via replaceAllText with unique marker
|
|
4
|
-
const marker = `__CMD_MARK_${Date.now()}__`
|
|
5
|
-
const replaceRes = await integration.fetch(`/documents/${encodeURIComponent(documentId)}:batchUpdate`, {
|
|
6
|
-
method: 'POST',
|
|
7
|
-
body: { requests: [{ replaceAllText: { containsText: { text: findText, matchCase: false }, replaceText: marker } }] },
|
|
8
|
-
})
|
|
9
|
-
const rep = await replaceRes.json()
|
|
10
|
-
// 2) Get doc, locate marker, compute indices
|
|
11
|
-
const getRes = await integration.fetch(`/documents/${encodeURIComponent(documentId)}`)
|
|
12
|
-
const doc = await getRes.json()
|
|
13
|
-
let startIndex = -1
|
|
14
|
-
let endIndex = -1
|
|
15
|
-
for (const el of (doc?.body?.content || [])) {
|
|
16
|
-
const p = el.paragraph
|
|
17
|
-
if (!p)
|
|
18
|
-
continue
|
|
19
|
-
for (const e of (p.elements || [])) {
|
|
20
|
-
const t = e?.textRun?.content
|
|
21
|
-
if (!t)
|
|
22
|
-
continue
|
|
23
|
-
const idx = t.indexOf(marker)
|
|
24
|
-
if (idx >= 0) {
|
|
25
|
-
const elStart = e.startIndex || 1
|
|
26
|
-
startIndex = elStart + idx
|
|
27
|
-
endIndex = startIndex + marker.length
|
|
28
|
-
break
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
if (startIndex >= 0)
|
|
32
|
-
break
|
|
33
|
-
}
|
|
34
|
-
if (startIndex < 0)
|
|
35
|
-
return rep
|
|
36
|
-
// 3) Apply style and restore original text
|
|
37
|
-
const requests = []
|
|
38
|
-
requests.push({ updateTextStyle: { range: { startIndex, endIndex }, textStyle, fields: fields || Object.keys(textStyle || {}).join(',') } })
|
|
39
|
-
requests.push({ replaceAllText: { containsText: { text: marker, matchCase: true }, replaceText: findText } })
|
|
40
|
-
const res = await integration.fetch(`/documents/${encodeURIComponent(documentId)}:batchUpdate`, { method: 'POST', body: { requests } })
|
|
41
|
-
return await res.json()
|
|
42
|
-
}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const { documentId, documentStyle, fields } = input
|
|
3
|
-
const res = await integration.fetch(`/documents/${encodeURIComponent(documentId)}:batchUpdate`, {
|
|
4
|
-
method: 'POST',
|
|
5
|
-
body: { requests: [{ updateDocumentStyle: { documentStyle, fields: fields || Object.keys(documentStyle || {}).join(',') } }] },
|
|
6
|
-
})
|
|
7
|
-
return await res.json()
|
|
8
|
-
}
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const { documentId, findText, paragraphStyle, fields } = input
|
|
3
|
-
const marker = `__CMD_MARK_${Date.now()}__`
|
|
4
|
-
const replaceRes = await integration.fetch(`/documents/${encodeURIComponent(documentId)}:batchUpdate`, {
|
|
5
|
-
method: 'POST',
|
|
6
|
-
body: { requests: [{ replaceAllText: { containsText: { text: findText, matchCase: false }, replaceText: marker } }] },
|
|
7
|
-
})
|
|
8
|
-
await replaceRes.json()
|
|
9
|
-
|
|
10
|
-
const getRes = await integration.fetch(`/documents/${encodeURIComponent(documentId)}`)
|
|
11
|
-
const doc = await getRes.json()
|
|
12
|
-
let paragraphStart = -1
|
|
13
|
-
let paragraphEnd = -1
|
|
14
|
-
for (const el of (doc?.body?.content || [])) {
|
|
15
|
-
const p = el.paragraph
|
|
16
|
-
if (!p)
|
|
17
|
-
continue
|
|
18
|
-
for (const e of (p.elements || [])) {
|
|
19
|
-
const t = e?.textRun?.content
|
|
20
|
-
if (!t)
|
|
21
|
-
continue
|
|
22
|
-
const idx = t.indexOf(marker)
|
|
23
|
-
if (idx >= 0) {
|
|
24
|
-
paragraphStart = p.elements?.[0]?.startIndex || e.startIndex || 1
|
|
25
|
-
paragraphEnd = (p.elements?.[p.elements.length - 1]?.endIndex) || (e.endIndex) || (paragraphStart + marker.length)
|
|
26
|
-
break
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
if (paragraphStart >= 0)
|
|
30
|
-
break
|
|
31
|
-
}
|
|
32
|
-
if (paragraphStart < 0) {
|
|
33
|
-
const confirm = await integration.fetch(`/documents/${encodeURIComponent(documentId)}`)
|
|
34
|
-
const got = await confirm.json()
|
|
35
|
-
return { documentId: got?.documentId || documentId, applied: false, replies: [] }
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
const requests = []
|
|
39
|
-
requests.push({ updateParagraphStyle: { range: { startIndex: paragraphStart, endIndex: paragraphEnd }, paragraphStyle, fields: fields || Object.keys(paragraphStyle || {}).join(',') } })
|
|
40
|
-
requests.push({ replaceAllText: { containsText: { text: marker, matchCase: true }, replaceText: findText } })
|
|
41
|
-
const res = await integration.fetch(`/documents/${encodeURIComponent(documentId)}:batchUpdate`, { method: 'POST', body: { requests } })
|
|
42
|
-
const out = await res.json()
|
|
43
|
-
if (out?.documentId || Array.isArray(out?.replies))
|
|
44
|
-
return { ...out, applied: true }
|
|
45
|
-
const confirm = await integration.fetch(`/documents/${encodeURIComponent(documentId)}`)
|
|
46
|
-
const got = await confirm.json()
|
|
47
|
-
return { documentId: got?.documentId || documentId, applied: true, replies: Array.isArray(out?.replies) ? out.replies : [] }
|
|
48
|
-
}
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "google-docs",
|
|
3
|
-
"version": "0.1.0",
|
|
4
|
-
"baseUrl": "https://docs.googleapis.com/v1",
|
|
5
|
-
"tools": [
|
|
6
|
-
{
|
|
7
|
-
"name": "read_document",
|
|
8
|
-
"description": "Read a Google Doc and return its content as clean Markdown. Preserves headings, bold, italic, strikethrough, links, code spans, ordered/unordered lists with nesting, and tables. This is the standard way to read document content. For editing, use append_text, replace_all_text, first-match tools, or batch_update.",
|
|
9
|
-
"inputSchema": "schemas/read_document.json",
|
|
10
|
-
"handler": "handlers/read_document.js",
|
|
11
|
-
"scope": "read"
|
|
12
|
-
},
|
|
13
|
-
{
|
|
14
|
-
"name": "create_document",
|
|
15
|
-
"description": "Create a new empty Google Doc with the given title. Returns the created document's metadata including its documentId, which is needed for all subsequent operations on the document.",
|
|
16
|
-
"inputSchema": "schemas/create_document.json",
|
|
17
|
-
"handler": "handlers/create_document.js",
|
|
18
|
-
"scope": "write"
|
|
19
|
-
},
|
|
20
|
-
{
|
|
21
|
-
"name": "batch_update",
|
|
22
|
-
"description": "Send a documents.batchUpdate request to modify a document with one or more structured requests. Supports insertText, deleteContentRange, replaceAllText, createNamedRange, updateTextStyle, updateParagraphStyle, insertTable, insertInlineImage, and more. For common operations, prefer the higher-level tools: append_text, replace_all_text, and the first-match tools. Use batch_update for operations not covered by those helpers.",
|
|
23
|
-
"inputSchema": "schemas/batch_update.json",
|
|
24
|
-
"handler": "handlers/batch_update.js",
|
|
25
|
-
"scope": "write"
|
|
26
|
-
},
|
|
27
|
-
{ "name": "append_text", "description": "Append plain text to the end of a Google Doc. Automatically fetches the document to find the correct end index and inserts the text there. Use this for adding content to the end of a document without needing to know the document structure.", "inputSchema": "schemas/append_text.json", "handler": "handlers/append_text.js", "scope": "write" },
|
|
28
|
-
{ "name": "replace_all_text", "description": "Replace all occurrences of a text string in a Google Doc with new text. Case-sensitive by default. More efficient than the first-match tools when you need to replace every occurrence. Returns the number of occurrences replaced.", "inputSchema": "schemas/replace_all_text.json", "handler": "handlers/replace_all_text.js", "scope": "write" },
|
|
29
|
-
{ "name": "style_first_match", "description": "Find the first occurrence of text in a document and apply a TextStyle to it (bold, italic, fontSize, foregroundColor, etc.). Uses a marker-based approach: replaces the text with a unique marker, locates the marker's position, applies the style, then restores the original text. Returns {applied: true/false}.", "inputSchema": "schemas/style_first_match.json", "handler": "handlers/style_first_match.js", "scope": "write" },
|
|
30
|
-
{ "name": "insert_text_after_first_match", "description": "Find the first occurrence of text and insert new text immediately before or after it. Useful for inserting content at a specific anchor point in the document without knowing exact character indices. Returns {applied: true/false}.", "inputSchema": "schemas/insert_text_after_first_match.json", "handler": "handlers/insert_text_after_first_match.js", "scope": "write" },
|
|
31
|
-
{ "name": "insert_table_after_first_match", "description": "Find the first occurrence of text and insert a table with the specified number of rows and columns nearby. Returns {applied: true/false}.", "inputSchema": "schemas/insert_table_after_first_match.json", "handler": "handlers/insert_table_after_first_match.js", "scope": "write" },
|
|
32
|
-
{ "name": "insert_page_break_after_first_match", "description": "Find the first occurrence of text and insert a page break nearby. Useful for structuring long documents. Returns {applied: true/false}.", "inputSchema": "schemas/insert_page_break_after_first_match.json", "handler": "handlers/insert_page_break_after_first_match.js", "scope": "write" },
|
|
33
|
-
{ "name": "insert_inline_image_after_first_match", "description": "Find the first occurrence of text and insert an inline image nearby, referenced by URL. Returns {applied: true/false}.", "inputSchema": "schemas/insert_inline_image_after_first_match.json", "handler": "handlers/insert_inline_image_after_first_match.js", "scope": "write" },
|
|
34
|
-
{ "name": "delete_first_match", "description": "Find the first occurrence of text in the document and delete it. Only the first match is removed. Use replace_all_text with an empty string to remove all occurrences. Returns {applied: true/false}.", "inputSchema": "schemas/delete_first_match.json", "handler": "handlers/delete_first_match.js", "scope": "write" },
|
|
35
|
-
{ "name": "update_paragraph_style_for_first_match", "description": "Find the first occurrence of text and update the paragraph style for the paragraph containing it. Use to apply heading levels (HEADING_1 through HEADING_6), NORMAL_TEXT, or adjust spacing, alignment, and indentation. Returns {applied: true/false}.", "inputSchema": "schemas/update_paragraph_style_for_first_match.json", "handler": "handlers/update_paragraph_style_for_first_match.js", "scope": "write" },
|
|
36
|
-
{
|
|
37
|
-
"name": "update_document_style",
|
|
38
|
-
"description": "Update document-level style properties such as page size (pageSize.width, pageSize.height in pt), margins (marginTop, marginBottom, marginLeft, marginRight in pt), and page orientation. Does not affect individual paragraph or text styles.",
|
|
39
|
-
"inputSchema": "schemas/update_document_style.json",
|
|
40
|
-
"handler": "handlers/update_document_style.js",
|
|
41
|
-
"scope": "write"
|
|
42
|
-
}
|
|
43
|
-
]
|
|
44
|
-
}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
## Reading documents
|
|
2
|
-
|
|
3
|
-
Use `read_document` as the standard read tool. It returns clean markdown with headings, lists, links, inline code, and tables preserved as much as possible.
|
|
4
|
-
|
|
5
|
-
`read_document` includes an escape hatch: if markdown conversion fails to produce useful content, it falls back to plain-text extraction so you still get readable output.
|
|
6
|
-
|
|
7
|
-
For editing workflows, read with `read_document` first, then use `append_text`, `replace_all_text`, first-match tools, or `batch_update`.
|
|
8
|
-
|
|
9
|
-
## Editing documents
|
|
10
|
-
|
|
11
|
-
The Google Docs API uses character-index-based editing, but the high-level tools handle index resolution automatically:
|
|
12
|
-
|
|
13
|
-
- **`append_text`** — adds text to the end of the document (no index needed)
|
|
14
|
-
- **`replace_all_text`** — replaces every occurrence of a string (no index needed)
|
|
15
|
-
- **First-match tools** (`style_first_match`, `insert_text_after_first_match`, etc.) — locate text by content, then act on the first match
|
|
16
|
-
|
|
17
|
-
Only use `batch_update` with raw index operations when the higher-level tools don't cover your use case.
|
|
18
|
-
|
|
19
|
-
## First-match pattern
|
|
20
|
-
|
|
21
|
-
The `*_first_match` tools use a 3-step marker approach:
|
|
22
|
-
1. Replace all occurrences of `findText` with a unique marker (`__CMD_MARK_...`)
|
|
23
|
-
2. Fetch the document to find the marker's exact character indices
|
|
24
|
-
3. Apply the operation at those indices, then restore the original text
|
|
25
|
-
|
|
26
|
-
This means each first-match operation makes 3 API calls. They return `{applied: true}` on success or `{applied: false}` if the text was not found.
|
|
27
|
-
|
|
28
|
-
## Common batch_update operations
|
|
29
|
-
|
|
30
|
-
```json
|
|
31
|
-
{ "requests": [
|
|
32
|
-
{ "insertText": { "text": "Hello", "location": { "index": 1 } } },
|
|
33
|
-
{ "deleteContentRange": { "range": { "startIndex": 5, "endIndex": 10 } } },
|
|
34
|
-
{ "updateTextStyle": {
|
|
35
|
-
"range": { "startIndex": 1, "endIndex": 6 },
|
|
36
|
-
"textStyle": { "bold": true },
|
|
37
|
-
"fields": "bold"
|
|
38
|
-
}},
|
|
39
|
-
{ "updateParagraphStyle": {
|
|
40
|
-
"range": { "startIndex": 1, "endIndex": 2 },
|
|
41
|
-
"paragraphStyle": { "namedStyleType": "HEADING_1" },
|
|
42
|
-
"fields": "namedStyleType"
|
|
43
|
-
}}
|
|
44
|
-
]}
|
|
45
|
-
```
|
|
46
|
-
|
|
47
|
-
## Document IDs
|
|
48
|
-
|
|
49
|
-
The documentId appears in the Google Docs URL: `https://docs.google.com/document/d/{documentId}/edit`
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
-
"type": "object",
|
|
4
|
-
"properties": {
|
|
5
|
-
"documentId": { "type": "string" },
|
|
6
|
-
"startIndex": { "type": "number", "minimum": 1 },
|
|
7
|
-
"endIndex": { "type": "number", "minimum": 1 },
|
|
8
|
-
"textStyle": { "type": "object", "description": "Docs API TextStyle object, e.g., { bold: true }" },
|
|
9
|
-
"fields": { "type": "string", "description": "Fields mask for update, e.g., 'bold,italic'" }
|
|
10
|
-
},
|
|
11
|
-
"required": ["documentId", "startIndex", "endIndex", "textStyle"],
|
|
12
|
-
"additionalProperties": false
|
|
13
|
-
}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
-
"type": "object",
|
|
4
|
-
"properties": {
|
|
5
|
-
"documentId": { "type": "string", "description": "The document ID of the Google Doc." },
|
|
6
|
-
"requests": {
|
|
7
|
-
"type": "array",
|
|
8
|
-
"description": "Array of Docs API requests (insertText, updateParagraphStyle, replaceAllText, etc).",
|
|
9
|
-
"items": { "type": "object" }
|
|
10
|
-
},
|
|
11
|
-
"writeControl": { "type": "object", "description": "Write control to ensure idempotency (requiredRevisionId, targetRevisionId)." },
|
|
12
|
-
"includeTabStops": { "type": "boolean", "description": "Include tab stops in responses where applicable." }
|
|
13
|
-
},
|
|
14
|
-
"required": ["documentId", "requests"],
|
|
15
|
-
"additionalProperties": true
|
|
16
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
-
"type": "object",
|
|
4
|
-
"properties": {
|
|
5
|
-
"documentId": { "type": "string" },
|
|
6
|
-
"startIndex": { "type": "number", "minimum": 1 },
|
|
7
|
-
"endIndex": { "type": "number", "minimum": 1 }
|
|
8
|
-
},
|
|
9
|
-
"required": ["documentId", "startIndex", "endIndex"],
|
|
10
|
-
"additionalProperties": false
|
|
11
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
-
"type": "object",
|
|
4
|
-
"properties": {
|
|
5
|
-
"documentId": { "type": "string" },
|
|
6
|
-
"index": { "type": "number", "minimum": 1 },
|
|
7
|
-
"uri": { "type": "string", "description": "Publicly accessible image URL" },
|
|
8
|
-
"altText": { "type": "string" }
|
|
9
|
-
},
|
|
10
|
-
"required": ["documentId", "index", "uri"],
|
|
11
|
-
"additionalProperties": false
|
|
12
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
-
"type": "object",
|
|
4
|
-
"properties": {
|
|
5
|
-
"documentId": { "type": "string" },
|
|
6
|
-
"findText": { "type": "string" },
|
|
7
|
-
"uri": { "type": "string" },
|
|
8
|
-
"position": { "type": "string", "enum": ["after", "before"], "default": "after" }
|
|
9
|
-
},
|
|
10
|
-
"required": ["documentId", "findText", "uri"],
|
|
11
|
-
"additionalProperties": false
|
|
12
|
-
}
|