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