@chief-clancy/core 0.1.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/LICENSE +21 -0
- package/README.md +50 -0
- package/dist/board/azdo/api/api.d.ts +95 -0
- package/dist/board/azdo/api/api.d.ts.map +1 -0
- package/dist/board/azdo/api/api.js +173 -0
- package/dist/board/azdo/api/api.js.map +1 -0
- package/dist/board/azdo/api/helpers.d.ts +89 -0
- package/dist/board/azdo/api/helpers.d.ts.map +1 -0
- package/dist/board/azdo/api/helpers.js +133 -0
- package/dist/board/azdo/api/helpers.js.map +1 -0
- package/dist/board/azdo/api/index.d.ts +5 -0
- package/dist/board/azdo/api/index.d.ts.map +1 -0
- package/dist/board/azdo/api/index.js +3 -0
- package/dist/board/azdo/api/index.js.map +1 -0
- package/dist/board/azdo/azdo-board.d.ts +12 -0
- package/dist/board/azdo/azdo-board.d.ts.map +1 -0
- package/dist/board/azdo/azdo-board.js +104 -0
- package/dist/board/azdo/azdo-board.js.map +1 -0
- package/dist/board/azdo/index.d.ts +3 -0
- package/dist/board/azdo/index.d.ts.map +1 -0
- package/dist/board/azdo/index.js +3 -0
- package/dist/board/azdo/index.js.map +1 -0
- package/dist/board/azdo/labels/index.d.ts +2 -0
- package/dist/board/azdo/labels/index.d.ts.map +1 -0
- package/dist/board/azdo/labels/index.js +2 -0
- package/dist/board/azdo/labels/index.js.map +1 -0
- package/dist/board/azdo/labels/labels.d.ts +27 -0
- package/dist/board/azdo/labels/labels.d.ts.map +1 -0
- package/dist/board/azdo/labels/labels.js +64 -0
- package/dist/board/azdo/labels/labels.js.map +1 -0
- package/dist/board/azdo/relations/index.d.ts +2 -0
- package/dist/board/azdo/relations/index.d.ts.map +1 -0
- package/dist/board/azdo/relations/index.js +2 -0
- package/dist/board/azdo/relations/index.js.map +1 -0
- package/dist/board/azdo/relations/relations.d.ts +37 -0
- package/dist/board/azdo/relations/relations.d.ts.map +1 -0
- package/dist/board/azdo/relations/relations.js +109 -0
- package/dist/board/azdo/relations/relations.js.map +1 -0
- package/dist/board/detect-board.d.ts +28 -0
- package/dist/board/detect-board.d.ts.map +1 -0
- package/dist/board/detect-board.js +80 -0
- package/dist/board/detect-board.js.map +1 -0
- package/dist/board/factory/factory.d.ts +18 -0
- package/dist/board/factory/factory.d.ts.map +1 -0
- package/dist/board/factory/factory.js +34 -0
- package/dist/board/factory/factory.js.map +1 -0
- package/dist/board/factory/index.d.ts +2 -0
- package/dist/board/factory/index.d.ts.map +1 -0
- package/dist/board/factory/index.js +2 -0
- package/dist/board/factory/index.js.map +1 -0
- package/dist/board/github/api/api.d.ts +86 -0
- package/dist/board/github/api/api.d.ts.map +1 -0
- package/dist/board/github/api/api.js +161 -0
- package/dist/board/github/api/api.js.map +1 -0
- package/dist/board/github/api/index.d.ts +3 -0
- package/dist/board/github/api/index.d.ts.map +1 -0
- package/dist/board/github/api/index.js +2 -0
- package/dist/board/github/api/index.js.map +1 -0
- package/dist/board/github/github-board.d.ts +19 -0
- package/dist/board/github/github-board.d.ts.map +1 -0
- package/dist/board/github/github-board.js +104 -0
- package/dist/board/github/github-board.js.map +1 -0
- package/dist/board/github/index.d.ts +3 -0
- package/dist/board/github/index.d.ts.map +1 -0
- package/dist/board/github/index.js +3 -0
- package/dist/board/github/index.js.map +1 -0
- package/dist/board/github/labels/index.d.ts +2 -0
- package/dist/board/github/labels/index.d.ts.map +1 -0
- package/dist/board/github/labels/index.js +2 -0
- package/dist/board/github/labels/index.js.map +1 -0
- package/dist/board/github/labels/labels.d.ts +42 -0
- package/dist/board/github/labels/labels.d.ts.map +1 -0
- package/dist/board/github/labels/labels.js +93 -0
- package/dist/board/github/labels/labels.js.map +1 -0
- package/dist/board/github/relations/index.d.ts +2 -0
- package/dist/board/github/relations/index.d.ts.map +1 -0
- package/dist/board/github/relations/index.js +2 -0
- package/dist/board/github/relations/index.js.map +1 -0
- package/dist/board/github/relations/relations.d.ts +54 -0
- package/dist/board/github/relations/relations.d.ts.map +1 -0
- package/dist/board/github/relations/relations.js +152 -0
- package/dist/board/github/relations/relations.js.map +1 -0
- package/dist/board/index.d.ts +2 -0
- package/dist/board/index.d.ts.map +1 -0
- package/dist/board/index.js +2 -0
- package/dist/board/index.js.map +1 -0
- package/dist/board/jira/api/api.d.ts +129 -0
- package/dist/board/jira/api/api.d.ts.map +1 -0
- package/dist/board/jira/api/api.js +207 -0
- package/dist/board/jira/api/api.js.map +1 -0
- package/dist/board/jira/api/index.d.ts +3 -0
- package/dist/board/jira/api/index.d.ts.map +1 -0
- package/dist/board/jira/api/index.js +2 -0
- package/dist/board/jira/api/index.js.map +1 -0
- package/dist/board/jira/index.d.ts +3 -0
- package/dist/board/jira/index.d.ts.map +1 -0
- package/dist/board/jira/index.js +3 -0
- package/dist/board/jira/index.js.map +1 -0
- package/dist/board/jira/jira-board.d.ts +12 -0
- package/dist/board/jira/jira-board.d.ts.map +1 -0
- package/dist/board/jira/jira-board.js +112 -0
- package/dist/board/jira/jira-board.js.map +1 -0
- package/dist/board/jira/labels/index.d.ts +2 -0
- package/dist/board/jira/labels/index.d.ts.map +1 -0
- package/dist/board/jira/labels/index.js +2 -0
- package/dist/board/jira/labels/index.js.map +1 -0
- package/dist/board/jira/labels/labels.d.ts +34 -0
- package/dist/board/jira/labels/labels.d.ts.map +1 -0
- package/dist/board/jira/labels/labels.js +69 -0
- package/dist/board/jira/labels/labels.js.map +1 -0
- package/dist/board/jira/relations/index.d.ts +2 -0
- package/dist/board/jira/relations/index.d.ts.map +1 -0
- package/dist/board/jira/relations/index.js +2 -0
- package/dist/board/jira/relations/index.js.map +1 -0
- package/dist/board/jira/relations/relations.d.ts +44 -0
- package/dist/board/jira/relations/relations.d.ts.map +1 -0
- package/dist/board/jira/relations/relations.js +111 -0
- package/dist/board/jira/relations/relations.js.map +1 -0
- package/dist/board/linear/api/api.d.ts +68 -0
- package/dist/board/linear/api/api.d.ts.map +1 -0
- package/dist/board/linear/api/api.js +179 -0
- package/dist/board/linear/api/api.js.map +1 -0
- package/dist/board/linear/api/index.d.ts +2 -0
- package/dist/board/linear/api/index.d.ts.map +1 -0
- package/dist/board/linear/api/index.js +2 -0
- package/dist/board/linear/api/index.js.map +1 -0
- package/dist/board/linear/index.d.ts +3 -0
- package/dist/board/linear/index.d.ts.map +1 -0
- package/dist/board/linear/index.js +3 -0
- package/dist/board/linear/index.js.map +1 -0
- package/dist/board/linear/labels/index.d.ts +2 -0
- package/dist/board/linear/labels/index.d.ts.map +1 -0
- package/dist/board/linear/labels/index.js +2 -0
- package/dist/board/linear/labels/index.js.map +1 -0
- package/dist/board/linear/labels/labels.d.ts +63 -0
- package/dist/board/linear/labels/labels.d.ts.map +1 -0
- package/dist/board/linear/labels/labels.js +204 -0
- package/dist/board/linear/labels/labels.js.map +1 -0
- package/dist/board/linear/linear-board.d.ts +18 -0
- package/dist/board/linear/linear-board.d.ts.map +1 -0
- package/dist/board/linear/linear-board.js +115 -0
- package/dist/board/linear/linear-board.js.map +1 -0
- package/dist/board/linear/relations/index.d.ts +2 -0
- package/dist/board/linear/relations/index.d.ts.map +1 -0
- package/dist/board/linear/relations/index.js +2 -0
- package/dist/board/linear/relations/index.js.map +1 -0
- package/dist/board/linear/relations/relations.d.ts +67 -0
- package/dist/board/linear/relations/relations.d.ts.map +1 -0
- package/dist/board/linear/relations/relations.js +195 -0
- package/dist/board/linear/relations/relations.js.map +1 -0
- package/dist/board/notion/api/api.d.ts +83 -0
- package/dist/board/notion/api/api.d.ts.map +1 -0
- package/dist/board/notion/api/api.js +124 -0
- package/dist/board/notion/api/api.js.map +1 -0
- package/dist/board/notion/api/helpers.d.ts +105 -0
- package/dist/board/notion/api/helpers.d.ts.map +1 -0
- package/dist/board/notion/api/helpers.js +175 -0
- package/dist/board/notion/api/helpers.js.map +1 -0
- package/dist/board/notion/api/index.d.ts +4 -0
- package/dist/board/notion/api/index.d.ts.map +1 -0
- package/dist/board/notion/api/index.js +3 -0
- package/dist/board/notion/api/index.js.map +1 -0
- package/dist/board/notion/index.d.ts +3 -0
- package/dist/board/notion/index.d.ts.map +1 -0
- package/dist/board/notion/index.js +3 -0
- package/dist/board/notion/index.js.map +1 -0
- package/dist/board/notion/labels/index.d.ts +2 -0
- package/dist/board/notion/labels/index.d.ts.map +1 -0
- package/dist/board/notion/labels/index.js +2 -0
- package/dist/board/notion/labels/index.js.map +1 -0
- package/dist/board/notion/labels/labels.d.ts +30 -0
- package/dist/board/notion/labels/labels.d.ts.map +1 -0
- package/dist/board/notion/labels/labels.js +56 -0
- package/dist/board/notion/labels/labels.js.map +1 -0
- package/dist/board/notion/notion-board.d.ts +12 -0
- package/dist/board/notion/notion-board.d.ts.map +1 -0
- package/dist/board/notion/notion-board.js +156 -0
- package/dist/board/notion/notion-board.js.map +1 -0
- package/dist/board/notion/relations/index.d.ts +2 -0
- package/dist/board/notion/relations/index.d.ts.map +1 -0
- package/dist/board/notion/relations/index.js +2 -0
- package/dist/board/notion/relations/index.js.map +1 -0
- package/dist/board/notion/relations/relations.d.ts +43 -0
- package/dist/board/notion/relations/relations.d.ts.map +1 -0
- package/dist/board/notion/relations/relations.js +127 -0
- package/dist/board/notion/relations/relations.js.map +1 -0
- package/dist/board/shortcut/api/api.d.ts +110 -0
- package/dist/board/shortcut/api/api.d.ts.map +1 -0
- package/dist/board/shortcut/api/api.js +227 -0
- package/dist/board/shortcut/api/api.js.map +1 -0
- package/dist/board/shortcut/api/index.d.ts +2 -0
- package/dist/board/shortcut/api/index.d.ts.map +1 -0
- package/dist/board/shortcut/api/index.js +2 -0
- package/dist/board/shortcut/api/index.js.map +1 -0
- package/dist/board/shortcut/index.d.ts +3 -0
- package/dist/board/shortcut/index.d.ts.map +1 -0
- package/dist/board/shortcut/index.js +3 -0
- package/dist/board/shortcut/index.js.map +1 -0
- package/dist/board/shortcut/labels/index.d.ts +2 -0
- package/dist/board/shortcut/labels/index.d.ts.map +1 -0
- package/dist/board/shortcut/labels/index.js +2 -0
- package/dist/board/shortcut/labels/index.js.map +1 -0
- package/dist/board/shortcut/labels/labels.d.ts +95 -0
- package/dist/board/shortcut/labels/labels.d.ts.map +1 -0
- package/dist/board/shortcut/labels/labels.js +154 -0
- package/dist/board/shortcut/labels/labels.js.map +1 -0
- package/dist/board/shortcut/relations/index.d.ts +2 -0
- package/dist/board/shortcut/relations/index.d.ts.map +1 -0
- package/dist/board/shortcut/relations/index.js +2 -0
- package/dist/board/shortcut/relations/index.js.map +1 -0
- package/dist/board/shortcut/relations/relations.d.ts +44 -0
- package/dist/board/shortcut/relations/relations.d.ts.map +1 -0
- package/dist/board/shortcut/relations/relations.js +118 -0
- package/dist/board/shortcut/relations/relations.js.map +1 -0
- package/dist/board/shortcut/shortcut-board.d.ts +18 -0
- package/dist/board/shortcut/shortcut-board.d.ts.map +1 -0
- package/dist/board/shortcut/shortcut-board.js +143 -0
- package/dist/board/shortcut/shortcut-board.js.map +1 -0
- package/dist/dev/lifecycle/branch/branch.d.ts +35 -0
- package/dist/dev/lifecycle/branch/branch.d.ts.map +1 -0
- package/dist/dev/lifecycle/branch/branch.js +48 -0
- package/dist/dev/lifecycle/branch/branch.js.map +1 -0
- package/dist/dev/lifecycle/branch/index.d.ts +2 -0
- package/dist/dev/lifecycle/branch/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/branch/index.js +2 -0
- package/dist/dev/lifecycle/branch/index.js.map +1 -0
- package/dist/dev/lifecycle/commit-type/commit-type.d.ts +22 -0
- package/dist/dev/lifecycle/commit-type/commit-type.d.ts.map +1 -0
- package/dist/dev/lifecycle/commit-type/commit-type.js +50 -0
- package/dist/dev/lifecycle/commit-type/commit-type.js.map +1 -0
- package/dist/dev/lifecycle/commit-type/index.d.ts +2 -0
- package/dist/dev/lifecycle/commit-type/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/commit-type/index.js +2 -0
- package/dist/dev/lifecycle/commit-type/index.js.map +1 -0
- package/dist/dev/lifecycle/cost/cost.d.ts +28 -0
- package/dist/dev/lifecycle/cost/cost.d.ts.map +1 -0
- package/dist/dev/lifecycle/cost/cost.js +36 -0
- package/dist/dev/lifecycle/cost/cost.js.map +1 -0
- package/dist/dev/lifecycle/deliver-epic/deliver-epic.d.ts +44 -0
- package/dist/dev/lifecycle/deliver-epic/deliver-epic.d.ts.map +1 -0
- package/dist/dev/lifecycle/deliver-epic/deliver-epic.js +75 -0
- package/dist/dev/lifecycle/deliver-epic/deliver-epic.js.map +1 -0
- package/dist/dev/lifecycle/deliver-ticket/deliver-ticket.d.ts +51 -0
- package/dist/dev/lifecycle/deliver-ticket/deliver-ticket.d.ts.map +1 -0
- package/dist/dev/lifecycle/deliver-ticket/deliver-ticket.js +132 -0
- package/dist/dev/lifecycle/deliver-ticket/deliver-ticket.js.map +1 -0
- package/dist/dev/lifecycle/epic/epic.d.ts +66 -0
- package/dist/dev/lifecycle/epic/epic.d.ts.map +1 -0
- package/dist/dev/lifecycle/epic/epic.js +91 -0
- package/dist/dev/lifecycle/epic/epic.js.map +1 -0
- package/dist/dev/lifecycle/epic/index.d.ts +2 -0
- package/dist/dev/lifecycle/epic/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/epic/index.js +2 -0
- package/dist/dev/lifecycle/epic/index.js.map +1 -0
- package/dist/dev/lifecycle/feasibility/feasibility.d.ts +55 -0
- package/dist/dev/lifecycle/feasibility/feasibility.d.ts.map +1 -0
- package/dist/dev/lifecycle/feasibility/feasibility.js +75 -0
- package/dist/dev/lifecycle/feasibility/feasibility.js.map +1 -0
- package/dist/dev/lifecycle/fetch-ticket/fetch-ticket.d.ts +49 -0
- package/dist/dev/lifecycle/fetch-ticket/fetch-ticket.d.ts.map +1 -0
- package/dist/dev/lifecycle/fetch-ticket/fetch-ticket.js +81 -0
- package/dist/dev/lifecycle/fetch-ticket/fetch-ticket.js.map +1 -0
- package/dist/dev/lifecycle/format/format.d.ts +11 -0
- package/dist/dev/lifecycle/format/format.d.ts.map +1 -0
- package/dist/dev/lifecycle/format/format.js +23 -0
- package/dist/dev/lifecycle/format/format.js.map +1 -0
- package/dist/dev/lifecycle/lock/index.d.ts +3 -0
- package/dist/dev/lifecycle/lock/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/lock/index.js +2 -0
- package/dist/dev/lifecycle/lock/index.js.map +1 -0
- package/dist/dev/lifecycle/lock/lock.d.ts +68 -0
- package/dist/dev/lifecycle/lock/lock.d.ts.map +1 -0
- package/dist/dev/lifecycle/lock/lock.js +125 -0
- package/dist/dev/lifecycle/lock/lock.js.map +1 -0
- package/dist/dev/lifecycle/outcome/index.d.ts +2 -0
- package/dist/dev/lifecycle/outcome/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/outcome/index.js +2 -0
- package/dist/dev/lifecycle/outcome/index.js.map +1 -0
- package/dist/dev/lifecycle/outcome/outcome.d.ts +65 -0
- package/dist/dev/lifecycle/outcome/outcome.d.ts.map +1 -0
- package/dist/dev/lifecycle/outcome/outcome.js +61 -0
- package/dist/dev/lifecycle/outcome/outcome.js.map +1 -0
- package/dist/dev/lifecycle/pr-creation/index.d.ts +3 -0
- package/dist/dev/lifecycle/pr-creation/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/pr-creation/index.js +2 -0
- package/dist/dev/lifecycle/pr-creation/index.js.map +1 -0
- package/dist/dev/lifecycle/pr-creation/pr-creation.d.ts +47 -0
- package/dist/dev/lifecycle/pr-creation/pr-creation.d.ts.map +1 -0
- package/dist/dev/lifecycle/pr-creation/pr-creation.js +143 -0
- package/dist/dev/lifecycle/pr-creation/pr-creation.js.map +1 -0
- package/dist/dev/lifecycle/preflight/preflight.d.ts +42 -0
- package/dist/dev/lifecycle/preflight/preflight.d.ts.map +1 -0
- package/dist/dev/lifecycle/preflight/preflight.js +101 -0
- package/dist/dev/lifecycle/preflight/preflight.js.map +1 -0
- package/dist/dev/lifecycle/progress/index.d.ts +3 -0
- package/dist/dev/lifecycle/progress/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/progress/index.js +2 -0
- package/dist/dev/lifecycle/progress/index.js.map +1 -0
- package/dist/dev/lifecycle/progress/progress.d.ts +98 -0
- package/dist/dev/lifecycle/progress/progress.d.ts.map +1 -0
- package/dist/dev/lifecycle/progress/progress.js +212 -0
- package/dist/dev/lifecycle/progress/progress.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/azdo/azdo.d.ts +86 -0
- package/dist/dev/lifecycle/pull-request/azdo/azdo.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/azdo/azdo.js +198 -0
- package/dist/dev/lifecycle/pull-request/azdo/azdo.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/azdo/index.d.ts +2 -0
- package/dist/dev/lifecycle/pull-request/azdo/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/azdo/index.js +2 -0
- package/dist/dev/lifecycle/pull-request/azdo/index.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/cloud.d.ts +85 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/cloud.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/cloud.js +158 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/cloud.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/index.d.ts +3 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/index.js +3 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/index.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/server.d.ts +85 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/server.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/server.js +168 -0
- package/dist/dev/lifecycle/pull-request/bitbucket/server.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/github/github.d.ts +107 -0
- package/dist/dev/lifecycle/pull-request/github/github.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/github/github.js +225 -0
- package/dist/dev/lifecycle/pull-request/github/github.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/github/index.d.ts +2 -0
- package/dist/dev/lifecycle/pull-request/github/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/github/index.js +2 -0
- package/dist/dev/lifecycle/pull-request/github/index.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/gitlab/gitlab.d.ts +103 -0
- package/dist/dev/lifecycle/pull-request/gitlab/gitlab.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/gitlab/gitlab.js +215 -0
- package/dist/dev/lifecycle/pull-request/gitlab/gitlab.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/gitlab/index.d.ts +2 -0
- package/dist/dev/lifecycle/pull-request/gitlab/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/gitlab/index.js +2 -0
- package/dist/dev/lifecycle/pull-request/gitlab/index.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/post-pr/post-pr.d.ts +44 -0
- package/dist/dev/lifecycle/pull-request/post-pr/post-pr.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/post-pr/post-pr.js +64 -0
- package/dist/dev/lifecycle/pull-request/post-pr/post-pr.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/pr-body/index.d.ts +3 -0
- package/dist/dev/lifecycle/pull-request/pr-body/index.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/pr-body/index.js +2 -0
- package/dist/dev/lifecycle/pull-request/pr-body/index.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/pr-body/pr-body.d.ts +65 -0
- package/dist/dev/lifecycle/pull-request/pr-body/pr-body.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/pr-body/pr-body.js +144 -0
- package/dist/dev/lifecycle/pull-request/pr-body/pr-body.js.map +1 -0
- package/dist/dev/lifecycle/pull-request/rework-comment/rework-comment.d.ts +30 -0
- package/dist/dev/lifecycle/pull-request/rework-comment/rework-comment.d.ts.map +1 -0
- package/dist/dev/lifecycle/pull-request/rework-comment/rework-comment.js +39 -0
- package/dist/dev/lifecycle/pull-request/rework-comment/rework-comment.js.map +1 -0
- package/dist/dev/lifecycle/quality/quality.d.ts +99 -0
- package/dist/dev/lifecycle/quality/quality.d.ts.map +1 -0
- package/dist/dev/lifecycle/quality/quality.js +213 -0
- package/dist/dev/lifecycle/quality/quality.js.map +1 -0
- package/dist/dev/lifecycle/resume/resume.d.ts +64 -0
- package/dist/dev/lifecycle/resume/resume.d.ts.map +1 -0
- package/dist/dev/lifecycle/resume/resume.js +171 -0
- package/dist/dev/lifecycle/resume/resume.js.map +1 -0
- package/dist/dev/lifecycle/rework/rework-builders.d.ts +20 -0
- package/dist/dev/lifecycle/rework/rework-builders.d.ts.map +1 -0
- package/dist/dev/lifecycle/rework/rework-builders.js +203 -0
- package/dist/dev/lifecycle/rework/rework-builders.js.map +1 -0
- package/dist/dev/lifecycle/rework/rework-handlers.d.ts +50 -0
- package/dist/dev/lifecycle/rework/rework-handlers.d.ts.map +1 -0
- package/dist/dev/lifecycle/rework/rework-handlers.js +41 -0
- package/dist/dev/lifecycle/rework/rework-handlers.js.map +1 -0
- package/dist/dev/lifecycle/rework/rework.d.ts +63 -0
- package/dist/dev/lifecycle/rework/rework.d.ts.map +1 -0
- package/dist/dev/lifecycle/rework/rework.js +141 -0
- package/dist/dev/lifecycle/rework/rework.js.map +1 -0
- package/dist/dev/pipeline/context.d.ts +105 -0
- package/dist/dev/pipeline/context.d.ts.map +1 -0
- package/dist/dev/pipeline/context.js +107 -0
- package/dist/dev/pipeline/context.js.map +1 -0
- package/dist/dev/pipeline/index.d.ts +6 -0
- package/dist/dev/pipeline/index.d.ts.map +1 -0
- package/dist/dev/pipeline/index.js +5 -0
- package/dist/dev/pipeline/index.js.map +1 -0
- package/dist/dev/pipeline/phases/branch-setup/branch-setup.d.ts +62 -0
- package/dist/dev/pipeline/phases/branch-setup/branch-setup.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/branch-setup/branch-setup.js +128 -0
- package/dist/dev/pipeline/phases/branch-setup/branch-setup.js.map +1 -0
- package/dist/dev/pipeline/phases/branch-setup/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/branch-setup/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/branch-setup/index.js +2 -0
- package/dist/dev/pipeline/phases/branch-setup/index.js.map +1 -0
- package/dist/dev/pipeline/phases/cleanup-phase/cleanup-phase.d.ts +32 -0
- package/dist/dev/pipeline/phases/cleanup-phase/cleanup-phase.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/cleanup-phase/cleanup-phase.js +32 -0
- package/dist/dev/pipeline/phases/cleanup-phase/cleanup-phase.js.map +1 -0
- package/dist/dev/pipeline/phases/cleanup-phase/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/cleanup-phase/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/cleanup-phase/index.js +2 -0
- package/dist/dev/pipeline/phases/cleanup-phase/index.js.map +1 -0
- package/dist/dev/pipeline/phases/cost-phase/cost-phase.d.ts +40 -0
- package/dist/dev/pipeline/phases/cost-phase/cost-phase.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/cost-phase/cost-phase.js +43 -0
- package/dist/dev/pipeline/phases/cost-phase/cost-phase.js.map +1 -0
- package/dist/dev/pipeline/phases/cost-phase/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/cost-phase/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/cost-phase/index.js +2 -0
- package/dist/dev/pipeline/phases/cost-phase/index.js.map +1 -0
- package/dist/dev/pipeline/phases/deliver-phase/deliver-phase.d.ts +68 -0
- package/dist/dev/pipeline/phases/deliver-phase/deliver-phase.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/deliver-phase/deliver-phase.js +125 -0
- package/dist/dev/pipeline/phases/deliver-phase/deliver-phase.js.map +1 -0
- package/dist/dev/pipeline/phases/deliver-phase/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/deliver-phase/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/deliver-phase/index.js +2 -0
- package/dist/dev/pipeline/phases/deliver-phase/index.js.map +1 -0
- package/dist/dev/pipeline/phases/dry-run/dry-run.d.ts +38 -0
- package/dist/dev/pipeline/phases/dry-run/dry-run.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/dry-run/dry-run.js +33 -0
- package/dist/dev/pipeline/phases/dry-run/dry-run.js.map +1 -0
- package/dist/dev/pipeline/phases/dry-run/index.d.ts +2 -0
- package/dist/dev/pipeline/phases/dry-run/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/dry-run/index.js +2 -0
- package/dist/dev/pipeline/phases/dry-run/index.js.map +1 -0
- package/dist/dev/pipeline/phases/epic-completion/epic-completion.d.ts +48 -0
- package/dist/dev/pipeline/phases/epic-completion/epic-completion.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/epic-completion/epic-completion.js +42 -0
- package/dist/dev/pipeline/phases/epic-completion/epic-completion.js.map +1 -0
- package/dist/dev/pipeline/phases/epic-completion/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/epic-completion/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/epic-completion/index.js +2 -0
- package/dist/dev/pipeline/phases/epic-completion/index.js.map +1 -0
- package/dist/dev/pipeline/phases/feasibility/feasibility.d.ts +52 -0
- package/dist/dev/pipeline/phases/feasibility/feasibility.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/feasibility/feasibility.js +34 -0
- package/dist/dev/pipeline/phases/feasibility/feasibility.js.map +1 -0
- package/dist/dev/pipeline/phases/feasibility/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/feasibility/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/feasibility/index.js +2 -0
- package/dist/dev/pipeline/phases/feasibility/index.js.map +1 -0
- package/dist/dev/pipeline/phases/index.d.ts +26 -0
- package/dist/dev/pipeline/phases/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/index.js +14 -0
- package/dist/dev/pipeline/phases/index.js.map +1 -0
- package/dist/dev/pipeline/phases/lock-check/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/lock-check/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/lock-check/index.js +2 -0
- package/dist/dev/pipeline/phases/lock-check/index.js.map +1 -0
- package/dist/dev/pipeline/phases/lock-check/lock-check.d.ts +55 -0
- package/dist/dev/pipeline/phases/lock-check/lock-check.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/lock-check/lock-check.js +60 -0
- package/dist/dev/pipeline/phases/lock-check/lock-check.js.map +1 -0
- package/dist/dev/pipeline/phases/pr-retry/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/pr-retry/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/pr-retry/index.js +2 -0
- package/dist/dev/pipeline/phases/pr-retry/index.js.map +1 -0
- package/dist/dev/pipeline/phases/pr-retry/pr-retry.d.ts +58 -0
- package/dist/dev/pipeline/phases/pr-retry/pr-retry.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/pr-retry/pr-retry.js +82 -0
- package/dist/dev/pipeline/phases/pr-retry/pr-retry.js.map +1 -0
- package/dist/dev/pipeline/phases/preflight-phase/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/preflight-phase/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/preflight-phase/index.js +2 -0
- package/dist/dev/pipeline/phases/preflight-phase/index.js.map +1 -0
- package/dist/dev/pipeline/phases/preflight-phase/preflight-phase.d.ts +42 -0
- package/dist/dev/pipeline/phases/preflight-phase/preflight-phase.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/preflight-phase/preflight-phase.js +41 -0
- package/dist/dev/pipeline/phases/preflight-phase/preflight-phase.js.map +1 -0
- package/dist/dev/pipeline/phases/rework-detection/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/rework-detection/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/rework-detection/index.js +2 -0
- package/dist/dev/pipeline/phases/rework-detection/index.js.map +1 -0
- package/dist/dev/pipeline/phases/rework-detection/rework-detection.d.ts +40 -0
- package/dist/dev/pipeline/phases/rework-detection/rework-detection.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/rework-detection/rework-detection.js +38 -0
- package/dist/dev/pipeline/phases/rework-detection/rework-detection.js.map +1 -0
- package/dist/dev/pipeline/phases/ticket-fetch/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/ticket-fetch/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/ticket-fetch/index.js +2 -0
- package/dist/dev/pipeline/phases/ticket-fetch/index.js.map +1 -0
- package/dist/dev/pipeline/phases/ticket-fetch/ticket-fetch.d.ts +46 -0
- package/dist/dev/pipeline/phases/ticket-fetch/ticket-fetch.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/ticket-fetch/ticket-fetch.js +64 -0
- package/dist/dev/pipeline/phases/ticket-fetch/ticket-fetch.js.map +1 -0
- package/dist/dev/pipeline/phases/transition/index.d.ts +3 -0
- package/dist/dev/pipeline/phases/transition/index.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/transition/index.js +2 -0
- package/dist/dev/pipeline/phases/transition/index.js.map +1 -0
- package/dist/dev/pipeline/phases/transition/transition.d.ts +30 -0
- package/dist/dev/pipeline/phases/transition/transition.d.ts.map +1 -0
- package/dist/dev/pipeline/phases/transition/transition.js +27 -0
- package/dist/dev/pipeline/phases/transition/transition.js.map +1 -0
- package/dist/dev/pipeline/run-pipeline.d.ts +98 -0
- package/dist/dev/pipeline/run-pipeline.d.ts.map +1 -0
- package/dist/dev/pipeline/run-pipeline.js +106 -0
- package/dist/dev/pipeline/run-pipeline.js.map +1 -0
- package/dist/index.d.ts +58 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +58 -0
- package/dist/index.js.map +1 -0
- package/dist/schemas/azdo/azdo-pr.d.ts +58 -0
- package/dist/schemas/azdo/azdo-pr.d.ts.map +1 -0
- package/dist/schemas/azdo/azdo-pr.js +48 -0
- package/dist/schemas/azdo/azdo-pr.js.map +1 -0
- package/dist/schemas/azdo/azdo.d.ts +88 -0
- package/dist/schemas/azdo/azdo.d.ts.map +1 -0
- package/dist/schemas/azdo/azdo.js +60 -0
- package/dist/schemas/azdo/azdo.js.map +1 -0
- package/dist/schemas/bitbucket/bitbucket.d.ts +112 -0
- package/dist/schemas/bitbucket/bitbucket.d.ts.map +1 -0
- package/dist/schemas/bitbucket/bitbucket.js +73 -0
- package/dist/schemas/bitbucket/bitbucket.js.map +1 -0
- package/dist/schemas/env/env.d.ts +336 -0
- package/dist/schemas/env/env.d.ts.map +1 -0
- package/dist/schemas/env/env.js +94 -0
- package/dist/schemas/env/env.js.map +1 -0
- package/dist/schemas/github/github.d.ts +128 -0
- package/dist/schemas/github/github.d.ts.map +1 -0
- package/dist/schemas/github/github.js +65 -0
- package/dist/schemas/github/github.js.map +1 -0
- package/dist/schemas/gitlab/gitlab.d.ts +72 -0
- package/dist/schemas/gitlab/gitlab.d.ts.map +1 -0
- package/dist/schemas/gitlab/gitlab.js +38 -0
- package/dist/schemas/gitlab/gitlab.js.map +1 -0
- package/dist/schemas/index.d.ts +15 -0
- package/dist/schemas/index.d.ts.map +1 -0
- package/dist/schemas/index.js +8 -0
- package/dist/schemas/index.js.map +1 -0
- package/dist/schemas/jira/jira.d.ts +79 -0
- package/dist/schemas/jira/jira.d.ts.map +1 -0
- package/dist/schemas/jira/jira.js +69 -0
- package/dist/schemas/jira/jira.js.map +1 -0
- package/dist/schemas/linear/linear.d.ts +178 -0
- package/dist/schemas/linear/linear.d.ts.map +1 -0
- package/dist/schemas/linear/linear.js +136 -0
- package/dist/schemas/linear/linear.js.map +1 -0
- package/dist/schemas/notion/notion.d.ts +131 -0
- package/dist/schemas/notion/notion.d.ts.map +1 -0
- package/dist/schemas/notion/notion.js +102 -0
- package/dist/schemas/notion/notion.js.map +1 -0
- package/dist/schemas/shortcut/shortcut.d.ts +149 -0
- package/dist/schemas/shortcut/shortcut.d.ts.map +1 -0
- package/dist/schemas/shortcut/shortcut.js +68 -0
- package/dist/schemas/shortcut/shortcut.js.map +1 -0
- package/dist/shared/cache/cache.d.ts +14 -0
- package/dist/shared/cache/cache.d.ts.map +1 -0
- package/dist/shared/cache/cache.js +25 -0
- package/dist/shared/cache/cache.js.map +1 -0
- package/dist/shared/cache/index.d.ts +2 -0
- package/dist/shared/cache/index.d.ts.map +1 -0
- package/dist/shared/cache/index.js +2 -0
- package/dist/shared/cache/index.js.map +1 -0
- package/dist/shared/env-parser/env-parser.d.ts +42 -0
- package/dist/shared/env-parser/env-parser.d.ts.map +1 -0
- package/dist/shared/env-parser/env-parser.js +97 -0
- package/dist/shared/env-parser/env-parser.js.map +1 -0
- package/dist/shared/env-parser/index.d.ts +3 -0
- package/dist/shared/env-parser/index.d.ts.map +1 -0
- package/dist/shared/env-parser/index.js +2 -0
- package/dist/shared/env-parser/index.js.map +1 -0
- package/dist/shared/git-ops/git-ops.d.ts +127 -0
- package/dist/shared/git-ops/git-ops.d.ts.map +1 -0
- package/dist/shared/git-ops/git-ops.js +225 -0
- package/dist/shared/git-ops/git-ops.js.map +1 -0
- package/dist/shared/git-ops/index.d.ts +3 -0
- package/dist/shared/git-ops/index.d.ts.map +1 -0
- package/dist/shared/git-ops/index.js +2 -0
- package/dist/shared/git-ops/index.js.map +1 -0
- package/dist/shared/git-token/git-token.d.ts +18 -0
- package/dist/shared/git-token/git-token.d.ts.map +1 -0
- package/dist/shared/git-token/git-token.js +28 -0
- package/dist/shared/git-token/git-token.js.map +1 -0
- package/dist/shared/git-token/index.d.ts +2 -0
- package/dist/shared/git-token/index.d.ts.map +1 -0
- package/dist/shared/git-token/index.js +2 -0
- package/dist/shared/git-token/index.js.map +1 -0
- package/dist/shared/http/fetch-and-parse/fetch-and-parse.d.ts +32 -0
- package/dist/shared/http/fetch-and-parse/fetch-and-parse.d.ts.map +1 -0
- package/dist/shared/http/fetch-and-parse/fetch-and-parse.js +53 -0
- package/dist/shared/http/fetch-and-parse/fetch-and-parse.js.map +1 -0
- package/dist/shared/http/fetch-and-parse/index.d.ts +3 -0
- package/dist/shared/http/fetch-and-parse/index.d.ts.map +1 -0
- package/dist/shared/http/fetch-and-parse/index.js +2 -0
- package/dist/shared/http/fetch-and-parse/index.js.map +1 -0
- package/dist/shared/http/index.d.ts +7 -0
- package/dist/shared/http/index.d.ts.map +1 -0
- package/dist/shared/http/index.js +4 -0
- package/dist/shared/http/index.js.map +1 -0
- package/dist/shared/http/ping-endpoint/index.d.ts +3 -0
- package/dist/shared/http/ping-endpoint/index.d.ts.map +1 -0
- package/dist/shared/http/ping-endpoint/index.js +2 -0
- package/dist/shared/http/ping-endpoint/index.js.map +1 -0
- package/dist/shared/http/ping-endpoint/ping-endpoint.d.ts +29 -0
- package/dist/shared/http/ping-endpoint/ping-endpoint.d.ts.map +1 -0
- package/dist/shared/http/ping-endpoint/ping-endpoint.js +31 -0
- package/dist/shared/http/ping-endpoint/ping-endpoint.js.map +1 -0
- package/dist/shared/http/retry-fetch/index.d.ts +3 -0
- package/dist/shared/http/retry-fetch/index.d.ts.map +1 -0
- package/dist/shared/http/retry-fetch/index.js +2 -0
- package/dist/shared/http/retry-fetch/index.js.map +1 -0
- package/dist/shared/http/retry-fetch/retry-fetch.d.ts +33 -0
- package/dist/shared/http/retry-fetch/retry-fetch.d.ts.map +1 -0
- package/dist/shared/http/retry-fetch/retry-fetch.js +94 -0
- package/dist/shared/http/retry-fetch/retry-fetch.js.map +1 -0
- package/dist/shared/label-helpers/index.d.ts +3 -0
- package/dist/shared/label-helpers/index.d.ts.map +1 -0
- package/dist/shared/label-helpers/index.js +2 -0
- package/dist/shared/label-helpers/index.js.map +1 -0
- package/dist/shared/label-helpers/label-helpers.d.ts +41 -0
- package/dist/shared/label-helpers/label-helpers.d.ts.map +1 -0
- package/dist/shared/label-helpers/label-helpers.js +51 -0
- package/dist/shared/label-helpers/label-helpers.js.map +1 -0
- package/dist/shared/remote/index.d.ts +2 -0
- package/dist/shared/remote/index.d.ts.map +1 -0
- package/dist/shared/remote/index.js +2 -0
- package/dist/shared/remote/index.js.map +1 -0
- package/dist/shared/remote/remote.d.ts +39 -0
- package/dist/shared/remote/remote.d.ts.map +1 -0
- package/dist/shared/remote/remote.js +180 -0
- package/dist/shared/remote/remote.js.map +1 -0
- package/dist/types/board.d.ts +62 -0
- package/dist/types/board.d.ts.map +1 -0
- package/dist/types/board.js +5 -0
- package/dist/types/board.js.map +1 -0
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/progress.d.ts +21 -0
- package/dist/types/progress.d.ts.map +1 -0
- package/dist/types/progress.js +34 -0
- package/dist/types/progress.js.map +1 -0
- package/dist/types/remote.d.ts +77 -0
- package/dist/types/remote.d.ts.map +1 -0
- package/dist/types/remote.js +5 -0
- package/dist/types/remote.js.map +1 -0
- package/package.json +44 -0
|
@@ -0,0 +1,179 @@
|
|
|
1
|
+
import { linearIssuesResponseSchema, linearViewerResponseSchema, } from '../../../schemas/index.js';
|
|
2
|
+
/** Linear GraphQL API endpoint. */
|
|
3
|
+
const LINEAR_API = 'https://api.linear.app/graphql';
|
|
4
|
+
const SAFE_ID_PATTERN = /^[a-zA-Z0-9_-]+$/;
|
|
5
|
+
/**
|
|
6
|
+
* Build standard Linear API request headers.
|
|
7
|
+
*
|
|
8
|
+
* Personal API keys do NOT use "Bearer" prefix — only OAuth tokens do.
|
|
9
|
+
*
|
|
10
|
+
* @param apiKey - The Linear personal API key.
|
|
11
|
+
* @returns Headers object for Linear GraphQL requests.
|
|
12
|
+
*/
|
|
13
|
+
export function linearHeaders(apiKey) {
|
|
14
|
+
return {
|
|
15
|
+
Authorization: apiKey,
|
|
16
|
+
'Content-Type': 'application/json',
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Validate that a team ID is safe for use in GraphQL variables.
|
|
21
|
+
*
|
|
22
|
+
* @param teamId - The Linear team ID to validate.
|
|
23
|
+
* @returns `true` if the ID matches the safe pattern.
|
|
24
|
+
*/
|
|
25
|
+
export function isValidTeamId(teamId) {
|
|
26
|
+
return SAFE_ID_PATTERN.test(teamId);
|
|
27
|
+
}
|
|
28
|
+
/** Build a GraphQL POST request init. */
|
|
29
|
+
function graphqlInit(apiKey, query, variables) {
|
|
30
|
+
return {
|
|
31
|
+
method: 'POST',
|
|
32
|
+
headers: linearHeaders(apiKey),
|
|
33
|
+
body: JSON.stringify({ query, variables }),
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Make a GraphQL request to the Linear API.
|
|
38
|
+
*
|
|
39
|
+
* @param opts - API key, query, optional variables, and optional fetcher.
|
|
40
|
+
* @returns The raw JSON response, or `undefined` on failure.
|
|
41
|
+
*/
|
|
42
|
+
export async function linearGraphql(opts) {
|
|
43
|
+
const { apiKey, query, variables, fetcher } = opts;
|
|
44
|
+
const doFetch = fetcher ?? fetch;
|
|
45
|
+
const response = await doFetch(LINEAR_API, graphqlInit(apiKey, query, variables)).catch((err) => {
|
|
46
|
+
console.warn(`⚠ Linear API request failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
47
|
+
return undefined;
|
|
48
|
+
});
|
|
49
|
+
if (!response)
|
|
50
|
+
return undefined;
|
|
51
|
+
if (!response.ok) {
|
|
52
|
+
console.warn(`⚠ Linear API returned HTTP ${response.status}`);
|
|
53
|
+
return undefined;
|
|
54
|
+
}
|
|
55
|
+
try {
|
|
56
|
+
return await response.json();
|
|
57
|
+
}
|
|
58
|
+
catch {
|
|
59
|
+
console.warn('⚠ Linear API returned invalid JSON');
|
|
60
|
+
return undefined;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
/** Map a Linear ping HTTP status to a failure result. */
|
|
64
|
+
function mapPingStatus(status) {
|
|
65
|
+
const isAuthError = status === 401 || status === 403;
|
|
66
|
+
return isAuthError
|
|
67
|
+
? { ok: false, error: '✗ Linear auth failed — check LINEAR_API_KEY' }
|
|
68
|
+
: { ok: false, error: `✗ Linear API returned HTTP ${status}` };
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Ping the Linear API to verify connectivity and credentials.
|
|
72
|
+
*
|
|
73
|
+
* @param apiKey - The Linear personal API key.
|
|
74
|
+
* @param fetcher - Optional custom fetch function for DI in tests.
|
|
75
|
+
* @returns Ping result with `ok` and optional `error`.
|
|
76
|
+
*/
|
|
77
|
+
export async function pingLinear(apiKey, fetcher) {
|
|
78
|
+
const response = await (fetcher ?? fetch)(LINEAR_API, graphqlInit(apiKey, '{ viewer { id } }')).catch(() => undefined);
|
|
79
|
+
if (!response) {
|
|
80
|
+
return { ok: false, error: '✗ Could not reach Linear — check network' };
|
|
81
|
+
}
|
|
82
|
+
if (!response.ok)
|
|
83
|
+
return mapPingStatus(response.status);
|
|
84
|
+
try {
|
|
85
|
+
const json = await response.json();
|
|
86
|
+
const parsed = linearViewerResponseSchema.safeParse(json);
|
|
87
|
+
if (parsed.success && parsed.data.data?.viewer?.id)
|
|
88
|
+
return { ok: true };
|
|
89
|
+
}
|
|
90
|
+
catch {
|
|
91
|
+
// Invalid JSON — treat as auth issue
|
|
92
|
+
}
|
|
93
|
+
return { ok: false, error: '✗ Linear auth failed — check LINEAR_API_KEY' };
|
|
94
|
+
}
|
|
95
|
+
/** Map a raw Linear issue node to a {@link LinearTicket}. */
|
|
96
|
+
function toLinearTicket(issue) {
|
|
97
|
+
return {
|
|
98
|
+
key: issue.identifier,
|
|
99
|
+
title: issue.title,
|
|
100
|
+
description: issue.description ?? '',
|
|
101
|
+
provider: 'linear',
|
|
102
|
+
issueId: issue.id,
|
|
103
|
+
parentIdentifier: issue.parent?.identifier,
|
|
104
|
+
labels: issue.labels?.nodes
|
|
105
|
+
?.map((l) => l.name)
|
|
106
|
+
.filter((n) => Boolean(n)),
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
/** Build the GraphQL query for fetching assigned issues. */
|
|
110
|
+
function buildIssuesQuery(opts) {
|
|
111
|
+
const { teamId, label, excludeHitl, limit = 5 } = opts;
|
|
112
|
+
const hasLabel = Boolean(label?.trim());
|
|
113
|
+
const varDecls = ['$teamId: ID!', ...(hasLabel ? ['$label: String!'] : [])];
|
|
114
|
+
const labelFilter = hasLabel ? 'labels: { name: { eq: $label } }' : '';
|
|
115
|
+
const filterParts = [
|
|
116
|
+
'state: { type: { eq: "unstarted" } }',
|
|
117
|
+
'team: { id: { eq: $teamId } }',
|
|
118
|
+
labelFilter,
|
|
119
|
+
].filter(Boolean);
|
|
120
|
+
const clampedLimit = Math.min(Math.max(limit, 1), 50);
|
|
121
|
+
const fetchLimit = excludeHitl ? clampedLimit * 3 : clampedLimit;
|
|
122
|
+
const query = `
|
|
123
|
+
query(${varDecls.join(', ')}) {
|
|
124
|
+
viewer {
|
|
125
|
+
assignedIssues(
|
|
126
|
+
filter: {
|
|
127
|
+
${filterParts.join('\n ')}
|
|
128
|
+
}
|
|
129
|
+
first: ${String(fetchLimit)}
|
|
130
|
+
orderBy: createdAt
|
|
131
|
+
) {
|
|
132
|
+
nodes {
|
|
133
|
+
id
|
|
134
|
+
identifier
|
|
135
|
+
title
|
|
136
|
+
description
|
|
137
|
+
parent { identifier title }
|
|
138
|
+
labels { nodes { name } }
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
`;
|
|
144
|
+
const variables = hasLabel
|
|
145
|
+
? { teamId, label }
|
|
146
|
+
: { teamId };
|
|
147
|
+
return { query, variables };
|
|
148
|
+
}
|
|
149
|
+
/** Check if an issue has the HITL exclusion label. */
|
|
150
|
+
function isHitlIssue(issue) {
|
|
151
|
+
return issue.labels?.nodes?.some((l) => l.name === 'clancy:hitl') === true;
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* Fetch candidate issues from Linear.
|
|
155
|
+
*
|
|
156
|
+
* @param opts - API key, team ID, and optional filters.
|
|
157
|
+
* @returns Array of fetched tickets (may be empty).
|
|
158
|
+
*/
|
|
159
|
+
export async function fetchIssues(opts) {
|
|
160
|
+
if (!isValidTeamId(opts.teamId))
|
|
161
|
+
return [];
|
|
162
|
+
const { apiKey, excludeHitl, limit = 5 } = opts;
|
|
163
|
+
const { query, variables } = buildIssuesQuery(opts);
|
|
164
|
+
const raw = await linearGraphql({
|
|
165
|
+
apiKey,
|
|
166
|
+
query,
|
|
167
|
+
variables,
|
|
168
|
+
fetcher: opts.fetcher,
|
|
169
|
+
});
|
|
170
|
+
const parsed = linearIssuesResponseSchema.safeParse(raw);
|
|
171
|
+
if (!parsed.success)
|
|
172
|
+
return [];
|
|
173
|
+
const allNodes = parsed.data.data?.viewer?.assignedIssues?.nodes ?? [];
|
|
174
|
+
const filtered = excludeHitl
|
|
175
|
+
? allNodes.filter((n) => !isHitlIssue(n))
|
|
176
|
+
: allNodes;
|
|
177
|
+
return filtered.slice(0, limit).map(toLinearTicket);
|
|
178
|
+
}
|
|
179
|
+
//# sourceMappingURL=api.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api.js","sourceRoot":"","sources":["../../../../src/board/linear/api/api.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/board/linear/api/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,WAAW,EACX,aAAa,EACb,aAAa,EACb,UAAU,GACX,MAAM,UAAU,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/board/linear/api/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,WAAW,EACX,aAAa,EACb,aAAa,EACb,UAAU,GACX,MAAM,UAAU,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/board/linear/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/board/linear/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/board/linear/labels/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/board/linear/labels/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Linear issue label operations.
|
|
3
|
+
*
|
|
4
|
+
* Linear labels are ID-based — adding/removing requires reading the
|
|
5
|
+
* current label IDs, modifying the list, and writing back via GraphQL.
|
|
6
|
+
* Label name→UUID resolution uses a {@link CachedMap} for efficiency.
|
|
7
|
+
*
|
|
8
|
+
* The 3-step {@link ensureLabel} flow: team labels → workspace labels → create.
|
|
9
|
+
*/
|
|
10
|
+
import type { CachedMap } from '../../../shared/cache/index.js';
|
|
11
|
+
import type { Fetcher } from '../../../shared/http/index.js';
|
|
12
|
+
/** Options for {@link ensureLabel}. */
|
|
13
|
+
type EnsureLabelOpts = {
|
|
14
|
+
readonly apiKey: string;
|
|
15
|
+
readonly teamId: string;
|
|
16
|
+
readonly labelCache: CachedMap<string, string>;
|
|
17
|
+
readonly label: string;
|
|
18
|
+
readonly fetcher?: Fetcher;
|
|
19
|
+
};
|
|
20
|
+
/**
|
|
21
|
+
* Ensure a label exists and cache its ID.
|
|
22
|
+
*
|
|
23
|
+
* 1. Check the label cache.
|
|
24
|
+
* 2. Search team labels.
|
|
25
|
+
* 3. Search workspace labels.
|
|
26
|
+
* 4. Create a new team-scoped label.
|
|
27
|
+
*
|
|
28
|
+
* @param opts - API key, team ID, cache, and label name.
|
|
29
|
+
* @returns Resolves when complete (best-effort — never throws).
|
|
30
|
+
*/
|
|
31
|
+
export declare function ensureLabel(opts: EnsureLabelOpts): Promise<void>;
|
|
32
|
+
/** Options for {@link addLabel}. */
|
|
33
|
+
type AddLabelOpts = {
|
|
34
|
+
readonly apiKey: string;
|
|
35
|
+
readonly labelCache: CachedMap<string, string>;
|
|
36
|
+
readonly issueKey: string;
|
|
37
|
+
readonly label: string;
|
|
38
|
+
readonly fetcher?: Fetcher;
|
|
39
|
+
};
|
|
40
|
+
/**
|
|
41
|
+
* Add a label to a Linear issue (best-effort).
|
|
42
|
+
*
|
|
43
|
+
* @param opts - API key, label cache, issue key, and label name.
|
|
44
|
+
* @returns Resolves when complete (best-effort — never throws).
|
|
45
|
+
*/
|
|
46
|
+
export declare function addLabel(opts: AddLabelOpts): Promise<void>;
|
|
47
|
+
/** Options for {@link removeLabel}. */
|
|
48
|
+
type RemoveLabelOpts = {
|
|
49
|
+
readonly apiKey: string;
|
|
50
|
+
readonly labelCache: CachedMap<string, string>;
|
|
51
|
+
readonly issueKey: string;
|
|
52
|
+
readonly label: string;
|
|
53
|
+
readonly fetcher?: Fetcher;
|
|
54
|
+
};
|
|
55
|
+
/**
|
|
56
|
+
* Remove a label from a Linear issue (best-effort).
|
|
57
|
+
*
|
|
58
|
+
* @param opts - API key, label cache, issue key, and label name.
|
|
59
|
+
* @returns Resolves when complete (best-effort — never throws).
|
|
60
|
+
*/
|
|
61
|
+
export declare function removeLabel(opts: RemoveLabelOpts): Promise<void>;
|
|
62
|
+
export {};
|
|
63
|
+
//# sourceMappingURL=labels.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"labels.d.ts","sourceRoot":"","sources":["../../../../src/board/linear/labels/labels.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AACH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AAYxD,uCAAuC;AACvC,KAAK,eAAe,GAAG;IACrB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,UAAU,EAAE,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC/C,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,OAAO,CAAC,EAAE,OAAO,CAAC;CAC5B,CAAC;AAsFF;;;;;;;;;;GAUG;AACH,wBAAsB,WAAW,CAAC,IAAI,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC,CAsBtE;AAED,oCAAoC;AACpC,KAAK,YAAY,GAAG;IAClB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,UAAU,EAAE,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC/C,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,OAAO,CAAC,EAAE,OAAO,CAAC;CAC5B,CAAC;AAEF;;;;;GAKG;AACH,wBAAsB,QAAQ,CAAC,IAAI,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CAoBhE;AAED,uCAAuC;AACvC,KAAK,eAAe,GAAG;IACrB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,UAAU,EAAE,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC/C,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,OAAO,CAAC,EAAE,OAAO,CAAC;CAC5B,CAAC;AAEF;;;;;GAKG;AACH,wBAAsB,WAAW,CAAC,IAAI,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC,CA2BtE"}
|
|
@@ -0,0 +1,204 @@
|
|
|
1
|
+
import { linearIssueLabelSearchResponseSchema, linearLabelCreateResponseSchema, linearTeamLabelsResponseSchema, linearWorkspaceLabelsResponseSchema, } from '../../../schemas/index.js';
|
|
2
|
+
import { safeLabel } from '../../../shared/label-helpers/index.js';
|
|
3
|
+
import { linearGraphql } from '../api/index.js';
|
|
4
|
+
/** Search team labels for a match by name and return its ID. */
|
|
5
|
+
async function findTeamLabel(opts) {
|
|
6
|
+
const { apiKey, teamId, label, fetcher } = opts;
|
|
7
|
+
const query = `
|
|
8
|
+
query($teamId: String!, $name: String!) {
|
|
9
|
+
team(id: $teamId) {
|
|
10
|
+
labels(filter: { name: { eq: $name } }) { nodes { id name } }
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
`;
|
|
14
|
+
const raw = await linearGraphql({
|
|
15
|
+
apiKey,
|
|
16
|
+
query,
|
|
17
|
+
variables: { teamId, name: label },
|
|
18
|
+
fetcher,
|
|
19
|
+
});
|
|
20
|
+
const parsed = linearTeamLabelsResponseSchema.safeParse(raw);
|
|
21
|
+
return parsed.success
|
|
22
|
+
? parsed.data.data?.team?.labels?.nodes?.[0]?.id
|
|
23
|
+
: undefined;
|
|
24
|
+
}
|
|
25
|
+
/** Search workspace labels for a match and return its ID. */
|
|
26
|
+
async function findWorkspaceLabel(opts) {
|
|
27
|
+
const { apiKey, label, fetcher } = opts;
|
|
28
|
+
const query = `
|
|
29
|
+
query($name: String!) {
|
|
30
|
+
issueLabels(filter: { name: { eq: $name } }) {
|
|
31
|
+
nodes { id name }
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
`;
|
|
35
|
+
const raw = await linearGraphql({
|
|
36
|
+
apiKey,
|
|
37
|
+
query,
|
|
38
|
+
variables: { name: label },
|
|
39
|
+
fetcher,
|
|
40
|
+
});
|
|
41
|
+
const parsed = linearWorkspaceLabelsResponseSchema.safeParse(raw);
|
|
42
|
+
return parsed.success
|
|
43
|
+
? parsed.data.data?.issueLabels?.nodes?.[0]?.id
|
|
44
|
+
: undefined;
|
|
45
|
+
}
|
|
46
|
+
/** Create a new team-scoped label and return its ID. */
|
|
47
|
+
async function createTeamLabel(opts) {
|
|
48
|
+
const { apiKey, teamId, label, fetcher } = opts;
|
|
49
|
+
const mutation = `
|
|
50
|
+
mutation($teamId: String!, $name: String!) {
|
|
51
|
+
issueLabelCreate(input: { teamId: $teamId, name: $name, color: "#0075ca" }) {
|
|
52
|
+
issueLabel { id }
|
|
53
|
+
success
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
`;
|
|
57
|
+
const raw = await linearGraphql({
|
|
58
|
+
apiKey,
|
|
59
|
+
query: mutation,
|
|
60
|
+
variables: { teamId, name: label },
|
|
61
|
+
fetcher,
|
|
62
|
+
});
|
|
63
|
+
const parsed = linearLabelCreateResponseSchema.safeParse(raw);
|
|
64
|
+
return parsed.success
|
|
65
|
+
? parsed.data.data?.issueLabelCreate?.issueLabel?.id
|
|
66
|
+
: undefined;
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* Ensure a label exists and cache its ID.
|
|
70
|
+
*
|
|
71
|
+
* 1. Check the label cache.
|
|
72
|
+
* 2. Search team labels.
|
|
73
|
+
* 3. Search workspace labels.
|
|
74
|
+
* 4. Create a new team-scoped label.
|
|
75
|
+
*
|
|
76
|
+
* @param opts - API key, team ID, cache, and label name.
|
|
77
|
+
* @returns Resolves when complete (best-effort — never throws).
|
|
78
|
+
*/
|
|
79
|
+
export async function ensureLabel(opts) {
|
|
80
|
+
const { apiKey, teamId, labelCache, label, fetcher } = opts;
|
|
81
|
+
const lookup = { apiKey, teamId, label, fetcher };
|
|
82
|
+
await safeLabel(async () => {
|
|
83
|
+
if (labelCache.has(label))
|
|
84
|
+
return;
|
|
85
|
+
const teamId_ = await findTeamLabel(lookup);
|
|
86
|
+
if (teamId_) {
|
|
87
|
+
labelCache.store(label, teamId_);
|
|
88
|
+
return;
|
|
89
|
+
}
|
|
90
|
+
const wsId = await findWorkspaceLabel(lookup);
|
|
91
|
+
if (wsId) {
|
|
92
|
+
labelCache.store(label, wsId);
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
const newId = await createTeamLabel(lookup);
|
|
96
|
+
if (newId)
|
|
97
|
+
labelCache.store(label, newId);
|
|
98
|
+
}, 'ensureLabel');
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Add a label to a Linear issue (best-effort).
|
|
102
|
+
*
|
|
103
|
+
* @param opts - API key, label cache, issue key, and label name.
|
|
104
|
+
* @returns Resolves when complete (best-effort — never throws).
|
|
105
|
+
*/
|
|
106
|
+
export async function addLabel(opts) {
|
|
107
|
+
const { apiKey, labelCache, issueKey, label, fetcher } = opts;
|
|
108
|
+
await safeLabel(async () => {
|
|
109
|
+
const labelId = labelCache.get(label);
|
|
110
|
+
if (!labelId)
|
|
111
|
+
return;
|
|
112
|
+
const issue = await fetchIssueLabelIds(apiKey, issueKey, fetcher);
|
|
113
|
+
if (!issue)
|
|
114
|
+
return;
|
|
115
|
+
const currentIds = issue.labelIds;
|
|
116
|
+
if (currentIds.includes(labelId))
|
|
117
|
+
return;
|
|
118
|
+
await updateIssueLabels({
|
|
119
|
+
apiKey,
|
|
120
|
+
issueId: issue.id,
|
|
121
|
+
labelIds: [...currentIds, labelId],
|
|
122
|
+
fetcher,
|
|
123
|
+
});
|
|
124
|
+
}, 'addLabel');
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Remove a label from a Linear issue (best-effort).
|
|
128
|
+
*
|
|
129
|
+
* @param opts - API key, label cache, issue key, and label name.
|
|
130
|
+
* @returns Resolves when complete (best-effort — never throws).
|
|
131
|
+
*/
|
|
132
|
+
export async function removeLabel(opts) {
|
|
133
|
+
const { apiKey, labelCache, issueKey, label, fetcher } = opts;
|
|
134
|
+
await safeLabel(async () => {
|
|
135
|
+
const issue = await fetchIssueLabelIds(apiKey, issueKey, fetcher);
|
|
136
|
+
if (!issue)
|
|
137
|
+
return;
|
|
138
|
+
const cachedId = labelCache.get(label);
|
|
139
|
+
const currentLabels = issue.labels;
|
|
140
|
+
const targetId = cachedId ?? currentLabels.find((l) => l.name === label)?.id;
|
|
141
|
+
if (!targetId)
|
|
142
|
+
return;
|
|
143
|
+
const updatedIds = currentLabels
|
|
144
|
+
.map((l) => l.id)
|
|
145
|
+
.filter((id) => id !== targetId);
|
|
146
|
+
if (updatedIds.length === currentLabels.length)
|
|
147
|
+
return;
|
|
148
|
+
await updateIssueLabels({
|
|
149
|
+
apiKey,
|
|
150
|
+
issueId: issue.id,
|
|
151
|
+
labelIds: updatedIds,
|
|
152
|
+
fetcher,
|
|
153
|
+
});
|
|
154
|
+
}, 'removeLabel');
|
|
155
|
+
}
|
|
156
|
+
/** Fetch an issue's UUID and current label IDs by identifier. */
|
|
157
|
+
async function fetchIssueLabelIds(apiKey, issueKey, fetcher) {
|
|
158
|
+
const query = `
|
|
159
|
+
query($identifier: String!) {
|
|
160
|
+
issueSearch: issues(filter: { identifier: { eq: $identifier } }, first: 1) {
|
|
161
|
+
nodes {
|
|
162
|
+
id
|
|
163
|
+
labels { nodes { id name } }
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
`;
|
|
168
|
+
const raw = await linearGraphql({
|
|
169
|
+
apiKey,
|
|
170
|
+
query,
|
|
171
|
+
variables: { identifier: issueKey },
|
|
172
|
+
fetcher,
|
|
173
|
+
});
|
|
174
|
+
const parsed = linearIssueLabelSearchResponseSchema.safeParse(raw);
|
|
175
|
+
if (!parsed.success)
|
|
176
|
+
return undefined;
|
|
177
|
+
const node = parsed.data.data?.issueSearch?.nodes?.[0];
|
|
178
|
+
if (!node)
|
|
179
|
+
return undefined;
|
|
180
|
+
const labels = node.labels?.nodes ?? [];
|
|
181
|
+
return {
|
|
182
|
+
id: node.id,
|
|
183
|
+
labelIds: labels.map((l) => l.id),
|
|
184
|
+
labels,
|
|
185
|
+
};
|
|
186
|
+
}
|
|
187
|
+
/** Update an issue's labels via GraphQL mutation. */
|
|
188
|
+
async function updateIssueLabels(opts) {
|
|
189
|
+
const { apiKey, issueId, labelIds, fetcher } = opts;
|
|
190
|
+
const mutation = `
|
|
191
|
+
mutation($issueId: String!, $labelIds: [String!]!) {
|
|
192
|
+
issueUpdate(id: $issueId, input: { labelIds: $labelIds }) {
|
|
193
|
+
success
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
`;
|
|
197
|
+
await linearGraphql({
|
|
198
|
+
apiKey,
|
|
199
|
+
query: mutation,
|
|
200
|
+
variables: { issueId, labelIds },
|
|
201
|
+
fetcher,
|
|
202
|
+
});
|
|
203
|
+
}
|
|
204
|
+
//# sourceMappingURL=labels.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"labels.js","sourceRoot":"","sources":["../../../../src/board/linear/labels/labels.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Linear board factory.
|
|
3
|
+
*
|
|
4
|
+
* Returns a plain object conforming to the Board type, delegating
|
|
5
|
+
* to the Linear API, relations, and label functions.
|
|
6
|
+
*/
|
|
7
|
+
import type { LinearEnv } from '../../schemas/index.js';
|
|
8
|
+
import type { Fetcher } from '../../shared/http/index.js';
|
|
9
|
+
import type { Board } from '../../types/index.js';
|
|
10
|
+
/**
|
|
11
|
+
* Create a Board implementation for Linear.
|
|
12
|
+
*
|
|
13
|
+
* @param env - The validated Linear environment variables.
|
|
14
|
+
* @param fetcher - Optional custom fetch function for DI in tests.
|
|
15
|
+
* @returns A Board object that delegates to Linear API functions.
|
|
16
|
+
*/
|
|
17
|
+
export declare function createLinearBoard(env: LinearEnv, fetcher?: Fetcher): Board;
|
|
18
|
+
//# sourceMappingURL=linear-board.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"linear-board.d.ts","sourceRoot":"","sources":["../../../src/board/linear/linear-board.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,KAAK,EAAE,KAAK,EAAkC,MAAM,oBAAoB,CAAC;AAqGhF;;;;;;GAMG;AACH,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,SAAS,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,KAAK,CA4D1E"}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { CachedMap } from '../../shared/cache/index.js';
|
|
2
|
+
import { fetchIssues, isValidTeamId, pingLinear } from './api/index.js';
|
|
3
|
+
import { addLabel, ensureLabel, removeLabel } from './labels/index.js';
|
|
4
|
+
import { fetchBlockerStatus, fetchChildrenStatus, transitionIssue, } from './relations/index.js';
|
|
5
|
+
/** Map a Linear ticket to the normalised FetchedTicket shape. */
|
|
6
|
+
function toFetchedTicket(ticket) {
|
|
7
|
+
return {
|
|
8
|
+
key: ticket.key,
|
|
9
|
+
title: ticket.title,
|
|
10
|
+
description: ticket.description,
|
|
11
|
+
parentInfo: ticket.parentIdentifier ?? 'none',
|
|
12
|
+
blockers: 'None',
|
|
13
|
+
linearIssueId: ticket.issueId,
|
|
14
|
+
issueId: ticket.issueId,
|
|
15
|
+
labels: ticket.labels ?? [],
|
|
16
|
+
status: 'unstarted',
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
/** Fetch and normalise Linear issues into FetchedTickets. */
|
|
20
|
+
async function fetchLinearTickets(ctx, opts) {
|
|
21
|
+
const tickets = await fetchIssues({
|
|
22
|
+
apiKey: ctx.apiKey,
|
|
23
|
+
teamId: ctx.teamId,
|
|
24
|
+
label: opts.buildLabel ?? ctx.defaultLabel,
|
|
25
|
+
excludeHitl: opts.excludeHitl,
|
|
26
|
+
fetcher: ctx.fetcher,
|
|
27
|
+
});
|
|
28
|
+
return tickets.map(toFetchedTicket);
|
|
29
|
+
}
|
|
30
|
+
/** Transition a Linear issue and log on success. */
|
|
31
|
+
async function doTransition(ctx, ticket, status) {
|
|
32
|
+
if (!ticket.linearIssueId)
|
|
33
|
+
return false;
|
|
34
|
+
const ok = await transitionIssue({
|
|
35
|
+
apiKey: ctx.apiKey,
|
|
36
|
+
teamId: ctx.teamId,
|
|
37
|
+
issueId: ticket.linearIssueId,
|
|
38
|
+
stateName: status,
|
|
39
|
+
fetcher: ctx.fetcher,
|
|
40
|
+
});
|
|
41
|
+
if (ok)
|
|
42
|
+
console.log(` → Transitioned to ${status}`);
|
|
43
|
+
return ok;
|
|
44
|
+
}
|
|
45
|
+
/** Ensure a label exists then add it to an issue. */
|
|
46
|
+
async function ensureAndAddLabel(ctx, issueKey, label) {
|
|
47
|
+
await ensureLabel({
|
|
48
|
+
apiKey: ctx.apiKey,
|
|
49
|
+
teamId: ctx.teamId,
|
|
50
|
+
labelCache: ctx.labelCache,
|
|
51
|
+
label,
|
|
52
|
+
fetcher: ctx.fetcher,
|
|
53
|
+
});
|
|
54
|
+
await addLabel({
|
|
55
|
+
apiKey: ctx.apiKey,
|
|
56
|
+
labelCache: ctx.labelCache,
|
|
57
|
+
issueKey,
|
|
58
|
+
label,
|
|
59
|
+
fetcher: ctx.fetcher,
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Create a Board implementation for Linear.
|
|
64
|
+
*
|
|
65
|
+
* @param env - The validated Linear environment variables.
|
|
66
|
+
* @param fetcher - Optional custom fetch function for DI in tests.
|
|
67
|
+
* @returns A Board object that delegates to Linear API functions.
|
|
68
|
+
*/
|
|
69
|
+
export function createLinearBoard(env, fetcher) {
|
|
70
|
+
const ctx = {
|
|
71
|
+
apiKey: env.LINEAR_API_KEY,
|
|
72
|
+
teamId: env.LINEAR_TEAM_ID,
|
|
73
|
+
defaultLabel: env.CLANCY_LABEL,
|
|
74
|
+
labelCache: new CachedMap(),
|
|
75
|
+
fetcher,
|
|
76
|
+
};
|
|
77
|
+
const doFetch = (opts) => fetchLinearTickets(ctx, opts);
|
|
78
|
+
return {
|
|
79
|
+
ping: () => pingLinear(ctx.apiKey, ctx.fetcher),
|
|
80
|
+
validateInputs: () => isValidTeamId(ctx.teamId)
|
|
81
|
+
? undefined
|
|
82
|
+
: '✗ LINEAR_TEAM_ID contains invalid characters',
|
|
83
|
+
fetchTicket: async (opts) => (await doFetch(opts))[0],
|
|
84
|
+
fetchTickets: doFetch,
|
|
85
|
+
async fetchBlockerStatus(ticket) {
|
|
86
|
+
if (!ticket.issueId)
|
|
87
|
+
return false;
|
|
88
|
+
return fetchBlockerStatus(ctx.apiKey, ticket.issueId, ctx.fetcher);
|
|
89
|
+
},
|
|
90
|
+
fetchChildrenStatus: (parentKey, parentId) => fetchChildrenStatus({
|
|
91
|
+
apiKey: ctx.apiKey,
|
|
92
|
+
parentId: parentId ?? parentKey,
|
|
93
|
+
parentIdentifier: parentKey,
|
|
94
|
+
fetcher: ctx.fetcher,
|
|
95
|
+
}),
|
|
96
|
+
transitionTicket: (ticket, status) => doTransition(ctx, ticket, status),
|
|
97
|
+
ensureLabel: (label) => ensureLabel({
|
|
98
|
+
apiKey: ctx.apiKey,
|
|
99
|
+
teamId: ctx.teamId,
|
|
100
|
+
labelCache: ctx.labelCache,
|
|
101
|
+
label,
|
|
102
|
+
fetcher: ctx.fetcher,
|
|
103
|
+
}),
|
|
104
|
+
addLabel: (issueKey, label) => ensureAndAddLabel(ctx, issueKey, label),
|
|
105
|
+
removeLabel: (issueKey, label) => removeLabel({
|
|
106
|
+
apiKey: ctx.apiKey,
|
|
107
|
+
labelCache: ctx.labelCache,
|
|
108
|
+
issueKey,
|
|
109
|
+
label,
|
|
110
|
+
fetcher: ctx.fetcher,
|
|
111
|
+
}),
|
|
112
|
+
sharedEnv: () => env,
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
//# sourceMappingURL=linear-board.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"linear-board.js","sourceRoot":"","sources":["../../../src/board/linear/linear-board.ts"],"names":[],"mappings":"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"}
|