@commandable/integration-data 0.3.0 → 0.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/credentials-index.d.ts +2 -7
- package/dist/credentials-index.d.ts.map +1 -1
- package/dist/credentials-index.js +11 -677
- package/dist/credentials-index.js.map +1 -1
- package/dist/generated/registry.d.ts +3 -0
- package/dist/generated/registry.d.ts.map +1 -0
- package/dist/generated/registry.js +11889 -0
- package/dist/generated/registry.js.map +1 -0
- package/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/loader.d.ts +1 -133
- package/dist/loader.d.ts.map +1 -1
- package/dist/loader.js +63 -194
- package/dist/loader.js.map +1 -1
- package/dist/tools.d.ts +2 -2
- package/dist/tools.d.ts.map +1 -1
- package/dist/tools.js +1 -1
- package/dist/tools.js.map +1 -1
- package/dist/types.d.ts +88 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/package.json +3 -4
- package/integrations/README.md +0 -52
- package/integrations/__tests__/liveHarness.ts +0 -97
- package/integrations/__tests__/usageParity.ts +0 -54
- package/integrations/airtable/.env.test +0 -9
- package/integrations/airtable/.env.test.example +0 -11
- package/integrations/airtable/README.md +0 -27
- package/integrations/airtable/__tests__/get_handlers.test.ts +0 -187
- package/integrations/airtable/__tests__/usage_parity.test.ts +0 -9
- package/integrations/airtable/__tests__/write_and_admin_handlers.test.ts +0 -116
- package/integrations/airtable/credentials.json +0 -26
- package/integrations/airtable/credentials_hint.md +0 -4
- package/integrations/airtable/handlers/create_record.js +0 -12
- package/integrations/airtable/handlers/delete_record.js +0 -7
- package/integrations/airtable/handlers/get_record.js +0 -4
- package/integrations/airtable/handlers/get_table_schema.js +0 -6
- package/integrations/airtable/handlers/list_bases.js +0 -4
- package/integrations/airtable/handlers/list_records.js +0 -25
- package/integrations/airtable/handlers/list_table_fields.js +0 -6
- package/integrations/airtable/handlers/list_tables.js +0 -4
- package/integrations/airtable/handlers/list_views.js +0 -6
- package/integrations/airtable/handlers/search_records.js +0 -6
- package/integrations/airtable/handlers/update_record.js +0 -11
- package/integrations/airtable/manifest.json +0 -83
- package/integrations/airtable/schemas/create_record.json +0 -12
- package/integrations/airtable/schemas/delete_record.json +0 -11
- package/integrations/airtable/schemas/empty.json +0 -6
- package/integrations/airtable/schemas/get_record.json +0 -11
- package/integrations/airtable/schemas/id_base.json +0 -9
- package/integrations/airtable/schemas/id_base_table.json +0 -10
- package/integrations/airtable/schemas/list_records.json +0 -26
- package/integrations/airtable/schemas/search_records.json +0 -12
- package/integrations/airtable/schemas/update_record.json +0 -13
- package/integrations/confluence/.env.test +0 -25
- package/integrations/confluence/.env.test.example +0 -36
- package/integrations/confluence/README.md +0 -28
- package/integrations/confluence/__tests__/get_handlers.test.ts +0 -121
- package/integrations/confluence/__tests__/usage_parity.test.ts +0 -14
- package/integrations/confluence/__tests__/write_handlers.test.ts +0 -131
- package/integrations/confluence/credentials.json +0 -39
- package/integrations/confluence/credentials_hint.md +0 -4
- package/integrations/confluence/credentials_hint_api_token.md +0 -9
- package/integrations/confluence/credentials_hint_oauth_token.md +0 -8
- package/integrations/confluence/handlers/add_comment.js +0 -19
- package/integrations/confluence/handlers/add_label.js +0 -16
- package/integrations/confluence/handlers/create_page.js +0 -22
- package/integrations/confluence/handlers/delete_page.js +0 -17
- package/integrations/confluence/handlers/get_comments.js +0 -33
- package/integrations/confluence/handlers/get_page_children.js +0 -30
- package/integrations/confluence/handlers/get_space.js +0 -22
- package/integrations/confluence/handlers/list_spaces.js +0 -39
- package/integrations/confluence/handlers/read_page.js +0 -49
- package/integrations/confluence/handlers/search_pages.js +0 -42
- package/integrations/confluence/handlers/update_page.js +0 -42
- package/integrations/confluence/manifest.json +0 -85
- package/integrations/confluence/prompt.md +0 -55
- package/integrations/confluence/schemas/add_comment.json +0 -22
- package/integrations/confluence/schemas/add_label.json +0 -19
- package/integrations/confluence/schemas/create_page.json +0 -33
- package/integrations/confluence/schemas/delete_page.json +0 -23
- package/integrations/confluence/schemas/empty.json +0 -6
- package/integrations/confluence/schemas/get_comments.json +0 -24
- package/integrations/confluence/schemas/get_page_children.json +0 -28
- package/integrations/confluence/schemas/get_space.json +0 -18
- package/integrations/confluence/schemas/list_spaces.json +0 -36
- package/integrations/confluence/schemas/read_page.json +0 -28
- package/integrations/confluence/schemas/search_pages.json +0 -26
- package/integrations/confluence/schemas/update_page.json +0 -31
- package/integrations/github/.env.test +0 -16
- package/integrations/github/.env.test.example +0 -17
- package/integrations/github/README.md +0 -75
- package/integrations/github/__tests__/get_handlers.test.ts +0 -305
- package/integrations/github/__tests__/usage_parity.test.ts +0 -22
- package/integrations/github/__tests__/write_handlers.test.ts +0 -496
- package/integrations/github/credentials.json +0 -47
- package/integrations/github/credentials_hint.md +0 -7
- package/integrations/github/credentials_hint_classic_pat.md +0 -8
- package/integrations/github/credentials_hint_fine_grained_pat.md +0 -9
- package/integrations/github/handlers/add_labels_to_issue.js +0 -12
- package/integrations/github/handlers/close_issue.js +0 -5
- package/integrations/github/handlers/comment_on_issue.js +0 -5
- package/integrations/github/handlers/create_branch.js +0 -33
- package/integrations/github/handlers/create_commit.js +0 -84
- package/integrations/github/handlers/create_file.js +0 -46
- package/integrations/github/handlers/create_issue.js +0 -10
- package/integrations/github/handlers/create_or_update_file.js +0 -21
- package/integrations/github/handlers/create_pull_request.js +0 -16
- package/integrations/github/handlers/create_pull_request_review.js +0 -10
- package/integrations/github/handlers/create_release.js +0 -14
- package/integrations/github/handlers/create_repo.js +0 -11
- package/integrations/github/handlers/delete_branch.js +0 -8
- package/integrations/github/handlers/delete_file.js +0 -22
- package/integrations/github/handlers/delete_repo.js +0 -6
- package/integrations/github/handlers/edit_file.js +0 -52
- package/integrations/github/handlers/edit_files.js +0 -107
- package/integrations/github/handlers/fork_repo.js +0 -10
- package/integrations/github/handlers/get_commit.js +0 -8
- package/integrations/github/handlers/get_file_contents.js +0 -21
- package/integrations/github/handlers/get_issue.js +0 -4
- package/integrations/github/handlers/get_job_logs.js +0 -6
- package/integrations/github/handlers/get_latest_release.js +0 -4
- package/integrations/github/handlers/get_me.js +0 -4
- package/integrations/github/handlers/get_pull_request.js +0 -4
- package/integrations/github/handlers/get_pull_request_diff.js +0 -8
- package/integrations/github/handlers/get_repo.js +0 -4
- package/integrations/github/handlers/get_repo_tree.js +0 -12
- package/integrations/github/handlers/get_workflow_run.js +0 -4
- package/integrations/github/handlers/list_branches.js +0 -9
- package/integrations/github/handlers/list_commits.js +0 -11
- package/integrations/github/handlers/list_issue_comments.js +0 -8
- package/integrations/github/handlers/list_issues.js +0 -11
- package/integrations/github/handlers/list_labels.js +0 -8
- package/integrations/github/handlers/list_pull_request_comments.js +0 -8
- package/integrations/github/handlers/list_pull_request_files.js +0 -8
- package/integrations/github/handlers/list_pull_requests.js +0 -13
- package/integrations/github/handlers/list_releases.js +0 -8
- package/integrations/github/handlers/list_repos_install.js +0 -4
- package/integrations/github/handlers/list_repos_user.js +0 -4
- package/integrations/github/handlers/list_tags.js +0 -8
- package/integrations/github/handlers/list_workflow_runs.js +0 -11
- package/integrations/github/handlers/merge_pull_request.js +0 -14
- package/integrations/github/handlers/request_pull_request_reviewers.js +0 -10
- package/integrations/github/handlers/search_code.js +0 -8
- package/integrations/github/handlers/search_issues.js +0 -8
- package/integrations/github/handlers/search_pull_requests.js +0 -8
- package/integrations/github/handlers/search_repos.js +0 -10
- package/integrations/github/handlers/update_issue.js +0 -15
- package/integrations/github/handlers/update_pull_request.js +0 -13
- package/integrations/github/manifest.json +0 -91
- package/integrations/github/prompt.md +0 -36
- package/integrations/github/schemas/add_labels_to_issue.json +0 -12
- package/integrations/github/schemas/close_issue.json +0 -10
- package/integrations/github/schemas/comment_on_issue.json +0 -11
- package/integrations/github/schemas/create_branch.json +0 -12
- package/integrations/github/schemas/create_commit.json +0 -25
- package/integrations/github/schemas/create_file.json +0 -13
- package/integrations/github/schemas/create_issue.json +0 -13
- package/integrations/github/schemas/create_or_update_file.json +0 -15
- package/integrations/github/schemas/create_pull_request.json +0 -15
- package/integrations/github/schemas/create_pull_request_review.json +0 -17
- package/integrations/github/schemas/create_release.json +0 -16
- package/integrations/github/schemas/create_repo.json +0 -12
- package/integrations/github/schemas/delete_branch.json +0 -10
- package/integrations/github/schemas/delete_file.json +0 -13
- package/integrations/github/schemas/delete_repo.json +0 -10
- package/integrations/github/schemas/edit_file.json +0 -26
- package/integrations/github/schemas/edit_files.json +0 -39
- package/integrations/github/schemas/empty.json +0 -5
- package/integrations/github/schemas/fork_repo.json +0 -11
- package/integrations/github/schemas/get_commit.json +0 -12
- package/integrations/github/schemas/get_file_contents.json +0 -11
- package/integrations/github/schemas/get_issue.json +0 -10
- package/integrations/github/schemas/get_job_logs.json +0 -10
- package/integrations/github/schemas/get_pull_request.json +0 -10
- package/integrations/github/schemas/get_pull_request_diff.json +0 -10
- package/integrations/github/schemas/get_repo.json +0 -9
- package/integrations/github/schemas/get_repo_tree.json +0 -12
- package/integrations/github/schemas/get_workflow_run.json +0 -10
- package/integrations/github/schemas/list_branches.json +0 -12
- package/integrations/github/schemas/list_commits.json +0 -14
- package/integrations/github/schemas/list_issue_comments.json +0 -12
- package/integrations/github/schemas/list_issues.json +0 -14
- package/integrations/github/schemas/list_labels.json +0 -11
- package/integrations/github/schemas/list_pull_request_comments.json +0 -12
- package/integrations/github/schemas/list_pull_request_files.json +0 -12
- package/integrations/github/schemas/list_pull_requests.json +0 -16
- package/integrations/github/schemas/list_releases.json +0 -11
- package/integrations/github/schemas/list_tags.json +0 -11
- package/integrations/github/schemas/list_workflow_runs.json +0 -18
- package/integrations/github/schemas/merge_pull_request.json +0 -14
- package/integrations/github/schemas/owner_repo.json +0 -9
- package/integrations/github/schemas/request_pull_request_reviewers.json +0 -20
- package/integrations/github/schemas/search_code.json +0 -10
- package/integrations/github/schemas/search_issues.json +0 -10
- package/integrations/github/schemas/search_pull_requests.json +0 -10
- package/integrations/github/schemas/search_repos.json +0 -12
- package/integrations/github/schemas/update_issue.json +0 -15
- package/integrations/github/schemas/update_pull_request.json +0 -15
- package/integrations/google-calendar/.env.test.example +0 -11
- package/integrations/google-calendar/README.md +0 -41
- package/integrations/google-calendar/__tests__/get_handlers.test.ts +0 -120
- package/integrations/google-calendar/__tests__/usage_parity.test.ts +0 -9
- package/integrations/google-calendar/__tests__/write_and_admin_handlers.test.ts +0 -155
- package/integrations/google-calendar/credentials.json +0 -59
- package/integrations/google-calendar/credentials_hint.md +0 -9
- package/integrations/google-calendar/credentials_hint_oauth_token.md +0 -8
- package/integrations/google-calendar/credentials_hint_service_account.md +0 -10
- package/integrations/google-calendar/handlers/create_event.js +0 -6
- package/integrations/google-calendar/handlers/delete_acl.js +0 -6
- package/integrations/google-calendar/handlers/delete_event.js +0 -7
- package/integrations/google-calendar/handlers/freebusy_query.js +0 -4
- package/integrations/google-calendar/handlers/get_acl.js +0 -5
- package/integrations/google-calendar/handlers/get_calendar.js +0 -4
- package/integrations/google-calendar/handlers/get_event.js +0 -9
- package/integrations/google-calendar/handlers/insert_acl.js +0 -6
- package/integrations/google-calendar/handlers/list_acl.js +0 -5
- package/integrations/google-calendar/handlers/list_calendars.js +0 -4
- package/integrations/google-calendar/handlers/list_colors.js +0 -4
- package/integrations/google-calendar/handlers/list_events.js +0 -23
- package/integrations/google-calendar/handlers/list_settings.js +0 -4
- package/integrations/google-calendar/handlers/move_event.js +0 -6
- package/integrations/google-calendar/handlers/patch_event.js +0 -5
- package/integrations/google-calendar/handlers/quick_add.js +0 -6
- package/integrations/google-calendar/handlers/update_acl.js +0 -7
- package/integrations/google-calendar/manifest.json +0 -35
- package/integrations/google-calendar/prompt.md +0 -68
- package/integrations/google-calendar/schemas/create_event.json +0 -34
- package/integrations/google-calendar/schemas/delete_acl.json +0 -9
- package/integrations/google-calendar/schemas/empty.json +0 -1
- package/integrations/google-calendar/schemas/freebusy_query.json +0 -13
- package/integrations/google-calendar/schemas/get_acl.json +0 -9
- package/integrations/google-calendar/schemas/id_calendar.json +0 -8
- package/integrations/google-calendar/schemas/id_calendar_event.json +0 -11
- package/integrations/google-calendar/schemas/insert_acl.json +0 -18
- package/integrations/google-calendar/schemas/list_events.json +0 -17
- package/integrations/google-calendar/schemas/move_event.json +0 -10
- package/integrations/google-calendar/schemas/patch_event.json +0 -10
- package/integrations/google-calendar/schemas/quick_add.json +0 -9
- package/integrations/google-calendar/schemas/update_acl.json +0 -10
- package/integrations/google-docs/README.md +0 -30
- package/integrations/google-docs/__tests__/get_handlers.test.ts +0 -83
- package/integrations/google-docs/__tests__/usage_parity.test.ts +0 -9
- package/integrations/google-docs/__tests__/write_handlers.test.ts +0 -238
- package/integrations/google-docs/credentials.json +0 -57
- package/integrations/google-docs/credentials_hint.md +0 -9
- package/integrations/google-docs/credentials_hint_oauth_token.md +0 -8
- package/integrations/google-docs/credentials_hint_service_account.md +0 -10
- package/integrations/google-docs/handlers/append_text.js +0 -12
- package/integrations/google-docs/handlers/batch_update.js +0 -13
- package/integrations/google-docs/handlers/create_document.js +0 -9
- package/integrations/google-docs/handlers/delete_first_match.js +0 -50
- package/integrations/google-docs/handlers/insert_inline_image_after_first_match.js +0 -41
- package/integrations/google-docs/handlers/insert_page_break_after_first_match.js +0 -49
- package/integrations/google-docs/handlers/insert_table_after_first_match.js +0 -49
- package/integrations/google-docs/handlers/insert_text_after_first_match.js +0 -51
- package/integrations/google-docs/handlers/read_document.js +0 -189
- package/integrations/google-docs/handlers/replace_all_text.js +0 -8
- package/integrations/google-docs/handlers/style_first_match.js +0 -42
- package/integrations/google-docs/handlers/update_document_style.js +0 -8
- package/integrations/google-docs/handlers/update_paragraph_style_for_first_match.js +0 -48
- package/integrations/google-docs/manifest.json +0 -43
- package/integrations/google-docs/prompt.md +0 -49
- package/integrations/google-docs/schemas/append_text.json +0 -10
- package/integrations/google-docs/schemas/apply_text_style.json +0 -13
- package/integrations/google-docs/schemas/batch_update.json +0 -16
- package/integrations/google-docs/schemas/create_document.json +0 -8
- package/integrations/google-docs/schemas/delete_content_range.json +0 -11
- package/integrations/google-docs/schemas/delete_first_match.json +0 -10
- package/integrations/google-docs/schemas/insert_inline_image.json +0 -12
- package/integrations/google-docs/schemas/insert_inline_image_after_first_match.json +0 -12
- package/integrations/google-docs/schemas/insert_page_break.json +0 -10
- package/integrations/google-docs/schemas/insert_page_break_after_first_match.json +0 -11
- package/integrations/google-docs/schemas/insert_table.json +0 -12
- package/integrations/google-docs/schemas/insert_table_after_first_match.json +0 -13
- package/integrations/google-docs/schemas/insert_text_after_first_match.json +0 -12
- package/integrations/google-docs/schemas/insert_text_at.json +0 -11
- package/integrations/google-docs/schemas/read_document.json +0 -12
- package/integrations/google-docs/schemas/replace_all_text.json +0 -12
- package/integrations/google-docs/schemas/style_first_match.json +0 -12
- package/integrations/google-docs/schemas/update_document_style.json +0 -11
- package/integrations/google-docs/schemas/update_paragraph_style.json +0 -13
- package/integrations/google-docs/schemas/update_paragraph_style_for_first_match.json +0 -12
- package/integrations/google-docs/todo.md +0 -18
- package/integrations/google-drive/README.md +0 -26
- package/integrations/google-drive/__tests__/handlers.test.ts +0 -145
- package/integrations/google-drive/__tests__/usage_parity.test.ts +0 -9
- package/integrations/google-drive/credentials.json +0 -59
- package/integrations/google-drive/credentials_hint_oauth_token.md +0 -8
- package/integrations/google-drive/credentials_hint_service_account.md +0 -10
- package/integrations/google-drive/handlers/create_file.js +0 -15
- package/integrations/google-drive/handlers/create_folder.js +0 -15
- package/integrations/google-drive/handlers/delete_file.js +0 -14
- package/integrations/google-drive/handlers/get_file.js +0 -5
- package/integrations/google-drive/handlers/get_file_content.js +0 -41
- package/integrations/google-drive/handlers/list_files.js +0 -15
- package/integrations/google-drive/handlers/move_file.js +0 -12
- package/integrations/google-drive/handlers/search_files.js +0 -20
- package/integrations/google-drive/handlers/share_file.js +0 -20
- package/integrations/google-drive/manifest.json +0 -69
- package/integrations/google-drive/prompt.md +0 -59
- package/integrations/google-drive/schemas/create_file.json +0 -12
- package/integrations/google-drive/schemas/create_folder.json +0 -11
- package/integrations/google-drive/schemas/delete_file.json +0 -10
- package/integrations/google-drive/schemas/get_file.json +0 -10
- package/integrations/google-drive/schemas/get_file_content.json +0 -11
- package/integrations/google-drive/schemas/list_files.json +0 -12
- package/integrations/google-drive/schemas/move_file.json +0 -12
- package/integrations/google-drive/schemas/search_files.json +0 -14
- package/integrations/google-drive/schemas/share_file.json +0 -23
- package/integrations/google-gmail/.env.test.example +0 -11
- package/integrations/google-gmail/README.md +0 -49
- package/integrations/google-gmail/__tests__/get_handlers.test.ts +0 -134
- package/integrations/google-gmail/__tests__/usage_parity.test.ts +0 -9
- package/integrations/google-gmail/__tests__/write_and_admin_handlers.test.ts +0 -211
- package/integrations/google-gmail/credentials.json +0 -59
- package/integrations/google-gmail/credentials_hint_oauth_token.md +0 -8
- package/integrations/google-gmail/credentials_hint_service_account.md +0 -10
- package/integrations/google-gmail/handlers/create_draft_email.js +0 -27
- package/integrations/google-gmail/handlers/create_label.js +0 -12
- package/integrations/google-gmail/handlers/delete_draft.js +0 -13
- package/integrations/google-gmail/handlers/delete_label.js +0 -13
- package/integrations/google-gmail/handlers/delete_message.js +0 -13
- package/integrations/google-gmail/handlers/delete_thread.js +0 -13
- package/integrations/google-gmail/handlers/get_draft.js +0 -6
- package/integrations/google-gmail/handlers/get_label.js +0 -6
- package/integrations/google-gmail/handlers/get_message.js +0 -14
- package/integrations/google-gmail/handlers/get_profile.js +0 -5
- package/integrations/google-gmail/handlers/get_thread.js +0 -14
- package/integrations/google-gmail/handlers/list_drafts.js +0 -15
- package/integrations/google-gmail/handlers/list_labels.js +0 -5
- package/integrations/google-gmail/handlers/list_messages.js +0 -19
- package/integrations/google-gmail/handlers/list_threads.js +0 -19
- package/integrations/google-gmail/handlers/modify_message.js +0 -11
- package/integrations/google-gmail/handlers/modify_thread.js +0 -11
- package/integrations/google-gmail/handlers/read_email.js +0 -56
- package/integrations/google-gmail/handlers/send_draft.js +0 -15
- package/integrations/google-gmail/handlers/send_email.js +0 -22
- package/integrations/google-gmail/handlers/trash_message.js +0 -6
- package/integrations/google-gmail/handlers/trash_thread.js +0 -6
- package/integrations/google-gmail/handlers/untrash_message.js +0 -6
- package/integrations/google-gmail/handlers/untrash_thread.js +0 -6
- package/integrations/google-gmail/handlers/update_label.js +0 -15
- package/integrations/google-gmail/manifest.json +0 -44
- package/integrations/google-gmail/prompt.md +0 -52
- package/integrations/google-gmail/schemas/create_draft_email.json +0 -16
- package/integrations/google-gmail/schemas/create_label.json +0 -26
- package/integrations/google-gmail/schemas/get_message.json +0 -20
- package/integrations/google-gmail/schemas/get_profile.json +0 -11
- package/integrations/google-gmail/schemas/get_thread.json +0 -20
- package/integrations/google-gmail/schemas/id_draft.json +0 -16
- package/integrations/google-gmail/schemas/id_label.json +0 -16
- package/integrations/google-gmail/schemas/id_message.json +0 -16
- package/integrations/google-gmail/schemas/id_thread.json +0 -16
- package/integrations/google-gmail/schemas/list_drafts.json +0 -30
- package/integrations/google-gmail/schemas/list_labels.json +0 -11
- package/integrations/google-gmail/schemas/list_messages.json +0 -35
- package/integrations/google-gmail/schemas/list_threads.json +0 -35
- package/integrations/google-gmail/schemas/modify_message.json +0 -24
- package/integrations/google-gmail/schemas/modify_thread.json +0 -24
- package/integrations/google-gmail/schemas/read_email.json +0 -10
- package/integrations/google-gmail/schemas/send_draft.json +0 -29
- package/integrations/google-gmail/schemas/send_email.json +0 -17
- package/integrations/google-gmail/schemas/update_label.json +0 -33
- package/integrations/google-sheet/README.md +0 -27
- package/integrations/google-sheet/__tests__/get_handlers.test.ts +0 -76
- package/integrations/google-sheet/__tests__/usage_parity.test.ts +0 -9
- package/integrations/google-sheet/__tests__/write_handlers.test.ts +0 -153
- package/integrations/google-sheet/credentials.json +0 -57
- package/integrations/google-sheet/credentials_hint.md +0 -9
- package/integrations/google-sheet/credentials_hint_oauth_token.md +0 -8
- package/integrations/google-sheet/credentials_hint_service_account.md +0 -10
- package/integrations/google-sheet/handlers/append_values.js +0 -18
- package/integrations/google-sheet/handlers/batch_clear_values.js +0 -6
- package/integrations/google-sheet/handlers/batch_update.js +0 -14
- package/integrations/google-sheet/handlers/batch_update_values.js +0 -16
- package/integrations/google-sheet/handlers/clear_values.js +0 -6
- package/integrations/google-sheet/handlers/copy_to_spreadsheet.js +0 -6
- package/integrations/google-sheet/handlers/create_spreadsheet.js +0 -5
- package/integrations/google-sheet/handlers/get_spreadsheet.js +0 -14
- package/integrations/google-sheet/handlers/read_sheet.js +0 -75
- package/integrations/google-sheet/handlers/update_values.js +0 -16
- package/integrations/google-sheet/manifest.json +0 -76
- package/integrations/google-sheet/prompt.md +0 -49
- package/integrations/google-sheet/schemas/append_values.json +0 -16
- package/integrations/google-sheet/schemas/batch_clear_values.json +0 -10
- package/integrations/google-sheet/schemas/batch_update.json +0 -13
- package/integrations/google-sheet/schemas/batch_update_values.json +0 -25
- package/integrations/google-sheet/schemas/clear_values.json +0 -10
- package/integrations/google-sheet/schemas/copy_to_spreadsheet.json +0 -11
- package/integrations/google-sheet/schemas/create_spreadsheet.json +0 -11
- package/integrations/google-sheet/schemas/get_spreadsheet.json +0 -16
- package/integrations/google-sheet/schemas/read_sheet.json +0 -21
- package/integrations/google-sheet/schemas/update_values.json +0 -15
- package/integrations/google-slides/README.md +0 -28
- package/integrations/google-slides/__tests__/get_handlers.test.ts +0 -74
- package/integrations/google-slides/__tests__/usage_parity.test.ts +0 -9
- package/integrations/google-slides/__tests__/write_handlers.test.ts +0 -131
- package/integrations/google-slides/credentials.json +0 -57
- package/integrations/google-slides/credentials_hint.md +0 -9
- package/integrations/google-slides/credentials_hint_oauth_token.md +0 -8
- package/integrations/google-slides/credentials_hint_service_account.md +0 -10
- package/integrations/google-slides/handlers/append_text_to_title_of_first_slide.js +0 -17
- package/integrations/google-slides/handlers/batch_update.js +0 -15
- package/integrations/google-slides/handlers/create_presentation.js +0 -8
- package/integrations/google-slides/handlers/create_slide_after_first_match.js +0 -20
- package/integrations/google-slides/handlers/get_page_thumbnail.js +0 -12
- package/integrations/google-slides/handlers/insert_image_after_first_match.js +0 -19
- package/integrations/google-slides/handlers/insert_shape_after_first_match.js +0 -21
- package/integrations/google-slides/handlers/read_presentation.js +0 -51
- package/integrations/google-slides/handlers/replace_text_first_match.js +0 -9
- package/integrations/google-slides/handlers/set_background_color_for_slide_index.js +0 -15
- package/integrations/google-slides/handlers/style_text_first_match.js +0 -48
- package/integrations/google-slides/manifest.json +0 -41
- package/integrations/google-slides/prompt.md +0 -56
- package/integrations/google-slides/schemas/append_text_to_title_of_first_slide.json +0 -11
- package/integrations/google-slides/schemas/batch_update.json +0 -13
- package/integrations/google-slides/schemas/create_presentation.json +0 -8
- package/integrations/google-slides/schemas/create_slide_after_first_match.json +0 -11
- package/integrations/google-slides/schemas/get_page_thumbnail.json +0 -12
- package/integrations/google-slides/schemas/get_presentation.json +0 -9
- package/integrations/google-slides/schemas/insert_image_after_first_match.json +0 -13
- package/integrations/google-slides/schemas/insert_shape_after_first_match.json +0 -13
- package/integrations/google-slides/schemas/replace_text_first_match.json +0 -12
- package/integrations/google-slides/schemas/set_background_color_for_slide_index.json +0 -11
- package/integrations/google-slides/schemas/style_text_first_match.json +0 -12
- package/integrations/hubspot/.env.test.example +0 -20
- package/integrations/hubspot/README.md +0 -48
- package/integrations/hubspot/__tests__/get_handlers.test.ts +0 -151
- package/integrations/hubspot/__tests__/usage_parity.test.ts +0 -10
- package/integrations/hubspot/__tests__/write_handlers.test.ts +0 -244
- package/integrations/hubspot/credentials.json +0 -50
- package/integrations/hubspot/credentials_hint.md +0 -20
- package/integrations/hubspot/credentials_hint_oauth_token.md +0 -16
- package/integrations/hubspot/handlers/archive_company.js +0 -13
- package/integrations/hubspot/handlers/archive_contact.js +0 -13
- package/integrations/hubspot/handlers/archive_deal.js +0 -13
- package/integrations/hubspot/handlers/archive_ticket.js +0 -13
- package/integrations/hubspot/handlers/create_association.js +0 -18
- package/integrations/hubspot/handlers/create_company.js +0 -13
- package/integrations/hubspot/handlers/create_contact.js +0 -14
- package/integrations/hubspot/handlers/create_deal.js +0 -16
- package/integrations/hubspot/handlers/create_note.js +0 -44
- package/integrations/hubspot/handlers/create_task.js +0 -48
- package/integrations/hubspot/handlers/create_ticket.js +0 -15
- package/integrations/hubspot/handlers/get_associations.js +0 -14
- package/integrations/hubspot/handlers/get_company.js +0 -18
- package/integrations/hubspot/handlers/get_contact.js +0 -18
- package/integrations/hubspot/handlers/get_deal.js +0 -18
- package/integrations/hubspot/handlers/get_ticket.js +0 -20
- package/integrations/hubspot/handlers/list_owners.js +0 -12
- package/integrations/hubspot/handlers/list_pipelines.js +0 -5
- package/integrations/hubspot/handlers/list_properties.js +0 -11
- package/integrations/hubspot/handlers/remove_association.js +0 -22
- package/integrations/hubspot/handlers/search_companies.js +0 -43
- package/integrations/hubspot/handlers/search_contacts.js +0 -43
- package/integrations/hubspot/handlers/search_deals.js +0 -43
- package/integrations/hubspot/handlers/search_notes.js +0 -43
- package/integrations/hubspot/handlers/search_tasks.js +0 -43
- package/integrations/hubspot/handlers/search_tickets.js +0 -43
- package/integrations/hubspot/handlers/update_company.js +0 -13
- package/integrations/hubspot/handlers/update_contact.js +0 -14
- package/integrations/hubspot/handlers/update_deal.js +0 -16
- package/integrations/hubspot/handlers/update_task.js +0 -17
- package/integrations/hubspot/handlers/update_ticket.js +0 -15
- package/integrations/hubspot/manifest.json +0 -230
- package/integrations/hubspot/prompt.md +0 -69
- package/integrations/hubspot/schemas/archive_company.json +0 -13
- package/integrations/hubspot/schemas/archive_contact.json +0 -13
- package/integrations/hubspot/schemas/archive_deal.json +0 -9
- package/integrations/hubspot/schemas/archive_ticket.json +0 -9
- package/integrations/hubspot/schemas/create_association.json +0 -24
- package/integrations/hubspot/schemas/create_company.json +0 -14
- package/integrations/hubspot/schemas/create_contact.json +0 -15
- package/integrations/hubspot/schemas/create_deal.json +0 -20
- package/integrations/hubspot/schemas/create_note.json +0 -37
- package/integrations/hubspot/schemas/create_task.json +0 -51
- package/integrations/hubspot/schemas/create_ticket.json +0 -16
- package/integrations/hubspot/schemas/empty.json +0 -6
- package/integrations/hubspot/schemas/get_associations.json +0 -30
- package/integrations/hubspot/schemas/get_company.json +0 -27
- package/integrations/hubspot/schemas/get_contact.json +0 -27
- package/integrations/hubspot/schemas/get_deal.json +0 -20
- package/integrations/hubspot/schemas/get_ticket.json +0 -20
- package/integrations/hubspot/schemas/list_owners.json +0 -25
- package/integrations/hubspot/schemas/list_pipelines.json +0 -13
- package/integrations/hubspot/schemas/list_properties.json +0 -17
- package/integrations/hubspot/schemas/remove_association.json +0 -24
- package/integrations/hubspot/schemas/search_companies.json +0 -56
- package/integrations/hubspot/schemas/search_contacts.json +0 -56
- package/integrations/hubspot/schemas/search_deals.json +0 -43
- package/integrations/hubspot/schemas/search_notes.json +0 -43
- package/integrations/hubspot/schemas/search_tasks.json +0 -43
- package/integrations/hubspot/schemas/search_tickets.json +0 -43
- package/integrations/hubspot/schemas/update_company.json +0 -20
- package/integrations/hubspot/schemas/update_contact.json +0 -21
- package/integrations/hubspot/schemas/update_deal.json +0 -19
- package/integrations/hubspot/schemas/update_task.json +0 -31
- package/integrations/hubspot/schemas/update_ticket.json +0 -18
- package/integrations/jira/.env.test +0 -46
- package/integrations/jira/.env.test.example +0 -41
- package/integrations/jira/README.md +0 -46
- package/integrations/jira/__tests__/get_handlers.test.ts +0 -193
- package/integrations/jira/__tests__/usage_parity.test.ts +0 -14
- package/integrations/jira/__tests__/write_handlers.test.ts +0 -157
- package/integrations/jira/credentials.json +0 -39
- package/integrations/jira/credentials_hint.md +0 -4
- package/integrations/jira/credentials_hint_api_token.md +0 -6
- package/integrations/jira/credentials_hint_oauth_token.md +0 -6
- package/integrations/jira/handlers/add_comment.js +0 -9
- package/integrations/jira/handlers/assign_issue.js +0 -11
- package/integrations/jira/handlers/create_issue.js +0 -37
- package/integrations/jira/handlers/create_sprint.js +0 -19
- package/integrations/jira/handlers/delete_issue.js +0 -10
- package/integrations/jira/handlers/get_backlog_issues.js +0 -13
- package/integrations/jira/handlers/get_board.js +0 -6
- package/integrations/jira/handlers/get_issue.js +0 -63
- package/integrations/jira/handlers/get_issue_comments.js +0 -31
- package/integrations/jira/handlers/get_myself.js +0 -14
- package/integrations/jira/handlers/get_project.js +0 -28
- package/integrations/jira/handlers/get_sprint.js +0 -5
- package/integrations/jira/handlers/get_sprint_issues.js +0 -13
- package/integrations/jira/handlers/get_transitions.js +0 -23
- package/integrations/jira/handlers/list_boards.js +0 -34
- package/integrations/jira/handlers/list_projects.js +0 -29
- package/integrations/jira/handlers/list_sprints.js +0 -29
- package/integrations/jira/handlers/move_issues_to_sprint.js +0 -11
- package/integrations/jira/handlers/search_issues.js +0 -43
- package/integrations/jira/handlers/search_users.js +0 -21
- package/integrations/jira/handlers/transition_issue.js +0 -44
- package/integrations/jira/handlers/update_issue.js +0 -40
- package/integrations/jira/handlers/update_sprint.js +0 -20
- package/integrations/jira/manifest.json +0 -204
- package/integrations/jira/prompt.md +0 -80
- package/integrations/jira/schemas/add_comment.json +0 -16
- package/integrations/jira/schemas/assign_issue.json +0 -16
- package/integrations/jira/schemas/create_issue.json +0 -49
- package/integrations/jira/schemas/create_sprint.json +0 -29
- package/integrations/jira/schemas/delete_issue.json +0 -12
- package/integrations/jira/schemas/empty.json +0 -6
- package/integrations/jira/schemas/get_backlog_issues.json +0 -33
- package/integrations/jira/schemas/get_board.json +0 -13
- package/integrations/jira/schemas/get_issue.json +0 -23
- package/integrations/jira/schemas/get_issue_comments.json +0 -23
- package/integrations/jira/schemas/get_project.json +0 -17
- package/integrations/jira/schemas/get_sprint.json +0 -13
- package/integrations/jira/schemas/get_sprint_issues.json +0 -33
- package/integrations/jira/schemas/get_transitions.json +0 -12
- package/integrations/jira/schemas/list_boards.json +0 -27
- package/integrations/jira/schemas/list_projects.json +0 -22
- package/integrations/jira/schemas/list_sprints.json +0 -29
- package/integrations/jira/schemas/move_issues_to_sprint.json +0 -19
- package/integrations/jira/schemas/search_issues.json +0 -28
- package/integrations/jira/schemas/search_users.json +0 -18
- package/integrations/jira/schemas/transition_issue.json +0 -38
- package/integrations/jira/schemas/update_issue.json +0 -47
- package/integrations/jira/schemas/update_sprint.json +0 -33
- package/integrations/new_integration_prompt.md +0 -216
- package/integrations/notion/.env.test +0 -10
- package/integrations/notion/.env.test.example +0 -13
- package/integrations/notion/README.md +0 -42
- package/integrations/notion/__tests__/get_handlers.test.ts +0 -156
- package/integrations/notion/__tests__/usage_parity.test.ts +0 -9
- package/integrations/notion/__tests__/write_and_admin_handlers.test.ts +0 -186
- package/integrations/notion/credentials.json +0 -27
- package/integrations/notion/credentials_hint.md +0 -5
- package/integrations/notion/handlers/append_block_children.js +0 -7
- package/integrations/notion/handlers/create_comment.js +0 -10
- package/integrations/notion/handlers/create_database.js +0 -11
- package/integrations/notion/handlers/create_page.js +0 -13
- package/integrations/notion/handlers/delete_block.js +0 -8
- package/integrations/notion/handlers/get_me.js +0 -4
- package/integrations/notion/handlers/list_block_children.js +0 -10
- package/integrations/notion/handlers/list_comments.js +0 -14
- package/integrations/notion/handlers/list_users.js +0 -10
- package/integrations/notion/handlers/query_database.js +0 -10
- package/integrations/notion/handlers/retrieve_block.js +0 -4
- package/integrations/notion/handlers/retrieve_database.js +0 -4
- package/integrations/notion/handlers/retrieve_page.js +0 -4
- package/integrations/notion/handlers/retrieve_page_property_item.js +0 -10
- package/integrations/notion/handlers/retrieve_user.js +0 -4
- package/integrations/notion/handlers/search.js +0 -11
- package/integrations/notion/handlers/update_block.js +0 -7
- package/integrations/notion/handlers/update_database.js +0 -10
- package/integrations/notion/handlers/update_page_properties.js +0 -10
- package/integrations/notion/manifest.json +0 -168
- package/integrations/notion/prompt.md +0 -26
- package/integrations/notion/schemas/append_block_children.json +0 -10
- package/integrations/notion/schemas/create_comment.json +0 -18
- package/integrations/notion/schemas/create_database.json +0 -18
- package/integrations/notion/schemas/create_page.json +0 -22
- package/integrations/notion/schemas/delete_block.json +0 -9
- package/integrations/notion/schemas/empty.json +0 -6
- package/integrations/notion/schemas/id_block.json +0 -9
- package/integrations/notion/schemas/id_database.json +0 -9
- package/integrations/notion/schemas/id_page.json +0 -9
- package/integrations/notion/schemas/id_user.json +0 -9
- package/integrations/notion/schemas/list_block_children.json +0 -11
- package/integrations/notion/schemas/list_comments.json +0 -15
- package/integrations/notion/schemas/list_users.json +0 -9
- package/integrations/notion/schemas/query_database.json +0 -13
- package/integrations/notion/schemas/retrieve_page_property_item.json +0 -12
- package/integrations/notion/schemas/search.json +0 -27
- package/integrations/notion/schemas/update_block.json +0 -10
- package/integrations/notion/schemas/update_database.json +0 -13
- package/integrations/notion/schemas/update_page_properties.json +0 -13
- package/integrations/trello/.env.test +0 -6
- package/integrations/trello/.env.test.example +0 -9
- package/integrations/trello/README.md +0 -50
- package/integrations/trello/__tests__/get_handlers.test.ts +0 -225
- package/integrations/trello/__tests__/usage_parity.test.ts +0 -9
- package/integrations/trello/__tests__/write_and_admin_handlers.test.ts +0 -171
- package/integrations/trello/credentials.json +0 -32
- package/integrations/trello/credentials_hint.md +0 -4
- package/integrations/trello/handlers/add_checklist_to_card.js +0 -5
- package/integrations/trello/handlers/add_member_to_card.js +0 -5
- package/integrations/trello/handlers/archive_list.js +0 -5
- package/integrations/trello/handlers/close_board.js +0 -6
- package/integrations/trello/handlers/create_board.js +0 -11
- package/integrations/trello/handlers/create_card.js +0 -13
- package/integrations/trello/handlers/create_list.js +0 -7
- package/integrations/trello/handlers/delete_board.js +0 -13
- package/integrations/trello/handlers/delete_card.js +0 -9
- package/integrations/trello/handlers/get_board.js +0 -4
- package/integrations/trello/handlers/get_board_cards.js +0 -4
- package/integrations/trello/handlers/get_board_custom_fields.js +0 -4
- package/integrations/trello/handlers/get_board_labels.js +0 -4
- package/integrations/trello/handlers/get_board_lists.js +0 -4
- package/integrations/trello/handlers/get_board_members.js +0 -4
- package/integrations/trello/handlers/get_board_memberships.js +0 -4
- package/integrations/trello/handlers/get_card.js +0 -4
- package/integrations/trello/handlers/get_card_actions.js +0 -4
- package/integrations/trello/handlers/get_card_attachments.js +0 -4
- package/integrations/trello/handlers/get_card_checklists.js +0 -4
- package/integrations/trello/handlers/get_card_custom_field_items.js +0 -4
- package/integrations/trello/handlers/get_card_members.js +0 -4
- package/integrations/trello/handlers/get_list.js +0 -4
- package/integrations/trello/handlers/get_list_cards.js +0 -4
- package/integrations/trello/handlers/get_member.js +0 -4
- package/integrations/trello/handlers/get_member_boards.js +0 -4
- package/integrations/trello/handlers/get_member_organizations.js +0 -4
- package/integrations/trello/handlers/get_organization.js +0 -4
- package/integrations/trello/handlers/get_organization_boards.js +0 -4
- package/integrations/trello/handlers/move_card_to_list.js +0 -5
- package/integrations/trello/handlers/remove_member_from_card.js +0 -9
- package/integrations/trello/handlers/search.js +0 -5
- package/integrations/trello/handlers/update_card.js +0 -19
- package/integrations/trello/handlers/update_list.js +0 -11
- package/integrations/trello/manifest.json +0 -252
- package/integrations/trello/schemas/add_checklist_to_card.json +0 -10
- package/integrations/trello/schemas/add_member_to_card.json +0 -10
- package/integrations/trello/schemas/archive_list.json +0 -9
- package/integrations/trello/schemas/close_board.json +0 -10
- package/integrations/trello/schemas/create_board.json +0 -12
- package/integrations/trello/schemas/create_card.json +0 -13
- package/integrations/trello/schemas/create_list.json +0 -11
- package/integrations/trello/schemas/delete_board.json +0 -10
- package/integrations/trello/schemas/delete_card.json +0 -9
- package/integrations/trello/schemas/display_trello_cards.json +0 -45
- package/integrations/trello/schemas/empty.json +0 -5
- package/integrations/trello/schemas/get_member.json +0 -5
- package/integrations/trello/schemas/id_board.json +0 -8
- package/integrations/trello/schemas/id_card.json +0 -8
- package/integrations/trello/schemas/id_list.json +0 -8
- package/integrations/trello/schemas/id_org.json +0 -8
- package/integrations/trello/schemas/move_card_to_list.json +0 -10
- package/integrations/trello/schemas/remove_member_from_card.json +0 -10
- package/integrations/trello/schemas/search.json +0 -8
- package/integrations/trello/schemas/update_card.json +0 -16
- package/integrations/trello/schemas/update_list.json +0 -12
|
@@ -1,157 +0,0 @@
|
|
|
1
|
-
import { afterAll, beforeAll, describe, expect, it } from 'vitest'
|
|
2
|
-
import { createCredentialStore, createIntegrationNode, createProxy, createToolbox, hasEnv, safeCleanup } from '../../__tests__/liveHarness.js'
|
|
3
|
-
|
|
4
|
-
// LIVE Jira write tests using credentials
|
|
5
|
-
//
|
|
6
|
-
// Required for write tests:
|
|
7
|
-
// - JIRA_TEST_PROJECT_KEY
|
|
8
|
-
//
|
|
9
|
-
// Variant: api_token
|
|
10
|
-
// - JIRA_DOMAIN
|
|
11
|
-
// - JIRA_EMAIL
|
|
12
|
-
// - JIRA_API_TOKEN
|
|
13
|
-
//
|
|
14
|
-
// Optional:
|
|
15
|
-
// - JIRA_TEST_TRANSITION_NAME (enables transition_issue)
|
|
16
|
-
// - JIRA_TEST_BOARD_ID (enables sprint roundtrip: create_sprint -> update_sprint -> move_issues_to_sprint -> update_sprint)
|
|
17
|
-
|
|
18
|
-
const env = process.env as Record<string, string | undefined>
|
|
19
|
-
|
|
20
|
-
const suiteOrSkip = (hasEnv('JIRA_DOMAIN', 'JIRA_EMAIL', 'JIRA_API_TOKEN') && hasEnv('JIRA_TEST_PROJECT_KEY'))
|
|
21
|
-
? describe
|
|
22
|
-
: describe.skip
|
|
23
|
-
|
|
24
|
-
suiteOrSkip('jira write handlers (live)', () => {
|
|
25
|
-
describe('variant: api_token', () => {
|
|
26
|
-
const ctx: {
|
|
27
|
-
createdIssueKey?: string
|
|
28
|
-
createdSprintId?: number
|
|
29
|
-
} = {}
|
|
30
|
-
|
|
31
|
-
let jira: ReturnType<typeof createToolbox>
|
|
32
|
-
|
|
33
|
-
beforeAll(async () => {
|
|
34
|
-
const credentialStore = createCredentialStore(async () => ({
|
|
35
|
-
domain: env.JIRA_DOMAIN!,
|
|
36
|
-
email: env.JIRA_EMAIL!,
|
|
37
|
-
apiToken: env.JIRA_API_TOKEN!,
|
|
38
|
-
}))
|
|
39
|
-
const proxy = createProxy(credentialStore)
|
|
40
|
-
jira = createToolbox('jira', proxy, createIntegrationNode('jira', { label: 'Jira', credentialId: 'jira-creds', credentialVariant: 'api_token' }), 'api_token')
|
|
41
|
-
}, 60000)
|
|
42
|
-
|
|
43
|
-
afterAll(async () => {
|
|
44
|
-
await safeCleanup(async () => {
|
|
45
|
-
if (!ctx.createdSprintId)
|
|
46
|
-
return
|
|
47
|
-
const update_sprint = jira.write('update_sprint')
|
|
48
|
-
await update_sprint({ sprintId: ctx.createdSprintId, state: 'closed' })
|
|
49
|
-
})
|
|
50
|
-
await safeCleanup(async () => {
|
|
51
|
-
if (!ctx.createdIssueKey)
|
|
52
|
-
return
|
|
53
|
-
const delete_issue = jira.write('delete_issue')
|
|
54
|
-
await delete_issue({ issueIdOrKey: ctx.createdIssueKey })
|
|
55
|
-
})
|
|
56
|
-
}, 60000)
|
|
57
|
-
|
|
58
|
-
it('create_issue -> get_issue -> update_issue -> add_comment -> get_issue_comments (and optional assign/transition) roundtrip', async () => {
|
|
59
|
-
const get_myself = jira.read('get_myself')
|
|
60
|
-
const me = await get_myself({})
|
|
61
|
-
expect(me?.accountId).toBeTruthy()
|
|
62
|
-
|
|
63
|
-
const get_project = jira.read('get_project')
|
|
64
|
-
const project = await get_project({ projectIdOrKey: env.JIRA_TEST_PROJECT_KEY, expandIssueTypes: true })
|
|
65
|
-
const issueTypes = Array.isArray(project?.issueTypes) ? project.issueTypes : []
|
|
66
|
-
const picked = issueTypes.find((t: any) => t && t.subtask === false) || issueTypes[0]
|
|
67
|
-
if (!picked?.id && !picked?.name)
|
|
68
|
-
return expect(true).toBe(true)
|
|
69
|
-
|
|
70
|
-
const create_issue = jira.write('create_issue')
|
|
71
|
-
const created = await create_issue({
|
|
72
|
-
projectKey: env.JIRA_TEST_PROJECT_KEY,
|
|
73
|
-
issueTypeId: picked?.id || undefined,
|
|
74
|
-
issueTypeName: picked?.id ? undefined : (picked?.name || undefined),
|
|
75
|
-
summary: `CmdTest ${Date.now()}`,
|
|
76
|
-
descriptionText: 'Created by integration tests.',
|
|
77
|
-
assigneeAccountId: me.accountId,
|
|
78
|
-
labels: ['cmdtest'],
|
|
79
|
-
})
|
|
80
|
-
const issueKey = created?.key || created?.id
|
|
81
|
-
expect(issueKey).toBeTruthy()
|
|
82
|
-
ctx.createdIssueKey = created?.key || created?.id
|
|
83
|
-
|
|
84
|
-
const get_issue = jira.read('get_issue')
|
|
85
|
-
const got = await get_issue({ issueIdOrKey: issueKey })
|
|
86
|
-
expect(got?.key).toBeTruthy()
|
|
87
|
-
|
|
88
|
-
const update_issue = jira.write('update_issue')
|
|
89
|
-
const updated = await update_issue({
|
|
90
|
-
issueIdOrKey: issueKey,
|
|
91
|
-
summary: `CmdTest Updated ${Date.now()}`,
|
|
92
|
-
descriptionText: 'Updated by integration tests.',
|
|
93
|
-
})
|
|
94
|
-
expect(updated?.success === true || updated).toBeTruthy()
|
|
95
|
-
|
|
96
|
-
const add_comment = jira.write('add_comment')
|
|
97
|
-
const commentText = `Test comment ${Date.now()}`
|
|
98
|
-
const comment = await add_comment({ issueIdOrKey: issueKey, bodyText: commentText })
|
|
99
|
-
expect(comment?.id).toBeTruthy()
|
|
100
|
-
|
|
101
|
-
const get_issue_comments = jira.read('get_issue_comments')
|
|
102
|
-
const comments = await get_issue_comments({ issueIdOrKey: issueKey, maxResults: 20 })
|
|
103
|
-
const found = (comments?.comments || []).some((c: any) =>
|
|
104
|
-
(c?.bodyMarkdown && String(c.bodyMarkdown).includes('Test comment'))
|
|
105
|
-
|| (c?.bodyText && String(c.bodyText).includes('Test comment')),
|
|
106
|
-
)
|
|
107
|
-
expect(found).toBe(true)
|
|
108
|
-
|
|
109
|
-
const assign_issue = jira.write('assign_issue')
|
|
110
|
-
const assigned = await assign_issue({ issueIdOrKey: issueKey, accountId: me.accountId })
|
|
111
|
-
expect(assigned?.success === true || assigned).toBeTruthy()
|
|
112
|
-
const unassigned = await assign_issue({ issueIdOrKey: issueKey, accountId: null })
|
|
113
|
-
expect(unassigned?.success === true || unassigned).toBeTruthy()
|
|
114
|
-
|
|
115
|
-
if (env.JIRA_TEST_TRANSITION_NAME) {
|
|
116
|
-
const transition_issue = jira.write('transition_issue')
|
|
117
|
-
const transitioned = await transition_issue({
|
|
118
|
-
issueIdOrKey: issueKey,
|
|
119
|
-
transitionName: env.JIRA_TEST_TRANSITION_NAME,
|
|
120
|
-
commentText: 'Transitioned by integration tests.',
|
|
121
|
-
})
|
|
122
|
-
expect(transitioned?.success === true || transitioned).toBeTruthy()
|
|
123
|
-
}
|
|
124
|
-
}, 120000)
|
|
125
|
-
|
|
126
|
-
it('sprint roundtrip: create_sprint -> update_sprint (start) -> move_issues_to_sprint -> update_sprint (close) (optional)', async () => {
|
|
127
|
-
if (!env.JIRA_TEST_BOARD_ID || !ctx.createdIssueKey)
|
|
128
|
-
return expect(true).toBe(true)
|
|
129
|
-
const boardId = Number(env.JIRA_TEST_BOARD_ID)
|
|
130
|
-
if (!Number.isFinite(boardId))
|
|
131
|
-
return expect(true).toBe(true)
|
|
132
|
-
|
|
133
|
-
const create_sprint = jira.write('create_sprint')
|
|
134
|
-
const name = `CmdTest Sprint ${Date.now()}`
|
|
135
|
-
const sprint = await create_sprint({ boardId, name })
|
|
136
|
-
const sprintId = sprint?.id
|
|
137
|
-
expect(typeof sprintId).toBe('number')
|
|
138
|
-
ctx.createdSprintId = sprintId
|
|
139
|
-
|
|
140
|
-
const update_sprint = jira.write('update_sprint')
|
|
141
|
-
const today = new Date().toISOString().slice(0, 10)
|
|
142
|
-
const twoWeeks = new Date(Date.now() + 14 * 24 * 60 * 60 * 1000).toISOString().slice(0, 10)
|
|
143
|
-
const started = await update_sprint({ sprintId, state: 'active', startDate: today, endDate: twoWeeks })
|
|
144
|
-
expect(started?.state === 'active' || started?.id === sprintId || started).toBeTruthy()
|
|
145
|
-
|
|
146
|
-
const move_issues_to_sprint = jira.write('move_issues_to_sprint')
|
|
147
|
-
const moved = await move_issues_to_sprint({ sprintId, issueKeys: [ctx.createdIssueKey] })
|
|
148
|
-
expect(moved?.success === true || moved).toBeTruthy()
|
|
149
|
-
|
|
150
|
-
const closed = await update_sprint({ sprintId, state: 'closed' })
|
|
151
|
-
expect(closed?.state === 'closed' || closed?.id === sprintId || closed).toBeTruthy()
|
|
152
|
-
ctx.createdSprintId = undefined
|
|
153
|
-
}, 120000)
|
|
154
|
-
|
|
155
|
-
})
|
|
156
|
-
})
|
|
157
|
-
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"variants": {
|
|
3
|
-
"api_token": {
|
|
4
|
-
"label": "API Token (Email + Token)",
|
|
5
|
-
"schema": {
|
|
6
|
-
"type": "object",
|
|
7
|
-
"properties": {
|
|
8
|
-
"domain": {
|
|
9
|
-
"type": "string",
|
|
10
|
-
"title": "Jira site domain",
|
|
11
|
-
"description": "The subdomain of your Jira Cloud site. Example: for https://mycompany.atlassian.net, enter 'mycompany'."
|
|
12
|
-
},
|
|
13
|
-
"email": {
|
|
14
|
-
"type": "string",
|
|
15
|
-
"title": "Atlassian account email",
|
|
16
|
-
"description": "Email address of the Atlassian account that owns the API token."
|
|
17
|
-
},
|
|
18
|
-
"apiToken": {
|
|
19
|
-
"type": "string",
|
|
20
|
-
"title": "Atlassian API token",
|
|
21
|
-
"description": "Atlassian API token for Jira Cloud. Combined with your email to form the Basic auth header."
|
|
22
|
-
}
|
|
23
|
-
},
|
|
24
|
-
"required": ["domain", "email", "apiToken"],
|
|
25
|
-
"additionalProperties": false
|
|
26
|
-
},
|
|
27
|
-
"baseUrlTemplate": "https://{{domain}}.atlassian.net",
|
|
28
|
-
"injection": {
|
|
29
|
-
"headers": {
|
|
30
|
-
"Authorization": "Basic {{base64(email + \":\" + apiToken)}}",
|
|
31
|
-
"Accept": "application/json"
|
|
32
|
-
}
|
|
33
|
-
},
|
|
34
|
-
"healthCheck": { "path": "/rest/api/3/myself" }
|
|
35
|
-
}
|
|
36
|
-
},
|
|
37
|
-
"default": "api_token"
|
|
38
|
-
}
|
|
39
|
-
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
1. Open your Jira Cloud site in the browser (it looks like `https://YOUR_DOMAIN.atlassian.net`).
|
|
2
|
-
2. Copy `YOUR_DOMAIN` (the subdomain) and use it as `domain`.
|
|
3
|
-
3. Create an Atlassian API token at `https://id.atlassian.com/manage-profile/security/api-tokens`.
|
|
4
|
-
4. Use the same Atlassian account email as `email` and paste the token as `apiToken`.
|
|
5
|
-
5. Ensure the Atlassian account has access to the Jira projects you want to work with.
|
|
6
|
-
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
1. Create an OAuth 2.0 (3LO) app in the Atlassian developer console.
|
|
2
|
-
2. Add Jira scopes (typical minimum): `read:jira-work`, `write:jira-work`, `read:jira-user` (and `offline_access` if you want refresh tokens).
|
|
3
|
-
3. Complete the OAuth flow to obtain an access token.
|
|
4
|
-
4. Discover your `cloudId` by calling `GET https://api.atlassian.com/oauth/token/accessible-resources` with `Authorization: Bearer <access_token>` and using the returned `id`.
|
|
5
|
-
5. Paste `cloudId` and the current OAuth `token` here.
|
|
6
|
-
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const res = await integration.fetch(`/rest/api/3/issue/${encodeURIComponent(input.issueIdOrKey)}/assignee`, {
|
|
3
|
-
method: 'PUT',
|
|
4
|
-
body: { accountId: input.accountId },
|
|
5
|
-
})
|
|
6
|
-
|
|
7
|
-
if (res.status === 204)
|
|
8
|
-
return { success: true }
|
|
9
|
-
return await res.json()
|
|
10
|
-
}
|
|
11
|
-
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const fields = {
|
|
3
|
-
project: { key: input.projectKey },
|
|
4
|
-
summary: input.summary,
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
if (input.descriptionText)
|
|
8
|
-
fields.description = utils.adf?.fromMarkdown(input.descriptionText)
|
|
9
|
-
|
|
10
|
-
if (input.issueTypeId) {
|
|
11
|
-
fields.issuetype = { id: String(input.issueTypeId) }
|
|
12
|
-
}
|
|
13
|
-
else if (input.issueTypeName) {
|
|
14
|
-
fields.issuetype = { name: String(input.issueTypeName) }
|
|
15
|
-
}
|
|
16
|
-
else {
|
|
17
|
-
throw new Error(`Missing issue type. Provide issueTypeId or issueTypeName (call get_project to discover available issue types).`)
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
if (input.priorityId)
|
|
21
|
-
fields.priority = { id: input.priorityId }
|
|
22
|
-
else if (input.priorityName)
|
|
23
|
-
fields.priority = { name: input.priorityName }
|
|
24
|
-
|
|
25
|
-
if (Array.isArray(input.labels))
|
|
26
|
-
fields.labels = input.labels
|
|
27
|
-
|
|
28
|
-
if (input.assigneeAccountId)
|
|
29
|
-
fields.assignee = { accountId: input.assigneeAccountId }
|
|
30
|
-
|
|
31
|
-
const res = await integration.fetch('/rest/api/3/issue', {
|
|
32
|
-
method: 'POST',
|
|
33
|
-
body: { fields },
|
|
34
|
-
})
|
|
35
|
-
|
|
36
|
-
return await res.json()
|
|
37
|
-
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const body = {
|
|
3
|
-
originBoardId: input.boardId,
|
|
4
|
-
name: input.name,
|
|
5
|
-
}
|
|
6
|
-
if (input.startDate)
|
|
7
|
-
body.startDate = input.startDate
|
|
8
|
-
if (input.endDate)
|
|
9
|
-
body.endDate = input.endDate
|
|
10
|
-
if (input.goal)
|
|
11
|
-
body.goal = input.goal
|
|
12
|
-
|
|
13
|
-
const res = await integration.fetch('/rest/agile/1.0/sprint', {
|
|
14
|
-
method: 'POST',
|
|
15
|
-
body,
|
|
16
|
-
})
|
|
17
|
-
return await res.json()
|
|
18
|
-
}
|
|
19
|
-
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const params = new URLSearchParams()
|
|
3
|
-
if (input.jql)
|
|
4
|
-
params.set('jql', input.jql)
|
|
5
|
-
if (Array.isArray(input.fields) && input.fields.length)
|
|
6
|
-
params.set('fields', input.fields.join(','))
|
|
7
|
-
params.set('startAt', String(input.startAt ?? 0))
|
|
8
|
-
params.set('maxResults', String(input.maxResults ?? 50))
|
|
9
|
-
|
|
10
|
-
const res = await integration.fetch(`/rest/agile/1.0/board/${encodeURIComponent(String(input.boardId))}/backlog?${params.toString()}`)
|
|
11
|
-
return await res.json()
|
|
12
|
-
}
|
|
13
|
-
|
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const defaultFields = [
|
|
3
|
-
'summary',
|
|
4
|
-
'status',
|
|
5
|
-
'assignee',
|
|
6
|
-
'priority',
|
|
7
|
-
'issuetype',
|
|
8
|
-
'project',
|
|
9
|
-
'description',
|
|
10
|
-
'created',
|
|
11
|
-
'updated',
|
|
12
|
-
'labels',
|
|
13
|
-
]
|
|
14
|
-
|
|
15
|
-
const fields = Array.isArray(input.fields) && input.fields.length ? input.fields : defaultFields
|
|
16
|
-
const params = new URLSearchParams()
|
|
17
|
-
if (fields?.length)
|
|
18
|
-
params.set('fields', fields.join(','))
|
|
19
|
-
if (Array.isArray(input.expand) && input.expand.length)
|
|
20
|
-
params.set('expand', input.expand.join(','))
|
|
21
|
-
|
|
22
|
-
const path = `/rest/api/3/issue/${encodeURIComponent(input.issueIdOrKey)}${params.toString() ? `?${params.toString()}` : ''}`
|
|
23
|
-
const res = await integration.fetch(path)
|
|
24
|
-
const data = await res.json()
|
|
25
|
-
|
|
26
|
-
const descAdf = data?.fields?.description
|
|
27
|
-
const descMarkdown = utils.adf?.toMarkdown(descAdf) || ''
|
|
28
|
-
const descText = descMarkdown ? '' : (utils.adf?.toPlainText(descAdf) || '')
|
|
29
|
-
|
|
30
|
-
return {
|
|
31
|
-
id: data.id ?? null,
|
|
32
|
-
key: data.key ?? null,
|
|
33
|
-
self: data.self ?? null,
|
|
34
|
-
summary: data.fields?.summary ?? null,
|
|
35
|
-
status: data.fields?.status
|
|
36
|
-
? {
|
|
37
|
-
id: data.fields.status.id ?? null,
|
|
38
|
-
name: data.fields.status.name ?? null,
|
|
39
|
-
category: data.fields.status.statusCategory
|
|
40
|
-
? {
|
|
41
|
-
key: data.fields.status.statusCategory.key ?? null,
|
|
42
|
-
name: data.fields.status.statusCategory.name ?? null,
|
|
43
|
-
}
|
|
44
|
-
: null,
|
|
45
|
-
}
|
|
46
|
-
: null,
|
|
47
|
-
assignee: data.fields?.assignee
|
|
48
|
-
? {
|
|
49
|
-
accountId: data.fields.assignee.accountId ?? null,
|
|
50
|
-
displayName: data.fields.assignee.displayName ?? null,
|
|
51
|
-
}
|
|
52
|
-
: null,
|
|
53
|
-
priority: data.fields?.priority ? { id: data.fields.priority.id ?? null, name: data.fields.priority.name ?? null } : null,
|
|
54
|
-
issueType: data.fields?.issuetype ? { id: data.fields.issuetype.id ?? null, name: data.fields.issuetype.name ?? null } : null,
|
|
55
|
-
project: data.fields?.project ? { id: data.fields.project.id ?? null, key: data.fields.project.key ?? null, name: data.fields.project.name ?? null } : null,
|
|
56
|
-
labels: Array.isArray(data.fields?.labels) ? data.fields.labels : [],
|
|
57
|
-
descriptionMarkdown: descMarkdown || null,
|
|
58
|
-
descriptionText: descMarkdown ? null : (descText || null),
|
|
59
|
-
created: data.fields?.created ?? null,
|
|
60
|
-
updated: data.fields?.updated ?? null,
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const params = new URLSearchParams()
|
|
3
|
-
params.set('startAt', String(input.startAt ?? 0))
|
|
4
|
-
params.set('maxResults', String(input.maxResults ?? 50))
|
|
5
|
-
|
|
6
|
-
const path = `/rest/api/3/issue/${encodeURIComponent(input.issueIdOrKey)}/comment?${params.toString()}`
|
|
7
|
-
const res = await integration.fetch(path)
|
|
8
|
-
const data = await res.json()
|
|
9
|
-
const comments = Array.isArray(data.comments) ? data.comments : []
|
|
10
|
-
|
|
11
|
-
return {
|
|
12
|
-
startAt: data.startAt ?? (input.startAt ?? 0),
|
|
13
|
-
maxResults: data.maxResults ?? (input.maxResults ?? 50),
|
|
14
|
-
total: data.total ?? comments.length,
|
|
15
|
-
comments: comments.map((c) => {
|
|
16
|
-
const md = utils.adf?.toMarkdown(c.body) || ''
|
|
17
|
-
const text = md ? '' : (utils.adf?.toPlainText(c.body) || '')
|
|
18
|
-
return {
|
|
19
|
-
id: c.id ?? null,
|
|
20
|
-
created: c.created ?? null,
|
|
21
|
-
updated: c.updated ?? null,
|
|
22
|
-
author: c.author
|
|
23
|
-
? { accountId: c.author.accountId ?? null, displayName: c.author.displayName ?? null }
|
|
24
|
-
: null,
|
|
25
|
-
bodyMarkdown: md || null,
|
|
26
|
-
bodyText: md ? null : (text || null),
|
|
27
|
-
}
|
|
28
|
-
}),
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
async (_input) => {
|
|
2
|
-
const res = await integration.fetch('/rest/api/3/myself')
|
|
3
|
-
const data = await res.json()
|
|
4
|
-
|
|
5
|
-
return {
|
|
6
|
-
accountId: data.accountId ?? null,
|
|
7
|
-
displayName: data.displayName ?? null,
|
|
8
|
-
active: data.active ?? null,
|
|
9
|
-
timeZone: data.timeZone ?? null,
|
|
10
|
-
locale: data.locale ?? null,
|
|
11
|
-
emailAddress: data.emailAddress ?? null,
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const params = new URLSearchParams()
|
|
3
|
-
if (input.expandIssueTypes !== false)
|
|
4
|
-
params.set('expand', 'issueTypes')
|
|
5
|
-
|
|
6
|
-
const path = `/rest/api/3/project/${encodeURIComponent(input.projectIdOrKey)}${params.toString() ? `?${params.toString()}` : ''}`
|
|
7
|
-
const res = await integration.fetch(path)
|
|
8
|
-
const data = await res.json()
|
|
9
|
-
|
|
10
|
-
const issueTypes = Array.isArray(data.issueTypes) ? data.issueTypes : []
|
|
11
|
-
|
|
12
|
-
return {
|
|
13
|
-
id: data.id ?? null,
|
|
14
|
-
key: data.key ?? null,
|
|
15
|
-
name: data.name ?? null,
|
|
16
|
-
projectTypeKey: data.projectTypeKey ?? null,
|
|
17
|
-
simplified: data.simplified ?? null,
|
|
18
|
-
style: data.style ?? null,
|
|
19
|
-
isPrivate: data.isPrivate ?? null,
|
|
20
|
-
issueTypes: issueTypes.map(t => ({
|
|
21
|
-
id: t.id ?? null,
|
|
22
|
-
name: t.name ?? null,
|
|
23
|
-
description: t.description ?? null,
|
|
24
|
-
subtask: t.subtask ?? null,
|
|
25
|
-
})),
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const params = new URLSearchParams()
|
|
3
|
-
if (input.jql)
|
|
4
|
-
params.set('jql', input.jql)
|
|
5
|
-
if (Array.isArray(input.fields) && input.fields.length)
|
|
6
|
-
params.set('fields', input.fields.join(','))
|
|
7
|
-
params.set('startAt', String(input.startAt ?? 0))
|
|
8
|
-
params.set('maxResults', String(input.maxResults ?? 50))
|
|
9
|
-
|
|
10
|
-
const res = await integration.fetch(`/rest/agile/1.0/sprint/${encodeURIComponent(String(input.sprintId))}/issue?${params.toString()}`)
|
|
11
|
-
return await res.json()
|
|
12
|
-
}
|
|
13
|
-
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const path = `/rest/api/3/issue/${encodeURIComponent(input.issueIdOrKey)}/transitions`
|
|
3
|
-
const res = await integration.fetch(path)
|
|
4
|
-
const data = await res.json()
|
|
5
|
-
const transitions = Array.isArray(data.transitions) ? data.transitions : []
|
|
6
|
-
|
|
7
|
-
return {
|
|
8
|
-
transitions: transitions.map(t => ({
|
|
9
|
-
id: t.id ?? null,
|
|
10
|
-
name: t.name ?? null,
|
|
11
|
-
to: t.to
|
|
12
|
-
? {
|
|
13
|
-
id: t.to.id ?? null,
|
|
14
|
-
name: t.to.name ?? null,
|
|
15
|
-
statusCategory: t.to.statusCategory
|
|
16
|
-
? { key: t.to.statusCategory.key ?? null, name: t.to.statusCategory.name ?? null }
|
|
17
|
-
: null,
|
|
18
|
-
}
|
|
19
|
-
: null,
|
|
20
|
-
})),
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const params = new URLSearchParams()
|
|
3
|
-
if (input?.projectKeyOrId)
|
|
4
|
-
params.set('projectKeyOrId', input.projectKeyOrId)
|
|
5
|
-
if (input?.type)
|
|
6
|
-
params.set('type', input.type)
|
|
7
|
-
params.set('startAt', String(input?.startAt ?? 0))
|
|
8
|
-
params.set('maxResults', String(input?.maxResults ?? 50))
|
|
9
|
-
|
|
10
|
-
const res = await integration.fetch(`/rest/agile/1.0/board?${params.toString()}`)
|
|
11
|
-
const data = await res.json()
|
|
12
|
-
const values = Array.isArray(data.values) ? data.values : []
|
|
13
|
-
|
|
14
|
-
return {
|
|
15
|
-
startAt: data.startAt ?? (input?.startAt ?? 0),
|
|
16
|
-
maxResults: data.maxResults ?? (input?.maxResults ?? 50),
|
|
17
|
-
total: data.total ?? values.length,
|
|
18
|
-
isLast: Boolean(data.isLast),
|
|
19
|
-
boards: values.map(b => ({
|
|
20
|
-
id: b.id ?? null,
|
|
21
|
-
name: b.name ?? null,
|
|
22
|
-
type: b.type ?? null,
|
|
23
|
-
location: b.location
|
|
24
|
-
? {
|
|
25
|
-
projectId: b.location.projectId ?? null,
|
|
26
|
-
projectKey: b.location.projectKey ?? null,
|
|
27
|
-
projectName: b.location.projectName ?? null,
|
|
28
|
-
}
|
|
29
|
-
: null,
|
|
30
|
-
self: b.self ?? null,
|
|
31
|
-
})),
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const params = new URLSearchParams()
|
|
3
|
-
if (input?.query)
|
|
4
|
-
params.set('query', input.query)
|
|
5
|
-
params.set('startAt', String(input?.startAt ?? 0))
|
|
6
|
-
params.set('maxResults', String(input?.maxResults ?? 50))
|
|
7
|
-
|
|
8
|
-
const path = `/rest/api/3/project/search?${params.toString()}`
|
|
9
|
-
const res = await integration.fetch(path)
|
|
10
|
-
const data = await res.json()
|
|
11
|
-
const values = Array.isArray(data.values) ? data.values : []
|
|
12
|
-
|
|
13
|
-
return {
|
|
14
|
-
startAt: data.startAt ?? (input?.startAt ?? 0),
|
|
15
|
-
maxResults: data.maxResults ?? (input?.maxResults ?? 50),
|
|
16
|
-
total: data.total ?? values.length,
|
|
17
|
-
isLast: Boolean(data.isLast),
|
|
18
|
-
projects: values.map(p => ({
|
|
19
|
-
id: p.id ?? null,
|
|
20
|
-
key: p.key ?? null,
|
|
21
|
-
name: p.name ?? null,
|
|
22
|
-
projectTypeKey: p.projectTypeKey ?? null,
|
|
23
|
-
simplified: p.simplified ?? null,
|
|
24
|
-
style: p.style ?? null,
|
|
25
|
-
isPrivate: p.isPrivate ?? null,
|
|
26
|
-
})),
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const params = new URLSearchParams()
|
|
3
|
-
if (Array.isArray(input.state) && input.state.length)
|
|
4
|
-
params.set('state', input.state.join(','))
|
|
5
|
-
params.set('startAt', String(input.startAt ?? 0))
|
|
6
|
-
params.set('maxResults', String(input.maxResults ?? 50))
|
|
7
|
-
|
|
8
|
-
const res = await integration.fetch(`/rest/agile/1.0/board/${encodeURIComponent(String(input.boardId))}/sprint?${params.toString()}`)
|
|
9
|
-
const data = await res.json()
|
|
10
|
-
const values = Array.isArray(data.values) ? data.values : []
|
|
11
|
-
|
|
12
|
-
return {
|
|
13
|
-
startAt: data.startAt ?? (input.startAt ?? 0),
|
|
14
|
-
maxResults: data.maxResults ?? (input.maxResults ?? 50),
|
|
15
|
-
total: data.total ?? values.length,
|
|
16
|
-
isLast: Boolean(data.isLast),
|
|
17
|
-
sprints: values.map(s => ({
|
|
18
|
-
id: s.id ?? null,
|
|
19
|
-
name: s.name ?? null,
|
|
20
|
-
state: s.state ?? null,
|
|
21
|
-
goal: s.goal ?? null,
|
|
22
|
-
startDate: s.startDate ?? null,
|
|
23
|
-
endDate: s.endDate ?? null,
|
|
24
|
-
completeDate: s.completeDate ?? null,
|
|
25
|
-
self: s.self ?? null,
|
|
26
|
-
})),
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const res = await integration.fetch(`/rest/agile/1.0/sprint/${encodeURIComponent(String(input.sprintId))}/issue`, {
|
|
3
|
-
method: 'POST',
|
|
4
|
-
body: { issues: input.issueKeys },
|
|
5
|
-
})
|
|
6
|
-
|
|
7
|
-
if (res.status === 204)
|
|
8
|
-
return { success: true }
|
|
9
|
-
return await res.json()
|
|
10
|
-
}
|
|
11
|
-
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
async (input) => {
|
|
2
|
-
const body = {
|
|
3
|
-
jql: input.jql,
|
|
4
|
-
maxResults: input.maxResults ?? 50,
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
if (Array.isArray(input.fields) && input.fields.length)
|
|
8
|
-
body.fields = input.fields
|
|
9
|
-
if (input.nextPageToken)
|
|
10
|
-
body.nextPageToken = input.nextPageToken
|
|
11
|
-
|
|
12
|
-
const res = await integration.fetch('/rest/api/3/search/jql', {
|
|
13
|
-
method: 'POST',
|
|
14
|
-
body,
|
|
15
|
-
})
|
|
16
|
-
|
|
17
|
-
const data = await res.json()
|
|
18
|
-
const issues = Array.isArray(data.issues) ? data.issues : []
|
|
19
|
-
|
|
20
|
-
return {
|
|
21
|
-
isLast: Boolean(data.isLast),
|
|
22
|
-
nextPageToken: data.nextPageToken ?? null,
|
|
23
|
-
issues: issues.map((i) => ({
|
|
24
|
-
id: i.id,
|
|
25
|
-
key: i.key,
|
|
26
|
-
summary: i.fields?.summary ?? null,
|
|
27
|
-
status: i.fields?.status?.name ?? null,
|
|
28
|
-
assignee: i.fields?.assignee
|
|
29
|
-
? {
|
|
30
|
-
accountId: i.fields.assignee.accountId ?? null,
|
|
31
|
-
displayName: i.fields.assignee.displayName ?? null,
|
|
32
|
-
}
|
|
33
|
-
: null,
|
|
34
|
-
priority: i.fields?.priority?.name ?? null,
|
|
35
|
-
issueType: i.fields?.issuetype?.name ?? null,
|
|
36
|
-
project: i.fields?.project
|
|
37
|
-
? { key: i.fields.project.key ?? null, name: i.fields.project.name ?? null }
|
|
38
|
-
: null,
|
|
39
|
-
updated: i.fields?.updated ?? null,
|
|
40
|
-
})),
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
|