@ghx-dev/core 0.1.2 → 0.2.1

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 (216) hide show
  1. package/.claude-plugin/plugin.json +21 -0
  2. package/README.md +49 -45
  3. package/dist/cards/issue.assignees.add.yaml +51 -0
  4. package/dist/cards/issue.assignees.remove.yaml +51 -0
  5. package/dist/cards/issue.assignees.set.yaml +48 -0
  6. package/dist/cards/issue.close.yaml +17 -2
  7. package/dist/cards/issue.comments.create.yaml +17 -2
  8. package/dist/cards/issue.comments.list.yaml +1 -0
  9. package/dist/cards/issue.create.yaml +12 -0
  10. package/dist/cards/issue.delete.yaml +17 -2
  11. package/dist/cards/issue.labels.add.yaml +49 -0
  12. package/dist/cards/issue.labels.remove.yaml +51 -0
  13. package/dist/cards/issue.labels.set.yaml +48 -0
  14. package/dist/cards/issue.list.yaml +1 -0
  15. package/dist/cards/issue.milestone.clear.yaml +41 -0
  16. package/dist/cards/issue.milestone.set.yaml +24 -4
  17. package/dist/{core/registry/cards/issue.blocked_by.add.yaml → cards/issue.relations.blocked_by.add.yaml} +4 -2
  18. package/dist/cards/{issue.blocked_by.remove.yaml → issue.relations.blocked_by.remove.yaml} +2 -1
  19. package/dist/cards/{issue.parent.remove.yaml → issue.relations.parent.remove.yaml} +12 -1
  20. package/dist/{core/registry/cards/issue.parent.set.yaml → cards/issue.relations.parent.set.yaml} +4 -2
  21. package/dist/{core/registry/cards/issue.linked_prs.list.yaml → cards/issue.relations.prs.list.yaml} +2 -1
  22. package/dist/cards/{issue.relations.get.yaml → issue.relations.view.yaml} +2 -1
  23. package/dist/cards/issue.reopen.yaml +17 -2
  24. package/dist/cards/issue.update.yaml +17 -2
  25. package/dist/cards/issue.view.yaml +8 -5
  26. package/dist/cards/pr.assignees.add.yaml +33 -0
  27. package/dist/cards/pr.assignees.remove.yaml +33 -0
  28. package/dist/cards/pr.branch.update.yaml +6 -2
  29. package/dist/{core/registry/cards/pr.status.checks.yaml → cards/pr.checks.list.yaml} +15 -2
  30. package/dist/{core/registry/cards/pr.checks.rerun_all.yaml → cards/pr.checks.rerun.all.yaml} +2 -4
  31. package/dist/{core/registry/cards/pr.checks.rerun_failed.yaml → cards/pr.checks.rerun.failed.yaml} +3 -5
  32. package/dist/cards/pr.create.yaml +34 -0
  33. package/dist/cards/{pr.diff.list_files.yaml → pr.diff.files.yaml} +2 -1
  34. package/dist/cards/{pr.ready_for_review.set.yaml → pr.diff.view.yaml} +6 -8
  35. package/dist/cards/pr.list.yaml +1 -0
  36. package/dist/{core/registry/cards/pr.mergeability.view.yaml → cards/pr.merge.status.yaml} +7 -3
  37. package/dist/{core/registry/cards/pr.merge.execute.yaml → cards/pr.merge.yaml} +10 -4
  38. package/dist/cards/pr.reviews.list.yaml +2 -1
  39. package/dist/cards/{pr.reviewers.request.yaml → pr.reviews.request.yaml} +7 -4
  40. package/dist/cards/pr.reviews.submit.yaml +68 -0
  41. package/dist/cards/{pr.comments.list.yaml → pr.threads.list.yaml} +3 -2
  42. package/dist/cards/{pr.comment.reply.yaml → pr.threads.reply.yaml} +5 -2
  43. package/dist/{core/registry/cards/pr.comment.resolve.yaml → cards/pr.threads.resolve.yaml} +2 -1
  44. package/dist/cards/{pr.comment.unresolve.yaml → pr.threads.unresolve.yaml} +2 -1
  45. package/dist/cards/pr.update.yaml +34 -0
  46. package/dist/cards/pr.view.yaml +8 -5
  47. package/dist/cards/project_v2.fields.list.yaml +18 -2
  48. package/dist/cards/{project_v2.item.field.update.yaml → project_v2.items.field.update.yaml} +9 -6
  49. package/dist/cards/{project_v2.item.add_issue.yaml → project_v2.items.issue.add.yaml} +10 -6
  50. package/dist/cards/project_v2.items.issue.remove.yaml +26 -0
  51. package/dist/cards/project_v2.items.list.yaml +8 -2
  52. package/dist/{core/registry/cards/project_v2.org.get.yaml → cards/project_v2.org.view.yaml} +7 -3
  53. package/dist/cards/{project_v2.user.get.yaml → project_v2.user.view.yaml} +7 -3
  54. package/dist/{core/registry/cards/release.create_draft.yaml → cards/release.create.yaml} +1 -1
  55. package/dist/cards/release.list.yaml +8 -3
  56. package/dist/cards/{release.publish_draft.yaml → release.publish.yaml} +1 -1
  57. package/dist/cards/{release.get.yaml → release.view.yaml} +9 -5
  58. package/dist/cards/repo.issue_types.list.yaml +7 -3
  59. package/dist/cards/repo.labels.list.yaml +7 -2
  60. package/dist/cards/repo.view.yaml +3 -4
  61. package/dist/cards/{workflow_dispatch.run.yaml → workflow.dispatch.yaml} +1 -1
  62. package/dist/cards/{workflow_job.logs.get.yaml → workflow.job.logs.raw.yaml} +2 -2
  63. package/dist/{core/registry/cards/workflow_job.logs.analyze.yaml → cards/workflow.job.logs.view.yaml} +1 -1
  64. package/dist/{core/registry/cards/workflow_run.artifacts.list.yaml → cards/workflow.run.artifacts.list.yaml} +1 -1
  65. package/dist/cards/{workflow_run.cancel.yaml → workflow.run.cancel.yaml} +1 -1
  66. package/dist/cards/{workflow_run.rerun_all.yaml → workflow.run.rerun.all.yaml} +3 -3
  67. package/dist/{core/registry/cards/workflow_run.rerun_failed.yaml → cards/workflow.run.rerun.failed.yaml} +3 -3
  68. package/dist/{core/registry/cards/workflow_run.get.yaml → cards/workflow.run.view.yaml} +19 -4
  69. package/dist/cards/{workflow_runs.list.yaml → workflow.runs.list.yaml} +1 -1
  70. package/dist/cards/{workflow.get.yaml → workflow.view.yaml} +2 -2
  71. package/dist/chunk-3DU2WHXF.js +15 -0
  72. package/dist/chunk-3DU2WHXF.js.map +1 -0
  73. package/dist/chunk-7HUKYNI2.js +536 -0
  74. package/dist/chunk-7HUKYNI2.js.map +1 -0
  75. package/dist/chunk-GQO6BHJV.js +98 -0
  76. package/dist/chunk-GQO6BHJV.js.map +1 -0
  77. package/dist/chunk-H7CLZHRO.js +280 -0
  78. package/dist/chunk-H7CLZHRO.js.map +1 -0
  79. package/dist/chunk-HEHONZTO.js +121 -0
  80. package/dist/chunk-HEHONZTO.js.map +1 -0
  81. package/dist/chunk-M5PJLKL5.js +6132 -0
  82. package/dist/chunk-M5PJLKL5.js.map +1 -0
  83. package/dist/chunk-NQ53ETYV.js +128 -0
  84. package/dist/chunk-NQ53ETYV.js.map +1 -0
  85. package/dist/chunk-OQWLEFAH.js +436 -0
  86. package/dist/chunk-OQWLEFAH.js.map +1 -0
  87. package/dist/chunk-Q2NW7DJE.js +878 -0
  88. package/dist/chunk-Q2NW7DJE.js.map +1 -0
  89. package/dist/chunk-QRHKAMRY.js +211 -0
  90. package/dist/chunk-QRHKAMRY.js.map +1 -0
  91. package/dist/chunk-R3CBGJZX.js +12 -0
  92. package/dist/chunk-R3CBGJZX.js.map +1 -0
  93. package/dist/chunk-TGL33GEA.js +132 -0
  94. package/dist/chunk-TGL33GEA.js.map +1 -0
  95. package/dist/chunk-TPQYVCAS.js +15 -0
  96. package/dist/chunk-TPQYVCAS.js.map +1 -0
  97. package/dist/chunk-ZGBVX2VG.js +32 -0
  98. package/dist/chunk-ZGBVX2VG.js.map +1 -0
  99. package/dist/cli/index.js +268 -22
  100. package/dist/cli/index.js.map +1 -1
  101. package/dist/core/registry/cards/issue.assignees.add.yaml +51 -0
  102. package/dist/core/registry/cards/issue.assignees.remove.yaml +51 -0
  103. package/dist/core/registry/cards/issue.assignees.set.yaml +48 -0
  104. package/dist/core/registry/cards/issue.close.yaml +17 -2
  105. package/dist/core/registry/cards/issue.comments.create.yaml +17 -2
  106. package/dist/core/registry/cards/issue.comments.list.yaml +1 -0
  107. package/dist/core/registry/cards/issue.create.yaml +12 -0
  108. package/dist/core/registry/cards/issue.delete.yaml +17 -2
  109. package/dist/core/registry/cards/issue.labels.add.yaml +49 -0
  110. package/dist/core/registry/cards/issue.labels.remove.yaml +51 -0
  111. package/dist/core/registry/cards/issue.labels.set.yaml +48 -0
  112. package/dist/core/registry/cards/issue.list.yaml +1 -0
  113. package/dist/core/registry/cards/issue.milestone.clear.yaml +41 -0
  114. package/dist/core/registry/cards/issue.milestone.set.yaml +24 -4
  115. package/dist/{cards/issue.blocked_by.add.yaml → core/registry/cards/issue.relations.blocked_by.add.yaml} +4 -2
  116. package/dist/core/registry/cards/{issue.blocked_by.remove.yaml → issue.relations.blocked_by.remove.yaml} +2 -1
  117. package/dist/core/registry/cards/{issue.parent.remove.yaml → issue.relations.parent.remove.yaml} +12 -1
  118. package/dist/{cards/issue.parent.set.yaml → core/registry/cards/issue.relations.parent.set.yaml} +4 -2
  119. package/dist/{cards/issue.linked_prs.list.yaml → core/registry/cards/issue.relations.prs.list.yaml} +2 -1
  120. package/dist/core/registry/cards/{issue.relations.get.yaml → issue.relations.view.yaml} +2 -1
  121. package/dist/core/registry/cards/issue.reopen.yaml +17 -2
  122. package/dist/core/registry/cards/issue.update.yaml +17 -2
  123. package/dist/core/registry/cards/issue.view.yaml +8 -5
  124. package/dist/core/registry/cards/pr.assignees.add.yaml +33 -0
  125. package/dist/core/registry/cards/pr.assignees.remove.yaml +33 -0
  126. package/dist/core/registry/cards/pr.branch.update.yaml +6 -2
  127. package/dist/{cards/pr.status.checks.yaml → core/registry/cards/pr.checks.list.yaml} +15 -2
  128. package/dist/{cards/pr.checks.rerun_all.yaml → core/registry/cards/pr.checks.rerun.all.yaml} +2 -4
  129. package/dist/{cards/pr.checks.rerun_failed.yaml → core/registry/cards/pr.checks.rerun.failed.yaml} +3 -5
  130. package/dist/core/registry/cards/pr.create.yaml +34 -0
  131. package/dist/core/registry/cards/{pr.diff.list_files.yaml → pr.diff.files.yaml} +2 -1
  132. package/dist/core/registry/cards/{pr.ready_for_review.set.yaml → pr.diff.view.yaml} +6 -8
  133. package/dist/core/registry/cards/pr.list.yaml +1 -0
  134. package/dist/{cards/pr.mergeability.view.yaml → core/registry/cards/pr.merge.status.yaml} +7 -3
  135. package/dist/{cards/pr.merge.execute.yaml → core/registry/cards/pr.merge.yaml} +10 -4
  136. package/dist/core/registry/cards/pr.reviews.list.yaml +2 -1
  137. package/dist/core/registry/cards/{pr.reviewers.request.yaml → pr.reviews.request.yaml} +7 -4
  138. package/dist/core/registry/cards/pr.reviews.submit.yaml +68 -0
  139. package/dist/core/registry/cards/{pr.comments.list.yaml → pr.threads.list.yaml} +3 -2
  140. package/dist/core/registry/cards/{pr.comment.reply.yaml → pr.threads.reply.yaml} +5 -2
  141. package/dist/{cards/pr.comment.resolve.yaml → core/registry/cards/pr.threads.resolve.yaml} +2 -1
  142. package/dist/core/registry/cards/{pr.comment.unresolve.yaml → pr.threads.unresolve.yaml} +2 -1
  143. package/dist/core/registry/cards/pr.update.yaml +34 -0
  144. package/dist/core/registry/cards/pr.view.yaml +8 -5
  145. package/dist/core/registry/cards/project_v2.fields.list.yaml +18 -2
  146. package/dist/core/registry/cards/{project_v2.item.field.update.yaml → project_v2.items.field.update.yaml} +9 -6
  147. package/dist/core/registry/cards/{project_v2.item.add_issue.yaml → project_v2.items.issue.add.yaml} +10 -6
  148. package/dist/core/registry/cards/project_v2.items.issue.remove.yaml +26 -0
  149. package/dist/core/registry/cards/project_v2.items.list.yaml +8 -2
  150. package/dist/{cards/project_v2.org.get.yaml → core/registry/cards/project_v2.org.view.yaml} +7 -3
  151. package/dist/core/registry/cards/{project_v2.user.get.yaml → project_v2.user.view.yaml} +7 -3
  152. package/dist/{cards/release.create_draft.yaml → core/registry/cards/release.create.yaml} +1 -1
  153. package/dist/core/registry/cards/release.list.yaml +8 -3
  154. package/dist/core/registry/cards/{release.publish_draft.yaml → release.publish.yaml} +1 -1
  155. package/dist/core/registry/cards/{release.get.yaml → release.view.yaml} +9 -5
  156. package/dist/core/registry/cards/repo.issue_types.list.yaml +7 -3
  157. package/dist/core/registry/cards/repo.labels.list.yaml +7 -2
  158. package/dist/core/registry/cards/repo.view.yaml +3 -4
  159. package/dist/core/registry/cards/{workflow_dispatch.run.yaml → workflow.dispatch.yaml} +1 -1
  160. package/dist/core/registry/cards/{workflow_job.logs.get.yaml → workflow.job.logs.raw.yaml} +2 -2
  161. package/dist/{cards/workflow_job.logs.analyze.yaml → core/registry/cards/workflow.job.logs.view.yaml} +1 -1
  162. package/dist/{cards/workflow_run.artifacts.list.yaml → core/registry/cards/workflow.run.artifacts.list.yaml} +1 -1
  163. package/dist/core/registry/cards/{workflow_run.cancel.yaml → workflow.run.cancel.yaml} +1 -1
  164. package/dist/core/registry/cards/{workflow_run.rerun_all.yaml → workflow.run.rerun.all.yaml} +3 -3
  165. package/dist/{cards/workflow_run.rerun_failed.yaml → core/registry/cards/workflow.run.rerun.failed.yaml} +3 -3
  166. package/dist/{cards/workflow_run.get.yaml → core/registry/cards/workflow.run.view.yaml} +19 -4
  167. package/dist/core/registry/cards/{workflow_runs.list.yaml → workflow.runs.list.yaml} +1 -1
  168. package/dist/core/registry/cards/{workflow.get.yaml → workflow.view.yaml} +2 -2
  169. package/dist/index.d.ts +671 -35
  170. package/dist/index.js +41 -5
  171. package/dist/index.js.map +1 -1
  172. package/dist/issue-mutations-OW464JP3.js +645 -0
  173. package/dist/issue-mutations-OW464JP3.js.map +1 -0
  174. package/dist/issue-queries-ORG3VPK4.js +93 -0
  175. package/dist/issue-queries-ORG3VPK4.js.map +1 -0
  176. package/dist/pr-mutations-WOTG6FAB.js +484 -0
  177. package/dist/pr-mutations-WOTG6FAB.js.map +1 -0
  178. package/dist/pr-queries-6CJJW7BT.js +143 -0
  179. package/dist/pr-queries-6CJJW7BT.js.map +1 -0
  180. package/dist/project-QFSCYDDW.js +429 -0
  181. package/dist/project-QFSCYDDW.js.map +1 -0
  182. package/dist/release-33236BBA.js +57 -0
  183. package/dist/release-33236BBA.js.map +1 -0
  184. package/dist/repo-M6DKCWBG.js +82 -0
  185. package/dist/repo-M6DKCWBG.js.map +1 -0
  186. package/package.json +19 -16
  187. package/skills/using-ghx/SKILL.md +127 -0
  188. package/dist/agent.d.ts +0 -32
  189. package/dist/agent.js +0 -36
  190. package/dist/agent.js.map +0 -1
  191. package/dist/cards/check_run.annotations.list.yaml +0 -35
  192. package/dist/cards/issue.assignees.update.yaml +0 -27
  193. package/dist/cards/issue.labels.update.yaml +0 -27
  194. package/dist/cards/pr.assignees.update.yaml +0 -38
  195. package/dist/cards/pr.checks.get_failed.yaml +0 -42
  196. package/dist/cards/pr.review.submit_approve.yaml +0 -26
  197. package/dist/cards/pr.review.submit_comment.yaml +0 -26
  198. package/dist/cards/pr.review.submit_request_changes.yaml +0 -26
  199. package/dist/cards/workflow_run.jobs.list.yaml +0 -35
  200. package/dist/chunk-2FCPR3XZ.js +0 -54
  201. package/dist/chunk-2FCPR3XZ.js.map +0 -1
  202. package/dist/chunk-RDUPMVHG.js +0 -4139
  203. package/dist/chunk-RDUPMVHG.js.map +0 -1
  204. package/dist/chunk-UN5YHUNK.js +0 -245
  205. package/dist/chunk-UN5YHUNK.js.map +0 -1
  206. package/dist/cli/assets/skills/ghx/SKILL.md +0 -57
  207. package/dist/core/registry/cards/check_run.annotations.list.yaml +0 -35
  208. package/dist/core/registry/cards/issue.assignees.update.yaml +0 -27
  209. package/dist/core/registry/cards/issue.labels.update.yaml +0 -27
  210. package/dist/core/registry/cards/pr.assignees.update.yaml +0 -38
  211. package/dist/core/registry/cards/pr.checks.get_failed.yaml +0 -42
  212. package/dist/core/registry/cards/pr.review.submit_approve.yaml +0 -26
  213. package/dist/core/registry/cards/pr.review.submit_comment.yaml +0 -26
  214. package/dist/core/registry/cards/pr.review.submit_request_changes.yaml +0 -26
  215. package/dist/core/registry/cards/workflow_run.jobs.list.yaml +0 -35
  216. package/dist/envelope-BpF6MNCv.d.ts +0 -55
