@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.
Files changed (335) hide show
  1. package/dist/credentials-index.d.ts +30 -0
  2. package/dist/credentials-index.d.ts.map +1 -0
  3. package/dist/credentials-index.js +292 -0
  4. package/dist/credentials-index.js.map +1 -0
  5. package/dist/index.d.ts +3 -0
  6. package/dist/index.d.ts.map +1 -0
  7. package/dist/index.js +2 -0
  8. package/dist/index.js.map +1 -0
  9. package/dist/loader.d.ts +69 -0
  10. package/dist/loader.d.ts.map +1 -0
  11. package/dist/loader.js +164 -0
  12. package/dist/loader.js.map +1 -0
  13. package/integrations/README.md +52 -0
  14. package/integrations/airtable/__tests__/get_handlers.test.ts +137 -0
  15. package/integrations/airtable/__tests__/usage_parity.test.ts +35 -0
  16. package/integrations/airtable/__tests__/write_and_admin_handlers.test.ts +113 -0
  17. package/integrations/airtable/credentials.json +20 -0
  18. package/integrations/airtable/credentials_hint.md +4 -0
  19. package/integrations/airtable/handlers/create_record.js +12 -0
  20. package/integrations/airtable/handlers/delete_record.js +7 -0
  21. package/integrations/airtable/handlers/get_record.js +4 -0
  22. package/integrations/airtable/handlers/get_table_schema.js +6 -0
  23. package/integrations/airtable/handlers/list_bases.js +4 -0
  24. package/integrations/airtable/handlers/list_records.js +25 -0
  25. package/integrations/airtable/handlers/list_table_fields.js +6 -0
  26. package/integrations/airtable/handlers/list_tables.js +4 -0
  27. package/integrations/airtable/handlers/list_views.js +6 -0
  28. package/integrations/airtable/handlers/search_records.js +6 -0
  29. package/integrations/airtable/handlers/update_record.js +11 -0
  30. package/integrations/airtable/manifest.json +83 -0
  31. package/integrations/airtable/schemas/create_record.json +12 -0
  32. package/integrations/airtable/schemas/delete_record.json +11 -0
  33. package/integrations/airtable/schemas/empty.json +6 -0
  34. package/integrations/airtable/schemas/get_record.json +11 -0
  35. package/integrations/airtable/schemas/id_base.json +9 -0
  36. package/integrations/airtable/schemas/id_base_table.json +10 -0
  37. package/integrations/airtable/schemas/list_records.json +26 -0
  38. package/integrations/airtable/schemas/search_records.json +12 -0
  39. package/integrations/airtable/schemas/update_record.json +13 -0
  40. package/integrations/github/__tests__/get_handlers.test.ts +117 -0
  41. package/integrations/github/__tests__/usage_parity.test.ts +34 -0
  42. package/integrations/github/__tests__/write_handlers.test.ts +311 -0
  43. package/integrations/github/credentials.json +20 -0
  44. package/integrations/github/credentials_hint.md +7 -0
  45. package/integrations/github/handlers/add_labels_to_issue.js +12 -0
  46. package/integrations/github/handlers/close_issue.js +5 -0
  47. package/integrations/github/handlers/comment_on_issue.js +5 -0
  48. package/integrations/github/handlers/create_branch.js +33 -0
  49. package/integrations/github/handlers/create_commit.js +91 -0
  50. package/integrations/github/handlers/create_issue.js +10 -0
  51. package/integrations/github/handlers/create_or_update_file.js +21 -0
  52. package/integrations/github/handlers/create_pull_request.js +16 -0
  53. package/integrations/github/handlers/create_repo.js +11 -0
  54. package/integrations/github/handlers/delete_repo.js +6 -0
  55. package/integrations/github/handlers/get_issue.js +4 -0
  56. package/integrations/github/handlers/get_repo.js +4 -0
  57. package/integrations/github/handlers/list_branches.js +4 -0
  58. package/integrations/github/handlers/list_commits.js +12 -0
  59. package/integrations/github/handlers/list_issues.js +12 -0
  60. package/integrations/github/handlers/list_pull_requests.js +8 -0
  61. package/integrations/github/handlers/list_repos_install.js +4 -0
  62. package/integrations/github/handlers/list_repos_user.js +4 -0
  63. package/integrations/github/handlers/merge_pull_request.js +14 -0
  64. package/integrations/github/handlers/update_issue.js +15 -0
  65. package/integrations/github/manifest.json +26 -0
  66. package/integrations/github/schemas/add_labels_to_issue.json +12 -0
  67. package/integrations/github/schemas/close_issue.json +10 -0
  68. package/integrations/github/schemas/comment_on_issue.json +11 -0
  69. package/integrations/github/schemas/create_branch.json +12 -0
  70. package/integrations/github/schemas/create_commit.json +25 -0
  71. package/integrations/github/schemas/create_issue.json +13 -0
  72. package/integrations/github/schemas/create_or_update_file.json +15 -0
  73. package/integrations/github/schemas/create_pull_request.json +15 -0
  74. package/integrations/github/schemas/create_repo.json +12 -0
  75. package/integrations/github/schemas/delete_repo.json +10 -0
  76. package/integrations/github/schemas/empty.json +5 -0
  77. package/integrations/github/schemas/get_issue.json +10 -0
  78. package/integrations/github/schemas/get_repo.json +9 -0
  79. package/integrations/github/schemas/list_commits.json +12 -0
  80. package/integrations/github/schemas/list_issues.json +12 -0
  81. package/integrations/github/schemas/list_pull_requests.json +10 -0
  82. package/integrations/github/schemas/merge_pull_request.json +14 -0
  83. package/integrations/github/schemas/owner_repo.json +9 -0
  84. package/integrations/github/schemas/update_issue.json +15 -0
  85. package/integrations/google-calendar/__tests__/get_handlers.test.ts +112 -0
  86. package/integrations/google-calendar/__tests__/usage_parity.test.ts +34 -0
  87. package/integrations/google-calendar/__tests__/write_and_admin_handlers.test.ts +161 -0
  88. package/integrations/google-calendar/credentials.json +36 -0
  89. package/integrations/google-calendar/credentials_hint.md +9 -0
  90. package/integrations/google-calendar/handlers/create_event.js +6 -0
  91. package/integrations/google-calendar/handlers/delete_acl.js +6 -0
  92. package/integrations/google-calendar/handlers/delete_event.js +7 -0
  93. package/integrations/google-calendar/handlers/freebusy_query.js +4 -0
  94. package/integrations/google-calendar/handlers/get_acl.js +5 -0
  95. package/integrations/google-calendar/handlers/get_calendar.js +4 -0
  96. package/integrations/google-calendar/handlers/get_event.js +5 -0
  97. package/integrations/google-calendar/handlers/insert_acl.js +6 -0
  98. package/integrations/google-calendar/handlers/list_acl.js +5 -0
  99. package/integrations/google-calendar/handlers/list_calendars.js +4 -0
  100. package/integrations/google-calendar/handlers/list_colors.js +4 -0
  101. package/integrations/google-calendar/handlers/list_events.js +21 -0
  102. package/integrations/google-calendar/handlers/list_settings.js +4 -0
  103. package/integrations/google-calendar/handlers/move_event.js +6 -0
  104. package/integrations/google-calendar/handlers/patch_event.js +5 -0
  105. package/integrations/google-calendar/handlers/quick_add.js +6 -0
  106. package/integrations/google-calendar/handlers/update_acl.js +7 -0
  107. package/integrations/google-calendar/handlers/update_event.js +5 -0
  108. package/integrations/google-calendar/manifest.json +26 -0
  109. package/integrations/google-calendar/schemas/create_event.json +34 -0
  110. package/integrations/google-calendar/schemas/delete_acl.json +9 -0
  111. package/integrations/google-calendar/schemas/empty.json +1 -0
  112. package/integrations/google-calendar/schemas/freebusy_query.json +13 -0
  113. package/integrations/google-calendar/schemas/get_acl.json +9 -0
  114. package/integrations/google-calendar/schemas/id_calendar.json +8 -0
  115. package/integrations/google-calendar/schemas/id_calendar_event.json +9 -0
  116. package/integrations/google-calendar/schemas/insert_acl.json +18 -0
  117. package/integrations/google-calendar/schemas/list_events.json +15 -0
  118. package/integrations/google-calendar/schemas/move_event.json +10 -0
  119. package/integrations/google-calendar/schemas/patch_event.json +10 -0
  120. package/integrations/google-calendar/schemas/quick_add.json +9 -0
  121. package/integrations/google-calendar/schemas/update_acl.json +10 -0
  122. package/integrations/google-calendar/schemas/update_event.json +10 -0
  123. package/integrations/google-docs/__tests__/get_handlers.test.ts +72 -0
  124. package/integrations/google-docs/__tests__/usage_parity.test.ts +34 -0
  125. package/integrations/google-docs/__tests__/write_handlers.test.ts +249 -0
  126. package/integrations/google-docs/credentials.json +36 -0
  127. package/integrations/google-docs/credentials_hint.md +9 -0
  128. package/integrations/google-docs/handlers/append_text.js +12 -0
  129. package/integrations/google-docs/handlers/batch_update.js +13 -0
  130. package/integrations/google-docs/handlers/create_document.js +9 -0
  131. package/integrations/google-docs/handlers/delete_first_match.js +50 -0
  132. package/integrations/google-docs/handlers/get_document.js +12 -0
  133. package/integrations/google-docs/handlers/get_document_structured.js +6 -0
  134. package/integrations/google-docs/handlers/get_document_text.js +17 -0
  135. package/integrations/google-docs/handlers/insert_inline_image_after_first_match.js +41 -0
  136. package/integrations/google-docs/handlers/insert_page_break_after_first_match.js +49 -0
  137. package/integrations/google-docs/handlers/insert_table_after_first_match.js +49 -0
  138. package/integrations/google-docs/handlers/insert_text_after_first_match.js +51 -0
  139. package/integrations/google-docs/handlers/replace_all_text.js +8 -0
  140. package/integrations/google-docs/handlers/style_first_match.js +42 -0
  141. package/integrations/google-docs/handlers/update_document_style.js +8 -0
  142. package/integrations/google-docs/handlers/update_paragraph_style_for_first_match.js +48 -0
  143. package/integrations/google-docs/manifest.json +58 -0
  144. package/integrations/google-docs/schemas/append_text.json +10 -0
  145. package/integrations/google-docs/schemas/apply_text_style.json +13 -0
  146. package/integrations/google-docs/schemas/batch_update.json +16 -0
  147. package/integrations/google-docs/schemas/create_document.json +8 -0
  148. package/integrations/google-docs/schemas/delete_content_range.json +11 -0
  149. package/integrations/google-docs/schemas/delete_first_match.json +10 -0
  150. package/integrations/google-docs/schemas/get_document.json +11 -0
  151. package/integrations/google-docs/schemas/get_document_structured.json +9 -0
  152. package/integrations/google-docs/schemas/get_document_text.json +9 -0
  153. package/integrations/google-docs/schemas/insert_inline_image.json +12 -0
  154. package/integrations/google-docs/schemas/insert_inline_image_after_first_match.json +13 -0
  155. package/integrations/google-docs/schemas/insert_page_break.json +10 -0
  156. package/integrations/google-docs/schemas/insert_page_break_after_first_match.json +11 -0
  157. package/integrations/google-docs/schemas/insert_table.json +12 -0
  158. package/integrations/google-docs/schemas/insert_table_after_first_match.json +13 -0
  159. package/integrations/google-docs/schemas/insert_text_after_first_match.json +12 -0
  160. package/integrations/google-docs/schemas/insert_text_at.json +11 -0
  161. package/integrations/google-docs/schemas/replace_all_text.json +12 -0
  162. package/integrations/google-docs/schemas/style_first_match.json +12 -0
  163. package/integrations/google-docs/schemas/update_document_style.json +11 -0
  164. package/integrations/google-docs/schemas/update_paragraph_style.json +13 -0
  165. package/integrations/google-docs/schemas/update_paragraph_style_for_first_match.json +12 -0
  166. package/integrations/google-sheet/__tests__/get_handlers.test.ts +129 -0
  167. package/integrations/google-sheet/__tests__/usage_parity.test.ts +35 -0
  168. package/integrations/google-sheet/__tests__/write_handlers.test.ts +171 -0
  169. package/integrations/google-sheet/credentials.json +36 -0
  170. package/integrations/google-sheet/credentials_hint.md +9 -0
  171. package/integrations/google-sheet/handlers/append_values.js +18 -0
  172. package/integrations/google-sheet/handlers/batch_clear_values.js +6 -0
  173. package/integrations/google-sheet/handlers/batch_clear_values_by_data_filter.js +6 -0
  174. package/integrations/google-sheet/handlers/batch_get_values.js +16 -0
  175. package/integrations/google-sheet/handlers/batch_update.js +14 -0
  176. package/integrations/google-sheet/handlers/batch_update_values.js +16 -0
  177. package/integrations/google-sheet/handlers/batch_update_values_by_data_filter.js +16 -0
  178. package/integrations/google-sheet/handlers/clear_values.js +6 -0
  179. package/integrations/google-sheet/handlers/copy_to_spreadsheet.js +6 -0
  180. package/integrations/google-sheet/handlers/create_spreadsheet.js +5 -0
  181. package/integrations/google-sheet/handlers/get_developer_metadata.js +6 -0
  182. package/integrations/google-sheet/handlers/get_spreadsheet.js +12 -0
  183. package/integrations/google-sheet/handlers/get_spreadsheet_by_data_filter.js +10 -0
  184. package/integrations/google-sheet/handlers/get_values.js +14 -0
  185. package/integrations/google-sheet/handlers/get_values_by_data_filter.js +14 -0
  186. package/integrations/google-sheet/handlers/search_developer_metadata.js +7 -0
  187. package/integrations/google-sheet/handlers/update_values.js +16 -0
  188. package/integrations/google-sheet/manifest.json +125 -0
  189. package/integrations/google-sheet/schemas/append_values.json +16 -0
  190. package/integrations/google-sheet/schemas/batch_clear_values.json +10 -0
  191. package/integrations/google-sheet/schemas/batch_clear_values_by_data_filter.json +10 -0
  192. package/integrations/google-sheet/schemas/batch_get_values.json +13 -0
  193. package/integrations/google-sheet/schemas/batch_update.json +13 -0
  194. package/integrations/google-sheet/schemas/batch_update_values.json +25 -0
  195. package/integrations/google-sheet/schemas/batch_update_values_by_data_filter.json +25 -0
  196. package/integrations/google-sheet/schemas/clear_values.json +10 -0
  197. package/integrations/google-sheet/schemas/copy_to_spreadsheet.json +11 -0
  198. package/integrations/google-sheet/schemas/create_spreadsheet.json +11 -0
  199. package/integrations/google-sheet/schemas/get_developer_metadata.json +10 -0
  200. package/integrations/google-sheet/schemas/get_spreadsheet.json +15 -0
  201. package/integrations/google-sheet/schemas/get_spreadsheet_by_data_filter.json +11 -0
  202. package/integrations/google-sheet/schemas/get_values.json +13 -0
  203. package/integrations/google-sheet/schemas/get_values_by_data_filter.json +17 -0
  204. package/integrations/google-sheet/schemas/search_developer_metadata.json +14 -0
  205. package/integrations/google-sheet/schemas/update_values.json +15 -0
  206. package/integrations/google-slides/__tests__/get_handlers.test.ts +69 -0
  207. package/integrations/google-slides/__tests__/usage_parity.test.ts +34 -0
  208. package/integrations/google-slides/__tests__/write_handlers.test.ts +125 -0
  209. package/integrations/google-slides/credentials.json +36 -0
  210. package/integrations/google-slides/credentials_hint.md +9 -0
  211. package/integrations/google-slides/handlers/append_text_to_title_of_first_slide.js +17 -0
  212. package/integrations/google-slides/handlers/batch_update.js +15 -0
  213. package/integrations/google-slides/handlers/create_presentation.js +8 -0
  214. package/integrations/google-slides/handlers/create_slide_after_first_match.js +20 -0
  215. package/integrations/google-slides/handlers/get_page_thumbnail.js +12 -0
  216. package/integrations/google-slides/handlers/get_presentation.js +6 -0
  217. package/integrations/google-slides/handlers/insert_image_after_first_match.js +19 -0
  218. package/integrations/google-slides/handlers/insert_shape_after_first_match.js +21 -0
  219. package/integrations/google-slides/handlers/replace_text_first_match.js +9 -0
  220. package/integrations/google-slides/handlers/set_background_color_for_slide_index.js +15 -0
  221. package/integrations/google-slides/handlers/style_text_first_match.js +48 -0
  222. package/integrations/google-slides/manifest.json +41 -0
  223. package/integrations/google-slides/schemas/append_text_to_title_of_first_slide.json +11 -0
  224. package/integrations/google-slides/schemas/batch_update.json +13 -0
  225. package/integrations/google-slides/schemas/create_presentation.json +8 -0
  226. package/integrations/google-slides/schemas/create_slide_after_first_match.json +11 -0
  227. package/integrations/google-slides/schemas/get_page_thumbnail.json +12 -0
  228. package/integrations/google-slides/schemas/get_presentation.json +9 -0
  229. package/integrations/google-slides/schemas/insert_image_after_first_match.json +13 -0
  230. package/integrations/google-slides/schemas/insert_shape_after_first_match.json +13 -0
  231. package/integrations/google-slides/schemas/replace_text_first_match.json +12 -0
  232. package/integrations/google-slides/schemas/set_background_color_for_slide_index.json +11 -0
  233. package/integrations/google-slides/schemas/style_text_first_match.json +12 -0
  234. package/integrations/new_integration_prompt.md +41 -0
  235. package/integrations/notion/__tests__/get_handlers.test.ts +153 -0
  236. package/integrations/notion/__tests__/usage_parity.test.ts +34 -0
  237. package/integrations/notion/__tests__/write_and_admin_handlers.test.ts +190 -0
  238. package/integrations/notion/credentials.json +21 -0
  239. package/integrations/notion/credentials_hint.md +5 -0
  240. package/integrations/notion/handlers/append_block_children.js +7 -0
  241. package/integrations/notion/handlers/create_comment.js +10 -0
  242. package/integrations/notion/handlers/create_database.js +11 -0
  243. package/integrations/notion/handlers/create_page.js +13 -0
  244. package/integrations/notion/handlers/delete_block.js +8 -0
  245. package/integrations/notion/handlers/get_me.js +4 -0
  246. package/integrations/notion/handlers/list_block_children.js +10 -0
  247. package/integrations/notion/handlers/list_comments.js +14 -0
  248. package/integrations/notion/handlers/list_users.js +10 -0
  249. package/integrations/notion/handlers/query_database.js +10 -0
  250. package/integrations/notion/handlers/retrieve_block.js +4 -0
  251. package/integrations/notion/handlers/retrieve_database.js +4 -0
  252. package/integrations/notion/handlers/retrieve_page.js +4 -0
  253. package/integrations/notion/handlers/retrieve_page_property_item.js +10 -0
  254. package/integrations/notion/handlers/retrieve_user.js +4 -0
  255. package/integrations/notion/handlers/search.js +11 -0
  256. package/integrations/notion/handlers/update_block.js +7 -0
  257. package/integrations/notion/handlers/update_database.js +10 -0
  258. package/integrations/notion/handlers/update_page_properties.js +10 -0
  259. package/integrations/notion/manifest.json +139 -0
  260. package/integrations/notion/prompt.md +26 -0
  261. package/integrations/notion/schemas/append_block_children.json +10 -0
  262. package/integrations/notion/schemas/create_comment.json +18 -0
  263. package/integrations/notion/schemas/create_database.json +18 -0
  264. package/integrations/notion/schemas/create_page.json +22 -0
  265. package/integrations/notion/schemas/delete_block.json +9 -0
  266. package/integrations/notion/schemas/empty.json +6 -0
  267. package/integrations/notion/schemas/id_block.json +9 -0
  268. package/integrations/notion/schemas/id_database.json +9 -0
  269. package/integrations/notion/schemas/id_page.json +9 -0
  270. package/integrations/notion/schemas/id_user.json +9 -0
  271. package/integrations/notion/schemas/list_block_children.json +11 -0
  272. package/integrations/notion/schemas/list_comments.json +15 -0
  273. package/integrations/notion/schemas/list_users.json +9 -0
  274. package/integrations/notion/schemas/query_database.json +13 -0
  275. package/integrations/notion/schemas/retrieve_page_property_item.json +12 -0
  276. package/integrations/notion/schemas/search.json +27 -0
  277. package/integrations/notion/schemas/update_block.json +10 -0
  278. package/integrations/notion/schemas/update_database.json +13 -0
  279. package/integrations/notion/schemas/update_page_properties.json +13 -0
  280. package/integrations/trello/__tests__/get_handlers.test.ts +240 -0
  281. package/integrations/trello/__tests__/usage_parity.test.ts +34 -0
  282. package/integrations/trello/__tests__/write_and_admin_handlers.test.ts +189 -0
  283. package/integrations/trello/credentials.json +26 -0
  284. package/integrations/trello/credentials_hint.md +4 -0
  285. package/integrations/trello/handlers/add_checklist_to_card.js +5 -0
  286. package/integrations/trello/handlers/add_member_to_card.js +5 -0
  287. package/integrations/trello/handlers/archive_list.js +5 -0
  288. package/integrations/trello/handlers/create_card.js +13 -0
  289. package/integrations/trello/handlers/create_list.js +7 -0
  290. package/integrations/trello/handlers/delete_card.js +9 -0
  291. package/integrations/trello/handlers/get_board.js +4 -0
  292. package/integrations/trello/handlers/get_board_cards.js +4 -0
  293. package/integrations/trello/handlers/get_board_custom_fields.js +4 -0
  294. package/integrations/trello/handlers/get_board_labels.js +4 -0
  295. package/integrations/trello/handlers/get_board_lists.js +4 -0
  296. package/integrations/trello/handlers/get_board_members.js +4 -0
  297. package/integrations/trello/handlers/get_board_memberships.js +4 -0
  298. package/integrations/trello/handlers/get_card.js +4 -0
  299. package/integrations/trello/handlers/get_card_actions.js +4 -0
  300. package/integrations/trello/handlers/get_card_attachments.js +4 -0
  301. package/integrations/trello/handlers/get_card_checklists.js +4 -0
  302. package/integrations/trello/handlers/get_card_custom_field_items.js +4 -0
  303. package/integrations/trello/handlers/get_card_members.js +4 -0
  304. package/integrations/trello/handlers/get_list.js +4 -0
  305. package/integrations/trello/handlers/get_list_cards.js +4 -0
  306. package/integrations/trello/handlers/get_member.js +4 -0
  307. package/integrations/trello/handlers/get_member_boards.js +4 -0
  308. package/integrations/trello/handlers/get_member_organizations.js +4 -0
  309. package/integrations/trello/handlers/get_organization.js +4 -0
  310. package/integrations/trello/handlers/get_organization_boards.js +4 -0
  311. package/integrations/trello/handlers/move_card_to_list.js +5 -0
  312. package/integrations/trello/handlers/remove_member_from_card.js +9 -0
  313. package/integrations/trello/handlers/search.js +5 -0
  314. package/integrations/trello/handlers/update_card.js +19 -0
  315. package/integrations/trello/handlers/update_list.js +11 -0
  316. package/integrations/trello/manifest.json +231 -0
  317. package/integrations/trello/schemas/add_checklist_to_card.json +10 -0
  318. package/integrations/trello/schemas/add_member_to_card.json +10 -0
  319. package/integrations/trello/schemas/archive_list.json +9 -0
  320. package/integrations/trello/schemas/create_card.json +13 -0
  321. package/integrations/trello/schemas/create_list.json +11 -0
  322. package/integrations/trello/schemas/delete_card.json +9 -0
  323. package/integrations/trello/schemas/display_trello_cards.json +45 -0
  324. package/integrations/trello/schemas/empty.json +5 -0
  325. package/integrations/trello/schemas/get_member.json +5 -0
  326. package/integrations/trello/schemas/id_board.json +8 -0
  327. package/integrations/trello/schemas/id_card.json +8 -0
  328. package/integrations/trello/schemas/id_list.json +8 -0
  329. package/integrations/trello/schemas/id_org.json +8 -0
  330. package/integrations/trello/schemas/move_card_to_list.json +10 -0
  331. package/integrations/trello/schemas/remove_member_from_card.json +10 -0
  332. package/integrations/trello/schemas/search.json +8 -0
  333. package/integrations/trello/schemas/update_card.json +16 -0
  334. package/integrations/trello/schemas/update_list.json +12 -0
  335. 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,10 @@
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" }
8
+ },
9
+ "additionalProperties": false
10
+ }
@@ -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
+ })