@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
package/dist/index.js
CHANGED
|
@@ -1,38 +1,14 @@
|
|
|
1
1
|
import {
|
|
2
|
+
createGithubClient,
|
|
3
|
+
createGithubClientFromToken,
|
|
4
|
+
createGraphqlClient,
|
|
5
|
+
createSafeCliCommandRunner,
|
|
2
6
|
executeTask
|
|
3
|
-
} from "./chunk-
|
|
4
|
-
import {
|
|
5
|
-
createSafeCliCommandRunner
|
|
6
|
-
} from "./chunk-DLKIQBK6.js";
|
|
7
|
-
import "./chunk-SA2D4A5U.js";
|
|
8
|
-
import "./chunk-XNMM64WU.js";
|
|
9
|
-
import "./chunk-UGWIZ3RI.js";
|
|
10
|
-
import "./chunk-B6RLMKS4.js";
|
|
11
|
-
import "./chunk-573MDG3I.js";
|
|
12
|
-
import "./chunk-3MRJX72M.js";
|
|
13
|
-
import "./chunk-5JRLVOF2.js";
|
|
14
|
-
import "./chunk-W2TKG2UL.js";
|
|
15
|
-
import "./chunk-QEAMC4IJ.js";
|
|
16
|
-
import "./chunk-TDTKOJKN.js";
|
|
17
|
-
import "./chunk-UOJWOHRM.js";
|
|
7
|
+
} from "./chunk-RDUPMVHG.js";
|
|
18
8
|
import {
|
|
19
9
|
getOperationCard,
|
|
20
10
|
listOperationCards
|
|
21
|
-
} from "./chunk-
|
|
22
|
-
import "./chunk-2W4L5YCC.js";
|
|
23
|
-
import {
|
|
24
|
-
createGithubClient,
|
|
25
|
-
createGithubClientFromToken,
|
|
26
|
-
createGraphqlClient
|
|
27
|
-
} from "./chunk-JLDU462R.js";
|
|
28
|
-
import "./chunk-EBRDO4Y6.js";
|
|
29
|
-
import "./chunk-RUQXGZ35.js";
|
|
30
|
-
import "./chunk-TCLMLVUQ.js";
|
|
31
|
-
import "./chunk-VD5NXQP7.js";
|
|
32
|
-
import "./chunk-NFF5VF4U.js";
|
|
33
|
-
import "./chunk-D746VR3B.js";
|
|
34
|
-
import "./chunk-W6ROKCY5.js";
|
|
35
|
-
import "./chunk-QZZC53HF.js";
|
|
11
|
+
} from "./chunk-UN5YHUNK.js";
|
|
36
12
|
export {
|
|
37
13
|
createGithubClient,
|
|
38
14
|
createGithubClientFromToken,
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ghx-dev/core",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.2",
|
|
4
4
|
"description": "GitHub execution router for AI agents with deterministic routing and normalized output.",
|
|
5
5
|
"author": "Arye Kogan",
|
|
6
6
|
"license": "MIT",
|
|
@@ -56,12 +56,9 @@
|
|
|
56
56
|
},
|
|
57
57
|
"nx": {
|
|
58
58
|
"targets": {
|
|
59
|
-
"ci": {
|
|
59
|
+
"ci": {},
|
|
60
|
+
"ci:extra": {
|
|
60
61
|
"dependsOn": [
|
|
61
|
-
"lint",
|
|
62
|
-
"typecheck",
|
|
63
|
-
"test:coverage",
|
|
64
|
-
"build",
|
|
65
62
|
"gql:check"
|
|
66
63
|
]
|
|
67
64
|
},
|
|
@@ -69,20 +66,20 @@
|
|
|
69
66
|
}
|
|
70
67
|
},
|
|
71
68
|
"dependencies": {
|
|
72
|
-
"ajv": "^8.
|
|
69
|
+
"ajv": "^8.18.0",
|
|
73
70
|
"graphql": "^16.11.0",
|
|
74
71
|
"graphql-tag": "^2.12.6",
|
|
75
72
|
"graphql-request": "^7.3.1",
|
|
76
73
|
"js-yaml": "^4.1.0"
|
|
77
74
|
},
|
|
78
75
|
"devDependencies": {
|
|
79
|
-
"@opencode-ai/sdk": "^1.
|
|
76
|
+
"@opencode-ai/sdk": "^1.2.6",
|
|
80
77
|
"@vitest/coverage-v8": "^2.1.8",
|
|
81
|
-
"@graphql-codegen/cli": "^
|
|
82
|
-
"@graphql-codegen/near-operation-file-preset": "^
|
|
83
|
-
"@graphql-codegen/typescript": "^
|
|
78
|
+
"@graphql-codegen/cli": "^6.1.1",
|
|
79
|
+
"@graphql-codegen/near-operation-file-preset": "^4.0.0",
|
|
80
|
+
"@graphql-codegen/typescript": "^5.0.7",
|
|
84
81
|
"@graphql-codegen/typescript-graphql-request": "^6.3.0",
|
|
85
|
-
"@graphql-codegen/typescript-operations": "^
|
|
82
|
+
"@graphql-codegen/typescript-operations": "^5.0.7",
|
|
86
83
|
"@types/js-yaml": "^4.0.9",
|
|
87
84
|
"@types/node": "^25.2.3",
|
|
88
85
|
"tsup": "^8.5.0",
|
|
@@ -91,7 +88,9 @@
|
|
|
91
88
|
"vitest": "^2.1.8"
|
|
92
89
|
},
|
|
93
90
|
"scripts": {
|
|
94
|
-
"build": "tsup
|
|
91
|
+
"build": "tsup && node scripts/copy-registry-cards.mjs",
|
|
92
|
+
"format": "biome check --write .",
|
|
93
|
+
"format:check": "biome check .",
|
|
95
94
|
"lint": "eslint . --max-warnings=0",
|
|
96
95
|
"typecheck": "tsc --noEmit",
|
|
97
96
|
"test": "vitest run --project unit",
|
|
@@ -101,6 +100,6 @@
|
|
|
101
100
|
"test:e2e:sdk": "if [ -n \"$OPENAI_API_KEY\" ]; then vitest run --project e2e:sdk; else echo 'Skipping core SDK E2E: OPENAI_API_KEY not set'; fi",
|
|
102
101
|
"gql:codegen": "tsx scripts/run-gql-codegen.ts",
|
|
103
102
|
"gql:codegen:watch": "graphql-codegen --config codegen.ts --watch",
|
|
104
|
-
"gql:check": "pnpm run gql:codegen && git diff --exit-code -- src/gql/generated src/gql/operations/*.generated.ts"
|
|
103
|
+
"gql:check": "pnpm run gql:codegen && biome check --write --no-errors-on-unmatched src/gql/generated src/gql/operations && git diff --exit-code -- src/gql/generated src/gql/operations/*.generated.ts"
|
|
105
104
|
}
|
|
106
105
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { ResultEnvelope } from '../../core/contracts/envelope.js';
|
|
2
|
-
import '../../core/routing/reason-codes.js';
|
|
3
|
-
import '../../core/errors/codes.js';
|
|
4
|
-
|
|
5
|
-
type ExecuteTaskFn = (request: {
|
|
6
|
-
task: string;
|
|
7
|
-
input: Record<string, unknown>;
|
|
8
|
-
options?: Record<string, unknown>;
|
|
9
|
-
}) => Promise<ResultEnvelope>;
|
|
10
|
-
declare function createExecuteTool(deps: {
|
|
11
|
-
executeTask: ExecuteTaskFn;
|
|
12
|
-
}): {
|
|
13
|
-
execute(capabilityId: string, params: Record<string, unknown>, options?: Record<string, unknown>): Promise<ResultEnvelope>;
|
|
14
|
-
};
|
|
15
|
-
|
|
16
|
-
export { createExecuteTool };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
type CapabilityExplanation = {
|
|
2
|
-
capability_id: string;
|
|
3
|
-
purpose: string;
|
|
4
|
-
required_inputs: string[];
|
|
5
|
-
preferred_route: "cli" | "graphql" | "rest";
|
|
6
|
-
fallback_routes: Array<"cli" | "graphql" | "rest">;
|
|
7
|
-
output_fields: string[];
|
|
8
|
-
};
|
|
9
|
-
declare function explainCapability(capabilityId: string): CapabilityExplanation;
|
|
10
|
-
|
|
11
|
-
export { type CapabilityExplanation, explainCapability };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
package/dist/chunk-22WWCK6A.js
DELETED
|
@@ -1,92 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
executeTask
|
|
3
|
-
} from "./chunk-SD7U4BNA.js";
|
|
4
|
-
import {
|
|
5
|
-
createGithubClient
|
|
6
|
-
} from "./chunk-JLDU462R.js";
|
|
7
|
-
|
|
8
|
-
// src/cli/commands/run.ts
|
|
9
|
-
var GITHUB_GRAPHQL_ENDPOINT = "https://api.github.com/graphql";
|
|
10
|
-
function parseRunArgs(argv) {
|
|
11
|
-
const [task, ...rest] = argv;
|
|
12
|
-
if (!task || task.trim().length === 0) {
|
|
13
|
-
throw new Error("Usage: ghx run <task> --input '<json>'");
|
|
14
|
-
}
|
|
15
|
-
const inputIndex = rest.findIndex((arg) => arg === "--input");
|
|
16
|
-
const inlineInput = rest.find((arg) => arg.startsWith("--input="));
|
|
17
|
-
const inputRaw = inputIndex >= 0 ? rest[inputIndex + 1] : inlineInput ? inlineInput.slice("--input=".length) : void 0;
|
|
18
|
-
if (!inputRaw) {
|
|
19
|
-
throw new Error("Missing --input JSON");
|
|
20
|
-
}
|
|
21
|
-
let parsed;
|
|
22
|
-
try {
|
|
23
|
-
parsed = JSON.parse(inputRaw);
|
|
24
|
-
} catch {
|
|
25
|
-
throw new Error("Invalid JSON for --input");
|
|
26
|
-
}
|
|
27
|
-
if (typeof parsed !== "object" || parsed === null || Array.isArray(parsed)) {
|
|
28
|
-
throw new Error("--input must be a JSON object");
|
|
29
|
-
}
|
|
30
|
-
return { task, input: parsed };
|
|
31
|
-
}
|
|
32
|
-
function resolveGithubToken() {
|
|
33
|
-
const token = process.env.GITHUB_TOKEN ?? process.env.GH_TOKEN;
|
|
34
|
-
if (!token || token.trim().length === 0) {
|
|
35
|
-
throw new Error("Missing GITHUB_TOKEN or GH_TOKEN for GraphQL transport");
|
|
36
|
-
}
|
|
37
|
-
return token;
|
|
38
|
-
}
|
|
39
|
-
async function executeGraphqlRequest(token, query, variables) {
|
|
40
|
-
const response = await fetch(GITHUB_GRAPHQL_ENDPOINT, {
|
|
41
|
-
method: "POST",
|
|
42
|
-
headers: {
|
|
43
|
-
"content-type": "application/json",
|
|
44
|
-
accept: "application/json",
|
|
45
|
-
authorization: `Bearer ${token}`,
|
|
46
|
-
"user-agent": "ghx"
|
|
47
|
-
},
|
|
48
|
-
body: JSON.stringify({ query, variables: variables ?? {} })
|
|
49
|
-
});
|
|
50
|
-
const payload = await response.json();
|
|
51
|
-
if (!response.ok) {
|
|
52
|
-
const message = payload.message ?? `GitHub GraphQL request failed with status ${response.status}`;
|
|
53
|
-
throw new Error(message);
|
|
54
|
-
}
|
|
55
|
-
if (Array.isArray(payload.errors) && payload.errors.length > 0) {
|
|
56
|
-
const message = payload.errors[0]?.message ?? "GitHub GraphQL returned errors";
|
|
57
|
-
throw new Error(message);
|
|
58
|
-
}
|
|
59
|
-
if (payload.data === void 0) {
|
|
60
|
-
throw new Error("GitHub GraphQL response missing data");
|
|
61
|
-
}
|
|
62
|
-
return payload.data;
|
|
63
|
-
}
|
|
64
|
-
async function runCommand(argv = []) {
|
|
65
|
-
if (argv.length === 0) {
|
|
66
|
-
process.stdout.write("Usage: ghx run <task> --input '<json>'\n");
|
|
67
|
-
return 1;
|
|
68
|
-
}
|
|
69
|
-
const { task, input } = parseRunArgs(argv);
|
|
70
|
-
const githubToken = resolveGithubToken();
|
|
71
|
-
const githubClient = createGithubClient({
|
|
72
|
-
async execute(query, variables) {
|
|
73
|
-
return executeGraphqlRequest(githubToken, query, variables);
|
|
74
|
-
}
|
|
75
|
-
});
|
|
76
|
-
const request = {
|
|
77
|
-
task,
|
|
78
|
-
input
|
|
79
|
-
};
|
|
80
|
-
const result = await executeTask(request, {
|
|
81
|
-
githubClient,
|
|
82
|
-
githubToken
|
|
83
|
-
});
|
|
84
|
-
process.stdout.write(`${JSON.stringify(result)}
|
|
85
|
-
`);
|
|
86
|
-
return 0;
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
export {
|
|
90
|
-
runCommand
|
|
91
|
-
};
|
|
92
|
-
//# sourceMappingURL=chunk-22WWCK6A.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/cli/commands/run.ts"],"sourcesContent":["import { createGithubClient } from \"../../gql/client.js\"\nimport { executeTask } from \"../../core/routing/engine.js\"\nimport type { TaskRequest } from \"../../core/contracts/task.js\"\n\nconst GITHUB_GRAPHQL_ENDPOINT = \"https://api.github.com/graphql\"\n\nfunction parseRunArgs(argv: string[]): { task: string; input: Record<string, unknown> } {\n const [task, ...rest] = argv\n if (!task || task.trim().length === 0) {\n throw new Error(\"Usage: ghx run <task> --input '<json>'\")\n }\n\n const inputIndex = rest.findIndex((arg) => arg === \"--input\")\n const inlineInput = rest.find((arg) => arg.startsWith(\"--input=\"))\n const inputRaw =\n inputIndex >= 0\n ? rest[inputIndex + 1]\n : inlineInput\n ? inlineInput.slice(\"--input=\".length)\n : undefined\n\n if (!inputRaw) {\n throw new Error(\"Missing --input JSON\")\n }\n\n let parsed: unknown\n try {\n parsed = JSON.parse(inputRaw)\n } catch {\n throw new Error(\"Invalid JSON for --input\")\n }\n\n if (typeof parsed !== \"object\" || parsed === null || Array.isArray(parsed)) {\n throw new Error(\"--input must be a JSON object\")\n }\n\n return { task, input: parsed as Record<string, unknown> }\n}\n\nfunction resolveGithubToken(): string {\n const token = process.env.GITHUB_TOKEN ?? process.env.GH_TOKEN\n if (!token || token.trim().length === 0) {\n throw new Error(\"Missing GITHUB_TOKEN or GH_TOKEN for GraphQL transport\")\n }\n\n return token\n}\n\nasync function executeGraphqlRequest<TData>(\n token: string,\n query: string,\n variables?: Record<string, unknown>\n): Promise<TData> {\n const response = await fetch(GITHUB_GRAPHQL_ENDPOINT, {\n method: \"POST\",\n headers: {\n \"content-type\": \"application/json\",\n accept: \"application/json\",\n authorization: `Bearer ${token}`,\n \"user-agent\": \"ghx\"\n },\n body: JSON.stringify({ query, variables: variables ?? {} })\n })\n\n const payload = (await response.json()) as {\n data?: TData\n errors?: Array<{ message?: string }>\n message?: string\n }\n\n if (!response.ok) {\n const message = payload.message ?? `GitHub GraphQL request failed with status ${response.status}`\n throw new Error(message)\n }\n\n if (Array.isArray(payload.errors) && payload.errors.length > 0) {\n const message = payload.errors[0]?.message ?? \"GitHub GraphQL returned errors\"\n throw new Error(message)\n }\n\n if (payload.data === undefined) {\n throw new Error(\"GitHub GraphQL response missing data\")\n }\n\n return payload.data\n}\n\nexport async function runCommand(argv: string[] = []): Promise<number> {\n if (argv.length === 0) {\n process.stdout.write(\"Usage: ghx run <task> --input '<json>'\\n\")\n return 1\n }\n\n const { task, input } = parseRunArgs(argv)\n const githubToken = resolveGithubToken()\n\n const githubClient = createGithubClient({\n async execute<TData>(query: string, variables?: Record<string, unknown>): Promise<TData> {\n return executeGraphqlRequest<TData>(githubToken, query, variables)\n }\n })\n\n const request: TaskRequest = {\n task,\n input\n }\n\n const result = await executeTask(request, {\n githubClient,\n githubToken\n })\n\n process.stdout.write(`${JSON.stringify(result)}\\n`)\n return 0\n}\n"],"mappings":";;;;;;;;AAIA,IAAM,0BAA0B;AAEhC,SAAS,aAAa,MAAkE;AACtF,QAAM,CAAC,MAAM,GAAG,IAAI,IAAI;AACxB,MAAI,CAAC,QAAQ,KAAK,KAAK,EAAE,WAAW,GAAG;AACrC,UAAM,IAAI,MAAM,wCAAwC;AAAA,EAC1D;AAEA,QAAM,aAAa,KAAK,UAAU,CAAC,QAAQ,QAAQ,SAAS;AAC5D,QAAM,cAAc,KAAK,KAAK,CAAC,QAAQ,IAAI,WAAW,UAAU,CAAC;AACjE,QAAM,WACJ,cAAc,IACV,KAAK,aAAa,CAAC,IACnB,cACE,YAAY,MAAM,WAAW,MAAM,IACnC;AAER,MAAI,CAAC,UAAU;AACb,UAAM,IAAI,MAAM,sBAAsB;AAAA,EACxC;AAEA,MAAI;AACJ,MAAI;AACF,aAAS,KAAK,MAAM,QAAQ;AAAA,EAC9B,QAAQ;AACN,UAAM,IAAI,MAAM,0BAA0B;AAAA,EAC5C;AAEA,MAAI,OAAO,WAAW,YAAY,WAAW,QAAQ,MAAM,QAAQ,MAAM,GAAG;AAC1E,UAAM,IAAI,MAAM,+BAA+B;AAAA,EACjD;AAEA,SAAO,EAAE,MAAM,OAAO,OAAkC;AAC1D;AAEA,SAAS,qBAA6B;AACpC,QAAM,QAAQ,QAAQ,IAAI,gBAAgB,QAAQ,IAAI;AACtD,MAAI,CAAC,SAAS,MAAM,KAAK,EAAE,WAAW,GAAG;AACvC,UAAM,IAAI,MAAM,wDAAwD;AAAA,EAC1E;AAEA,SAAO;AACT;AAEA,eAAe,sBACb,OACA,OACA,WACgB;AAChB,QAAM,WAAW,MAAM,MAAM,yBAAyB;AAAA,IACpD,QAAQ;AAAA,IACR,SAAS;AAAA,MACP,gBAAgB;AAAA,MAChB,QAAQ;AAAA,MACR,eAAe,UAAU,KAAK;AAAA,MAC9B,cAAc;AAAA,IAChB;AAAA,IACA,MAAM,KAAK,UAAU,EAAE,OAAO,WAAW,aAAa,CAAC,EAAE,CAAC;AAAA,EAC5D,CAAC;AAED,QAAM,UAAW,MAAM,SAAS,KAAK;AAMrC,MAAI,CAAC,SAAS,IAAI;AAChB,UAAM,UAAU,QAAQ,WAAW,6CAA6C,SAAS,MAAM;AAC/F,UAAM,IAAI,MAAM,OAAO;AAAA,EACzB;AAEA,MAAI,MAAM,QAAQ,QAAQ,MAAM,KAAK,QAAQ,OAAO,SAAS,GAAG;AAC9D,UAAM,UAAU,QAAQ,OAAO,CAAC,GAAG,WAAW;AAC9C,UAAM,IAAI,MAAM,OAAO;AAAA,EACzB;AAEA,MAAI,QAAQ,SAAS,QAAW;AAC9B,UAAM,IAAI,MAAM,sCAAsC;AAAA,EACxD;AAEA,SAAO,QAAQ;AACjB;AAEA,eAAsB,WAAW,OAAiB,CAAC,GAAoB;AACrE,MAAI,KAAK,WAAW,GAAG;AACrB,YAAQ,OAAO,MAAM,0CAA0C;AAC/D,WAAO;AAAA,EACT;AAEA,QAAM,EAAE,MAAM,MAAM,IAAI,aAAa,IAAI;AACzC,QAAM,cAAc,mBAAmB;AAEvC,QAAM,eAAe,mBAAmB;AAAA,IACtC,MAAM,QAAe,OAAe,WAAqD;AACvF,aAAO,sBAA6B,aAAa,OAAO,SAAS;AAAA,IACnE;AAAA,EACF,CAAC;AAED,QAAM,UAAuB;AAAA,IAC3B;AAAA,IACA;AAAA,EACF;AAEA,QAAM,SAAS,MAAM,YAAY,SAAS;AAAA,IACxC;AAAA,IACA;AAAA,EACF,CAAC;AAED,UAAQ,OAAO,MAAM,GAAG,KAAK,UAAU,MAAM,CAAC;AAAA,CAAI;AAClD,SAAO;AACT;","names":[]}
|
package/dist/chunk-2W4L5YCC.js
DELETED
|
@@ -1,116 +0,0 @@
|
|
|
1
|
-
// src/core/registry/operation-card-schema.ts
|
|
2
|
-
var operationCardSchema = {
|
|
3
|
-
$id: "https://ghx.local/schemas/operation-card.json",
|
|
4
|
-
type: "object",
|
|
5
|
-
required: ["capability_id", "version", "description", "input_schema", "output_schema", "routing"],
|
|
6
|
-
properties: {
|
|
7
|
-
capability_id: { type: "string", minLength: 1 },
|
|
8
|
-
version: { type: "string", minLength: 1 },
|
|
9
|
-
description: { type: "string", minLength: 1 },
|
|
10
|
-
input_schema: { type: "object" },
|
|
11
|
-
output_schema: { type: "object" },
|
|
12
|
-
routing: {
|
|
13
|
-
type: "object",
|
|
14
|
-
required: ["preferred", "fallbacks"],
|
|
15
|
-
properties: {
|
|
16
|
-
preferred: { enum: ["cli", "graphql", "rest"] },
|
|
17
|
-
fallbacks: {
|
|
18
|
-
type: "array",
|
|
19
|
-
items: { enum: ["cli", "graphql", "rest"] }
|
|
20
|
-
},
|
|
21
|
-
suitability: {
|
|
22
|
-
type: "array",
|
|
23
|
-
items: {
|
|
24
|
-
type: "object",
|
|
25
|
-
required: ["when", "predicate", "reason"],
|
|
26
|
-
properties: {
|
|
27
|
-
when: { enum: ["always", "env", "params"] },
|
|
28
|
-
predicate: { type: "string", minLength: 1 },
|
|
29
|
-
reason: { type: "string", minLength: 1 }
|
|
30
|
-
},
|
|
31
|
-
additionalProperties: false
|
|
32
|
-
}
|
|
33
|
-
},
|
|
34
|
-
notes: {
|
|
35
|
-
type: "array",
|
|
36
|
-
items: { type: "string" }
|
|
37
|
-
}
|
|
38
|
-
},
|
|
39
|
-
additionalProperties: false
|
|
40
|
-
},
|
|
41
|
-
graphql: {
|
|
42
|
-
type: "object",
|
|
43
|
-
required: ["operationName", "documentPath"],
|
|
44
|
-
properties: {
|
|
45
|
-
operationName: { type: "string", minLength: 1 },
|
|
46
|
-
documentPath: { type: "string", minLength: 1 },
|
|
47
|
-
variables: { type: "object" },
|
|
48
|
-
limits: {
|
|
49
|
-
type: "object",
|
|
50
|
-
properties: {
|
|
51
|
-
maxPageSize: { type: "number" }
|
|
52
|
-
},
|
|
53
|
-
additionalProperties: false
|
|
54
|
-
}
|
|
55
|
-
},
|
|
56
|
-
additionalProperties: false
|
|
57
|
-
},
|
|
58
|
-
cli: {
|
|
59
|
-
type: "object",
|
|
60
|
-
required: ["command"],
|
|
61
|
-
properties: {
|
|
62
|
-
command: { type: "string", minLength: 1 },
|
|
63
|
-
jsonFields: {
|
|
64
|
-
type: "array",
|
|
65
|
-
items: { type: "string", minLength: 1 }
|
|
66
|
-
},
|
|
67
|
-
jq: { type: "string" },
|
|
68
|
-
limits: {
|
|
69
|
-
type: "object",
|
|
70
|
-
properties: {
|
|
71
|
-
maxItemsPerCall: { type: "number" }
|
|
72
|
-
},
|
|
73
|
-
additionalProperties: false
|
|
74
|
-
}
|
|
75
|
-
},
|
|
76
|
-
additionalProperties: false
|
|
77
|
-
},
|
|
78
|
-
rest: {
|
|
79
|
-
type: "object",
|
|
80
|
-
required: ["endpoints"],
|
|
81
|
-
properties: {
|
|
82
|
-
endpoints: {
|
|
83
|
-
type: "array",
|
|
84
|
-
items: {
|
|
85
|
-
type: "object",
|
|
86
|
-
required: ["method", "path"],
|
|
87
|
-
properties: {
|
|
88
|
-
method: { type: "string" },
|
|
89
|
-
path: { type: "string" }
|
|
90
|
-
},
|
|
91
|
-
additionalProperties: false
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
},
|
|
95
|
-
additionalProperties: false
|
|
96
|
-
},
|
|
97
|
-
examples: {
|
|
98
|
-
type: "array",
|
|
99
|
-
items: {
|
|
100
|
-
type: "object",
|
|
101
|
-
required: ["title", "input"],
|
|
102
|
-
properties: {
|
|
103
|
-
title: { type: "string" },
|
|
104
|
-
input: { type: "object" }
|
|
105
|
-
},
|
|
106
|
-
additionalProperties: false
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
},
|
|
110
|
-
additionalProperties: false
|
|
111
|
-
};
|
|
112
|
-
|
|
113
|
-
export {
|
|
114
|
-
operationCardSchema
|
|
115
|
-
};
|
|
116
|
-
//# sourceMappingURL=chunk-2W4L5YCC.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/core/registry/operation-card-schema.ts"],"sourcesContent":["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":";AAAO,IAAM,sBAAsB;AAAA,EACjC,KAAK;AAAA,EACL,MAAM;AAAA,EACN,UAAU,CAAC,iBAAiB,WAAW,eAAe,gBAAgB,iBAAiB,SAAS;AAAA,EAChG,YAAY;AAAA,IACV,eAAe,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,IAC9C,SAAS,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,IACxC,aAAa,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,IAC5C,cAAc,EAAE,MAAM,SAAS;AAAA,IAC/B,eAAe,EAAE,MAAM,SAAS;AAAA,IAChC,SAAS;AAAA,MACP,MAAM;AAAA,MACN,UAAU,CAAC,aAAa,WAAW;AAAA,MACnC,YAAY;AAAA,QACV,WAAW,EAAE,MAAM,CAAC,OAAO,WAAW,MAAM,EAAE;AAAA,QAC9C,WAAW;AAAA,UACT,MAAM;AAAA,UACN,OAAO,EAAE,MAAM,CAAC,OAAO,WAAW,MAAM,EAAE;AAAA,QAC5C;AAAA,QACA,aAAa;AAAA,UACX,MAAM;AAAA,UACN,OAAO;AAAA,YACL,MAAM;AAAA,YACN,UAAU,CAAC,QAAQ,aAAa,QAAQ;AAAA,YACxC,YAAY;AAAA,cACV,MAAM,EAAE,MAAM,CAAC,UAAU,OAAO,QAAQ,EAAE;AAAA,cAC1C,WAAW,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,cAC1C,QAAQ,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,YACzC;AAAA,YACA,sBAAsB;AAAA,UACxB;AAAA,QACF;AAAA,QACA,OAAO;AAAA,UACL,MAAM;AAAA,UACN,OAAO,EAAE,MAAM,SAAS;AAAA,QAC1B;AAAA,MACF;AAAA,MACA,sBAAsB;AAAA,IACxB;AAAA,IACA,SAAS;AAAA,MACP,MAAM;AAAA,MACN,UAAU,CAAC,iBAAiB,cAAc;AAAA,MAC1C,YAAY;AAAA,QACV,eAAe,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,QAC9C,cAAc,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,QAC7C,WAAW,EAAE,MAAM,SAAS;AAAA,QAC5B,QAAQ;AAAA,UACN,MAAM;AAAA,UACN,YAAY;AAAA,YACV,aAAa,EAAE,MAAM,SAAS;AAAA,UAChC;AAAA,UACA,sBAAsB;AAAA,QACxB;AAAA,MACF;AAAA,MACA,sBAAsB;AAAA,IACxB;AAAA,IACA,KAAK;AAAA,MACH,MAAM;AAAA,MACN,UAAU,CAAC,SAAS;AAAA,MACpB,YAAY;AAAA,QACV,SAAS,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,QACxC,YAAY;AAAA,UACV,MAAM;AAAA,UACN,OAAO,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,QACxC;AAAA,QACA,IAAI,EAAE,MAAM,SAAS;AAAA,QACrB,QAAQ;AAAA,UACN,MAAM;AAAA,UACN,YAAY;AAAA,YACV,iBAAiB,EAAE,MAAM,SAAS;AAAA,UACpC;AAAA,UACA,sBAAsB;AAAA,QACxB;AAAA,MACF;AAAA,MACA,sBAAsB;AAAA,IACxB;AAAA,IACA,MAAM;AAAA,MACJ,MAAM;AAAA,MACN,UAAU,CAAC,WAAW;AAAA,MACtB,YAAY;AAAA,QACV,WAAW;AAAA,UACT,MAAM;AAAA,UACN,OAAO;AAAA,YACL,MAAM;AAAA,YACN,UAAU,CAAC,UAAU,MAAM;AAAA,YAC3B,YAAY;AAAA,cACV,QAAQ,EAAE,MAAM,SAAS;AAAA,cACzB,MAAM,EAAE,MAAM,SAAS;AAAA,YACzB;AAAA,YACA,sBAAsB;AAAA,UACxB;AAAA,QACF;AAAA,MACF;AAAA,MACA,sBAAsB;AAAA,IACxB;AAAA,IACA,UAAU;AAAA,MACR,MAAM;AAAA,MACN,OAAO;AAAA,QACL,MAAM;AAAA,QACN,UAAU,CAAC,SAAS,OAAO;AAAA,QAC3B,YAAY;AAAA,UACV,OAAO,EAAE,MAAM,SAAS;AAAA,UACxB,OAAO,EAAE,MAAM,SAAS;AAAA,QAC1B;AAAA,QACA,sBAAsB;AAAA,MACxB;AAAA,IACF;AAAA,EACF;AAAA,EACA,sBAAsB;AACxB;","names":[]}
|
package/dist/chunk-3MRJX72M.js
DELETED
|
@@ -1,209 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
validateInput,
|
|
3
|
-
validateOutput
|
|
4
|
-
} from "./chunk-5JRLVOF2.js";
|
|
5
|
-
import {
|
|
6
|
-
logMetric
|
|
7
|
-
} from "./chunk-W2TKG2UL.js";
|
|
8
|
-
import {
|
|
9
|
-
normalizeError
|
|
10
|
-
} from "./chunk-QEAMC4IJ.js";
|
|
11
|
-
import {
|
|
12
|
-
errorCodes
|
|
13
|
-
} from "./chunk-UOJWOHRM.js";
|
|
14
|
-
|
|
15
|
-
// src/core/execute/execute.ts
|
|
16
|
-
function parsePredicateValue(raw) {
|
|
17
|
-
const value = raw.trim();
|
|
18
|
-
if (value === "true") {
|
|
19
|
-
return true;
|
|
20
|
-
}
|
|
21
|
-
if (value === "false") {
|
|
22
|
-
return false;
|
|
23
|
-
}
|
|
24
|
-
if (value === "null") {
|
|
25
|
-
return null;
|
|
26
|
-
}
|
|
27
|
-
const numeric = Number(value);
|
|
28
|
-
if (!Number.isNaN(numeric) && value.length > 0) {
|
|
29
|
-
return numeric;
|
|
30
|
-
}
|
|
31
|
-
return value.replace(/^['"]|['"]$/g, "");
|
|
32
|
-
}
|
|
33
|
-
function resolvePathValue(source, path) {
|
|
34
|
-
const segments = path.split(".").filter((segment) => segment.length > 0);
|
|
35
|
-
let current = source;
|
|
36
|
-
for (const segment of segments) {
|
|
37
|
-
if (typeof current !== "object" || current === null || Array.isArray(current)) {
|
|
38
|
-
return void 0;
|
|
39
|
-
}
|
|
40
|
-
current = current[segment];
|
|
41
|
-
}
|
|
42
|
-
return current;
|
|
43
|
-
}
|
|
44
|
-
function evaluateSuitabilityPreferred(card, params, routingContext) {
|
|
45
|
-
const rules = card.routing.suitability ?? [];
|
|
46
|
-
for (const rule of rules) {
|
|
47
|
-
const alwaysMatch = /^(cli|graphql|rest)$/i.exec(rule.predicate.trim());
|
|
48
|
-
const alwaysRoute = alwaysMatch?.[1];
|
|
49
|
-
if (rule.when === "always" && alwaysRoute) {
|
|
50
|
-
return alwaysRoute.toLowerCase();
|
|
51
|
-
}
|
|
52
|
-
const conditionalMatch = /^(cli|graphql|rest)\s+if\s+([a-zA-Z0-9_.]+)\s*(==|!=)\s*(.+)$/i.exec(
|
|
53
|
-
rule.predicate.trim()
|
|
54
|
-
);
|
|
55
|
-
if (!conditionalMatch) {
|
|
56
|
-
continue;
|
|
57
|
-
}
|
|
58
|
-
const [, targetRouteRaw = "", rawPath = "", operator = "==", rawExpected = ""] = conditionalMatch;
|
|
59
|
-
const targetRoute = targetRouteRaw.toLowerCase();
|
|
60
|
-
const source = rule.when === "env" ? routingContext : params;
|
|
61
|
-
const path = rawPath.startsWith("params.") || rawPath.startsWith("env.") ? rawPath.split(".").slice(1).join(".") : rawPath;
|
|
62
|
-
const actual = resolvePathValue(source, path);
|
|
63
|
-
const expected = parsePredicateValue(rawExpected);
|
|
64
|
-
const matches = operator === "==" ? actual === expected : actual !== expected;
|
|
65
|
-
if (matches) {
|
|
66
|
-
return targetRoute;
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
return card.routing.preferred;
|
|
70
|
-
}
|
|
71
|
-
function routePlan(card, params, routingContext) {
|
|
72
|
-
const preferred = evaluateSuitabilityPreferred(card, params, routingContext);
|
|
73
|
-
const planned = /* @__PURE__ */ new Set([preferred, ...card.routing.fallbacks]);
|
|
74
|
-
return [...planned];
|
|
75
|
-
}
|
|
76
|
-
async function execute(options) {
|
|
77
|
-
const inputValidation = validateInput(options.card.input_schema, options.params);
|
|
78
|
-
if (!inputValidation.ok) {
|
|
79
|
-
return normalizeError(
|
|
80
|
-
{
|
|
81
|
-
code: errorCodes.Validation,
|
|
82
|
-
message: "Input schema validation failed",
|
|
83
|
-
retryable: false,
|
|
84
|
-
details: { ajvErrors: inputValidation.errors }
|
|
85
|
-
},
|
|
86
|
-
options.card.routing.preferred,
|
|
87
|
-
{
|
|
88
|
-
capabilityId: options.card.capability_id,
|
|
89
|
-
reason: "INPUT_VALIDATION"
|
|
90
|
-
}
|
|
91
|
-
);
|
|
92
|
-
}
|
|
93
|
-
const attempts = [];
|
|
94
|
-
const maxAttemptsPerRoute = Math.max(1, options.retry?.maxAttemptsPerRoute ?? 1);
|
|
95
|
-
let lastError;
|
|
96
|
-
let firstError;
|
|
97
|
-
const routingContext = options.routingContext ?? {};
|
|
98
|
-
for (const route of routePlan(options.card, options.params, routingContext)) {
|
|
99
|
-
logMetric("route.plan", 1, {
|
|
100
|
-
capability_id: options.card.capability_id,
|
|
101
|
-
route
|
|
102
|
-
});
|
|
103
|
-
const preflight = await options.preflight(route);
|
|
104
|
-
if (!preflight.ok) {
|
|
105
|
-
logMetric("route.preflight_skipped", 1, {
|
|
106
|
-
capability_id: options.card.capability_id,
|
|
107
|
-
route,
|
|
108
|
-
error_code: preflight.code
|
|
109
|
-
});
|
|
110
|
-
attempts.push({ route, status: "skipped", error_code: preflight.code });
|
|
111
|
-
lastError = {
|
|
112
|
-
code: preflight.code,
|
|
113
|
-
message: preflight.message,
|
|
114
|
-
retryable: preflight.retryable,
|
|
115
|
-
...preflight.details ? { details: preflight.details } : {}
|
|
116
|
-
};
|
|
117
|
-
firstError ??= lastError;
|
|
118
|
-
continue;
|
|
119
|
-
}
|
|
120
|
-
const routeHandler = options.routes[route];
|
|
121
|
-
if (typeof routeHandler !== "function") {
|
|
122
|
-
logMetric("route.missing_handler", 1, {
|
|
123
|
-
capability_id: options.card.capability_id,
|
|
124
|
-
route
|
|
125
|
-
});
|
|
126
|
-
const handlerError = {
|
|
127
|
-
code: errorCodes.AdapterUnsupported,
|
|
128
|
-
message: `No route handler configured for '${route}'`,
|
|
129
|
-
retryable: false,
|
|
130
|
-
details: { route }
|
|
131
|
-
};
|
|
132
|
-
attempts.push({ route, status: "skipped", error_code: errorCodes.AdapterUnsupported });
|
|
133
|
-
lastError = handlerError;
|
|
134
|
-
firstError ??= handlerError;
|
|
135
|
-
continue;
|
|
136
|
-
}
|
|
137
|
-
for (let attempt = 0; attempt < maxAttemptsPerRoute; attempt += 1) {
|
|
138
|
-
const result = await routeHandler(options.params);
|
|
139
|
-
logMetric("route.attempt", 1, {
|
|
140
|
-
capability_id: options.card.capability_id,
|
|
141
|
-
route,
|
|
142
|
-
ok: result.ok
|
|
143
|
-
});
|
|
144
|
-
const attemptRecord = {
|
|
145
|
-
route,
|
|
146
|
-
status: result.ok ? "success" : "error"
|
|
147
|
-
};
|
|
148
|
-
if (result.error?.code) {
|
|
149
|
-
attemptRecord.error_code = result.error.code;
|
|
150
|
-
}
|
|
151
|
-
attempts.push(attemptRecord);
|
|
152
|
-
if (result.ok) {
|
|
153
|
-
const outputValidation = validateOutput(options.card.output_schema, result.data);
|
|
154
|
-
if (!outputValidation.ok) {
|
|
155
|
-
const envelope2 = normalizeError(
|
|
156
|
-
{
|
|
157
|
-
code: errorCodes.Server,
|
|
158
|
-
message: "Output schema validation failed",
|
|
159
|
-
retryable: false,
|
|
160
|
-
details: { ajvErrors: outputValidation.errors }
|
|
161
|
-
},
|
|
162
|
-
route,
|
|
163
|
-
{
|
|
164
|
-
capabilityId: options.card.capability_id,
|
|
165
|
-
reason: "OUTPUT_VALIDATION"
|
|
166
|
-
}
|
|
167
|
-
);
|
|
168
|
-
if (options.trace) {
|
|
169
|
-
envelope2.meta.attempts = attempts;
|
|
170
|
-
}
|
|
171
|
-
return envelope2;
|
|
172
|
-
}
|
|
173
|
-
if (options.trace) {
|
|
174
|
-
result.meta.attempts = attempts;
|
|
175
|
-
}
|
|
176
|
-
return result;
|
|
177
|
-
}
|
|
178
|
-
lastError = result.error;
|
|
179
|
-
firstError ??= result.error;
|
|
180
|
-
if (!result.error?.retryable) {
|
|
181
|
-
if (result.error?.code !== errorCodes.AdapterUnsupported) {
|
|
182
|
-
if (options.trace) {
|
|
183
|
-
result.meta.attempts = attempts;
|
|
184
|
-
}
|
|
185
|
-
return result;
|
|
186
|
-
}
|
|
187
|
-
break;
|
|
188
|
-
}
|
|
189
|
-
}
|
|
190
|
-
}
|
|
191
|
-
const finalError = lastError ?? firstError ?? {
|
|
192
|
-
code: errorCodes.Unknown,
|
|
193
|
-
message: "No route produced a result",
|
|
194
|
-
retryable: false
|
|
195
|
-
};
|
|
196
|
-
const envelope = normalizeError(finalError, options.card.routing.preferred, {
|
|
197
|
-
capabilityId: options.card.capability_id,
|
|
198
|
-
reason: "CARD_FALLBACK"
|
|
199
|
-
});
|
|
200
|
-
if (options.trace) {
|
|
201
|
-
envelope.meta.attempts = attempts;
|
|
202
|
-
}
|
|
203
|
-
return envelope;
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
export {
|
|
207
|
-
execute
|
|
208
|
-
};
|
|
209
|
-
//# sourceMappingURL=chunk-3MRJX72M.js.map
|