@commandable/integration-data 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/credentials-index.d.ts +30 -0
- package/dist/credentials-index.d.ts.map +1 -0
- package/dist/credentials-index.js +292 -0
- package/dist/credentials-index.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -0
- package/dist/loader.d.ts +69 -0
- package/dist/loader.d.ts.map +1 -0
- package/dist/loader.js +164 -0
- package/dist/loader.js.map +1 -0
- package/integrations/README.md +52 -0
- package/integrations/airtable/__tests__/get_handlers.test.ts +137 -0
- package/integrations/airtable/__tests__/usage_parity.test.ts +35 -0
- package/integrations/airtable/__tests__/write_and_admin_handlers.test.ts +113 -0
- package/integrations/airtable/credentials.json +20 -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 +83 -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/github/__tests__/get_handlers.test.ts +117 -0
- package/integrations/github/__tests__/usage_parity.test.ts +34 -0
- package/integrations/github/__tests__/write_handlers.test.ts +311 -0
- package/integrations/github/credentials.json +20 -0
- package/integrations/github/credentials_hint.md +7 -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 +91 -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_repo.js +11 -0
- package/integrations/github/handlers/delete_repo.js +6 -0
- package/integrations/github/handlers/get_issue.js +4 -0
- package/integrations/github/handlers/get_repo.js +4 -0
- package/integrations/github/handlers/list_branches.js +4 -0
- package/integrations/github/handlers/list_commits.js +12 -0
- package/integrations/github/handlers/list_issues.js +12 -0
- package/integrations/github/handlers/list_pull_requests.js +8 -0
- package/integrations/github/handlers/list_repos_install.js +4 -0
- package/integrations/github/handlers/list_repos_user.js +4 -0
- package/integrations/github/handlers/merge_pull_request.js +14 -0
- package/integrations/github/handlers/update_issue.js +15 -0
- package/integrations/github/manifest.json +26 -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_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_repo.json +12 -0
- package/integrations/github/schemas/delete_repo.json +10 -0
- package/integrations/github/schemas/empty.json +5 -0
- package/integrations/github/schemas/get_issue.json +10 -0
- package/integrations/github/schemas/get_repo.json +9 -0
- package/integrations/github/schemas/list_commits.json +12 -0
- package/integrations/github/schemas/list_issues.json +12 -0
- package/integrations/github/schemas/list_pull_requests.json +10 -0
- package/integrations/github/schemas/merge_pull_request.json +14 -0
- package/integrations/github/schemas/owner_repo.json +9 -0
- package/integrations/github/schemas/update_issue.json +15 -0
- package/integrations/google-calendar/__tests__/get_handlers.test.ts +112 -0
- package/integrations/google-calendar/__tests__/usage_parity.test.ts +34 -0
- package/integrations/google-calendar/__tests__/write_and_admin_handlers.test.ts +161 -0
- package/integrations/google-calendar/credentials.json +36 -0
- package/integrations/google-calendar/credentials_hint.md +9 -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 +5 -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 +21 -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/handlers/update_event.js +5 -0
- package/integrations/google-calendar/manifest.json +26 -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 +9 -0
- package/integrations/google-calendar/schemas/insert_acl.json +18 -0
- package/integrations/google-calendar/schemas/list_events.json +15 -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-calendar/schemas/update_event.json +10 -0
- package/integrations/google-docs/__tests__/get_handlers.test.ts +72 -0
- package/integrations/google-docs/__tests__/usage_parity.test.ts +34 -0
- package/integrations/google-docs/__tests__/write_handlers.test.ts +249 -0
- package/integrations/google-docs/credentials.json +36 -0
- package/integrations/google-docs/credentials_hint.md +9 -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/get_document.js +12 -0
- package/integrations/google-docs/handlers/get_document_structured.js +6 -0
- package/integrations/google-docs/handlers/get_document_text.js +17 -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/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 +58 -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/get_document.json +11 -0
- package/integrations/google-docs/schemas/get_document_structured.json +9 -0
- package/integrations/google-docs/schemas/get_document_text.json +9 -0
- package/integrations/google-docs/schemas/insert_inline_image.json +12 -0
- package/integrations/google-docs/schemas/insert_inline_image_after_first_match.json +13 -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/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-sheet/__tests__/get_handlers.test.ts +129 -0
- package/integrations/google-sheet/__tests__/usage_parity.test.ts +35 -0
- package/integrations/google-sheet/__tests__/write_handlers.test.ts +171 -0
- package/integrations/google-sheet/credentials.json +36 -0
- package/integrations/google-sheet/credentials_hint.md +9 -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_clear_values_by_data_filter.js +6 -0
- package/integrations/google-sheet/handlers/batch_get_values.js +16 -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/batch_update_values_by_data_filter.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_developer_metadata.js +6 -0
- package/integrations/google-sheet/handlers/get_spreadsheet.js +12 -0
- package/integrations/google-sheet/handlers/get_spreadsheet_by_data_filter.js +10 -0
- package/integrations/google-sheet/handlers/get_values.js +14 -0
- package/integrations/google-sheet/handlers/get_values_by_data_filter.js +14 -0
- package/integrations/google-sheet/handlers/search_developer_metadata.js +7 -0
- package/integrations/google-sheet/handlers/update_values.js +16 -0
- package/integrations/google-sheet/manifest.json +125 -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_clear_values_by_data_filter.json +10 -0
- package/integrations/google-sheet/schemas/batch_get_values.json +13 -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/batch_update_values_by_data_filter.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_developer_metadata.json +10 -0
- package/integrations/google-sheet/schemas/get_spreadsheet.json +15 -0
- package/integrations/google-sheet/schemas/get_spreadsheet_by_data_filter.json +11 -0
- package/integrations/google-sheet/schemas/get_values.json +13 -0
- package/integrations/google-sheet/schemas/get_values_by_data_filter.json +17 -0
- package/integrations/google-sheet/schemas/search_developer_metadata.json +14 -0
- package/integrations/google-sheet/schemas/update_values.json +15 -0
- package/integrations/google-slides/__tests__/get_handlers.test.ts +69 -0
- package/integrations/google-slides/__tests__/usage_parity.test.ts +34 -0
- package/integrations/google-slides/__tests__/write_handlers.test.ts +125 -0
- package/integrations/google-slides/credentials.json +36 -0
- package/integrations/google-slides/credentials_hint.md +9 -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/get_presentation.js +6 -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/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 +41 -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/new_integration_prompt.md +41 -0
- package/integrations/notion/__tests__/get_handlers.test.ts +153 -0
- package/integrations/notion/__tests__/usage_parity.test.ts +34 -0
- package/integrations/notion/__tests__/write_and_admin_handlers.test.ts +190 -0
- package/integrations/notion/credentials.json +21 -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 +139 -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/__tests__/get_handlers.test.ts +240 -0
- package/integrations/trello/__tests__/usage_parity.test.ts +34 -0
- package/integrations/trello/__tests__/write_and_admin_handlers.test.ts +189 -0
- package/integrations/trello/credentials.json +26 -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/create_card.js +13 -0
- package/integrations/trello/handlers/create_list.js +7 -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 +231 -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/create_card.json +13 -0
- package/integrations/trello/schemas/create_list.json +11 -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 +45 -0
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "google-sheet",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"tools": [
|
|
5
|
+
{
|
|
6
|
+
"name": "get_spreadsheet",
|
|
7
|
+
"description": "Retrieve spreadsheet metadata and optionally grid data.",
|
|
8
|
+
"inputSchema": "schemas/get_spreadsheet.json",
|
|
9
|
+
"handler": "handlers/get_spreadsheet.js",
|
|
10
|
+
"scope": "read"
|
|
11
|
+
},
|
|
12
|
+
{
|
|
13
|
+
"name": "get_spreadsheet_by_data_filter",
|
|
14
|
+
"description": "Retrieve spreadsheet metadata using DataFilters.",
|
|
15
|
+
"inputSchema": "schemas/get_spreadsheet_by_data_filter.json",
|
|
16
|
+
"handler": "handlers/get_spreadsheet_by_data_filter.js",
|
|
17
|
+
"scope": "read"
|
|
18
|
+
},
|
|
19
|
+
{
|
|
20
|
+
"name": "get_values",
|
|
21
|
+
"description": "Get values from a single A1 range.",
|
|
22
|
+
"inputSchema": "schemas/get_values.json",
|
|
23
|
+
"handler": "handlers/get_values.js",
|
|
24
|
+
"scope": "read"
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
"name": "batch_get_values",
|
|
28
|
+
"description": "Batch get values for multiple A1 ranges.",
|
|
29
|
+
"inputSchema": "schemas/batch_get_values.json",
|
|
30
|
+
"handler": "handlers/batch_get_values.js",
|
|
31
|
+
"scope": "read"
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
"name": "get_values_by_data_filter",
|
|
35
|
+
"description": "Batch get values using DataFilters.",
|
|
36
|
+
"inputSchema": "schemas/get_values_by_data_filter.json",
|
|
37
|
+
"handler": "handlers/get_values_by_data_filter.js",
|
|
38
|
+
"scope": "read"
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
"name": "search_developer_metadata",
|
|
42
|
+
"description": "Search developer metadata in a spreadsheet.",
|
|
43
|
+
"inputSchema": "schemas/search_developer_metadata.json",
|
|
44
|
+
"handler": "handlers/search_developer_metadata.js",
|
|
45
|
+
"scope": "read"
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
"name": "get_developer_metadata",
|
|
49
|
+
"description": "Get a developer metadata entry by ID.",
|
|
50
|
+
"inputSchema": "schemas/get_developer_metadata.json",
|
|
51
|
+
"handler": "handlers/get_developer_metadata.js",
|
|
52
|
+
"scope": "read"
|
|
53
|
+
},
|
|
54
|
+
{
|
|
55
|
+
"name": "create_spreadsheet",
|
|
56
|
+
"description": "Create a new spreadsheet.",
|
|
57
|
+
"inputSchema": "schemas/create_spreadsheet.json",
|
|
58
|
+
"handler": "handlers/create_spreadsheet.js",
|
|
59
|
+
"scope": "write"
|
|
60
|
+
},
|
|
61
|
+
{
|
|
62
|
+
"name": "update_values",
|
|
63
|
+
"description": "Update values in a range (PUT).",
|
|
64
|
+
"inputSchema": "schemas/update_values.json",
|
|
65
|
+
"handler": "handlers/update_values.js",
|
|
66
|
+
"scope": "write"
|
|
67
|
+
},
|
|
68
|
+
{
|
|
69
|
+
"name": "append_values",
|
|
70
|
+
"description": "Append values after the last row of a range.",
|
|
71
|
+
"inputSchema": "schemas/append_values.json",
|
|
72
|
+
"handler": "handlers/append_values.js",
|
|
73
|
+
"scope": "write"
|
|
74
|
+
},
|
|
75
|
+
{
|
|
76
|
+
"name": "batch_update_values",
|
|
77
|
+
"description": "Batch update values across multiple ranges.",
|
|
78
|
+
"inputSchema": "schemas/batch_update_values.json",
|
|
79
|
+
"handler": "handlers/batch_update_values.js",
|
|
80
|
+
"scope": "write"
|
|
81
|
+
},
|
|
82
|
+
{
|
|
83
|
+
"name": "batch_update_values_by_data_filter",
|
|
84
|
+
"description": "Batch update values using DataFilters.",
|
|
85
|
+
"inputSchema": "schemas/batch_update_values_by_data_filter.json",
|
|
86
|
+
"handler": "handlers/batch_update_values_by_data_filter.js",
|
|
87
|
+
"scope": "write"
|
|
88
|
+
},
|
|
89
|
+
{
|
|
90
|
+
"name": "clear_values",
|
|
91
|
+
"description": "Clear values in the specified range.",
|
|
92
|
+
"inputSchema": "schemas/clear_values.json",
|
|
93
|
+
"handler": "handlers/clear_values.js",
|
|
94
|
+
"scope": "write"
|
|
95
|
+
},
|
|
96
|
+
{
|
|
97
|
+
"name": "batch_clear_values",
|
|
98
|
+
"description": "Batch clear values across multiple ranges.",
|
|
99
|
+
"inputSchema": "schemas/batch_clear_values.json",
|
|
100
|
+
"handler": "handlers/batch_clear_values.js",
|
|
101
|
+
"scope": "write"
|
|
102
|
+
},
|
|
103
|
+
{
|
|
104
|
+
"name": "batch_clear_values_by_data_filter",
|
|
105
|
+
"description": "Batch clear values using DataFilters.",
|
|
106
|
+
"inputSchema": "schemas/batch_clear_values_by_data_filter.json",
|
|
107
|
+
"handler": "handlers/batch_clear_values_by_data_filter.js",
|
|
108
|
+
"scope": "write"
|
|
109
|
+
},
|
|
110
|
+
{
|
|
111
|
+
"name": "batch_update",
|
|
112
|
+
"description": "Send a batchUpdate request (addSheet, deleteSheet, etc).",
|
|
113
|
+
"inputSchema": "schemas/batch_update.json",
|
|
114
|
+
"handler": "handlers/batch_update.js",
|
|
115
|
+
"scope": "write"
|
|
116
|
+
},
|
|
117
|
+
{
|
|
118
|
+
"name": "copy_to_spreadsheet",
|
|
119
|
+
"description": "Copy a sheet to another spreadsheet.",
|
|
120
|
+
"inputSchema": "schemas/copy_to_spreadsheet.json",
|
|
121
|
+
"handler": "handlers/copy_to_spreadsheet.js",
|
|
122
|
+
"scope": "write"
|
|
123
|
+
}
|
|
124
|
+
]
|
|
125
|
+
}
|
|
@@ -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,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "dataFilters"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"dataFilters": { "type": "array", "items": { "type": "object" } }
|
|
8
|
+
},
|
|
9
|
+
"additionalProperties": false
|
|
10
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "ranges"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"ranges": { "type": "array", "items": { "type": "string" } },
|
|
8
|
+
"majorDimension": { "type": "string", "enum": ["ROWS", "COLUMNS"] },
|
|
9
|
+
"valueRenderOption": { "type": "string", "enum": ["FORMATTED_VALUE", "UNFORMATTED_VALUE", "FORMULA"] },
|
|
10
|
+
"dateTimeRenderOption": { "type": "string", "enum": ["SERIAL_NUMBER", "FORMATTED_STRING"] }
|
|
11
|
+
},
|
|
12
|
+
"additionalProperties": false
|
|
13
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "requests"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"requests": { "type": "array", "items": { "type": "object" } },
|
|
8
|
+
"includeSpreadsheetInResponse": { "type": "boolean" },
|
|
9
|
+
"responseRanges": { "type": "array", "items": { "type": "string" } },
|
|
10
|
+
"responseIncludeGridData": { "type": "boolean" }
|
|
11
|
+
},
|
|
12
|
+
"additionalProperties": true
|
|
13
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "data"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"data": {
|
|
8
|
+
"type": "array",
|
|
9
|
+
"items": {
|
|
10
|
+
"type": "object",
|
|
11
|
+
"required": ["range", "values"],
|
|
12
|
+
"properties": {
|
|
13
|
+
"range": { "type": "string" },
|
|
14
|
+
"values": { "type": "array", "items": { "type": "array", "items": {} } },
|
|
15
|
+
"majorDimension": { "type": "string", "enum": ["ROWS", "COLUMNS"] }
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
"valueInputOption": { "type": "string", "enum": ["RAW", "USER_ENTERED"] },
|
|
20
|
+
"includeValuesInResponse": { "type": "boolean" },
|
|
21
|
+
"responseValueRenderOption": { "type": "string", "enum": ["FORMATTED_VALUE", "UNFORMATTED_VALUE", "FORMULA"] },
|
|
22
|
+
"responseDateTimeRenderOption": { "type": "string", "enum": ["SERIAL_NUMBER", "FORMATTED_STRING"] }
|
|
23
|
+
},
|
|
24
|
+
"additionalProperties": false
|
|
25
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "data"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"data": {
|
|
8
|
+
"type": "array",
|
|
9
|
+
"items": {
|
|
10
|
+
"type": "object",
|
|
11
|
+
"required": ["dataFilter", "values"],
|
|
12
|
+
"properties": {
|
|
13
|
+
"dataFilter": { "type": "object" },
|
|
14
|
+
"values": { "type": "array", "items": { "type": "array", "items": {} } },
|
|
15
|
+
"majorDimension": { "type": "string", "enum": ["ROWS", "COLUMNS"] }
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
"valueInputOption": { "type": "string", "enum": ["RAW", "USER_ENTERED"] },
|
|
20
|
+
"includeValuesInResponse": { "type": "boolean" },
|
|
21
|
+
"responseValueRenderOption": { "type": "string", "enum": ["FORMATTED_VALUE", "UNFORMATTED_VALUE", "FORMULA"] },
|
|
22
|
+
"responseDateTimeRenderOption": { "type": "string", "enum": ["SERIAL_NUMBER", "FORMATTED_STRING"] }
|
|
23
|
+
},
|
|
24
|
+
"additionalProperties": false
|
|
25
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "sheetId", "destinationSpreadsheetId"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string", "description": "Source spreadsheet ID" },
|
|
7
|
+
"sheetId": { "type": "integer", "description": "Source sheet numeric ID" },
|
|
8
|
+
"destinationSpreadsheetId": { "type": "string", "description": "Destination spreadsheet ID" }
|
|
9
|
+
},
|
|
10
|
+
"additionalProperties": false
|
|
11
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"properties": {
|
|
5
|
+
"properties": { "type": "object", "description": "Spreadsheet properties" },
|
|
6
|
+
"sheets": { "type": "array", "items": { "type": "object" } },
|
|
7
|
+
"namedRanges": { "type": "array", "items": { "type": "object" } },
|
|
8
|
+
"dataSources": { "type": "array", "items": { "type": "object" } }
|
|
9
|
+
},
|
|
10
|
+
"additionalProperties": true
|
|
11
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "metadataId"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"metadataId": { "type": "integer" }
|
|
8
|
+
},
|
|
9
|
+
"additionalProperties": false
|
|
10
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string", "description": "ID of the spreadsheet" },
|
|
7
|
+
"includeGridData": { "type": "boolean", "description": "Whether to include grid data" },
|
|
8
|
+
"ranges": {
|
|
9
|
+
"type": "array",
|
|
10
|
+
"items": { "type": "string" },
|
|
11
|
+
"description": "Optional A1 ranges to include"
|
|
12
|
+
}
|
|
13
|
+
},
|
|
14
|
+
"additionalProperties": false
|
|
15
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"dataFilters": { "type": "array", "items": { "type": "object" } },
|
|
8
|
+
"includeGridData": { "type": "boolean" }
|
|
9
|
+
},
|
|
10
|
+
"additionalProperties": true
|
|
11
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "range"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"range": { "type": "string", "description": "A1 notation range" },
|
|
8
|
+
"majorDimension": { "type": "string", "enum": ["ROWS", "COLUMNS"], "description": "Return values by rows or columns" },
|
|
9
|
+
"valueRenderOption": { "type": "string", "enum": ["FORMATTED_VALUE", "UNFORMATTED_VALUE", "FORMULA"] },
|
|
10
|
+
"dateTimeRenderOption": { "type": "string", "enum": ["SERIAL_NUMBER", "FORMATTED_STRING"] }
|
|
11
|
+
},
|
|
12
|
+
"additionalProperties": false
|
|
13
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "dataFilters"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"dataFilters": {
|
|
8
|
+
"type": "array",
|
|
9
|
+
"items": { "type": "object" },
|
|
10
|
+
"description": "Array of DataFilter objects per Sheets API"
|
|
11
|
+
},
|
|
12
|
+
"majorDimension": { "type": "string", "enum": ["ROWS", "COLUMNS"] },
|
|
13
|
+
"valueRenderOption": { "type": "string", "enum": ["FORMATTED_VALUE", "UNFORMATTED_VALUE", "FORMULA"] },
|
|
14
|
+
"dateTimeRenderOption": { "type": "string", "enum": ["SERIAL_NUMBER", "FORMATTED_STRING"] }
|
|
15
|
+
},
|
|
16
|
+
"additionalProperties": false
|
|
17
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "dataFilters"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"dataFilters": {
|
|
8
|
+
"type": "array",
|
|
9
|
+
"items": { "type": "object" },
|
|
10
|
+
"description": "DeveloperMetadataLookup wrapped in DataFilter objects"
|
|
11
|
+
}
|
|
12
|
+
},
|
|
13
|
+
"additionalProperties": false
|
|
14
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"required": ["spreadsheetId", "range", "values"],
|
|
5
|
+
"properties": {
|
|
6
|
+
"spreadsheetId": { "type": "string" },
|
|
7
|
+
"range": { "type": "string" },
|
|
8
|
+
"values": { "type": "array", "items": { "type": "array", "items": {} } },
|
|
9
|
+
"valueInputOption": { "type": "string", "enum": ["RAW", "USER_ENTERED"] },
|
|
10
|
+
"includeValuesInResponse": { "type": "boolean" },
|
|
11
|
+
"responseValueRenderOption": { "type": "string", "enum": ["FORMATTED_VALUE", "UNFORMATTED_VALUE", "FORMULA"] },
|
|
12
|
+
"responseDateTimeRenderOption": { "type": "string", "enum": ["SERIAL_NUMBER", "FORMATTED_STRING"] }
|
|
13
|
+
},
|
|
14
|
+
"additionalProperties": false
|
|
15
|
+
}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { beforeAll, describe, expect, it } from 'vitest'
|
|
2
|
+
import { IntegrationProxy } from '../../../src/integrations/proxy.js'
|
|
3
|
+
import { loadIntegrationTools } from '../../../src/integrations/dataLoader.js'
|
|
4
|
+
|
|
5
|
+
// LIVE Google Slides read tests using managed OAuth
|
|
6
|
+
// Required env vars:
|
|
7
|
+
// - COMMANDABLE_MANAGED_OAUTH_BASE_URL
|
|
8
|
+
// - COMMANDABLE_MANAGED_OAUTH_SECRET_KEY
|
|
9
|
+
// - GSLIDES_TEST_CONNECTION_ID (managed OAuth connection for provider 'google-slides')
|
|
10
|
+
// - GSLIDES_TEST_PRESENTATION_ID (an accessible presentation ID)
|
|
11
|
+
|
|
12
|
+
const env = process.env as Record<string, string>
|
|
13
|
+
const hasEnv = (...keys: string[]) => keys.every(k => !!env[k] && env[k].trim().length > 0)
|
|
14
|
+
const suite = hasEnv(
|
|
15
|
+
'COMMANDABLE_MANAGED_OAUTH_BASE_URL',
|
|
16
|
+
'COMMANDABLE_MANAGED_OAUTH_SECRET_KEY',
|
|
17
|
+
'GSLIDES_TEST_CONNECTION_ID',
|
|
18
|
+
)
|
|
19
|
+
? describe
|
|
20
|
+
: describe.skip
|
|
21
|
+
|
|
22
|
+
suite('google-slides read handlers (live)', () => {
|
|
23
|
+
let buildReadHandler: (name: string) => ((input: any) => Promise<any>)
|
|
24
|
+
|
|
25
|
+
beforeAll(async () => {
|
|
26
|
+
const { COMMANDABLE_MANAGED_OAUTH_BASE_URL, COMMANDABLE_MANAGED_OAUTH_SECRET_KEY, GSLIDES_TEST_CONNECTION_ID } = env
|
|
27
|
+
|
|
28
|
+
const proxy = new IntegrationProxy({
|
|
29
|
+
managedOAuthBaseUrl: COMMANDABLE_MANAGED_OAUTH_BASE_URL,
|
|
30
|
+
managedOAuthSecretKey: COMMANDABLE_MANAGED_OAUTH_SECRET_KEY,
|
|
31
|
+
})
|
|
32
|
+
const integrationNode = { id: 'node-gslides', type: 'google-slides', label: 'Google Slides', connectionId: GSLIDES_TEST_CONNECTION_ID } as any
|
|
33
|
+
|
|
34
|
+
const tools = loadIntegrationTools('google-slides')
|
|
35
|
+
expect(tools).toBeTruthy()
|
|
36
|
+
|
|
37
|
+
buildReadHandler = (name: string) => {
|
|
38
|
+
const tool = tools!.read.find(t => t.name === name)
|
|
39
|
+
expect(tool, `read tool ${name} exists`).toBeTruthy()
|
|
40
|
+
const integration = { fetch: (path: string, init?: RequestInit) => proxy.call(integrationNode, path, init) }
|
|
41
|
+
const build = new Function('integration', `return (${tool!.handlerCode});`)
|
|
42
|
+
return build(integration) as (input: any) => Promise<any>
|
|
43
|
+
}
|
|
44
|
+
}, 60000)
|
|
45
|
+
|
|
46
|
+
it('get_presentation returns metadata', async () => {
|
|
47
|
+
const presentationId = env.GSLIDES_TEST_PRESENTATION_ID
|
|
48
|
+
if (!presentationId)
|
|
49
|
+
return expect(true).toBe(true)
|
|
50
|
+
const handler = buildReadHandler('get_presentation')
|
|
51
|
+
const result = await handler({ presentationId })
|
|
52
|
+
expect(result?.presentationId || Array.isArray(result?.slides)).toBeTruthy()
|
|
53
|
+
}, 30000)
|
|
54
|
+
|
|
55
|
+
it('get_page_thumbnail returns URL data', async () => {
|
|
56
|
+
const presentationId = env.GSLIDES_TEST_PRESENTATION_ID
|
|
57
|
+
if (!presentationId)
|
|
58
|
+
return expect(true).toBe(true)
|
|
59
|
+
// First query the presentation to discover a page id
|
|
60
|
+
const getPresentation = buildReadHandler('get_presentation')
|
|
61
|
+
const meta = await getPresentation({ presentationId })
|
|
62
|
+
const firstSlide = meta?.slides?.[0]
|
|
63
|
+
if (!firstSlide?.objectId)
|
|
64
|
+
return expect(true).toBe(true)
|
|
65
|
+
const handler = buildReadHandler('get_page_thumbnail')
|
|
66
|
+
const result = await handler({ presentationId, 'pageObjectId': firstSlide.objectId, 'thumbnailProperties.thumbnailSize': 'MEDIUM', 'thumbnailProperties.mimeType': 'PNG' })
|
|
67
|
+
expect(typeof result?.contentUrl === 'string' || typeof result?.thumbnailUrl === 'string').toBe(true)
|
|
68
|
+
}, 30000)
|
|
69
|
+
})
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { existsSync, readdirSync, readFileSync } from 'node:fs'
|
|
2
|
+
import { resolve } from 'node:path'
|
|
3
|
+
import { fileURLToPath } from 'node:url'
|
|
4
|
+
import { describe, expect, it } from 'vitest'
|
|
5
|
+
import { loadIntegrationManifest } from '../../../src/integrations/dataLoader.js'
|
|
6
|
+
|
|
7
|
+
function escapeRegExp(str: string): string {
|
|
8
|
+
return str.replace(/[.*+?^${}()|[\]\\]/g, '\\$&')
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
describe('google-slides static usage parity', () => {
|
|
12
|
+
it('every manifest tool is referenced in tests via build*(name)', () => {
|
|
13
|
+
const manifest = loadIntegrationManifest('google-slides')!
|
|
14
|
+
const toolNames = (manifest.tools as any[]).map(t => t.name)
|
|
15
|
+
|
|
16
|
+
const testsDir = fileURLToPath(new URL('.', import.meta.url))
|
|
17
|
+
expect(existsSync(testsDir)).toBe(true)
|
|
18
|
+
const testFiles = readdirSync(testsDir)
|
|
19
|
+
.filter(f => /\.test\.(t|j)s$/.test(f) && !f.includes('usage_parity.test'))
|
|
20
|
+
.map(f => resolve(testsDir, f))
|
|
21
|
+
|
|
22
|
+
const fileContents = testFiles.map(f => readFileSync(f, 'utf8'))
|
|
23
|
+
|
|
24
|
+
const missing: string[] = []
|
|
25
|
+
for (const name of toolNames) {
|
|
26
|
+
const nameRe = new RegExp(`build(?:Read|Write|Admin)?(?:Handler)?\\(\\s*['\"\`]${escapeRegExp(name)}['\"\`]\\s*\\)`, 'm')
|
|
27
|
+
const found = fileContents.some(src => nameRe.test(src))
|
|
28
|
+
if (!found)
|
|
29
|
+
missing.push(name)
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
expect(missing, `Missing handler usages in tests: ${missing.join(', ')}`).toEqual([])
|
|
33
|
+
})
|
|
34
|
+
})
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import { beforeAll, describe, expect, it } from 'vitest'
|
|
2
|
+
import { IntegrationProxy } from '../../../src/integrations/proxy.js'
|
|
3
|
+
import { loadIntegrationTools } from '../../../src/integrations/dataLoader.js'
|
|
4
|
+
|
|
5
|
+
// LIVE Google Slides write tests using managed OAuth
|
|
6
|
+
// Required env vars:
|
|
7
|
+
// - COMMANDABLE_MANAGED_OAUTH_BASE_URL
|
|
8
|
+
// - COMMANDABLE_MANAGED_OAUTH_SECRET_KEY
|
|
9
|
+
// - GSLIDES_TEST_CONNECTION_ID (managed OAuth connection for provider 'google-slides')
|
|
10
|
+
// - GSLIDES_TEST_PRESENTATION_ID (a presentation ID with write access)
|
|
11
|
+
|
|
12
|
+
interface Ctx { presentationId?: string }
|
|
13
|
+
|
|
14
|
+
const env = process.env as Record<string, string>
|
|
15
|
+
const hasEnv = (...keys: string[]) => keys.every(k => !!env[k] && env[k].trim().length > 0)
|
|
16
|
+
const suite = hasEnv(
|
|
17
|
+
'COMMANDABLE_MANAGED_OAUTH_BASE_URL',
|
|
18
|
+
'COMMANDABLE_MANAGED_OAUTH_SECRET_KEY',
|
|
19
|
+
'GSLIDES_TEST_CONNECTION_ID',
|
|
20
|
+
'GSLIDES_TEST_PRESENTATION_ID',
|
|
21
|
+
)
|
|
22
|
+
? describe
|
|
23
|
+
: describe.skip
|
|
24
|
+
|
|
25
|
+
suite('google-slides write handlers (live)', () => {
|
|
26
|
+
const ctx: Ctx = {}
|
|
27
|
+
let buildWriteHandler: (name: string) => ((input: any) => Promise<any>)
|
|
28
|
+
|
|
29
|
+
beforeAll(async () => {
|
|
30
|
+
const { COMMANDABLE_MANAGED_OAUTH_BASE_URL, COMMANDABLE_MANAGED_OAUTH_SECRET_KEY, GSLIDES_TEST_CONNECTION_ID, GSLIDES_TEST_PRESENTATION_ID } = env
|
|
31
|
+
|
|
32
|
+
const proxy = new IntegrationProxy({
|
|
33
|
+
managedOAuthBaseUrl: COMMANDABLE_MANAGED_OAUTH_BASE_URL,
|
|
34
|
+
managedOAuthSecretKey: COMMANDABLE_MANAGED_OAUTH_SECRET_KEY,
|
|
35
|
+
})
|
|
36
|
+
const integrationNode = { id: 'node-gslides', type: 'google-slides', label: 'Google Slides', connectionId: GSLIDES_TEST_CONNECTION_ID } as any
|
|
37
|
+
|
|
38
|
+
const tools = loadIntegrationTools('google-slides')
|
|
39
|
+
expect(tools).toBeTruthy()
|
|
40
|
+
|
|
41
|
+
buildWriteHandler = (name: string) => {
|
|
42
|
+
const tool = tools!.write.find(t => t.name === name)
|
|
43
|
+
expect(tool, `write tool ${name} exists`).toBeTruthy()
|
|
44
|
+
const integration = { fetch: (path: string, init?: RequestInit) => proxy.call(integrationNode, path, init) }
|
|
45
|
+
const build = new Function('integration', `return (${tool!.handlerCode});`)
|
|
46
|
+
return build(integration) as (input: any) => Promise<any>
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
ctx.presentationId = GSLIDES_TEST_PRESENTATION_ID
|
|
50
|
+
}, 60000)
|
|
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 = buildWriteHandler('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('create_presentation creates a presentation when allowed', async () => {
|
|
63
|
+
if (!env.GSLIDES_ALLOW_CREATE)
|
|
64
|
+
return expect(true).toBe(true)
|
|
65
|
+
const handler = buildWriteHandler('create_presentation')
|
|
66
|
+
const res = await handler({ title: `Cmd Slides ${Date.now()}` })
|
|
67
|
+
expect(typeof res?.presentationId === 'string').toBe(true)
|
|
68
|
+
}, 60000)
|
|
69
|
+
|
|
70
|
+
it('append_text_to_title_of_slide_index appends to title', async () => {
|
|
71
|
+
if (!ctx.presentationId)
|
|
72
|
+
return expect(true).toBe(true)
|
|
73
|
+
const handler = buildWriteHandler('append_text_to_title_of_slide_index')
|
|
74
|
+
const res = await handler({ presentationId: ctx.presentationId, slideIndex: 0, text: ` CmdTest ${Date.now()}` })
|
|
75
|
+
expect(res?.presentationId || Array.isArray(res?.replies)).toBeTruthy()
|
|
76
|
+
}, 60000)
|
|
77
|
+
|
|
78
|
+
it('replace_text_first_match replaces text (no-op ok)', async () => {
|
|
79
|
+
if (!ctx.presentationId)
|
|
80
|
+
return expect(true).toBe(true)
|
|
81
|
+
const handler = buildWriteHandler('replace_text_first_match')
|
|
82
|
+
const res = await handler({ presentationId: ctx.presentationId, findText: '___unlikely___', replaceText: '___unlikely___' })
|
|
83
|
+
expect(res?.presentationId || Array.isArray(res?.replies)).toBeTruthy()
|
|
84
|
+
}, 60000)
|
|
85
|
+
|
|
86
|
+
it('style_text_first_match applies style', async () => {
|
|
87
|
+
if (!ctx.presentationId)
|
|
88
|
+
return expect(true).toBe(true)
|
|
89
|
+
const handler = buildWriteHandler('style_text_first_match')
|
|
90
|
+
const res = await handler({ presentationId: ctx.presentationId, findText: 'the', textStyle: { bold: true } })
|
|
91
|
+
expect(res?.presentationId || Array.isArray(res?.replies)).toBeTruthy()
|
|
92
|
+
}, 60000)
|
|
93
|
+
|
|
94
|
+
it('insert_shape_after_first_match inserts a shape', async () => {
|
|
95
|
+
if (!ctx.presentationId)
|
|
96
|
+
return expect(true).toBe(true)
|
|
97
|
+
const handler = buildWriteHandler('insert_shape_after_first_match')
|
|
98
|
+
const res = await handler({ presentationId: ctx.presentationId, findText: 'the', shapeType: 'RECTANGLE' })
|
|
99
|
+
expect(res?.presentationId || Array.isArray(res?.replies)).toBeTruthy()
|
|
100
|
+
}, 60000)
|
|
101
|
+
|
|
102
|
+
it('insert_image_after_first_match inserts an image when allowed', async () => {
|
|
103
|
+
if (!ctx.presentationId || !env.GSLIDES_TEST_IMAGE_URI)
|
|
104
|
+
return expect(true).toBe(true)
|
|
105
|
+
const handler = buildWriteHandler('insert_image_after_first_match')
|
|
106
|
+
const res = await handler({ presentationId: ctx.presentationId, findText: 'the', uri: env.GSLIDES_TEST_IMAGE_URI })
|
|
107
|
+
expect(res?.presentationId || Array.isArray(res?.replies)).toBeTruthy()
|
|
108
|
+
}, 60000)
|
|
109
|
+
|
|
110
|
+
it('create_slide_after_first_match creates a slide near anchor', async () => {
|
|
111
|
+
if (!ctx.presentationId)
|
|
112
|
+
return expect(true).toBe(true)
|
|
113
|
+
const handler = buildWriteHandler('create_slide_after_first_match')
|
|
114
|
+
const res = await handler({ presentationId: ctx.presentationId, findText: 'the', layout: 'BLANK' })
|
|
115
|
+
expect(res?.presentationId || Array.isArray(res?.replies)).toBeTruthy()
|
|
116
|
+
}, 60000)
|
|
117
|
+
|
|
118
|
+
it('set_background_color_for_slide_index sets color', async () => {
|
|
119
|
+
if (!ctx.presentationId)
|
|
120
|
+
return expect(true).toBe(true)
|
|
121
|
+
const handler = buildWriteHandler('set_background_color_for_slide_index')
|
|
122
|
+
const res = await handler({ presentationId: ctx.presentationId, slideIndex: 0, rgbColor: { red: 0.9, green: 0.9, blue: 0.9 } })
|
|
123
|
+
expect(res?.presentationId || Array.isArray(res?.replies)).toBeTruthy()
|
|
124
|
+
}, 60000)
|
|
125
|
+
})
|