@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.
Files changed (494) hide show
  1. package/README.md +19 -7
  2. package/dist/agent.d.ts +32 -7
  3. package/dist/agent.js +27 -12
  4. package/dist/agent.js.map +1 -1
  5. package/dist/cards/project_v2.fields.list.yaml +2 -2
  6. package/dist/cards/project_v2.item.add_issue.yaml +2 -2
  7. package/dist/cards/project_v2.item.field.update.yaml +2 -2
  8. package/dist/cards/project_v2.items.list.yaml +2 -2
  9. package/dist/cards/project_v2.org.get.yaml +2 -2
  10. package/dist/cards/project_v2.user.get.yaml +2 -2
  11. package/dist/cards/repo.issue_types.list.yaml +2 -2
  12. package/dist/{chunk-4PLVKNCF.js → chunk-2FCPR3XZ.js} +14 -4
  13. package/dist/chunk-2FCPR3XZ.js.map +1 -0
  14. package/dist/chunk-RDUPMVHG.js +4139 -0
  15. package/dist/chunk-RDUPMVHG.js.map +1 -0
  16. package/dist/{chunk-JH6GM6XU.js → chunk-UN5YHUNK.js} +119 -7
  17. package/dist/chunk-UN5YHUNK.js.map +1 -0
  18. package/dist/cli/assets/skills/ghx/SKILL.md +57 -0
  19. package/dist/cli/index.js +373 -41
  20. package/dist/cli/index.js.map +1 -1
  21. package/dist/core/registry/cards/project_v2.fields.list.yaml +2 -2
  22. package/dist/core/registry/cards/project_v2.item.add_issue.yaml +2 -2
  23. package/dist/core/registry/cards/project_v2.item.field.update.yaml +2 -2
  24. package/dist/core/registry/cards/project_v2.items.list.yaml +2 -2
  25. package/dist/core/registry/cards/project_v2.org.get.yaml +2 -2
  26. package/dist/core/registry/cards/project_v2.user.get.yaml +2 -2
  27. package/dist/core/registry/cards/repo.issue_types.list.yaml +2 -2
  28. package/dist/{core/contracts/envelope.d.ts → envelope-BpF6MNCv.d.ts} +15 -3
  29. package/dist/index.d.ts +470 -22
  30. package/dist/index.js +6 -30
  31. package/package.json +13 -14
  32. package/dist/agent-interface/prompt/main-skill.d.ts +0 -3
  33. package/dist/agent-interface/prompt/main-skill.js +0 -7
  34. package/dist/agent-interface/prompt/main-skill.js.map +0 -1
  35. package/dist/agent-interface/tools/execute-tool.d.ts +0 -16
  36. package/dist/agent-interface/tools/execute-tool.js +0 -7
  37. package/dist/agent-interface/tools/execute-tool.js.map +0 -1
  38. package/dist/agent-interface/tools/explain-tool.d.ts +0 -11
  39. package/dist/agent-interface/tools/explain-tool.js +0 -9
  40. package/dist/agent-interface/tools/explain-tool.js.map +0 -1
  41. package/dist/agent-interface/tools/list-capabilities-tool.d.ts +0 -7
  42. package/dist/agent-interface/tools/list-capabilities-tool.js +0 -9
  43. package/dist/agent-interface/tools/list-capabilities-tool.js.map +0 -1
  44. package/dist/chunk-22WWCK6A.js +0 -92
  45. package/dist/chunk-22WWCK6A.js.map +0 -1
  46. package/dist/chunk-2W4L5YCC.js +0 -116
  47. package/dist/chunk-2W4L5YCC.js.map +0 -1
  48. package/dist/chunk-3MRJX72M.js +0 -209
  49. package/dist/chunk-3MRJX72M.js.map +0 -1
  50. package/dist/chunk-4PLVKNCF.js.map +0 -1
  51. package/dist/chunk-573MDG3I.js +0 -18
  52. package/dist/chunk-573MDG3I.js.map +0 -1
  53. package/dist/chunk-5JRLVOF2.js +0 -50
  54. package/dist/chunk-5JRLVOF2.js.map +0 -1
  55. package/dist/chunk-B6RLMKS4.js +0 -41
  56. package/dist/chunk-B6RLMKS4.js.map +0 -1
  57. package/dist/chunk-D746VR3B.js +0 -38
  58. package/dist/chunk-D746VR3B.js.map +0 -1
  59. package/dist/chunk-DJIEG6K7.js +0 -20
  60. package/dist/chunk-DJIEG6K7.js.map +0 -1
  61. package/dist/chunk-DLKIQBK6.js +0 -106
  62. package/dist/chunk-DLKIQBK6.js.map +0 -1
  63. package/dist/chunk-EBRDO4Y6.js +0 -31
  64. package/dist/chunk-EBRDO4Y6.js.map +0 -1
  65. package/dist/chunk-FXN6IIT5.js +0 -14
  66. package/dist/chunk-FXN6IIT5.js.map +0 -1
  67. package/dist/chunk-GMTG7X2L.js +0 -16
  68. package/dist/chunk-GMTG7X2L.js.map +0 -1
  69. package/dist/chunk-HQ2VRCH7.js +0 -42
  70. package/dist/chunk-HQ2VRCH7.js.map +0 -1
  71. package/dist/chunk-JH6GM6XU.js.map +0 -1
  72. package/dist/chunk-JLDU462R.js +0 -1352
  73. package/dist/chunk-JLDU462R.js.map +0 -1
  74. package/dist/chunk-MGNGSGMF.js +0 -203
  75. package/dist/chunk-MGNGSGMF.js.map +0 -1
  76. package/dist/chunk-NFF5VF4U.js +0 -28
  77. package/dist/chunk-NFF5VF4U.js.map +0 -1
  78. package/dist/chunk-QEAMC4IJ.js +0 -34
  79. package/dist/chunk-QEAMC4IJ.js.map +0 -1
  80. package/dist/chunk-QZZC53HF.js +0 -38
  81. package/dist/chunk-QZZC53HF.js.map +0 -1
  82. package/dist/chunk-RUQXGZ35.js +0 -34
  83. package/dist/chunk-RUQXGZ35.js.map +0 -1
  84. package/dist/chunk-SA2D4A5U.js +0 -1496
  85. package/dist/chunk-SA2D4A5U.js.map +0 -1
  86. package/dist/chunk-SD7U4BNA.js +0 -174
  87. package/dist/chunk-SD7U4BNA.js.map +0 -1
  88. package/dist/chunk-SJR2SACI.js +0 -30
  89. package/dist/chunk-SJR2SACI.js.map +0 -1
  90. package/dist/chunk-TCLMLVUQ.js +0 -38
  91. package/dist/chunk-TCLMLVUQ.js.map +0 -1
  92. package/dist/chunk-TDTKOJKN.js +0 -52
  93. package/dist/chunk-TDTKOJKN.js.map +0 -1
  94. package/dist/chunk-UGWIZ3RI.js +0 -7
  95. package/dist/chunk-UGWIZ3RI.js.map +0 -1
  96. package/dist/chunk-UOJWOHRM.js +0 -16
  97. package/dist/chunk-UOJWOHRM.js.map +0 -1
  98. package/dist/chunk-VD5NXQP7.js +0 -42
  99. package/dist/chunk-VD5NXQP7.js.map +0 -1
  100. package/dist/chunk-W2TKG2UL.js +0 -37
  101. package/dist/chunk-W2TKG2UL.js.map +0 -1
  102. package/dist/chunk-W6ROKCY5.js +0 -28
  103. package/dist/chunk-W6ROKCY5.js.map +0 -1
  104. package/dist/chunk-XNMM64WU.js +0 -221
  105. package/dist/chunk-XNMM64WU.js.map +0 -1
  106. package/dist/cli/commands/capabilities-explain.d.ts +0 -3
  107. package/dist/cli/commands/capabilities-explain.js +0 -10
  108. package/dist/cli/commands/capabilities-explain.js.map +0 -1
  109. package/dist/cli/commands/capabilities-list.d.ts +0 -3
  110. package/dist/cli/commands/capabilities-list.js +0 -10
  111. package/dist/cli/commands/capabilities-list.js.map +0 -1
  112. package/dist/cli/commands/doctor.d.ts +0 -3
  113. package/dist/cli/commands/doctor.js +0 -7
  114. package/dist/cli/commands/doctor.js.map +0 -1
  115. package/dist/cli/commands/routes.d.ts +0 -3
  116. package/dist/cli/commands/routes.js +0 -7
  117. package/dist/cli/commands/routes.js.map +0 -1
  118. package/dist/cli/commands/run.d.ts +0 -3
  119. package/dist/cli/commands/run.js +0 -31
  120. package/dist/cli/commands/run.js.map +0 -1
  121. package/dist/cli/commands/setup.d.ts +0 -3
  122. package/dist/cli/commands/setup.js +0 -7
  123. package/dist/cli/commands/setup.js.map +0 -1
  124. package/dist/cli/formatters/json.d.ts +0 -3
  125. package/dist/cli/formatters/json.js +0 -8
  126. package/dist/cli/formatters/json.js.map +0 -1
  127. package/dist/cli/formatters/table.d.ts +0 -3
  128. package/dist/cli/formatters/table.js +0 -8
  129. package/dist/cli/formatters/table.js.map +0 -1
  130. package/dist/core/contracts/envelope.js +0 -1
  131. package/dist/core/contracts/envelope.js.map +0 -1
  132. package/dist/core/contracts/task.d.ts +0 -7
  133. package/dist/core/contracts/task.js +0 -1
  134. package/dist/core/contracts/task.js.map +0 -1
  135. package/dist/core/contracts/tasks/check_run.annotations.list.d.ts +0 -5
  136. package/dist/core/contracts/tasks/check_run.annotations.list.js +0 -8
  137. package/dist/core/contracts/tasks/check_run.annotations.list.js.map +0 -1
  138. package/dist/core/contracts/tasks/issue.assignees.update.d.ts +0 -5
  139. package/dist/core/contracts/tasks/issue.assignees.update.js +0 -8
  140. package/dist/core/contracts/tasks/issue.assignees.update.js.map +0 -1
  141. package/dist/core/contracts/tasks/issue.blocked_by.add.d.ts +0 -5
  142. package/dist/core/contracts/tasks/issue.blocked_by.add.js +0 -8
  143. package/dist/core/contracts/tasks/issue.blocked_by.add.js.map +0 -1
  144. package/dist/core/contracts/tasks/issue.blocked_by.remove.d.ts +0 -5
  145. package/dist/core/contracts/tasks/issue.blocked_by.remove.js +0 -8
  146. package/dist/core/contracts/tasks/issue.blocked_by.remove.js.map +0 -1
  147. package/dist/core/contracts/tasks/issue.close.d.ts +0 -5
  148. package/dist/core/contracts/tasks/issue.close.js +0 -8
  149. package/dist/core/contracts/tasks/issue.close.js.map +0 -1
  150. package/dist/core/contracts/tasks/issue.comments.create.d.ts +0 -5
  151. package/dist/core/contracts/tasks/issue.comments.create.js +0 -8
  152. package/dist/core/contracts/tasks/issue.comments.create.js.map +0 -1
  153. package/dist/core/contracts/tasks/issue.comments.list.d.ts +0 -5
  154. package/dist/core/contracts/tasks/issue.comments.list.js +0 -8
  155. package/dist/core/contracts/tasks/issue.comments.list.js.map +0 -1
  156. package/dist/core/contracts/tasks/issue.create.d.ts +0 -5
  157. package/dist/core/contracts/tasks/issue.create.js +0 -8
  158. package/dist/core/contracts/tasks/issue.create.js.map +0 -1
  159. package/dist/core/contracts/tasks/issue.delete.d.ts +0 -5
  160. package/dist/core/contracts/tasks/issue.delete.js +0 -8
  161. package/dist/core/contracts/tasks/issue.delete.js.map +0 -1
  162. package/dist/core/contracts/tasks/issue.labels.update.d.ts +0 -5
  163. package/dist/core/contracts/tasks/issue.labels.update.js +0 -8
  164. package/dist/core/contracts/tasks/issue.labels.update.js.map +0 -1
  165. package/dist/core/contracts/tasks/issue.linked_prs.list.d.ts +0 -5
  166. package/dist/core/contracts/tasks/issue.linked_prs.list.js +0 -8
  167. package/dist/core/contracts/tasks/issue.linked_prs.list.js.map +0 -1
  168. package/dist/core/contracts/tasks/issue.list.d.ts +0 -5
  169. package/dist/core/contracts/tasks/issue.list.js +0 -8
  170. package/dist/core/contracts/tasks/issue.list.js.map +0 -1
  171. package/dist/core/contracts/tasks/issue.milestone.set.d.ts +0 -5
  172. package/dist/core/contracts/tasks/issue.milestone.set.js +0 -8
  173. package/dist/core/contracts/tasks/issue.milestone.set.js.map +0 -1
  174. package/dist/core/contracts/tasks/issue.parent.remove.d.ts +0 -5
  175. package/dist/core/contracts/tasks/issue.parent.remove.js +0 -8
  176. package/dist/core/contracts/tasks/issue.parent.remove.js.map +0 -1
  177. package/dist/core/contracts/tasks/issue.parent.set.d.ts +0 -5
  178. package/dist/core/contracts/tasks/issue.parent.set.js +0 -8
  179. package/dist/core/contracts/tasks/issue.parent.set.js.map +0 -1
  180. package/dist/core/contracts/tasks/issue.relations.get.d.ts +0 -5
  181. package/dist/core/contracts/tasks/issue.relations.get.js +0 -8
  182. package/dist/core/contracts/tasks/issue.relations.get.js.map +0 -1
  183. package/dist/core/contracts/tasks/issue.reopen.d.ts +0 -5
  184. package/dist/core/contracts/tasks/issue.reopen.js +0 -8
  185. package/dist/core/contracts/tasks/issue.reopen.js.map +0 -1
  186. package/dist/core/contracts/tasks/issue.update.d.ts +0 -5
  187. package/dist/core/contracts/tasks/issue.update.js +0 -8
  188. package/dist/core/contracts/tasks/issue.update.js.map +0 -1
  189. package/dist/core/contracts/tasks/issue.view.d.ts +0 -5
  190. package/dist/core/contracts/tasks/issue.view.js +0 -8
  191. package/dist/core/contracts/tasks/issue.view.js.map +0 -1
  192. package/dist/core/contracts/tasks/pr.assignees.update.d.ts +0 -5
  193. package/dist/core/contracts/tasks/pr.assignees.update.js +0 -8
  194. package/dist/core/contracts/tasks/pr.assignees.update.js.map +0 -1
  195. package/dist/core/contracts/tasks/pr.branch.update.d.ts +0 -5
  196. package/dist/core/contracts/tasks/pr.branch.update.js +0 -8
  197. package/dist/core/contracts/tasks/pr.branch.update.js.map +0 -1
  198. package/dist/core/contracts/tasks/pr.checks.get_failed.d.ts +0 -5
  199. package/dist/core/contracts/tasks/pr.checks.get_failed.js +0 -8
  200. package/dist/core/contracts/tasks/pr.checks.get_failed.js.map +0 -1
  201. package/dist/core/contracts/tasks/pr.checks.rerun_all.d.ts +0 -5
  202. package/dist/core/contracts/tasks/pr.checks.rerun_all.js +0 -8
  203. package/dist/core/contracts/tasks/pr.checks.rerun_all.js.map +0 -1
  204. package/dist/core/contracts/tasks/pr.checks.rerun_failed.d.ts +0 -5
  205. package/dist/core/contracts/tasks/pr.checks.rerun_failed.js +0 -8
  206. package/dist/core/contracts/tasks/pr.checks.rerun_failed.js.map +0 -1
  207. package/dist/core/contracts/tasks/pr.comment.reply.d.ts +0 -5
  208. package/dist/core/contracts/tasks/pr.comment.reply.js +0 -8
  209. package/dist/core/contracts/tasks/pr.comment.reply.js.map +0 -1
  210. package/dist/core/contracts/tasks/pr.comment.resolve.d.ts +0 -5
  211. package/dist/core/contracts/tasks/pr.comment.resolve.js +0 -8
  212. package/dist/core/contracts/tasks/pr.comment.resolve.js.map +0 -1
  213. package/dist/core/contracts/tasks/pr.comment.unresolve.d.ts +0 -5
  214. package/dist/core/contracts/tasks/pr.comment.unresolve.js +0 -8
  215. package/dist/core/contracts/tasks/pr.comment.unresolve.js.map +0 -1
  216. package/dist/core/contracts/tasks/pr.comments.list.d.ts +0 -5
  217. package/dist/core/contracts/tasks/pr.comments.list.js +0 -8
  218. package/dist/core/contracts/tasks/pr.comments.list.js.map +0 -1
  219. package/dist/core/contracts/tasks/pr.diff.list_files.d.ts +0 -5
  220. package/dist/core/contracts/tasks/pr.diff.list_files.js +0 -8
  221. package/dist/core/contracts/tasks/pr.diff.list_files.js.map +0 -1
  222. package/dist/core/contracts/tasks/pr.list.d.ts +0 -5
  223. package/dist/core/contracts/tasks/pr.list.js +0 -8
  224. package/dist/core/contracts/tasks/pr.list.js.map +0 -1
  225. package/dist/core/contracts/tasks/pr.merge.execute.d.ts +0 -5
  226. package/dist/core/contracts/tasks/pr.merge.execute.js +0 -8
  227. package/dist/core/contracts/tasks/pr.merge.execute.js.map +0 -1
  228. package/dist/core/contracts/tasks/pr.mergeability.view.d.ts +0 -5
  229. package/dist/core/contracts/tasks/pr.mergeability.view.js +0 -8
  230. package/dist/core/contracts/tasks/pr.mergeability.view.js.map +0 -1
  231. package/dist/core/contracts/tasks/pr.ready_for_review.set.d.ts +0 -5
  232. package/dist/core/contracts/tasks/pr.ready_for_review.set.js +0 -8
  233. package/dist/core/contracts/tasks/pr.ready_for_review.set.js.map +0 -1
  234. package/dist/core/contracts/tasks/pr.review.submit_approve.d.ts +0 -5
  235. package/dist/core/contracts/tasks/pr.review.submit_approve.js +0 -8
  236. package/dist/core/contracts/tasks/pr.review.submit_approve.js.map +0 -1
  237. package/dist/core/contracts/tasks/pr.review.submit_comment.d.ts +0 -5
  238. package/dist/core/contracts/tasks/pr.review.submit_comment.js +0 -8
  239. package/dist/core/contracts/tasks/pr.review.submit_comment.js.map +0 -1
  240. package/dist/core/contracts/tasks/pr.review.submit_request_changes.d.ts +0 -5
  241. package/dist/core/contracts/tasks/pr.review.submit_request_changes.js +0 -8
  242. package/dist/core/contracts/tasks/pr.review.submit_request_changes.js.map +0 -1
  243. package/dist/core/contracts/tasks/pr.reviewers.request.d.ts +0 -5
  244. package/dist/core/contracts/tasks/pr.reviewers.request.js +0 -8
  245. package/dist/core/contracts/tasks/pr.reviewers.request.js.map +0 -1
  246. package/dist/core/contracts/tasks/pr.reviews.list.d.ts +0 -5
  247. package/dist/core/contracts/tasks/pr.reviews.list.js +0 -8
  248. package/dist/core/contracts/tasks/pr.reviews.list.js.map +0 -1
  249. package/dist/core/contracts/tasks/pr.status.checks.d.ts +0 -5
  250. package/dist/core/contracts/tasks/pr.status.checks.js +0 -8
  251. package/dist/core/contracts/tasks/pr.status.checks.js.map +0 -1
  252. package/dist/core/contracts/tasks/pr.view.d.ts +0 -5
  253. package/dist/core/contracts/tasks/pr.view.js +0 -8
  254. package/dist/core/contracts/tasks/pr.view.js.map +0 -1
  255. package/dist/core/contracts/tasks/project_v2.fields.list.d.ts +0 -5
  256. package/dist/core/contracts/tasks/project_v2.fields.list.js +0 -8
  257. package/dist/core/contracts/tasks/project_v2.fields.list.js.map +0 -1
  258. package/dist/core/contracts/tasks/project_v2.item.add_issue.d.ts +0 -5
  259. package/dist/core/contracts/tasks/project_v2.item.add_issue.js +0 -8
  260. package/dist/core/contracts/tasks/project_v2.item.add_issue.js.map +0 -1
  261. package/dist/core/contracts/tasks/project_v2.item.field.update.d.ts +0 -5
  262. package/dist/core/contracts/tasks/project_v2.item.field.update.js +0 -8
  263. package/dist/core/contracts/tasks/project_v2.item.field.update.js.map +0 -1
  264. package/dist/core/contracts/tasks/project_v2.items.list.d.ts +0 -5
  265. package/dist/core/contracts/tasks/project_v2.items.list.js +0 -8
  266. package/dist/core/contracts/tasks/project_v2.items.list.js.map +0 -1
  267. package/dist/core/contracts/tasks/project_v2.org.get.d.ts +0 -5
  268. package/dist/core/contracts/tasks/project_v2.org.get.js +0 -8
  269. package/dist/core/contracts/tasks/project_v2.org.get.js.map +0 -1
  270. package/dist/core/contracts/tasks/project_v2.user.get.d.ts +0 -5
  271. package/dist/core/contracts/tasks/project_v2.user.get.js +0 -8
  272. package/dist/core/contracts/tasks/project_v2.user.get.js.map +0 -1
  273. package/dist/core/contracts/tasks/release.create_draft.d.ts +0 -5
  274. package/dist/core/contracts/tasks/release.create_draft.js +0 -8
  275. package/dist/core/contracts/tasks/release.create_draft.js.map +0 -1
  276. package/dist/core/contracts/tasks/release.get.d.ts +0 -5
  277. package/dist/core/contracts/tasks/release.get.js +0 -8
  278. package/dist/core/contracts/tasks/release.get.js.map +0 -1
  279. package/dist/core/contracts/tasks/release.list.d.ts +0 -5
  280. package/dist/core/contracts/tasks/release.list.js +0 -8
  281. package/dist/core/contracts/tasks/release.list.js.map +0 -1
  282. package/dist/core/contracts/tasks/release.publish_draft.d.ts +0 -5
  283. package/dist/core/contracts/tasks/release.publish_draft.js +0 -8
  284. package/dist/core/contracts/tasks/release.publish_draft.js.map +0 -1
  285. package/dist/core/contracts/tasks/release.update.d.ts +0 -5
  286. package/dist/core/contracts/tasks/release.update.js +0 -8
  287. package/dist/core/contracts/tasks/release.update.js.map +0 -1
  288. package/dist/core/contracts/tasks/repo.issue_types.list.d.ts +0 -5
  289. package/dist/core/contracts/tasks/repo.issue_types.list.js +0 -8
  290. package/dist/core/contracts/tasks/repo.issue_types.list.js.map +0 -1
  291. package/dist/core/contracts/tasks/repo.labels.list.d.ts +0 -5
  292. package/dist/core/contracts/tasks/repo.labels.list.js +0 -8
  293. package/dist/core/contracts/tasks/repo.labels.list.js.map +0 -1
  294. package/dist/core/contracts/tasks/repo.view.d.ts +0 -5
  295. package/dist/core/contracts/tasks/repo.view.js +0 -8
  296. package/dist/core/contracts/tasks/repo.view.js.map +0 -1
  297. package/dist/core/contracts/tasks/workflow.get.d.ts +0 -5
  298. package/dist/core/contracts/tasks/workflow.get.js +0 -8
  299. package/dist/core/contracts/tasks/workflow.get.js.map +0 -1
  300. package/dist/core/contracts/tasks/workflow.list.d.ts +0 -5
  301. package/dist/core/contracts/tasks/workflow.list.js +0 -8
  302. package/dist/core/contracts/tasks/workflow.list.js.map +0 -1
  303. package/dist/core/contracts/tasks/workflow_dispatch.run.d.ts +0 -5
  304. package/dist/core/contracts/tasks/workflow_dispatch.run.js +0 -8
  305. package/dist/core/contracts/tasks/workflow_dispatch.run.js.map +0 -1
  306. package/dist/core/contracts/tasks/workflow_job.logs.analyze.d.ts +0 -5
  307. package/dist/core/contracts/tasks/workflow_job.logs.analyze.js +0 -8
  308. package/dist/core/contracts/tasks/workflow_job.logs.analyze.js.map +0 -1
  309. package/dist/core/contracts/tasks/workflow_job.logs.get.d.ts +0 -5
  310. package/dist/core/contracts/tasks/workflow_job.logs.get.js +0 -8
  311. package/dist/core/contracts/tasks/workflow_job.logs.get.js.map +0 -1
  312. package/dist/core/contracts/tasks/workflow_run.artifacts.list.d.ts +0 -5
  313. package/dist/core/contracts/tasks/workflow_run.artifacts.list.js +0 -8
  314. package/dist/core/contracts/tasks/workflow_run.artifacts.list.js.map +0 -1
  315. package/dist/core/contracts/tasks/workflow_run.cancel.d.ts +0 -5
  316. package/dist/core/contracts/tasks/workflow_run.cancel.js +0 -8
  317. package/dist/core/contracts/tasks/workflow_run.cancel.js.map +0 -1
  318. package/dist/core/contracts/tasks/workflow_run.get.d.ts +0 -5
  319. package/dist/core/contracts/tasks/workflow_run.get.js +0 -8
  320. package/dist/core/contracts/tasks/workflow_run.get.js.map +0 -1
  321. package/dist/core/contracts/tasks/workflow_run.jobs.list.d.ts +0 -5
  322. package/dist/core/contracts/tasks/workflow_run.jobs.list.js +0 -8
  323. package/dist/core/contracts/tasks/workflow_run.jobs.list.js.map +0 -1
  324. package/dist/core/contracts/tasks/workflow_run.rerun_all.d.ts +0 -5
  325. package/dist/core/contracts/tasks/workflow_run.rerun_all.js +0 -8
  326. package/dist/core/contracts/tasks/workflow_run.rerun_all.js.map +0 -1
  327. package/dist/core/contracts/tasks/workflow_run.rerun_failed.d.ts +0 -5
  328. package/dist/core/contracts/tasks/workflow_run.rerun_failed.js +0 -8
  329. package/dist/core/contracts/tasks/workflow_run.rerun_failed.js.map +0 -1
  330. package/dist/core/contracts/tasks/workflow_runs.list.d.ts +0 -5
  331. package/dist/core/contracts/tasks/workflow_runs.list.js +0 -8
  332. package/dist/core/contracts/tasks/workflow_runs.list.js.map +0 -1
  333. package/dist/core/errors/codes.d.ts +0 -13
  334. package/dist/core/errors/codes.js +0 -7
  335. package/dist/core/errors/codes.js.map +0 -1
  336. package/dist/core/errors/map-error.d.ts +0 -5
  337. package/dist/core/errors/map-error.js +0 -8
  338. package/dist/core/errors/map-error.js.map +0 -1
  339. package/dist/core/errors/retryability.d.ts +0 -3
  340. package/dist/core/errors/retryability.js +0 -8
  341. package/dist/core/errors/retryability.js.map +0 -1
  342. package/dist/core/execute/execute.d.ts +0 -28
  343. package/dist/core/execute/execute.js +0 -11
  344. package/dist/core/execute/execute.js.map +0 -1
  345. package/dist/core/execution/adapters/cli-adapter.d.ts +0 -22
  346. package/dist/core/execution/adapters/cli-adapter.js +0 -69
  347. package/dist/core/execution/adapters/cli-adapter.js.map +0 -1
  348. package/dist/core/execution/adapters/cli-capability-adapter.d.ts +0 -16
  349. package/dist/core/execution/adapters/cli-capability-adapter.js +0 -11
  350. package/dist/core/execution/adapters/cli-capability-adapter.js.map +0 -1
  351. package/dist/core/execution/adapters/graphql-adapter.d.ts +0 -25
  352. package/dist/core/execution/adapters/graphql-adapter.js +0 -44
  353. package/dist/core/execution/adapters/graphql-adapter.js.map +0 -1
  354. package/dist/core/execution/adapters/graphql-capability-adapter.d.ts +0 -20
  355. package/dist/core/execution/adapters/graphql-capability-adapter.js +0 -11
  356. package/dist/core/execution/adapters/graphql-capability-adapter.js.map +0 -1
  357. package/dist/core/execution/adapters/rest-adapter.d.ts +0 -3
  358. package/dist/core/execution/adapters/rest-adapter.js +0 -8
  359. package/dist/core/execution/adapters/rest-adapter.js.map +0 -1
  360. package/dist/core/execution/cli/safe-runner.d.ts +0 -12
  361. package/dist/core/execution/cli/safe-runner.js +0 -7
  362. package/dist/core/execution/cli/safe-runner.js.map +0 -1
  363. package/dist/core/execution/normalizer.d.ts +0 -13
  364. package/dist/core/execution/normalizer.js +0 -9
  365. package/dist/core/execution/normalizer.js.map +0 -1
  366. package/dist/core/execution/preflight.d.ts +0 -24
  367. package/dist/core/execution/preflight.js +0 -8
  368. package/dist/core/execution/preflight.js.map +0 -1
  369. package/dist/core/registry/index.d.ts +0 -15
  370. package/dist/core/registry/index.js +0 -12
  371. package/dist/core/registry/index.js.map +0 -1
  372. package/dist/core/registry/operation-card-schema.d.ts +0 -167
  373. package/dist/core/registry/operation-card-schema.js +0 -7
  374. package/dist/core/registry/operation-card-schema.js.map +0 -1
  375. package/dist/core/registry/schema-validator.d.ts +0 -16
  376. package/dist/core/registry/schema-validator.js +0 -9
  377. package/dist/core/registry/schema-validator.js.map +0 -1
  378. package/dist/core/registry/types.d.ts +0 -51
  379. package/dist/core/registry/types.js +0 -1
  380. package/dist/core/registry/types.js.map +0 -1
  381. package/dist/core/routing/capability-registry.d.ts +0 -8
  382. package/dist/core/routing/capability-registry.js +0 -15
  383. package/dist/core/routing/capability-registry.js.map +0 -1
  384. package/dist/core/routing/engine.d.ts +0 -32
  385. package/dist/core/routing/engine.js +0 -23
  386. package/dist/core/routing/engine.js.map +0 -1
  387. package/dist/core/routing/policy.d.ts +0 -3
  388. package/dist/core/routing/policy.js +0 -7
  389. package/dist/core/routing/policy.js.map +0 -1
  390. package/dist/core/routing/reason-codes.d.ts +0 -4
  391. package/dist/core/routing/reason-codes.js +0 -15
  392. package/dist/core/routing/reason-codes.js.map +0 -1
  393. package/dist/core/telemetry/logger.d.ts +0 -8
  394. package/dist/core/telemetry/logger.js +0 -9
  395. package/dist/core/telemetry/logger.js.map +0 -1
  396. package/dist/core/telemetry/metrics.d.ts +0 -7
  397. package/dist/core/telemetry/metrics.js +0 -1
  398. package/dist/core/telemetry/metrics.js.map +0 -1
  399. package/dist/gql/client.d.ts +0 -314
  400. package/dist/gql/client.js +0 -19
  401. package/dist/gql/client.js.map +0 -1
  402. package/dist/gql/generated/common-types.d.ts +0 -36
  403. package/dist/gql/generated/common-types.js +0 -1
  404. package/dist/gql/generated/common-types.js.map +0 -1
  405. package/dist/gql/operations/issue-assignees-update.generated.d.ts +0 -33
  406. package/dist/gql/operations/issue-assignees-update.generated.js +0 -28
  407. package/dist/gql/operations/issue-assignees-update.generated.js.map +0 -1
  408. package/dist/gql/operations/issue-blocked-by-add.generated.d.ts +0 -30
  409. package/dist/gql/operations/issue-blocked-by-add.generated.js +0 -26
  410. package/dist/gql/operations/issue-blocked-by-add.generated.js.map +0 -1
  411. package/dist/gql/operations/issue-blocked-by-remove.generated.d.ts +0 -30
  412. package/dist/gql/operations/issue-blocked-by-remove.generated.js +0 -26
  413. package/dist/gql/operations/issue-blocked-by-remove.generated.js.map +0 -1
  414. package/dist/gql/operations/issue-close.generated.d.ts +0 -27
  415. package/dist/gql/operations/issue-close.generated.js +0 -25
  416. package/dist/gql/operations/issue-close.generated.js.map +0 -1
  417. package/dist/gql/operations/issue-comment-create.generated.d.ts +0 -31
  418. package/dist/gql/operations/issue-comment-create.generated.js +0 -27
  419. package/dist/gql/operations/issue-comment-create.generated.js.map +0 -1
  420. package/dist/gql/operations/issue-comments-list.generated.d.ts +0 -59
  421. package/dist/gql/operations/issue-comments-list.generated.js +0 -9
  422. package/dist/gql/operations/issue-comments-list.generated.js.map +0 -1
  423. package/dist/gql/operations/issue-create.generated.d.ts +0 -31
  424. package/dist/gql/operations/issue-create.generated.js +0 -27
  425. package/dist/gql/operations/issue-create.generated.js.map +0 -1
  426. package/dist/gql/operations/issue-delete.generated.d.ts +0 -22
  427. package/dist/gql/operations/issue-delete.generated.js +0 -21
  428. package/dist/gql/operations/issue-delete.generated.js.map +0 -1
  429. package/dist/gql/operations/issue-labels-update.generated.d.ts +0 -33
  430. package/dist/gql/operations/issue-labels-update.generated.js +0 -28
  431. package/dist/gql/operations/issue-labels-update.generated.js.map +0 -1
  432. package/dist/gql/operations/issue-linked-prs-list.generated.d.ts +0 -132
  433. package/dist/gql/operations/issue-linked-prs-list.generated.js +0 -39
  434. package/dist/gql/operations/issue-linked-prs-list.generated.js.map +0 -1
  435. package/dist/gql/operations/issue-list.generated.d.ts +0 -40
  436. package/dist/gql/operations/issue-list.generated.js +0 -9
  437. package/dist/gql/operations/issue-list.generated.js.map +0 -1
  438. package/dist/gql/operations/issue-milestone-set.generated.d.ts +0 -30
  439. package/dist/gql/operations/issue-milestone-set.generated.js +0 -26
  440. package/dist/gql/operations/issue-milestone-set.generated.js.map +0 -1
  441. package/dist/gql/operations/issue-parent-remove.generated.d.ts +0 -30
  442. package/dist/gql/operations/issue-parent-remove.generated.js +0 -26
  443. package/dist/gql/operations/issue-parent-remove.generated.js.map +0 -1
  444. package/dist/gql/operations/issue-parent-set.generated.d.ts +0 -30
  445. package/dist/gql/operations/issue-parent-set.generated.js +0 -26
  446. package/dist/gql/operations/issue-parent-set.generated.js.map +0 -1
  447. package/dist/gql/operations/issue-relations-get.generated.d.ts +0 -49
  448. package/dist/gql/operations/issue-relations-get.generated.js +0 -40
  449. package/dist/gql/operations/issue-relations-get.generated.js.map +0 -1
  450. package/dist/gql/operations/issue-reopen.generated.d.ts +0 -27
  451. package/dist/gql/operations/issue-reopen.generated.js +0 -25
  452. package/dist/gql/operations/issue-reopen.generated.js.map +0 -1
  453. package/dist/gql/operations/issue-update.generated.d.ts +0 -31
  454. package/dist/gql/operations/issue-update.generated.js +0 -27
  455. package/dist/gql/operations/issue-update.generated.js.map +0 -1
  456. package/dist/gql/operations/issue-view.generated.d.ts +0 -31
  457. package/dist/gql/operations/issue-view.generated.js +0 -9
  458. package/dist/gql/operations/issue-view.generated.js.map +0 -1
  459. package/dist/gql/operations/pr-comment-reply.generated.d.ts +0 -26
  460. package/dist/gql/operations/pr-comment-reply.generated.js +0 -25
  461. package/dist/gql/operations/pr-comment-reply.generated.js.map +0 -1
  462. package/dist/gql/operations/pr-comment-resolve.generated.d.ts +0 -26
  463. package/dist/gql/operations/pr-comment-resolve.generated.js +0 -24
  464. package/dist/gql/operations/pr-comment-resolve.generated.js.map +0 -1
  465. package/dist/gql/operations/pr-comment-unresolve.generated.d.ts +0 -26
  466. package/dist/gql/operations/pr-comment-unresolve.generated.js +0 -24
  467. package/dist/gql/operations/pr-comment-unresolve.generated.js.map +0 -1
  468. package/dist/gql/operations/pr-comments-list.generated.d.ts +0 -84
  469. package/dist/gql/operations/pr-comments-list.generated.js +0 -58
  470. package/dist/gql/operations/pr-comments-list.generated.js.map +0 -1
  471. package/dist/gql/operations/pr-diff-list-files.generated.d.ts +0 -42
  472. package/dist/gql/operations/pr-diff-list-files.generated.js +0 -9
  473. package/dist/gql/operations/pr-diff-list-files.generated.js.map +0 -1
  474. package/dist/gql/operations/pr-list.generated.d.ts +0 -40
  475. package/dist/gql/operations/pr-list.generated.js +0 -9
  476. package/dist/gql/operations/pr-list.generated.js.map +0 -1
  477. package/dist/gql/operations/pr-reviews-list.generated.d.ts +0 -64
  478. package/dist/gql/operations/pr-reviews-list.generated.js +0 -9
  479. package/dist/gql/operations/pr-reviews-list.generated.js.map +0 -1
  480. package/dist/gql/operations/pr-view.generated.d.ts +0 -31
  481. package/dist/gql/operations/pr-view.generated.js +0 -9
  482. package/dist/gql/operations/pr-view.generated.js.map +0 -1
  483. package/dist/gql/operations/repo-view.generated.d.ts +0 -33
  484. package/dist/gql/operations/repo-view.generated.js +0 -9
  485. package/dist/gql/operations/repo-view.generated.js.map +0 -1
  486. package/dist/shared/constants.d.ts +0 -3
  487. package/dist/shared/constants.js +0 -6
  488. package/dist/shared/constants.js.map +0 -1
  489. package/dist/shared/types.d.ts +0 -3
  490. package/dist/shared/types.js +0 -1
  491. package/dist/shared/types.js.map +0 -1
  492. package/dist/shared/utils.d.ts +0 -3
  493. package/dist/shared/utils.js +0 -8
  494. 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-SD7U4BNA.js";
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-JH6GM6XU.js";
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.0",
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.17.1",
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.1.64",
76
+ "@opencode-ai/sdk": "^1.2.6",
80
77
  "@vitest/coverage-v8": "^2.1.8",