@@ -1,245 +0,0 @@
1
- // src/core/registry/index.ts
2
- import { readdirSync, readFileSync } from "fs";
3
- import { dirname, extname, join } from "path";
4
- import { fileURLToPath } from "url";
5
- import { load as parseYaml } from "js-yaml";
6
-
7
- // src/core/registry/ajv-instance.ts
8
- import { Ajv } from "ajv";
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
124
- var validateCard = ajv.compile(operationCardSchema);
125
- function cardDirectory() {
126
- const currentDir = dirname(fileURLToPath(import.meta.url));
127
- return join(currentDir, "cards");
128
- }
129
- function loadCardsFromYaml() {
130
- const directory = cardDirectory();
131
- const preferredOrder = [
132
- "repo.view",
133
- "repo.labels.list",
134
- "repo.issue_types.list",
135
- "issue.view",
136
- "issue.list",
137
- "issue.comments.list",
138
- "issue.create",
139
- "issue.update",
140
- "issue.close",
141
- "issue.reopen",
142
- "issue.delete",
143
- "issue.labels.update",
144
- "issue.assignees.update",
145
- "issue.milestone.set",
146
- "issue.comments.create",
147
- "issue.linked_prs.list",
148
- "issue.relations.get",
149
- "issue.parent.set",
150
- "issue.parent.remove",
151
- "issue.blocked_by.add",
152
- "issue.blocked_by.remove",
153
- "pr.view",
154
- "pr.list",
155
- "pr.comments.list",
156
- "pr.reviews.list",
157
- "pr.diff.list_files",
158
- "pr.status.checks",
159
- "pr.checks.get_failed",
160
- "pr.mergeability.view",
161
- "pr.comment.reply",
162
- "pr.comment.resolve",
163
- "pr.comment.unresolve",
164
- "pr.ready_for_review.set",
165
- "pr.review.submit_approve",
166
- "pr.review.submit_request_changes",
167
- "pr.review.submit_comment",
168
- "pr.merge.execute",
169
- "pr.checks.rerun_failed",
170
- "pr.checks.rerun_all",
171
- "pr.reviewers.request",
172
- "pr.assignees.update",
173
- "pr.branch.update",
174
- "check_run.annotations.list",
175
- "workflow_runs.list",
176
- "workflow_run.jobs.list",
177
- "workflow_job.logs.get",
178
- "workflow_job.logs.analyze",
179
- "workflow.list",
180
- "workflow.get",
181
- "workflow_run.get",
182
- "workflow_run.rerun_all",
183
- "workflow_run.cancel",
184
- "workflow_run.artifacts.list",
185
- "project_v2.org.get",
186
- "project_v2.user.get",
187
- "project_v2.fields.list",
188
- "project_v2.items.list",
189
- "project_v2.item.add_issue",
190
- "project_v2.item.field.update",
191
- "release.list",
192
- "release.get",
193
- "release.create_draft",
194
- "release.update",
195
- "release.publish_draft",
196
- "workflow_dispatch.run",
197
- "workflow_run.rerun_failed"
198
- ];
199
- const orderMap = new Map(preferredOrder.map((id, index) => [id, index]));
200
- const entries = readdirSync(directory).filter((entry) => {
201
- const extension = extname(entry).toLowerCase();
202
- return extension === ".yaml" || extension === ".yml";
203
- }).sort((a, b) => {
204
- const capabilityA = a.replace(/\.ya?ml$/i, "");
205
- const capabilityB = b.replace(/\.ya?ml$/i, "");
206
- const orderA = orderMap.get(capabilityA) ?? Number.MAX_SAFE_INTEGER;
207
- const orderB = orderMap.get(capabilityB) ?? Number.MAX_SAFE_INTEGER;
208
- if (orderA !== orderB) {
209
- return orderA - orderB;
210
- }
211
- return a.localeCompare(b);
212
- });
213
- return entries.map((entry) => {
214
- const filePath = join(directory, entry);
215
- const raw = readFileSync(filePath, "utf8");
216
- const parsed = parseYaml(raw);
217
- const validation = validateOperationCard(parsed);
218
- if (!validation.ok) {
219
- throw new Error(`Invalid operation card '${entry}': ${validation.error}`);
220
- }
221
- return parsed;
222
- });
223
- }
224
- function validateOperationCard(card) {
225
- const valid = validateCard(card);
226
- if (!valid) {
227
- const message = validateCard.errors?.[0]?.message ?? "Operation card schema validation failed";
228
- return { ok: false, error: message };
229
- }
230
- return { ok: true };
231
- }
232
- var operationCards = loadCardsFromYaml();
233
- function listOperationCards() {
234
- return [...operationCards];
235
- }
236
- function getOperationCard(capabilityId) {
237
- return operationCards.find((card) => card.capability_id === capabilityId);
238
- }
239
-
240
- export {
241
- ajv,
242
- listOperationCards,
243
- getOperationCard
244
- };
245
- //# sourceMappingURL=chunk-UN5YHUNK.js.map
@@ -1 +0,0 @@
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":[]}
@@ -1,57 +0,0 @@
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.
@@ -1,35 +0,0 @@
1
- capability_id: check_run.annotations.list
2
- version: "1.0.0"
3
- description: List annotations for one check run.
4
- input_schema:
5
- type: object
6
- required: [owner, name, checkRunId]
7
- properties:
8
- owner: { type: string, minLength: 1 }
9
- name: { type: string, minLength: 1 }
10
- checkRunId: { type: integer, minimum: 1 }
11
- additionalProperties: false
12
- output_schema:
13
- type: object
14
- required: [items]
15
- properties:
16
- items:
17
- type: array
18
- items:
19
- type: object
20
- required: [path, startLine, endLine, level, message, title, details]
21
- properties:
22
- path: { type: [string, "null"] }
23
- startLine: { type: [integer, "null"] }
24
- endLine: { type: [integer, "null"] }
25
- level: { type: [string, "null"] }
26
- message: { type: [string, "null"] }
27
- title: { type: [string, "null"] }
28
- details: { type: [string, "null"] }
29
- additionalProperties: false
30
- additionalProperties: false
31
- routing:
32
- preferred: cli
33
- fallbacks: []
34
- cli:
35
- command: api
@@ -1,27 +0,0 @@
1
- capability_id: issue.assignees.update
2
- version: "1.0.0"
3
- description: Replace issue assignees.
4
- input_schema:
5
- type: object
6
- required: [issueId, assignees]
7
- properties:
8
- issueId: { type: string, minLength: 1 }
9
- assignees:
10
- type: array
11
- items: { type: string, minLength: 1 }
12
- additionalProperties: false
13
- output_schema:
14
- type: object
15
- required: [id, assignees]
16
- properties:
17
- id: { type: string, minLength: 1 }
18
- assignees:
19
- type: array
20
- items: { type: string, minLength: 1 }
21
- additionalProperties: false
22
- routing:
23
- preferred: graphql
24
- fallbacks: []
25
- graphql:
26
- operationName: IssueAssigneesUpdate
27
- documentPath: src/gql/operations/issue-assignees-update.graphql
@@ -1,27 +0,0 @@
1
- capability_id: issue.labels.update
2
- version: "1.0.0"
3
- description: Replace issue labels.
4
- input_schema:
5
- type: object
6
- required: [issueId, labels]
7
- properties:
8
- issueId: { type: string, minLength: 1 }
9
- labels:
10
- type: array
11
- items: { type: string, minLength: 1 }
12
- additionalProperties: false
13
- output_schema:
14
- type: object
15
- required: [id, labels]
16
- properties:
17
- id: { type: string, minLength: 1 }
18
- labels:
19
- type: array
20
- items: { type: string, minLength: 1 }
21
- additionalProperties: false
22
- routing:
23
- preferred: graphql
24
- fallbacks: []
25
- graphql:
26
- operationName: IssueLabelsUpdate
27
- documentPath: src/gql/operations/issue-labels-update.graphql
@@ -1,38 +0,0 @@
1
- capability_id: pr.assignees.update
2
- version: "1.0.0"
3
- description: Update pull request assignees.
4
- input_schema:
5
- type: object
6
- required: [owner, name, prNumber]
7
- properties:
8
- owner: { type: string, minLength: 1 }
9
- name: { type: string, minLength: 1 }
10
- prNumber: { type: integer, minimum: 1 }
11
- add:
12
- type: array
13
- items: { type: string, minLength: 1 }
14
- remove:
15
- type: array
16
- items: { type: string, minLength: 1 }
17
- anyOf:
18
- - required: [add]
19
- - required: [remove]
20
- additionalProperties: false
21
- output_schema:
22
- type: object
23
- required: [prNumber, add, remove, updated]
24
- properties:
25
- prNumber: { type: integer, minimum: 1 }
26
- add:
27
- type: array
28
- items: { type: string, minLength: 1 }
29
- remove:
30
- type: array
31
- items: { type: string, minLength: 1 }
32
- updated: { type: boolean }
33
- additionalProperties: false
34
- routing:
35
- preferred: cli
36
- fallbacks: []
37
- cli:
38
- command: pr edit
@@ -1,42 +0,0 @@
1
- capability_id: pr.checks.get_failed
2
- version: "1.0.0"
3
- description: List failed pull request checks.
4
- input_schema:
5
- type: object
6
- required: [owner, name, prNumber]
7
- properties:
8
- owner: { type: string, minLength: 1 }
9
- name: { type: string, minLength: 1 }
10
- prNumber: { type: integer, minimum: 1 }
11
- additionalProperties: false
12
- output_schema:
13
- type: object
14
- required: [items, summary]
15
- properties:
16
- items:
17
- type: array
18
- items:
19
- type: object
20
- required: [name, state, workflow, link]
21
- properties:
22
- name: { type: [string, "null"] }
23
- state: { type: [string, "null"] }
24
- workflow: { type: [string, "null"] }
25
- link: { type: [string, "null"] }
26
- additionalProperties: false
27
- summary:
28
- type: object
29
- required: [total, failed, pending, passed]
30
- properties:
31
- total: { type: integer, minimum: 0 }
32
- failed: { type: integer, minimum: 0 }
33
- pending: { type: integer, minimum: 0 }
34
- passed: { type: integer, minimum: 0 }
35
- additionalProperties: false
36
- additionalProperties: false
37
- routing:
38
- preferred: cli
39
- fallbacks: []
40
- cli:
41
- command: pr checks
42
- jsonFields: [name, state, workflow, link]
@@ -1,26 +0,0 @@
1
- capability_id: pr.review.submit_approve
2
- version: "1.0.0"
3
- description: Submit an approving pull request review.
4
- input_schema:
5
- type: object
6
- required: [owner, name, prNumber]
7
- properties:
8
- owner: { type: string, minLength: 1 }
9
- name: { type: string, minLength: 1 }
10
- prNumber: { type: integer, minimum: 1 }
11
- body: { type: string, minLength: 1 }
12
- additionalProperties: false
13
- output_schema:
14
- type: object
15
- required: [prNumber, event, submitted, body]
16
- properties:
17
- prNumber: { type: integer, minimum: 1 }
18
- event: { type: string, const: APPROVE }
19
- submitted: { type: boolean }
20
- body: { type: [string, "null"] }
21
- additionalProperties: false
22
- routing:
23
- preferred: cli
24
- fallbacks: []
25
- cli:
26
- command: pr review
@@ -1,26 +0,0 @@
1
- capability_id: pr.review.submit_comment
2
- version: "1.0.0"
3
- description: Submit a comment-only pull request review.
4
- input_schema:
5
- type: object
6
- required: [owner, name, prNumber, body]
7
- properties:
8
- owner: { type: string, minLength: 1 }
9
- name: { type: string, minLength: 1 }
10
- prNumber: { type: integer, minimum: 1 }
11
- body: { type: string, minLength: 1 }
12
- additionalProperties: false
13
- output_schema:
14
- type: object
15
- required: [prNumber, event, submitted, body]
16
- properties:
17
- prNumber: { type: integer, minimum: 1 }
18
- event: { type: string, const: COMMENT }
19
- submitted: { type: boolean }
20
- body: { type: string, minLength: 1 }
21
- additionalProperties: false
22
- routing:
23
- preferred: cli
24
- fallbacks: []
25
- cli:
26
- command: pr review
@@ -1,26 +0,0 @@
1
- capability_id: pr.review.submit_request_changes
2
- version: "1.0.0"
3
- description: Submit a pull request review requesting changes.
4
- input_schema:
5
- type: object
6
- required: [owner, name, prNumber, body]
7
- properties:
8
- owner: { type: string, minLength: 1 }
9
- name: { type: string, minLength: 1 }
10
- prNumber: { type: integer, minimum: 1 }
11
- body: { type: string, minLength: 1 }
12
- additionalProperties: false
13
- output_schema:
14
- type: object
15
- required: [prNumber, event, submitted, body]
16
- properties:
17
- prNumber: { type: integer, minimum: 1 }
18
- event: { type: string, const: REQUEST_CHANGES }
19
- submitted: { type: boolean }
20
- body: { type: string, minLength: 1 }
21
- additionalProperties: false
22
- routing:
23
- preferred: cli
24
- fallbacks: []
25
- cli:
26
- command: pr review
@@ -1,35 +0,0 @@
1
- capability_id: workflow_run.jobs.list
2
- version: "1.0.0"
3
- description: List jobs in a workflow run.
4
- input_schema:
5
- type: object
6
- required: [owner, name, runId]
7
- properties:
8
- owner: { type: string, minLength: 1 }
9
- name: { type: string, minLength: 1 }
10
- runId: { type: integer, minimum: 1 }
11
- additionalProperties: false
12
- output_schema:
13
- type: object
14
- required: [items]
15
- properties:
16
- items:
17
- type: array
18
- items:
19
- type: object
20
- required: [id, name, status, conclusion, startedAt, completedAt, url]
21
- properties:
22
- id: { type: integer, minimum: 0 }
23
- name: { type: [string, "null"] }
24
- status: { type: [string, "null"] }
25
- conclusion: { type: [string, "null"] }
26
- startedAt: { type: [string, "null"] }
27
- completedAt: { type: [string, "null"] }
28
- url: { type: [string, "null"] }
29
- additionalProperties: false
30
- additionalProperties: false
31
- routing:
32
- preferred: cli
33
- fallbacks: []
34
- cli:
35
- command: run view
@@ -1,55 +0,0 @@
1
- declare const errorCodes: {
2
- readonly Auth: "AUTH";
3
- readonly NotFound: "NOT_FOUND";
4
- readonly Validation: "VALIDATION";
5
- readonly RateLimit: "RATE_LIMIT";
6
- readonly Network: "NETWORK";
7
- readonly Server: "SERVER";
8
- readonly AdapterUnsupported: "ADAPTER_UNSUPPORTED";
9
- readonly Unknown: "UNKNOWN";
10
- };
11
- type ErrorCode = (typeof errorCodes)[keyof typeof errorCodes];
12
-
13
- declare const routeReasonCodes: readonly ["INPUT_VALIDATION", "OUTPUT_VALIDATION", "CARD_PREFERRED", "CARD_FALLBACK", "PREFLIGHT_FAILED", "ENV_CONSTRAINT", "CAPABILITY_LIMIT", "DEFAULT_POLICY"];
14
- type RouteReasonCode = (typeof routeReasonCodes)[number];
15
-
16
- type RouteSource = "cli" | "rest" | "graphql";
17
- interface ResultError {
18
- code: ErrorCode;
19
- message: string;
20
- retryable: boolean;
21
- details?: Record<string, unknown>;
22
- }
23
- interface AttemptMeta {
24
- route: RouteSource;
25
- status: "success" | "error" | "skipped";
26
- error_code?: ErrorCode;
27
- duration_ms?: number;
28
- }
29
- interface ResultMeta {
30
- capability_id: string;
31
- route_used?: RouteSource;
32
- reason?: RouteReasonCode;
33
- attempts?: AttemptMeta[];
34
- pagination?: {
35
- has_next_page?: boolean;
36
- end_cursor?: string;
37
- next?: unknown;
38
- };
39
- timings?: {
40
- total_ms?: number;
41
- adapter_ms?: number;
42
- };
43
- cost?: {
44
- tokens_in?: number;
45
- tokens_out?: number;
46
- };
47
- }
48
- interface ResultEnvelope<TData = unknown> {
49
- ok: boolean;
50
- data?: TData;
51
- error?: ResultError;
52
- meta: ResultMeta;
53
- }
54
-
55
- export type { AttemptMeta as A, ResultEnvelope as R, RouteSource as a, RouteReasonCode as b, ResultError as c, ResultMeta as d };