@ghx-dev/core 0.1.0 → 0.1.2
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/README.md +19 -7
- package/dist/agent.d.ts +32 -7
- package/dist/agent.js +27 -12
- package/dist/agent.js.map +1 -1
- package/dist/cards/project_v2.fields.list.yaml +2 -2
- package/dist/cards/project_v2.item.add_issue.yaml +2 -2
- package/dist/cards/project_v2.item.field.update.yaml +2 -2
- package/dist/cards/project_v2.items.list.yaml +2 -2
- package/dist/cards/project_v2.org.get.yaml +2 -2
- package/dist/cards/project_v2.user.get.yaml +2 -2
- package/dist/cards/repo.issue_types.list.yaml +2 -2
- package/dist/{chunk-4PLVKNCF.js → chunk-2FCPR3XZ.js} +14 -4
- package/dist/chunk-2FCPR3XZ.js.map +1 -0
- package/dist/chunk-RDUPMVHG.js +4139 -0
- package/dist/chunk-RDUPMVHG.js.map +1 -0
- package/dist/{chunk-JH6GM6XU.js → chunk-UN5YHUNK.js} +119 -7
- package/dist/chunk-UN5YHUNK.js.map +1 -0
- package/dist/cli/assets/skills/ghx/SKILL.md +57 -0
- package/dist/cli/index.js +373 -41
- package/dist/cli/index.js.map +1 -1
- package/dist/core/registry/cards/project_v2.fields.list.yaml +2 -2
- package/dist/core/registry/cards/project_v2.item.add_issue.yaml +2 -2
- package/dist/core/registry/cards/project_v2.item.field.update.yaml +2 -2
- package/dist/core/registry/cards/project_v2.items.list.yaml +2 -2
- package/dist/core/registry/cards/project_v2.org.get.yaml +2 -2
- package/dist/core/registry/cards/project_v2.user.get.yaml +2 -2
- package/dist/core/registry/cards/repo.issue_types.list.yaml +2 -2
- package/dist/{core/contracts/envelope.d.ts → envelope-BpF6MNCv.d.ts} +15 -3
- package/dist/index.d.ts +470 -22
- package/dist/index.js +6 -30
- package/package.json +13 -14
- package/dist/agent-interface/prompt/main-skill.d.ts +0 -3
- package/dist/agent-interface/prompt/main-skill.js +0 -7
- package/dist/agent-interface/prompt/main-skill.js.map +0 -1
- package/dist/agent-interface/tools/execute-tool.d.ts +0 -16
- package/dist/agent-interface/tools/execute-tool.js +0 -7
- package/dist/agent-interface/tools/execute-tool.js.map +0 -1
- package/dist/agent-interface/tools/explain-tool.d.ts +0 -11
- package/dist/agent-interface/tools/explain-tool.js +0 -9
- package/dist/agent-interface/tools/explain-tool.js.map +0 -1
- package/dist/agent-interface/tools/list-capabilities-tool.d.ts +0 -7
- package/dist/agent-interface/tools/list-capabilities-tool.js +0 -9
- package/dist/agent-interface/tools/list-capabilities-tool.js.map +0 -1
- package/dist/chunk-22WWCK6A.js +0 -92
- package/dist/chunk-22WWCK6A.js.map +0 -1
- package/dist/chunk-2W4L5YCC.js +0 -116
- package/dist/chunk-2W4L5YCC.js.map +0 -1
- package/dist/chunk-3MRJX72M.js +0 -209
- package/dist/chunk-3MRJX72M.js.map +0 -1
- package/dist/chunk-4PLVKNCF.js.map +0 -1
- package/dist/chunk-573MDG3I.js +0 -18
- package/dist/chunk-573MDG3I.js.map +0 -1
- package/dist/chunk-5JRLVOF2.js +0 -50
- package/dist/chunk-5JRLVOF2.js.map +0 -1
- package/dist/chunk-B6RLMKS4.js +0 -41
- package/dist/chunk-B6RLMKS4.js.map +0 -1
- package/dist/chunk-D746VR3B.js +0 -38
- package/dist/chunk-D746VR3B.js.map +0 -1
- package/dist/chunk-DJIEG6K7.js +0 -20
- package/dist/chunk-DJIEG6K7.js.map +0 -1
- package/dist/chunk-DLKIQBK6.js +0 -106
- package/dist/chunk-DLKIQBK6.js.map +0 -1
- package/dist/chunk-EBRDO4Y6.js +0 -31
- package/dist/chunk-EBRDO4Y6.js.map +0 -1
- package/dist/chunk-FXN6IIT5.js +0 -14
- package/dist/chunk-FXN6IIT5.js.map +0 -1
- package/dist/chunk-GMTG7X2L.js +0 -16
- package/dist/chunk-GMTG7X2L.js.map +0 -1
- package/dist/chunk-HQ2VRCH7.js +0 -42
- package/dist/chunk-HQ2VRCH7.js.map +0 -1
- package/dist/chunk-JH6GM6XU.js.map +0 -1
- package/dist/chunk-JLDU462R.js +0 -1352
- package/dist/chunk-JLDU462R.js.map +0 -1
- package/dist/chunk-MGNGSGMF.js +0 -203
- package/dist/chunk-MGNGSGMF.js.map +0 -1
- package/dist/chunk-NFF5VF4U.js +0 -28
- package/dist/chunk-NFF5VF4U.js.map +0 -1
- package/dist/chunk-QEAMC4IJ.js +0 -34
- package/dist/chunk-QEAMC4IJ.js.map +0 -1
- package/dist/chunk-QZZC53HF.js +0 -38
- package/dist/chunk-QZZC53HF.js.map +0 -1
- package/dist/chunk-RUQXGZ35.js +0 -34
- package/dist/chunk-RUQXGZ35.js.map +0 -1
- package/dist/chunk-SA2D4A5U.js +0 -1496
- package/dist/chunk-SA2D4A5U.js.map +0 -1
- package/dist/chunk-SD7U4BNA.js +0 -174
- package/dist/chunk-SD7U4BNA.js.map +0 -1
- package/dist/chunk-SJR2SACI.js +0 -30
- package/dist/chunk-SJR2SACI.js.map +0 -1
- package/dist/chunk-TCLMLVUQ.js +0 -38
- package/dist/chunk-TCLMLVUQ.js.map +0 -1
- package/dist/chunk-TDTKOJKN.js +0 -52
- package/dist/chunk-TDTKOJKN.js.map +0 -1
- package/dist/chunk-UGWIZ3RI.js +0 -7
- package/dist/chunk-UGWIZ3RI.js.map +0 -1
- package/dist/chunk-UOJWOHRM.js +0 -16
- package/dist/chunk-UOJWOHRM.js.map +0 -1
- package/dist/chunk-VD5NXQP7.js +0 -42
- package/dist/chunk-VD5NXQP7.js.map +0 -1
- package/dist/chunk-W2TKG2UL.js +0 -37
- package/dist/chunk-W2TKG2UL.js.map +0 -1
- package/dist/chunk-W6ROKCY5.js +0 -28
- package/dist/chunk-W6ROKCY5.js.map +0 -1
- package/dist/chunk-XNMM64WU.js +0 -221
- package/dist/chunk-XNMM64WU.js.map +0 -1
- package/dist/cli/commands/capabilities-explain.d.ts +0 -3
- package/dist/cli/commands/capabilities-explain.js +0 -10
- package/dist/cli/commands/capabilities-explain.js.map +0 -1
- package/dist/cli/commands/capabilities-list.d.ts +0 -3
- package/dist/cli/commands/capabilities-list.js +0 -10
- package/dist/cli/commands/capabilities-list.js.map +0 -1
- package/dist/cli/commands/doctor.d.ts +0 -3
- package/dist/cli/commands/doctor.js +0 -7
- package/dist/cli/commands/doctor.js.map +0 -1
- package/dist/cli/commands/routes.d.ts +0 -3
- package/dist/cli/commands/routes.js +0 -7
- package/dist/cli/commands/routes.js.map +0 -1
- package/dist/cli/commands/run.d.ts +0 -3
- package/dist/cli/commands/run.js +0 -31
- package/dist/cli/commands/run.js.map +0 -1
- package/dist/cli/commands/setup.d.ts +0 -3
- package/dist/cli/commands/setup.js +0 -7
- package/dist/cli/commands/setup.js.map +0 -1
- package/dist/cli/formatters/json.d.ts +0 -3
- package/dist/cli/formatters/json.js +0 -8
- package/dist/cli/formatters/json.js.map +0 -1
- package/dist/cli/formatters/table.d.ts +0 -3
- package/dist/cli/formatters/table.js +0 -8
- package/dist/cli/formatters/table.js.map +0 -1
- package/dist/core/contracts/envelope.js +0 -1
- package/dist/core/contracts/envelope.js.map +0 -1
- package/dist/core/contracts/task.d.ts +0 -7
- package/dist/core/contracts/task.js +0 -1
- package/dist/core/contracts/task.js.map +0 -1
- package/dist/core/contracts/tasks/check_run.annotations.list.d.ts +0 -5
- package/dist/core/contracts/tasks/check_run.annotations.list.js +0 -8
- package/dist/core/contracts/tasks/check_run.annotations.list.js.map +0 -1
- package/dist/core/contracts/tasks/issue.assignees.update.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.assignees.update.js +0 -8
- package/dist/core/contracts/tasks/issue.assignees.update.js.map +0 -1
- package/dist/core/contracts/tasks/issue.blocked_by.add.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.blocked_by.add.js +0 -8
- package/dist/core/contracts/tasks/issue.blocked_by.add.js.map +0 -1
- package/dist/core/contracts/tasks/issue.blocked_by.remove.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.blocked_by.remove.js +0 -8
- package/dist/core/contracts/tasks/issue.blocked_by.remove.js.map +0 -1
- package/dist/core/contracts/tasks/issue.close.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.close.js +0 -8
- package/dist/core/contracts/tasks/issue.close.js.map +0 -1
- package/dist/core/contracts/tasks/issue.comments.create.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.comments.create.js +0 -8
- package/dist/core/contracts/tasks/issue.comments.create.js.map +0 -1
- package/dist/core/contracts/tasks/issue.comments.list.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.comments.list.js +0 -8
- package/dist/core/contracts/tasks/issue.comments.list.js.map +0 -1
- package/dist/core/contracts/tasks/issue.create.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.create.js +0 -8
- package/dist/core/contracts/tasks/issue.create.js.map +0 -1
- package/dist/core/contracts/tasks/issue.delete.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.delete.js +0 -8
- package/dist/core/contracts/tasks/issue.delete.js.map +0 -1
- package/dist/core/contracts/tasks/issue.labels.update.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.labels.update.js +0 -8
- package/dist/core/contracts/tasks/issue.labels.update.js.map +0 -1
- package/dist/core/contracts/tasks/issue.linked_prs.list.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.linked_prs.list.js +0 -8
- package/dist/core/contracts/tasks/issue.linked_prs.list.js.map +0 -1
- package/dist/core/contracts/tasks/issue.list.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.list.js +0 -8
- package/dist/core/contracts/tasks/issue.list.js.map +0 -1
- package/dist/core/contracts/tasks/issue.milestone.set.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.milestone.set.js +0 -8
- package/dist/core/contracts/tasks/issue.milestone.set.js.map +0 -1
- package/dist/core/contracts/tasks/issue.parent.remove.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.parent.remove.js +0 -8
- package/dist/core/contracts/tasks/issue.parent.remove.js.map +0 -1
- package/dist/core/contracts/tasks/issue.parent.set.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.parent.set.js +0 -8
- package/dist/core/contracts/tasks/issue.parent.set.js.map +0 -1
- package/dist/core/contracts/tasks/issue.relations.get.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.relations.get.js +0 -8
- package/dist/core/contracts/tasks/issue.relations.get.js.map +0 -1
- package/dist/core/contracts/tasks/issue.reopen.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.reopen.js +0 -8
- package/dist/core/contracts/tasks/issue.reopen.js.map +0 -1
- package/dist/core/contracts/tasks/issue.update.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.update.js +0 -8
- package/dist/core/contracts/tasks/issue.update.js.map +0 -1
- package/dist/core/contracts/tasks/issue.view.d.ts +0 -5
- package/dist/core/contracts/tasks/issue.view.js +0 -8
- package/dist/core/contracts/tasks/issue.view.js.map +0 -1
- package/dist/core/contracts/tasks/pr.assignees.update.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.assignees.update.js +0 -8
- package/dist/core/contracts/tasks/pr.assignees.update.js.map +0 -1
- package/dist/core/contracts/tasks/pr.branch.update.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.branch.update.js +0 -8
- package/dist/core/contracts/tasks/pr.branch.update.js.map +0 -1
- package/dist/core/contracts/tasks/pr.checks.get_failed.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.checks.get_failed.js +0 -8
- package/dist/core/contracts/tasks/pr.checks.get_failed.js.map +0 -1
- package/dist/core/contracts/tasks/pr.checks.rerun_all.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.checks.rerun_all.js +0 -8
- package/dist/core/contracts/tasks/pr.checks.rerun_all.js.map +0 -1
- package/dist/core/contracts/tasks/pr.checks.rerun_failed.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.checks.rerun_failed.js +0 -8
- package/dist/core/contracts/tasks/pr.checks.rerun_failed.js.map +0 -1
- package/dist/core/contracts/tasks/pr.comment.reply.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.comment.reply.js +0 -8
- package/dist/core/contracts/tasks/pr.comment.reply.js.map +0 -1
- package/dist/core/contracts/tasks/pr.comment.resolve.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.comment.resolve.js +0 -8
- package/dist/core/contracts/tasks/pr.comment.resolve.js.map +0 -1
- package/dist/core/contracts/tasks/pr.comment.unresolve.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.comment.unresolve.js +0 -8
- package/dist/core/contracts/tasks/pr.comment.unresolve.js.map +0 -1
- package/dist/core/contracts/tasks/pr.comments.list.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.comments.list.js +0 -8
- package/dist/core/contracts/tasks/pr.comments.list.js.map +0 -1
- package/dist/core/contracts/tasks/pr.diff.list_files.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.diff.list_files.js +0 -8
- package/dist/core/contracts/tasks/pr.diff.list_files.js.map +0 -1
- package/dist/core/contracts/tasks/pr.list.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.list.js +0 -8
- package/dist/core/contracts/tasks/pr.list.js.map +0 -1
- package/dist/core/contracts/tasks/pr.merge.execute.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.merge.execute.js +0 -8
- package/dist/core/contracts/tasks/pr.merge.execute.js.map +0 -1
- package/dist/core/contracts/tasks/pr.mergeability.view.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.mergeability.view.js +0 -8
- package/dist/core/contracts/tasks/pr.mergeability.view.js.map +0 -1
- package/dist/core/contracts/tasks/pr.ready_for_review.set.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.ready_for_review.set.js +0 -8
- package/dist/core/contracts/tasks/pr.ready_for_review.set.js.map +0 -1
- package/dist/core/contracts/tasks/pr.review.submit_approve.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.review.submit_approve.js +0 -8
- package/dist/core/contracts/tasks/pr.review.submit_approve.js.map +0 -1
- package/dist/core/contracts/tasks/pr.review.submit_comment.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.review.submit_comment.js +0 -8
- package/dist/core/contracts/tasks/pr.review.submit_comment.js.map +0 -1
- package/dist/core/contracts/tasks/pr.review.submit_request_changes.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.review.submit_request_changes.js +0 -8
- package/dist/core/contracts/tasks/pr.review.submit_request_changes.js.map +0 -1
- package/dist/core/contracts/tasks/pr.reviewers.request.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.reviewers.request.js +0 -8
- package/dist/core/contracts/tasks/pr.reviewers.request.js.map +0 -1
- package/dist/core/contracts/tasks/pr.reviews.list.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.reviews.list.js +0 -8
- package/dist/core/contracts/tasks/pr.reviews.list.js.map +0 -1
- package/dist/core/contracts/tasks/pr.status.checks.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.status.checks.js +0 -8
- package/dist/core/contracts/tasks/pr.status.checks.js.map +0 -1
- package/dist/core/contracts/tasks/pr.view.d.ts +0 -5
- package/dist/core/contracts/tasks/pr.view.js +0 -8
- package/dist/core/contracts/tasks/pr.view.js.map +0 -1
- package/dist/core/contracts/tasks/project_v2.fields.list.d.ts +0 -5
- package/dist/core/contracts/tasks/project_v2.fields.list.js +0 -8
- package/dist/core/contracts/tasks/project_v2.fields.list.js.map +0 -1
- package/dist/core/contracts/tasks/project_v2.item.add_issue.d.ts +0 -5
- package/dist/core/contracts/tasks/project_v2.item.add_issue.js +0 -8
- package/dist/core/contracts/tasks/project_v2.item.add_issue.js.map +0 -1
- package/dist/core/contracts/tasks/project_v2.item.field.update.d.ts +0 -5
- package/dist/core/contracts/tasks/project_v2.item.field.update.js +0 -8
- package/dist/core/contracts/tasks/project_v2.item.field.update.js.map +0 -1
- package/dist/core/contracts/tasks/project_v2.items.list.d.ts +0 -5
- package/dist/core/contracts/tasks/project_v2.items.list.js +0 -8
- package/dist/core/contracts/tasks/project_v2.items.list.js.map +0 -1
- package/dist/core/contracts/tasks/project_v2.org.get.d.ts +0 -5
- package/dist/core/contracts/tasks/project_v2.org.get.js +0 -8
- package/dist/core/contracts/tasks/project_v2.org.get.js.map +0 -1
- package/dist/core/contracts/tasks/project_v2.user.get.d.ts +0 -5
- package/dist/core/contracts/tasks/project_v2.user.get.js +0 -8
- package/dist/core/contracts/tasks/project_v2.user.get.js.map +0 -1
- package/dist/core/contracts/tasks/release.create_draft.d.ts +0 -5
- package/dist/core/contracts/tasks/release.create_draft.js +0 -8
- package/dist/core/contracts/tasks/release.create_draft.js.map +0 -1
- package/dist/core/contracts/tasks/release.get.d.ts +0 -5
- package/dist/core/contracts/tasks/release.get.js +0 -8
- package/dist/core/contracts/tasks/release.get.js.map +0 -1
- package/dist/core/contracts/tasks/release.list.d.ts +0 -5
- package/dist/core/contracts/tasks/release.list.js +0 -8
- package/dist/core/contracts/tasks/release.list.js.map +0 -1
- package/dist/core/contracts/tasks/release.publish_draft.d.ts +0 -5
- package/dist/core/contracts/tasks/release.publish_draft.js +0 -8
- package/dist/core/contracts/tasks/release.publish_draft.js.map +0 -1
- package/dist/core/contracts/tasks/release.update.d.ts +0 -5
- package/dist/core/contracts/tasks/release.update.js +0 -8
- package/dist/core/contracts/tasks/release.update.js.map +0 -1
- package/dist/core/contracts/tasks/repo.issue_types.list.d.ts +0 -5
- package/dist/core/contracts/tasks/repo.issue_types.list.js +0 -8
- package/dist/core/contracts/tasks/repo.issue_types.list.js.map +0 -1
- package/dist/core/contracts/tasks/repo.labels.list.d.ts +0 -5
- package/dist/core/contracts/tasks/repo.labels.list.js +0 -8
- package/dist/core/contracts/tasks/repo.labels.list.js.map +0 -1
- package/dist/core/contracts/tasks/repo.view.d.ts +0 -5
- package/dist/core/contracts/tasks/repo.view.js +0 -8
- package/dist/core/contracts/tasks/repo.view.js.map +0 -1
- package/dist/core/contracts/tasks/workflow.get.d.ts +0 -5
- package/dist/core/contracts/tasks/workflow.get.js +0 -8
- package/dist/core/contracts/tasks/workflow.get.js.map +0 -1
- package/dist/core/contracts/tasks/workflow.list.d.ts +0 -5
- package/dist/core/contracts/tasks/workflow.list.js +0 -8
- package/dist/core/contracts/tasks/workflow.list.js.map +0 -1
- package/dist/core/contracts/tasks/workflow_dispatch.run.d.ts +0 -5
- package/dist/core/contracts/tasks/workflow_dispatch.run.js +0 -8
- package/dist/core/contracts/tasks/workflow_dispatch.run.js.map +0 -1
- package/dist/core/contracts/tasks/workflow_job.logs.analyze.d.ts +0 -5
- package/dist/core/contracts/tasks/workflow_job.logs.analyze.js +0 -8
- package/dist/core/contracts/tasks/workflow_job.logs.analyze.js.map +0 -1
- package/dist/core/contracts/tasks/workflow_job.logs.get.d.ts +0 -5
- package/dist/core/contracts/tasks/workflow_job.logs.get.js +0 -8
- package/dist/core/contracts/tasks/workflow_job.logs.get.js.map +0 -1
- package/dist/core/contracts/tasks/workflow_run.artifacts.list.d.ts +0 -5
- package/dist/core/contracts/tasks/workflow_run.artifacts.list.js +0 -8
- package/dist/core/contracts/tasks/workflow_run.artifacts.list.js.map +0 -1
- package/dist/core/contracts/tasks/workflow_run.cancel.d.ts +0 -5
- package/dist/core/contracts/tasks/workflow_run.cancel.js +0 -8
- package/dist/core/contracts/tasks/workflow_run.cancel.js.map +0 -1
- package/dist/core/contracts/tasks/workflow_run.get.d.ts +0 -5
- package/dist/core/contracts/tasks/workflow_run.get.js +0 -8
- package/dist/core/contracts/tasks/workflow_run.get.js.map +0 -1
- package/dist/core/contracts/tasks/workflow_run.jobs.list.d.ts +0 -5
- package/dist/core/contracts/tasks/workflow_run.jobs.list.js +0 -8
- package/dist/core/contracts/tasks/workflow_run.jobs.list.js.map +0 -1
- package/dist/core/contracts/tasks/workflow_run.rerun_all.d.ts +0 -5
- package/dist/core/contracts/tasks/workflow_run.rerun_all.js +0 -8
- package/dist/core/contracts/tasks/workflow_run.rerun_all.js.map +0 -1
- package/dist/core/contracts/tasks/workflow_run.rerun_failed.d.ts +0 -5
- package/dist/core/contracts/tasks/workflow_run.rerun_failed.js +0 -8
- package/dist/core/contracts/tasks/workflow_run.rerun_failed.js.map +0 -1
- package/dist/core/contracts/tasks/workflow_runs.list.d.ts +0 -5
- package/dist/core/contracts/tasks/workflow_runs.list.js +0 -8
- package/dist/core/contracts/tasks/workflow_runs.list.js.map +0 -1
- package/dist/core/errors/codes.d.ts +0 -13
- package/dist/core/errors/codes.js +0 -7
- package/dist/core/errors/codes.js.map +0 -1
- package/dist/core/errors/map-error.d.ts +0 -5
- package/dist/core/errors/map-error.js +0 -8
- package/dist/core/errors/map-error.js.map +0 -1
- package/dist/core/errors/retryability.d.ts +0 -3
- package/dist/core/errors/retryability.js +0 -8
- package/dist/core/errors/retryability.js.map +0 -1
- package/dist/core/execute/execute.d.ts +0 -28
- package/dist/core/execute/execute.js +0 -11
- package/dist/core/execute/execute.js.map +0 -1
- package/dist/core/execution/adapters/cli-adapter.d.ts +0 -22
- package/dist/core/execution/adapters/cli-adapter.js +0 -69
- package/dist/core/execution/adapters/cli-adapter.js.map +0 -1
- package/dist/core/execution/adapters/cli-capability-adapter.d.ts +0 -16
- package/dist/core/execution/adapters/cli-capability-adapter.js +0 -11
- package/dist/core/execution/adapters/cli-capability-adapter.js.map +0 -1
- package/dist/core/execution/adapters/graphql-adapter.d.ts +0 -25
- package/dist/core/execution/adapters/graphql-adapter.js +0 -44
- package/dist/core/execution/adapters/graphql-adapter.js.map +0 -1
- package/dist/core/execution/adapters/graphql-capability-adapter.d.ts +0 -20
- package/dist/core/execution/adapters/graphql-capability-adapter.js +0 -11
- package/dist/core/execution/adapters/graphql-capability-adapter.js.map +0 -1
- package/dist/core/execution/adapters/rest-adapter.d.ts +0 -3
- package/dist/core/execution/adapters/rest-adapter.js +0 -8
- package/dist/core/execution/adapters/rest-adapter.js.map +0 -1
- package/dist/core/execution/cli/safe-runner.d.ts +0 -12
- package/dist/core/execution/cli/safe-runner.js +0 -7
- package/dist/core/execution/cli/safe-runner.js.map +0 -1
- package/dist/core/execution/normalizer.d.ts +0 -13
- package/dist/core/execution/normalizer.js +0 -9
- package/dist/core/execution/normalizer.js.map +0 -1
- package/dist/core/execution/preflight.d.ts +0 -24
- package/dist/core/execution/preflight.js +0 -8
- package/dist/core/execution/preflight.js.map +0 -1
- package/dist/core/registry/index.d.ts +0 -15
- package/dist/core/registry/index.js +0 -12
- package/dist/core/registry/index.js.map +0 -1
- package/dist/core/registry/operation-card-schema.d.ts +0 -167
- package/dist/core/registry/operation-card-schema.js +0 -7
- package/dist/core/registry/operation-card-schema.js.map +0 -1
- package/dist/core/registry/schema-validator.d.ts +0 -16
- package/dist/core/registry/schema-validator.js +0 -9
- package/dist/core/registry/schema-validator.js.map +0 -1
- package/dist/core/registry/types.d.ts +0 -51
- package/dist/core/registry/types.js +0 -1
- package/dist/core/registry/types.js.map +0 -1
- package/dist/core/routing/capability-registry.d.ts +0 -8
- package/dist/core/routing/capability-registry.js +0 -15
- package/dist/core/routing/capability-registry.js.map +0 -1
- package/dist/core/routing/engine.d.ts +0 -32
- package/dist/core/routing/engine.js +0 -23
- package/dist/core/routing/engine.js.map +0 -1
- package/dist/core/routing/policy.d.ts +0 -3
- package/dist/core/routing/policy.js +0 -7
- package/dist/core/routing/policy.js.map +0 -1
- package/dist/core/routing/reason-codes.d.ts +0 -4
- package/dist/core/routing/reason-codes.js +0 -15
- package/dist/core/routing/reason-codes.js.map +0 -1
- package/dist/core/telemetry/logger.d.ts +0 -8
- package/dist/core/telemetry/logger.js +0 -9
- package/dist/core/telemetry/logger.js.map +0 -1
- package/dist/core/telemetry/metrics.d.ts +0 -7
- package/dist/core/telemetry/metrics.js +0 -1
- package/dist/core/telemetry/metrics.js.map +0 -1
- package/dist/gql/client.d.ts +0 -314
- package/dist/gql/client.js +0 -19
- package/dist/gql/client.js.map +0 -1
- package/dist/gql/generated/common-types.d.ts +0 -36
- package/dist/gql/generated/common-types.js +0 -1
- package/dist/gql/generated/common-types.js.map +0 -1
- package/dist/gql/operations/issue-assignees-update.generated.d.ts +0 -33
- package/dist/gql/operations/issue-assignees-update.generated.js +0 -28
- package/dist/gql/operations/issue-assignees-update.generated.js.map +0 -1
- package/dist/gql/operations/issue-blocked-by-add.generated.d.ts +0 -30
- package/dist/gql/operations/issue-blocked-by-add.generated.js +0 -26
- package/dist/gql/operations/issue-blocked-by-add.generated.js.map +0 -1
- package/dist/gql/operations/issue-blocked-by-remove.generated.d.ts +0 -30
- package/dist/gql/operations/issue-blocked-by-remove.generated.js +0 -26
- package/dist/gql/operations/issue-blocked-by-remove.generated.js.map +0 -1
- package/dist/gql/operations/issue-close.generated.d.ts +0 -27
- package/dist/gql/operations/issue-close.generated.js +0 -25
- package/dist/gql/operations/issue-close.generated.js.map +0 -1
- package/dist/gql/operations/issue-comment-create.generated.d.ts +0 -31
- package/dist/gql/operations/issue-comment-create.generated.js +0 -27
- package/dist/gql/operations/issue-comment-create.generated.js.map +0 -1
- package/dist/gql/operations/issue-comments-list.generated.d.ts +0 -59
- package/dist/gql/operations/issue-comments-list.generated.js +0 -9
- package/dist/gql/operations/issue-comments-list.generated.js.map +0 -1
- package/dist/gql/operations/issue-create.generated.d.ts +0 -31
- package/dist/gql/operations/issue-create.generated.js +0 -27
- package/dist/gql/operations/issue-create.generated.js.map +0 -1
- package/dist/gql/operations/issue-delete.generated.d.ts +0 -22
- package/dist/gql/operations/issue-delete.generated.js +0 -21
- package/dist/gql/operations/issue-delete.generated.js.map +0 -1
- package/dist/gql/operations/issue-labels-update.generated.d.ts +0 -33
- package/dist/gql/operations/issue-labels-update.generated.js +0 -28
- package/dist/gql/operations/issue-labels-update.generated.js.map +0 -1
- package/dist/gql/operations/issue-linked-prs-list.generated.d.ts +0 -132
- package/dist/gql/operations/issue-linked-prs-list.generated.js +0 -39
- package/dist/gql/operations/issue-linked-prs-list.generated.js.map +0 -1
- package/dist/gql/operations/issue-list.generated.d.ts +0 -40
- package/dist/gql/operations/issue-list.generated.js +0 -9
- package/dist/gql/operations/issue-list.generated.js.map +0 -1
- package/dist/gql/operations/issue-milestone-set.generated.d.ts +0 -30
- package/dist/gql/operations/issue-milestone-set.generated.js +0 -26
- package/dist/gql/operations/issue-milestone-set.generated.js.map +0 -1
- package/dist/gql/operations/issue-parent-remove.generated.d.ts +0 -30
- package/dist/gql/operations/issue-parent-remove.generated.js +0 -26
- package/dist/gql/operations/issue-parent-remove.generated.js.map +0 -1
- package/dist/gql/operations/issue-parent-set.generated.d.ts +0 -30
- package/dist/gql/operations/issue-parent-set.generated.js +0 -26
- package/dist/gql/operations/issue-parent-set.generated.js.map +0 -1
- package/dist/gql/operations/issue-relations-get.generated.d.ts +0 -49
- package/dist/gql/operations/issue-relations-get.generated.js +0 -40
- package/dist/gql/operations/issue-relations-get.generated.js.map +0 -1
- package/dist/gql/operations/issue-reopen.generated.d.ts +0 -27
- package/dist/gql/operations/issue-reopen.generated.js +0 -25
- package/dist/gql/operations/issue-reopen.generated.js.map +0 -1
- package/dist/gql/operations/issue-update.generated.d.ts +0 -31
- package/dist/gql/operations/issue-update.generated.js +0 -27
- package/dist/gql/operations/issue-update.generated.js.map +0 -1
- package/dist/gql/operations/issue-view.generated.d.ts +0 -31
- package/dist/gql/operations/issue-view.generated.js +0 -9
- package/dist/gql/operations/issue-view.generated.js.map +0 -1
- package/dist/gql/operations/pr-comment-reply.generated.d.ts +0 -26
- package/dist/gql/operations/pr-comment-reply.generated.js +0 -25
- package/dist/gql/operations/pr-comment-reply.generated.js.map +0 -1
- package/dist/gql/operations/pr-comment-resolve.generated.d.ts +0 -26
- package/dist/gql/operations/pr-comment-resolve.generated.js +0 -24
- package/dist/gql/operations/pr-comment-resolve.generated.js.map +0 -1
- package/dist/gql/operations/pr-comment-unresolve.generated.d.ts +0 -26
- package/dist/gql/operations/pr-comment-unresolve.generated.js +0 -24
- package/dist/gql/operations/pr-comment-unresolve.generated.js.map +0 -1
- package/dist/gql/operations/pr-comments-list.generated.d.ts +0 -84
- package/dist/gql/operations/pr-comments-list.generated.js +0 -58
- package/dist/gql/operations/pr-comments-list.generated.js.map +0 -1
- package/dist/gql/operations/pr-diff-list-files.generated.d.ts +0 -42
- package/dist/gql/operations/pr-diff-list-files.generated.js +0 -9
- package/dist/gql/operations/pr-diff-list-files.generated.js.map +0 -1
- package/dist/gql/operations/pr-list.generated.d.ts +0 -40
- package/dist/gql/operations/pr-list.generated.js +0 -9
- package/dist/gql/operations/pr-list.generated.js.map +0 -1
- package/dist/gql/operations/pr-reviews-list.generated.d.ts +0 -64
- package/dist/gql/operations/pr-reviews-list.generated.js +0 -9
- package/dist/gql/operations/pr-reviews-list.generated.js.map +0 -1
- package/dist/gql/operations/pr-view.generated.d.ts +0 -31
- package/dist/gql/operations/pr-view.generated.js +0 -9
- package/dist/gql/operations/pr-view.generated.js.map +0 -1
- package/dist/gql/operations/repo-view.generated.d.ts +0 -33
- package/dist/gql/operations/repo-view.generated.js +0 -9
- package/dist/gql/operations/repo-view.generated.js.map +0 -1
- package/dist/shared/constants.d.ts +0 -3
- package/dist/shared/constants.js +0 -6
- package/dist/shared/constants.js.map +0 -1
- package/dist/shared/types.d.ts +0 -3
- package/dist/shared/types.js +0 -1
- package/dist/shared/types.js.map +0 -1
- package/dist/shared/utils.d.ts +0 -3
- package/dist/shared/utils.js +0 -8
- package/dist/shared/utils.js.map +0 -1
|
@@ -1,14 +1,126 @@
|
|
|
1
|
-
import {
|
|
2
|
-
operationCardSchema
|
|
3
|
-
} from "./chunk-2W4L5YCC.js";
|
|
4
|
-
|
|
5
1
|
// src/core/registry/index.ts
|
|
6
2
|
import { readdirSync, readFileSync } from "fs";
|
|
7
3
|
import { dirname, extname, join } from "path";
|
|
8
4
|
import { fileURLToPath } from "url";
|
|
9
|
-
import Ajv from "ajv";
|
|
10
5
|
import { load as parseYaml } from "js-yaml";
|
|
6
|
+
|
|
7
|
+
// src/core/registry/ajv-instance.ts
|
|
8
|
+
import { Ajv } from "ajv";
|
|
11
9
|
var ajv = new Ajv({ allErrors: true, strict: false });
|
|
10
|
+
|
|
11
|
+
// src/core/registry/operation-card-schema.ts
|
|
12
|
+
var operationCardSchema = {
|
|
13
|
+
$id: "https://ghx.local/schemas/operation-card.json",
|
|
14
|
+
type: "object",
|
|
15
|
+
required: ["capability_id", "version", "description", "input_schema", "output_schema", "routing"],
|
|
16
|
+
properties: {
|
|
17
|
+
capability_id: { type: "string", minLength: 1 },
|
|
18
|
+
version: { type: "string", minLength: 1 },
|
|
19
|
+
description: { type: "string", minLength: 1 },
|
|
20
|
+
input_schema: { type: "object" },
|
|
21
|
+
output_schema: { type: "object" },
|
|
22
|
+
routing: {
|
|
23
|
+
type: "object",
|
|
24
|
+
required: ["preferred", "fallbacks"],
|
|
25
|
+
properties: {
|
|
26
|
+
preferred: { enum: ["cli", "graphql", "rest"] },
|
|
27
|
+
fallbacks: {
|
|
28
|
+
type: "array",
|
|
29
|
+
items: { enum: ["cli", "graphql", "rest"] }
|
|
30
|
+
},
|
|
31
|
+
suitability: {
|
|
32
|
+
type: "array",
|
|
33
|
+
items: {
|
|
34
|
+
type: "object",
|
|
35
|
+
required: ["when", "predicate", "reason"],
|
|
36
|
+
properties: {
|
|
37
|
+
when: { enum: ["always", "env", "params"] },
|
|
38
|
+
predicate: { type: "string", minLength: 1 },
|
|
39
|
+
reason: { type: "string", minLength: 1 }
|
|
40
|
+
},
|
|
41
|
+
additionalProperties: false
|
|
42
|
+
}
|
|
43
|
+
},
|
|
44
|
+
notes: {
|
|
45
|
+
type: "array",
|
|
46
|
+
items: { type: "string" }
|
|
47
|
+
}
|
|
48
|
+
},
|
|
49
|
+
additionalProperties: false
|
|
50
|
+
},
|
|
51
|
+
graphql: {
|
|
52
|
+
type: "object",
|
|
53
|
+
required: ["operationName", "documentPath"],
|
|
54
|
+
properties: {
|
|
55
|
+
operationName: { type: "string", minLength: 1 },
|
|
56
|
+
documentPath: { type: "string", minLength: 1 },
|
|
57
|
+
variables: { type: "object" },
|
|
58
|
+
limits: {
|
|
59
|
+
type: "object",
|
|
60
|
+
properties: {
|
|
61
|
+
maxPageSize: { type: "number" }
|
|
62
|
+
},
|
|
63
|
+
additionalProperties: false
|
|
64
|
+
}
|
|
65
|
+
},
|
|
66
|
+
additionalProperties: false
|
|
67
|
+
},
|
|
68
|
+
cli: {
|
|
69
|
+
type: "object",
|
|
70
|
+
required: ["command"],
|
|
71
|
+
properties: {
|
|
72
|
+
command: { type: "string", minLength: 1 },
|
|
73
|
+
jsonFields: {
|
|
74
|
+
type: "array",
|
|
75
|
+
items: { type: "string", minLength: 1 }
|
|
76
|
+
},
|
|
77
|
+
jq: { type: "string" },
|
|
78
|
+
limits: {
|
|
79
|
+
type: "object",
|
|
80
|
+
properties: {
|
|
81
|
+
maxItemsPerCall: { type: "number" }
|
|
82
|
+
},
|
|
83
|
+
additionalProperties: false
|
|
84
|
+
}
|
|
85
|
+
},
|
|
86
|
+
additionalProperties: false
|
|
87
|
+
},
|
|
88
|
+
rest: {
|
|
89
|
+
type: "object",
|
|
90
|
+
required: ["endpoints"],
|
|
91
|
+
properties: {
|
|
92
|
+
endpoints: {
|
|
93
|
+
type: "array",
|
|
94
|
+
items: {
|
|
95
|
+
type: "object",
|
|
96
|
+
required: ["method", "path"],
|
|
97
|
+
properties: {
|
|
98
|
+
method: { type: "string" },
|
|
99
|
+
path: { type: "string" }
|
|
100
|
+
},
|
|
101
|
+
additionalProperties: false
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
},
|
|
105
|
+
additionalProperties: false
|
|
106
|
+
},
|
|
107
|
+
examples: {
|
|
108
|
+
type: "array",
|
|
109
|
+
items: {
|
|
110
|
+
type: "object",
|
|
111
|
+
required: ["title", "input"],
|
|
112
|
+
properties: {
|
|
113
|
+
title: { type: "string" },
|
|
114
|
+
input: { type: "object" }
|
|
115
|
+
},
|
|
116
|
+
additionalProperties: false
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
},
|
|
120
|
+
additionalProperties: false
|
|
121
|
+
};
|
|
122
|
+
|
|
123
|
+
// src/core/registry/index.ts
|
|
12
124
|
var validateCard = ajv.compile(operationCardSchema);
|
|
13
125
|
function cardDirectory() {
|
|
14
126
|
const currentDir = dirname(fileURLToPath(import.meta.url));
|
|
@@ -126,8 +238,8 @@ function getOperationCard(capabilityId) {
|
|
|
126
238
|
}
|
|
127
239
|
|
|
128
240
|
export {
|
|
129
|
-
|
|
241
|
+
ajv,
|
|
130
242
|
listOperationCards,
|
|
131
243
|
getOperationCard
|
|
132
244
|
};
|
|
133
|
-
//# sourceMappingURL=chunk-
|
|
245
|
+
//# sourceMappingURL=chunk-UN5YHUNK.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/core/registry/index.ts","../src/core/registry/ajv-instance.ts","../src/core/registry/operation-card-schema.ts"],"sourcesContent":["import { readdirSync, readFileSync } from \"node:fs\"\nimport { dirname, extname, join } from \"node:path\"\nimport { fileURLToPath } from \"node:url\"\n\nimport { load as parseYaml } from \"js-yaml\"\nimport { ajv } from \"./ajv-instance.js\"\nimport { operationCardSchema } from \"./operation-card-schema.js\"\nimport type { OperationCard } from \"./types.js\"\n\nconst validateCard = ajv.compile(operationCardSchema)\n\nfunction cardDirectory(): string {\n const currentDir = dirname(fileURLToPath(import.meta.url))\n return join(currentDir, \"cards\")\n}\n\nfunction loadCardsFromYaml(): OperationCard[] {\n const directory = cardDirectory()\n const preferredOrder = [\n \"repo.view\",\n \"repo.labels.list\",\n \"repo.issue_types.list\",\n \"issue.view\",\n \"issue.list\",\n \"issue.comments.list\",\n \"issue.create\",\n \"issue.update\",\n \"issue.close\",\n \"issue.reopen\",\n \"issue.delete\",\n \"issue.labels.update\",\n \"issue.assignees.update\",\n \"issue.milestone.set\",\n \"issue.comments.create\",\n \"issue.linked_prs.list\",\n \"issue.relations.get\",\n \"issue.parent.set\",\n \"issue.parent.remove\",\n \"issue.blocked_by.add\",\n \"issue.blocked_by.remove\",\n \"pr.view\",\n \"pr.list\",\n \"pr.comments.list\",\n \"pr.reviews.list\",\n \"pr.diff.list_files\",\n \"pr.status.checks\",\n \"pr.checks.get_failed\",\n \"pr.mergeability.view\",\n \"pr.comment.reply\",\n \"pr.comment.resolve\",\n \"pr.comment.unresolve\",\n \"pr.ready_for_review.set\",\n \"pr.review.submit_approve\",\n \"pr.review.submit_request_changes\",\n \"pr.review.submit_comment\",\n \"pr.merge.execute\",\n \"pr.checks.rerun_failed\",\n \"pr.checks.rerun_all\",\n \"pr.reviewers.request\",\n \"pr.assignees.update\",\n \"pr.branch.update\",\n \"check_run.annotations.list\",\n \"workflow_runs.list\",\n \"workflow_run.jobs.list\",\n \"workflow_job.logs.get\",\n \"workflow_job.logs.analyze\",\n \"workflow.list\",\n \"workflow.get\",\n \"workflow_run.get\",\n \"workflow_run.rerun_all\",\n \"workflow_run.cancel\",\n \"workflow_run.artifacts.list\",\n \"project_v2.org.get\",\n \"project_v2.user.get\",\n \"project_v2.fields.list\",\n \"project_v2.items.list\",\n \"project_v2.item.add_issue\",\n \"project_v2.item.field.update\",\n \"release.list\",\n \"release.get\",\n \"release.create_draft\",\n \"release.update\",\n \"release.publish_draft\",\n \"workflow_dispatch.run\",\n \"workflow_run.rerun_failed\",\n ]\n const orderMap = new Map(preferredOrder.map((id, index) => [id, index]))\n\n const entries = readdirSync(directory)\n .filter((entry) => {\n const extension = extname(entry).toLowerCase()\n return extension === \".yaml\" || extension === \".yml\"\n })\n .sort((a, b) => {\n const capabilityA = a.replace(/\\.ya?ml$/i, \"\")\n const capabilityB = b.replace(/\\.ya?ml$/i, \"\")\n const orderA = orderMap.get(capabilityA) ?? Number.MAX_SAFE_INTEGER\n const orderB = orderMap.get(capabilityB) ?? Number.MAX_SAFE_INTEGER\n\n if (orderA !== orderB) {\n return orderA - orderB\n }\n\n return a.localeCompare(b)\n })\n\n return entries.map((entry): OperationCard => {\n const filePath = join(directory, entry)\n const raw = readFileSync(filePath, \"utf8\")\n const parsed = parseYaml(raw)\n const validation = validateOperationCard(parsed)\n if (!validation.ok) {\n throw new Error(`Invalid operation card '${entry}': ${validation.error}`)\n }\n\n return parsed as OperationCard\n })\n}\n\nexport function validateOperationCard(card: unknown): { ok: true } | { ok: false; error: string } {\n const valid = validateCard(card)\n if (!valid) {\n const message = validateCard.errors?.[0]?.message ?? \"Operation card schema validation failed\"\n return { ok: false, error: message }\n }\n\n return { ok: true }\n}\n\nconst operationCards = loadCardsFromYaml()\n\nexport function listOperationCards(): OperationCard[] {\n return [...operationCards]\n}\n\nexport function getOperationCard(capabilityId: string): OperationCard | undefined {\n return operationCards.find((card) => card.capability_id === capabilityId)\n}\n","import { Ajv } from \"ajv\"\n\nexport const ajv = new Ajv({ allErrors: true, strict: false })\n","export const operationCardSchema = {\n $id: \"https://ghx.local/schemas/operation-card.json\",\n type: \"object\",\n required: [\"capability_id\", \"version\", \"description\", \"input_schema\", \"output_schema\", \"routing\"],\n properties: {\n capability_id: { type: \"string\", minLength: 1 },\n version: { type: \"string\", minLength: 1 },\n description: { type: \"string\", minLength: 1 },\n input_schema: { type: \"object\" },\n output_schema: { type: \"object\" },\n routing: {\n type: \"object\",\n required: [\"preferred\", \"fallbacks\"],\n properties: {\n preferred: { enum: [\"cli\", \"graphql\", \"rest\"] },\n fallbacks: {\n type: \"array\",\n items: { enum: [\"cli\", \"graphql\", \"rest\"] },\n },\n suitability: {\n type: \"array\",\n items: {\n type: \"object\",\n required: [\"when\", \"predicate\", \"reason\"],\n properties: {\n when: { enum: [\"always\", \"env\", \"params\"] },\n predicate: { type: \"string\", minLength: 1 },\n reason: { type: \"string\", minLength: 1 },\n },\n additionalProperties: false,\n },\n },\n notes: {\n type: \"array\",\n items: { type: \"string\" },\n },\n },\n additionalProperties: false,\n },\n graphql: {\n type: \"object\",\n required: [\"operationName\", \"documentPath\"],\n properties: {\n operationName: { type: \"string\", minLength: 1 },\n documentPath: { type: \"string\", minLength: 1 },\n variables: { type: \"object\" },\n limits: {\n type: \"object\",\n properties: {\n maxPageSize: { type: \"number\" },\n },\n additionalProperties: false,\n },\n },\n additionalProperties: false,\n },\n cli: {\n type: \"object\",\n required: [\"command\"],\n properties: {\n command: { type: \"string\", minLength: 1 },\n jsonFields: {\n type: \"array\",\n items: { type: \"string\", minLength: 1 },\n },\n jq: { type: \"string\" },\n limits: {\n type: \"object\",\n properties: {\n maxItemsPerCall: { type: \"number\" },\n },\n additionalProperties: false,\n },\n },\n additionalProperties: false,\n },\n rest: {\n type: \"object\",\n required: [\"endpoints\"],\n properties: {\n endpoints: {\n type: \"array\",\n items: {\n type: \"object\",\n required: [\"method\", \"path\"],\n properties: {\n method: { type: \"string\" },\n path: { type: \"string\" },\n },\n additionalProperties: false,\n },\n },\n },\n additionalProperties: false,\n },\n examples: {\n type: \"array\",\n items: {\n type: \"object\",\n required: [\"title\", \"input\"],\n properties: {\n title: { type: \"string\" },\n input: { type: \"object\" },\n },\n additionalProperties: false,\n },\n },\n },\n additionalProperties: false,\n} as const\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
# ghx CLI Skill
|
|
2
|
+
|
|
3
|
+
Use `ghx` as the default interface for supported GitHub operations.
|
|
4
|
+
|
|
5
|
+
## Session Bootstrap (run once)
|
|
6
|
+
|
|
7
|
+
```bash
|
|
8
|
+
gh auth status
|
|
9
|
+
ghx capabilities list
|
|
10
|
+
```
|
|
11
|
+
|
|
12
|
+
If authentication fails, stop and request authentication before continuing.
|
|
13
|
+
|
|
14
|
+
## Workflow
|
|
15
|
+
|
|
16
|
+
1. Choose a capability from `ghx capabilities list`.
|
|
17
|
+
2. If required inputs are unclear, inspect the capability:
|
|
18
|
+
|
|
19
|
+
```bash
|
|
20
|
+
ghx capabilities explain <capability_id>
|
|
21
|
+
```
|
|
22
|
+
|
|
23
|
+
3. Execute with structured JSON input:
|
|
24
|
+
|
|
25
|
+
```bash
|
|
26
|
+
ghx run <capability_id> --input '<json>'
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
## Result Handling Rules
|
|
30
|
+
|
|
31
|
+
`ghx run` returns a result envelope: `{ ok, data, error, meta }`.
|
|
32
|
+
|
|
33
|
+
- Check `ok` first.
|
|
34
|
+
- If `ok=true`, use `data`.
|
|
35
|
+
- If `ok=false`, read `error.code` and `error.message`.
|
|
36
|
+
- If `error.retryable=true`, retry once.
|
|
37
|
+
- For supported operations, do not parse raw `gh` output.
|
|
38
|
+
|
|
39
|
+
## Input Conventions
|
|
40
|
+
|
|
41
|
+
- Repository identity is `owner` + `name`.
|
|
42
|
+
- Do not guess input fields; run `ghx capabilities explain <capability_id>`.
|
|
43
|
+
|
|
44
|
+
## Examples
|
|
45
|
+
|
|
46
|
+
```bash
|
|
47
|
+
ghx run repo.view --input '{"owner":"octocat","name":"hello-world"}'
|
|
48
|
+
ghx run issue.create --input '{"owner":"octocat","name":"hello-world","title":"Bug report","body":"Steps to reproduce"}'
|
|
49
|
+
ghx run pr.view --input '{"owner":"octocat","name":"hello-world","prNumber":42}'
|
|
50
|
+
ghx run pr.checks.get_failed --input '{"owner":"octocat","name":"hello-world","prNumber":42}'
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
## Guardrails
|
|
54
|
+
|
|
55
|
+
- Prefer `ghx` over direct `gh` or API calls for supported operations.
|
|
56
|
+
- Treat `meta.route_used` as informational only.
|
|
57
|
+
- If a required input is unknown, ask the user instead of guessing.
|
package/dist/cli/index.js
CHANGED
|
@@ -1,50 +1,382 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
import {
|
|
3
|
-
|
|
4
|
-
|
|
3
|
+
explainCapability,
|
|
4
|
+
listCapabilities
|
|
5
|
+
} from "../chunk-2FCPR3XZ.js";
|
|
5
6
|
import {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
import {
|
|
12
|
-
runCommand
|
|
13
|
-
} from "../chunk-22WWCK6A.js";
|
|
14
|
-
import "../chunk-4PLVKNCF.js";
|
|
15
|
-
import "../chunk-GMTG7X2L.js";
|
|
16
|
-
import "../chunk-SD7U4BNA.js";
|
|
17
|
-
import "../chunk-DLKIQBK6.js";
|
|
18
|
-
import "../chunk-SA2D4A5U.js";
|
|
19
|
-
import "../chunk-XNMM64WU.js";
|
|
20
|
-
import "../chunk-UGWIZ3RI.js";
|
|
21
|
-
import "../chunk-B6RLMKS4.js";
|
|
22
|
-
import "../chunk-573MDG3I.js";
|
|
23
|
-
import "../chunk-3MRJX72M.js";
|
|
24
|
-
import "../chunk-5JRLVOF2.js";
|
|
25
|
-
import "../chunk-W2TKG2UL.js";
|
|
26
|
-
import "../chunk-QEAMC4IJ.js";
|
|
27
|
-
import "../chunk-TDTKOJKN.js";
|
|
28
|
-
import "../chunk-UOJWOHRM.js";
|
|
29
|
-
import "../chunk-JH6GM6XU.js";
|
|
30
|
-
import "../chunk-2W4L5YCC.js";
|
|
31
|
-
import "../chunk-JLDU462R.js";
|
|
32
|
-
import "../chunk-EBRDO4Y6.js";
|
|
33
|
-
import "../chunk-RUQXGZ35.js";
|
|
34
|
-
import "../chunk-TCLMLVUQ.js";
|
|
35
|
-
import "../chunk-VD5NXQP7.js";
|
|
36
|
-
import "../chunk-NFF5VF4U.js";
|
|
37
|
-
import "../chunk-D746VR3B.js";
|
|
38
|
-
import "../chunk-W6ROKCY5.js";
|
|
39
|
-
import "../chunk-QZZC53HF.js";
|
|
7
|
+
createGithubClient,
|
|
8
|
+
errorCodes,
|
|
9
|
+
executeTask
|
|
10
|
+
} from "../chunk-RDUPMVHG.js";
|
|
11
|
+
import "../chunk-UN5YHUNK.js";
|
|
40
12
|
|
|
41
13
|
// src/cli/index.ts
|
|
42
14
|
import { realpathSync } from "fs";
|
|
43
15
|
import { pathToFileURL } from "url";
|
|
16
|
+
|
|
17
|
+
// src/cli/commands/capabilities-explain.ts
|
|
44
18
|
function usage() {
|
|
19
|
+
return "Usage: ghx capabilities explain <capability_id> [--json]";
|
|
20
|
+
}
|
|
21
|
+
function parseArgs(argv) {
|
|
22
|
+
const asJson = argv.includes("--json");
|
|
23
|
+
const capabilityId = argv.find((arg) => !arg.startsWith("-"));
|
|
24
|
+
return { capabilityId, asJson };
|
|
25
|
+
}
|
|
26
|
+
async function capabilitiesExplainCommand(argv = []) {
|
|
27
|
+
const { capabilityId, asJson } = parseArgs(argv);
|
|
28
|
+
if (!capabilityId) {
|
|
29
|
+
process.stderr.write(`${usage()}
|
|
30
|
+
`);
|
|
31
|
+
return 1;
|
|
32
|
+
}
|
|
33
|
+
try {
|
|
34
|
+
const explained = explainCapability(capabilityId);
|
|
35
|
+
if (asJson) {
|
|
36
|
+
process.stdout.write(`${JSON.stringify(explained)}
|
|
37
|
+
`);
|
|
38
|
+
return 0;
|
|
39
|
+
}
|
|
40
|
+
process.stdout.write(`${JSON.stringify(explained, null, 2)}
|
|
41
|
+
`);
|
|
42
|
+
return 0;
|
|
43
|
+
} catch (error) {
|
|
44
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
45
|
+
process.stderr.write(`${message}
|
|
46
|
+
`);
|
|
47
|
+
return 1;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
// src/cli/commands/capabilities-list.ts
|
|
52
|
+
function parseArgs2(argv) {
|
|
53
|
+
return {
|
|
54
|
+
asJson: argv.includes("--json")
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
async function capabilitiesListCommand(argv = []) {
|
|
58
|
+
const { asJson } = parseArgs2(argv);
|
|
59
|
+
const capabilities = listCapabilities();
|
|
60
|
+
if (asJson) {
|
|
61
|
+
process.stdout.write(`${JSON.stringify(capabilities)}
|
|
62
|
+
`);
|
|
63
|
+
return 0;
|
|
64
|
+
}
|
|
65
|
+
const lines = capabilities.map((item) => `${item.capability_id} - ${item.description}`);
|
|
66
|
+
process.stdout.write(`${lines.join("\n")}
|
|
67
|
+
`);
|
|
68
|
+
return 0;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
// src/cli/commands/run.ts
|
|
72
|
+
var GITHUB_GRAPHQL_ENDPOINT = "https://api.github.com/graphql";
|
|
73
|
+
function parseRunArgs(argv) {
|
|
74
|
+
const [task, ...rest] = argv;
|
|
75
|
+
if (!task || task.trim().length === 0) {
|
|
76
|
+
throw new Error("Usage: ghx run <task> --input '<json>' [--check-gh-preflight]");
|
|
77
|
+
}
|
|
78
|
+
const inputIndex = rest.findIndex((arg) => arg === "--input");
|
|
79
|
+
const inlineInput = rest.find((arg) => arg.startsWith("--input="));
|
|
80
|
+
const inputCandidate = inputIndex >= 0 ? rest[inputIndex + 1] : void 0;
|
|
81
|
+
const inputRaw = inputCandidate && !inputCandidate.startsWith("--") ? inputCandidate : inlineInput ? inlineInput.slice("--input=".length) : void 0;
|
|
82
|
+
if (!inputRaw) {
|
|
83
|
+
throw new Error("Missing --input JSON");
|
|
84
|
+
}
|
|
85
|
+
let parsed;
|
|
86
|
+
try {
|
|
87
|
+
parsed = JSON.parse(inputRaw);
|
|
88
|
+
} catch {
|
|
89
|
+
throw new Error("Invalid JSON for --input");
|
|
90
|
+
}
|
|
91
|
+
if (typeof parsed !== "object" || parsed === null || Array.isArray(parsed)) {
|
|
92
|
+
throw new Error("--input must be a JSON object");
|
|
93
|
+
}
|
|
94
|
+
const skipGhPreflight = !rest.includes("--check-gh-preflight");
|
|
95
|
+
return { task, input: parsed, skipGhPreflight };
|
|
96
|
+
}
|
|
97
|
+
function resolveGithubToken() {
|
|
98
|
+
const token = process.env.GITHUB_TOKEN ?? process.env.GH_TOKEN;
|
|
99
|
+
if (!token || token.trim().length === 0) {
|
|
100
|
+
throw new Error("Missing GITHUB_TOKEN or GH_TOKEN for GraphQL transport");
|
|
101
|
+
}
|
|
102
|
+
return token;
|
|
103
|
+
}
|
|
104
|
+
async function executeGraphqlRequest(token, query, variables) {
|
|
105
|
+
const response = await fetch(GITHUB_GRAPHQL_ENDPOINT, {
|
|
106
|
+
method: "POST",
|
|
107
|
+
headers: {
|
|
108
|
+
"content-type": "application/json",
|
|
109
|
+
accept: "application/json",
|
|
110
|
+
authorization: `Bearer ${token}`,
|
|
111
|
+
"user-agent": "ghx"
|
|
112
|
+
},
|
|
113
|
+
body: JSON.stringify({ query, variables: variables ?? {} })
|
|
114
|
+
});
|
|
115
|
+
const payload = await response.json();
|
|
116
|
+
if (!response.ok) {
|
|
117
|
+
const message = payload.message ?? `GitHub GraphQL request failed with status ${response.status}`;
|
|
118
|
+
throw new Error(message);
|
|
119
|
+
}
|
|
120
|
+
if (Array.isArray(payload.errors) && payload.errors.length > 0) {
|
|
121
|
+
const message = payload.errors[0]?.message ?? "GitHub GraphQL returned errors";
|
|
122
|
+
throw new Error(message);
|
|
123
|
+
}
|
|
124
|
+
if (payload.data === void 0) {
|
|
125
|
+
throw new Error("GitHub GraphQL response missing data");
|
|
126
|
+
}
|
|
127
|
+
return payload.data;
|
|
128
|
+
}
|
|
129
|
+
async function runCommand(argv = []) {
|
|
130
|
+
if (argv.length === 0) {
|
|
131
|
+
process.stdout.write("Usage: ghx run <task> --input '<json>' [--check-gh-preflight]\n");
|
|
132
|
+
return 1;
|
|
133
|
+
}
|
|
134
|
+
const { task, input, skipGhPreflight } = parseRunArgs(argv);
|
|
135
|
+
const githubToken = resolveGithubToken();
|
|
136
|
+
const githubClient = createGithubClient({
|
|
137
|
+
async execute(query, variables) {
|
|
138
|
+
return executeGraphqlRequest(githubToken, query, variables);
|
|
139
|
+
}
|
|
140
|
+
});
|
|
141
|
+
const request = {
|
|
142
|
+
task,
|
|
143
|
+
input
|
|
144
|
+
};
|
|
145
|
+
const result = await executeTask(request, {
|
|
146
|
+
githubClient,
|
|
147
|
+
githubToken,
|
|
148
|
+
skipGhPreflight
|
|
149
|
+
});
|
|
150
|
+
process.stdout.write(`${JSON.stringify(result)}
|
|
151
|
+
`);
|
|
152
|
+
return 0;
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
// src/cli/commands/setup.ts
|
|
156
|
+
import { access, appendFile, mkdir, readFile, writeFile } from "fs/promises";
|
|
157
|
+
import { homedir } from "os";
|
|
158
|
+
import { dirname, join } from "path";
|
|
159
|
+
import readline from "readline/promises";
|
|
160
|
+
import { fileURLToPath } from "url";
|
|
161
|
+
import { Ajv } from "ajv";
|
|
162
|
+
var ajv = new Ajv({ allErrors: true, strict: false });
|
|
163
|
+
var setupOptionsSchema = {
|
|
164
|
+
type: "object",
|
|
165
|
+
additionalProperties: false,
|
|
166
|
+
required: ["scope", "assumeYes", "dryRun", "verifyOnly", "track"],
|
|
167
|
+
properties: {
|
|
168
|
+
scope: {
|
|
169
|
+
type: "string",
|
|
170
|
+
enum: ["user", "project"]
|
|
171
|
+
},
|
|
172
|
+
assumeYes: { type: "boolean" },
|
|
173
|
+
dryRun: { type: "boolean" },
|
|
174
|
+
verifyOnly: { type: "boolean" },
|
|
175
|
+
track: { type: "boolean" }
|
|
176
|
+
}
|
|
177
|
+
};
|
|
178
|
+
var validateSetupOptions = ajv.compile(setupOptionsSchema);
|
|
179
|
+
var setupCommandDirectory = dirname(fileURLToPath(import.meta.url));
|
|
180
|
+
var setupSkillAssetPathCandidates = [
|
|
181
|
+
join(setupCommandDirectory, "..", "assets", "skills", "ghx", "SKILL.md"),
|
|
182
|
+
join(setupCommandDirectory, "assets", "skills", "ghx", "SKILL.md"),
|
|
183
|
+
join(setupCommandDirectory, "cli", "assets", "skills", "ghx", "SKILL.md")
|
|
184
|
+
];
|
|
185
|
+
function isENOENT(error) {
|
|
186
|
+
return typeof error === "object" && error !== null && "code" in error && error.code === "ENOENT";
|
|
187
|
+
}
|
|
188
|
+
function createSetupError(message, code) {
|
|
189
|
+
const error = new Error(message);
|
|
190
|
+
error.code = code;
|
|
191
|
+
return error;
|
|
192
|
+
}
|
|
193
|
+
async function loadSetupSkillContent() {
|
|
194
|
+
for (const candidatePath of setupSkillAssetPathCandidates) {
|
|
195
|
+
try {
|
|
196
|
+
return await readFile(candidatePath, "utf8");
|
|
197
|
+
} catch (error) {
|
|
198
|
+
if (isENOENT(error)) {
|
|
199
|
+
continue;
|
|
200
|
+
}
|
|
201
|
+
throw error;
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
throw createSetupError(
|
|
205
|
+
`Setup skill asset not found. Checked: ${setupSkillAssetPathCandidates.join(", ")}`,
|
|
206
|
+
errorCodes.NotFound
|
|
207
|
+
);
|
|
208
|
+
}
|
|
209
|
+
function usage2() {
|
|
210
|
+
return "Usage: ghx setup --scope <user|project> [--yes] [--dry-run] [--verify] [--track]";
|
|
211
|
+
}
|
|
212
|
+
function parseScope(argv) {
|
|
213
|
+
const inline = argv.find((arg) => arg.startsWith("--scope="));
|
|
214
|
+
if (inline) {
|
|
215
|
+
const raw = inline.slice("--scope=".length);
|
|
216
|
+
if (raw === "user" || raw === "project") {
|
|
217
|
+
return raw;
|
|
218
|
+
}
|
|
219
|
+
return void 0;
|
|
220
|
+
}
|
|
221
|
+
const scopeIndex = argv.findIndex((arg) => arg === "--scope");
|
|
222
|
+
if (scopeIndex < 0) {
|
|
223
|
+
return void 0;
|
|
224
|
+
}
|
|
225
|
+
const value = argv[scopeIndex + 1];
|
|
226
|
+
if (value === "user" || value === "project") {
|
|
227
|
+
return value;
|
|
228
|
+
}
|
|
229
|
+
return void 0;
|
|
230
|
+
}
|
|
231
|
+
function parseArgs3(argv) {
|
|
232
|
+
const scope = parseScope(argv);
|
|
233
|
+
if (!scope) {
|
|
234
|
+
return null;
|
|
235
|
+
}
|
|
236
|
+
const options = {
|
|
237
|
+
scope,
|
|
238
|
+
assumeYes: argv.includes("--yes"),
|
|
239
|
+
dryRun: argv.includes("--dry-run"),
|
|
240
|
+
verifyOnly: argv.includes("--verify"),
|
|
241
|
+
track: argv.includes("--track")
|
|
242
|
+
};
|
|
243
|
+
if (!validateSetupOptions(options)) {
|
|
244
|
+
return null;
|
|
245
|
+
}
|
|
246
|
+
return options;
|
|
247
|
+
}
|
|
248
|
+
function resolveSkillPath(scope) {
|
|
249
|
+
const base = scope === "user" ? homedir() : process.cwd();
|
|
250
|
+
return join(base, ".agents", "skills", "ghx", "SKILL.md");
|
|
251
|
+
}
|
|
252
|
+
function resolveTrackingPath() {
|
|
253
|
+
return join(homedir(), ".agents", "ghx", "setup-events.jsonl");
|
|
254
|
+
}
|
|
255
|
+
async function writeTrackingEvent(options) {
|
|
256
|
+
if (!options.track) {
|
|
257
|
+
return;
|
|
258
|
+
}
|
|
259
|
+
const trackingPath = resolveTrackingPath();
|
|
260
|
+
await mkdir(join(homedir(), ".agents", "ghx"), { recursive: true });
|
|
261
|
+
await appendFile(
|
|
262
|
+
trackingPath,
|
|
263
|
+
`${JSON.stringify({
|
|
264
|
+
command: "setup",
|
|
265
|
+
scope: options.scope,
|
|
266
|
+
mode: options.mode,
|
|
267
|
+
success: options.success,
|
|
268
|
+
timestamp: (/* @__PURE__ */ new Date()).toISOString()
|
|
269
|
+
})}
|
|
270
|
+
`,
|
|
271
|
+
"utf8"
|
|
272
|
+
);
|
|
273
|
+
}
|
|
274
|
+
async function confirmOverwrite(skillPath) {
|
|
275
|
+
if (!process.stdin.isTTY || !process.stdout.isTTY) {
|
|
276
|
+
return false;
|
|
277
|
+
}
|
|
278
|
+
const rl = readline.createInterface({
|
|
279
|
+
input: process.stdin,
|
|
280
|
+
output: process.stdout
|
|
281
|
+
});
|
|
282
|
+
try {
|
|
283
|
+
const answer = await rl.question(`Skill already exists at ${skillPath}. Overwrite? [y/N] `);
|
|
284
|
+
const normalized = answer.trim().toLowerCase();
|
|
285
|
+
return normalized === "y" || normalized === "yes";
|
|
286
|
+
} finally {
|
|
287
|
+
rl.close();
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
async function verifySkill(skillPath) {
|
|
291
|
+
try {
|
|
292
|
+
const content = await readFile(skillPath, "utf8");
|
|
293
|
+
return content.includes("ghx capabilities");
|
|
294
|
+
} catch (error) {
|
|
295
|
+
if (isENOENT(error)) {
|
|
296
|
+
return false;
|
|
297
|
+
}
|
|
298
|
+
throw error;
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
async function skillFileExists(skillPath) {
|
|
302
|
+
try {
|
|
303
|
+
await access(skillPath);
|
|
304
|
+
return true;
|
|
305
|
+
} catch (error) {
|
|
306
|
+
if (isENOENT(error)) {
|
|
307
|
+
return false;
|
|
308
|
+
}
|
|
309
|
+
throw error;
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
async function setupCommand(argv = []) {
|
|
313
|
+
const parsed = parseArgs3(argv);
|
|
314
|
+
if (!parsed) {
|
|
315
|
+
process.stderr.write(`${usage2()}
|
|
316
|
+
`);
|
|
317
|
+
return 1;
|
|
318
|
+
}
|
|
319
|
+
const skillPath = resolveSkillPath(parsed.scope);
|
|
320
|
+
try {
|
|
321
|
+
if (parsed.verifyOnly) {
|
|
322
|
+
const ok = await verifySkill(skillPath);
|
|
323
|
+
if (!ok) {
|
|
324
|
+
process.stderr.write(`Verify failed: skill not installed at ${skillPath}
|
|
325
|
+
`);
|
|
326
|
+
return 1;
|
|
327
|
+
}
|
|
328
|
+
process.stdout.write(`Verify passed: skill installed at ${skillPath}
|
|
329
|
+
`);
|
|
330
|
+
return 0;
|
|
331
|
+
}
|
|
332
|
+
if (parsed.dryRun) {
|
|
333
|
+
process.stdout.write(`Dry run: would write ${skillPath}
|
|
334
|
+
`);
|
|
335
|
+
return 0;
|
|
336
|
+
}
|
|
337
|
+
const alreadyExists = await skillFileExists(skillPath);
|
|
338
|
+
if (alreadyExists && !parsed.assumeYes) {
|
|
339
|
+
const approved = await confirmOverwrite(skillPath);
|
|
340
|
+
if (!approved) {
|
|
341
|
+
process.stderr.write(
|
|
342
|
+
`Skill already exists at ${skillPath}. Re-run with --yes or confirm overwrite interactively.
|
|
343
|
+
`
|
|
344
|
+
);
|
|
345
|
+
await writeTrackingEvent({
|
|
346
|
+
track: parsed.track,
|
|
347
|
+
scope: parsed.scope,
|
|
348
|
+
mode: "apply",
|
|
349
|
+
success: false
|
|
350
|
+
});
|
|
351
|
+
return 1;
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
const skillContent = await loadSetupSkillContent();
|
|
355
|
+
await mkdir(dirname(skillPath), { recursive: true });
|
|
356
|
+
await writeFile(skillPath, skillContent, "utf8");
|
|
357
|
+
process.stdout.write(`Setup complete: wrote ${skillPath}
|
|
358
|
+
`);
|
|
359
|
+
process.stdout.write("Try: ghx capabilities list\n");
|
|
360
|
+
await writeTrackingEvent({
|
|
361
|
+
track: parsed.track,
|
|
362
|
+
scope: parsed.scope,
|
|
363
|
+
mode: "apply",
|
|
364
|
+
success: true
|
|
365
|
+
});
|
|
366
|
+
return 0;
|
|
367
|
+
} catch (error) {
|
|
368
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
369
|
+
process.stderr.write(`Setup failed: ${message}
|
|
370
|
+
`);
|
|
371
|
+
return 1;
|
|
372
|
+
}
|
|
373
|
+
}
|
|
374
|
+
|
|
375
|
+
// src/cli/index.ts
|
|
376
|
+
function usage3() {
|
|
45
377
|
return [
|
|
46
378
|
"Usage:",
|
|
47
|
-
" ghx run <task> --input '<json>'",
|
|
379
|
+
" ghx run <task> --input '<json>' [--check-gh-preflight]",
|
|
48
380
|
" ghx setup --scope <user|project> [--yes] [--dry-run] [--verify] [--track]",
|
|
49
381
|
" ghx capabilities list",
|
|
50
382
|
" ghx capabilities explain <capability_id>"
|
|
@@ -53,7 +385,7 @@ function usage() {
|
|
|
53
385
|
async function main(argv = process.argv.slice(2)) {
|
|
54
386
|
const [command, ...rest] = argv;
|
|
55
387
|
if (!command || command === "--help" || command === "-h") {
|
|
56
|
-
process.stdout.write(`${
|
|
388
|
+
process.stdout.write(`${usage3()}
|
|
57
389
|
`);
|
|
58
390
|
return 0;
|
|
59
391
|
}
|
|
@@ -67,7 +399,7 @@ async function main(argv = process.argv.slice(2)) {
|
|
|
67
399
|
const [subcommand, ...subcommandArgs] = rest;
|
|
68
400
|
if (!subcommand) {
|
|
69
401
|
process.stderr.write(`Missing capabilities subcommand.
|
|
70
|
-
${
|
|
402
|
+
${usage3()}
|
|
71
403
|
`);
|
|
72
404
|
return 1;
|
|
73
405
|
}
|
|
@@ -78,12 +410,12 @@ ${usage()}
|
|
|
78
410
|
return capabilitiesExplainCommand(subcommandArgs);
|
|
79
411
|
}
|
|
80
412
|
process.stderr.write(`Unknown capabilities subcommand: ${subcommand}
|
|
81
|
-
${
|
|
413
|
+
${usage3()}
|
|
82
414
|
`);
|
|
83
415
|
return 1;
|
|
84
416
|
}
|
|
85
417
|
process.stderr.write(`Unknown command: ${command}
|
|
86
|
-
${
|
|
418
|
+
${usage3()}
|
|
87
419
|
`);
|
|
88
420
|
return 1;
|
|
89
421
|
}
|