81
- "@graphql-codegen/cli": "^5.0.7",
82
- "@graphql-codegen/near-operation-file-preset": "^3.1.0",
83
- "@graphql-codegen/typescript": "^4.1.6",
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": "^4.6.1",
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 \"src/**/*.ts\" --format esm --out-dir dist --clean --dts --sourcemap && node scripts/copy-registry-cards.mjs",
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,3 +0,0 @@
1
- declare const MAIN_SKILL_TEXT: string;
2
-
3
- export { MAIN_SKILL_TEXT };
@@ -1,7 +0,0 @@
1
- import {
2
- MAIN_SKILL_TEXT
3
- } from "../../chunk-FXN6IIT5.js";
4
- export {
5
- MAIN_SKILL_TEXT
6
- };
7
- //# sourceMappingURL=main-skill.js.map
@@ -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,7 +0,0 @@
1
- import {
2
- createExecuteTool
3
- } from "../../chunk-DJIEG6K7.js";
4
- export {
5
- createExecuteTool
6
- };
7
- //# sourceMappingURL=execute-tool.js.map
@@ -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,9 +0,0 @@
1
- import {
2
- explainCapability
3
- } from "../../chunk-4PLVKNCF.js";
4
- import "../../chunk-JH6GM6XU.js";
5
- import "../../chunk-2W4L5YCC.js";
6
- export {
7
- explainCapability
8
- };
9
- //# sourceMappingURL=explain-tool.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -1,7 +0,0 @@
1
- type CapabilityListItem = {
2
- capability_id: string;
3
- description: string;
4
- };
5
- declare function listCapabilities(): CapabilityListItem[];
6
-
7
- export { type CapabilityListItem, listCapabilities };
@@ -1,9 +0,0 @@
1
- import {
2
- listCapabilities
3
- } from "../../chunk-GMTG7X2L.js";
4
- import "../../chunk-JH6GM6XU.js";
5
- import "../../chunk-2W4L5YCC.js";
6
- export {
7
- listCapabilities
8
- };
9
- //# sourceMappingURL=list-capabilities-tool.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -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":[]}
@@ -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":[]}
@@ -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