@ghx-dev/core 0.1.1 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude-plugin/plugin.json +21 -0
- package/README.md +17 -20
- package/dist/cards/issue.assignees.add.yaml +50 -0
- package/dist/cards/issue.assignees.remove.yaml +50 -0
- package/dist/cards/issue.assignees.set.yaml +47 -0
- package/dist/cards/issue.close.yaml +16 -2
- package/dist/cards/issue.comments.create.yaml +16 -2
- package/dist/cards/issue.create.yaml +11 -0
- package/dist/cards/issue.delete.yaml +16 -2
- package/dist/cards/issue.labels.add.yaml +48 -0
- package/dist/cards/issue.labels.remove.yaml +50 -0
- package/dist/cards/issue.labels.set.yaml +47 -0
- package/dist/cards/issue.milestone.clear.yaml +40 -0
- package/dist/cards/issue.milestone.set.yaml +23 -4
- package/dist/{core/registry/cards/issue.blocked_by.add.yaml → cards/issue.relations.blocked_by.add.yaml} +3 -2
- package/dist/cards/{issue.blocked_by.remove.yaml → issue.relations.blocked_by.remove.yaml} +1 -1
- package/dist/cards/{issue.parent.remove.yaml → issue.relations.parent.remove.yaml} +11 -1
- package/dist/{core/registry/cards/issue.parent.set.yaml → cards/issue.relations.parent.set.yaml} +3 -2
- package/dist/{core/registry/cards/issue.linked_prs.list.yaml → cards/issue.relations.prs.list.yaml} +1 -1
- package/dist/cards/{issue.relations.get.yaml → issue.relations.view.yaml} +1 -1
- package/dist/cards/issue.reopen.yaml +16 -2
- package/dist/cards/issue.update.yaml +16 -2
- package/dist/cards/issue.view.yaml +7 -5
- package/dist/cards/{pr.review.submit_approve.yaml → pr.assignees.add.yaml} +12 -9
- package/dist/cards/pr.assignees.remove.yaml +29 -0
- package/dist/{core/registry/cards/pr.status.checks.yaml → cards/pr.checks.list.yaml} +15 -2
- package/dist/{core/registry/cards/pr.checks.rerun_all.yaml → cards/pr.checks.rerun.all.yaml} +2 -4
- package/dist/{core/registry/cards/pr.checks.rerun_failed.yaml → cards/pr.checks.rerun.failed.yaml} +3 -5
- package/dist/cards/pr.create.yaml +30 -0
- package/dist/cards/{pr.diff.list_files.yaml → pr.diff.files.yaml} +1 -1
- package/dist/cards/{pr.ready_for_review.set.yaml → pr.diff.view.yaml} +6 -8
- package/dist/{core/registry/cards/pr.mergeability.view.yaml → cards/pr.merge.status.yaml} +6 -3
- package/dist/{core/registry/cards/pr.merge.execute.yaml → cards/pr.merge.yaml} +1 -1
- package/dist/cards/pr.reviews.list.yaml +1 -1
- package/dist/cards/{pr.reviewers.request.yaml → pr.reviews.request.yaml} +1 -1
- package/dist/cards/pr.reviews.submit.yaml +67 -0
- package/dist/cards/{pr.comments.list.yaml → pr.threads.list.yaml} +2 -2
- package/dist/cards/{pr.comment.reply.yaml → pr.threads.reply.yaml} +4 -2
- package/dist/cards/{pr.comment.resolve.yaml → pr.threads.resolve.yaml} +1 -1
- package/dist/cards/{pr.comment.unresolve.yaml → pr.threads.unresolve.yaml} +1 -1
- package/dist/cards/pr.update.yaml +29 -0
- package/dist/cards/pr.view.yaml +7 -5
- package/dist/cards/project_v2.fields.list.yaml +2 -2
- package/dist/{core/registry/cards/project_v2.item.field.update.yaml → cards/project_v2.items.field.update.yaml} +3 -3
- package/dist/{core/registry/cards/project_v2.item.add_issue.yaml → cards/project_v2.items.issue.add.yaml} +3 -3
- package/dist/cards/project_v2.items.issue.remove.yaml +23 -0
- package/dist/cards/project_v2.items.list.yaml +2 -2
- package/dist/{core/registry/cards/project_v2.org.get.yaml → cards/project_v2.org.view.yaml} +3 -3
- package/dist/cards/{project_v2.user.get.yaml → project_v2.user.view.yaml} +3 -3
- package/dist/{core/registry/cards/release.create_draft.yaml → cards/release.create.yaml} +1 -1
- package/dist/cards/{release.publish_draft.yaml → release.publish.yaml} +1 -1
- package/dist/{core/registry/cards/release.get.yaml → cards/release.view.yaml} +1 -1
- package/dist/cards/repo.issue_types.list.yaml +2 -2
- package/dist/cards/repo.view.yaml +2 -4
- package/dist/cards/{workflow_dispatch.run.yaml → workflow.dispatch.yaml} +1 -1
- package/dist/{core/registry/cards/workflow_job.logs.get.yaml → cards/workflow.job.logs.raw.yaml} +2 -2
- package/dist/{core/registry/cards/workflow_job.logs.analyze.yaml → cards/workflow.job.logs.view.yaml} +1 -1
- package/dist/{core/registry/cards/workflow_run.artifacts.list.yaml → cards/workflow.run.artifacts.list.yaml} +1 -1
- package/dist/cards/{workflow_run.cancel.yaml → workflow.run.cancel.yaml} +1 -1
- package/dist/cards/{workflow_run.rerun_all.yaml → workflow.run.rerun.all.yaml} +3 -3
- package/dist/{core/registry/cards/workflow_run.rerun_failed.yaml → cards/workflow.run.rerun.failed.yaml} +3 -3
- package/dist/{core/registry/cards/workflow_run.get.yaml → cards/workflow.run.view.yaml} +19 -4
- package/dist/cards/{workflow_runs.list.yaml → workflow.runs.list.yaml} +1 -1
- package/dist/cards/{workflow.get.yaml → workflow.view.yaml} +2 -2
- package/dist/chunk-3DU2WHXF.js +15 -0
- package/dist/chunk-3DU2WHXF.js.map +1 -0
- package/dist/chunk-3P3KHWFU.js +5779 -0
- package/dist/chunk-3P3KHWFU.js.map +1 -0
- package/dist/chunk-BIWBJA2F.js +228 -0
- package/dist/chunk-BIWBJA2F.js.map +1 -0
- package/dist/chunk-HEHONZTO.js +121 -0
- package/dist/chunk-HEHONZTO.js.map +1 -0
- package/dist/chunk-Q7RCIK2C.js +773 -0
- package/dist/chunk-Q7RCIK2C.js.map +1 -0
- package/dist/chunk-R3CBGJZX.js +12 -0
- package/dist/chunk-R3CBGJZX.js.map +1 -0
- package/dist/chunk-TDABI6C7.js +167 -0
- package/dist/chunk-TDABI6C7.js.map +1 -0
- package/dist/chunk-TPQYVCAS.js +15 -0
- package/dist/chunk-TPQYVCAS.js.map +1 -0
- package/dist/cli/index.js +202 -21
- package/dist/cli/index.js.map +1 -1
- package/dist/core/registry/cards/issue.assignees.add.yaml +50 -0
- package/dist/core/registry/cards/issue.assignees.remove.yaml +50 -0
- package/dist/core/registry/cards/issue.assignees.set.yaml +47 -0
- package/dist/core/registry/cards/issue.close.yaml +16 -2
- package/dist/core/registry/cards/issue.comments.create.yaml +16 -2
- package/dist/core/registry/cards/issue.create.yaml +11 -0
- package/dist/core/registry/cards/issue.delete.yaml +16 -2
- package/dist/core/registry/cards/issue.labels.add.yaml +48 -0
- package/dist/core/registry/cards/issue.labels.remove.yaml +50 -0
- package/dist/core/registry/cards/issue.labels.set.yaml +47 -0
- package/dist/core/registry/cards/issue.milestone.clear.yaml +40 -0
- package/dist/core/registry/cards/issue.milestone.set.yaml +23 -4
- package/dist/{cards/issue.blocked_by.add.yaml → core/registry/cards/issue.relations.blocked_by.add.yaml} +3 -2
- package/dist/core/registry/cards/{issue.blocked_by.remove.yaml → issue.relations.blocked_by.remove.yaml} +1 -1
- package/dist/core/registry/cards/{issue.parent.remove.yaml → issue.relations.parent.remove.yaml} +11 -1
- package/dist/{cards/issue.parent.set.yaml → core/registry/cards/issue.relations.parent.set.yaml} +3 -2
- package/dist/{cards/issue.linked_prs.list.yaml → core/registry/cards/issue.relations.prs.list.yaml} +1 -1
- package/dist/core/registry/cards/{issue.relations.get.yaml → issue.relations.view.yaml} +1 -1
- package/dist/core/registry/cards/issue.reopen.yaml +16 -2
- package/dist/core/registry/cards/issue.update.yaml +16 -2
- package/dist/core/registry/cards/issue.view.yaml +7 -5
- package/dist/core/registry/cards/pr.assignees.add.yaml +29 -0
- package/dist/core/registry/cards/pr.assignees.remove.yaml +29 -0
- package/dist/{cards/pr.status.checks.yaml → core/registry/cards/pr.checks.list.yaml} +15 -2
- package/dist/{cards/pr.checks.rerun_all.yaml → core/registry/cards/pr.checks.rerun.all.yaml} +2 -4
- package/dist/{cards/pr.checks.rerun_failed.yaml → core/registry/cards/pr.checks.rerun.failed.yaml} +3 -5
- package/dist/core/registry/cards/pr.create.yaml +30 -0
- package/dist/core/registry/cards/{pr.diff.list_files.yaml → pr.diff.files.yaml} +1 -1
- package/dist/core/registry/cards/{pr.ready_for_review.set.yaml → pr.diff.view.yaml} +6 -8
- package/dist/{cards/pr.mergeability.view.yaml → core/registry/cards/pr.merge.status.yaml} +6 -3
- package/dist/{cards/pr.merge.execute.yaml → core/registry/cards/pr.merge.yaml} +1 -1
- package/dist/core/registry/cards/pr.reviews.list.yaml +1 -1
- package/dist/core/registry/cards/{pr.reviewers.request.yaml → pr.reviews.request.yaml} +1 -1
- package/dist/core/registry/cards/pr.reviews.submit.yaml +67 -0
- package/dist/core/registry/cards/{pr.comments.list.yaml → pr.threads.list.yaml} +2 -2
- package/dist/core/registry/cards/{pr.comment.reply.yaml → pr.threads.reply.yaml} +4 -2
- package/dist/core/registry/cards/{pr.comment.resolve.yaml → pr.threads.resolve.yaml} +1 -1
- package/dist/core/registry/cards/{pr.comment.unresolve.yaml → pr.threads.unresolve.yaml} +1 -1
- package/dist/core/registry/cards/pr.update.yaml +29 -0
- package/dist/core/registry/cards/pr.view.yaml +7 -5
- package/dist/core/registry/cards/project_v2.fields.list.yaml +2 -2
- package/dist/{cards/project_v2.item.field.update.yaml → core/registry/cards/project_v2.items.field.update.yaml} +3 -3
- package/dist/{cards/project_v2.item.add_issue.yaml → core/registry/cards/project_v2.items.issue.add.yaml} +3 -3
- package/dist/core/registry/cards/project_v2.items.issue.remove.yaml +23 -0
- package/dist/core/registry/cards/project_v2.items.list.yaml +2 -2
- package/dist/{cards/project_v2.org.get.yaml → core/registry/cards/project_v2.org.view.yaml} +3 -3
- package/dist/core/registry/cards/{project_v2.user.get.yaml → project_v2.user.view.yaml} +3 -3
- package/dist/{cards/release.create_draft.yaml → core/registry/cards/release.create.yaml} +1 -1
- package/dist/core/registry/cards/{release.publish_draft.yaml → release.publish.yaml} +1 -1
- package/dist/{cards/release.get.yaml → core/registry/cards/release.view.yaml} +1 -1
- package/dist/core/registry/cards/repo.issue_types.list.yaml +2 -2
- package/dist/core/registry/cards/repo.view.yaml +2 -4
- package/dist/core/registry/cards/{workflow_dispatch.run.yaml → workflow.dispatch.yaml} +1 -1
- package/dist/{cards/workflow_job.logs.get.yaml → core/registry/cards/workflow.job.logs.raw.yaml} +2 -2
- package/dist/{cards/workflow_job.logs.analyze.yaml → core/registry/cards/workflow.job.logs.view.yaml} +1 -1
- package/dist/{cards/workflow_run.artifacts.list.yaml → core/registry/cards/workflow.run.artifacts.list.yaml} +1 -1
- package/dist/core/registry/cards/{workflow_run.cancel.yaml → workflow.run.cancel.yaml} +1 -1
- package/dist/core/registry/cards/{workflow_run.rerun_all.yaml → workflow.run.rerun.all.yaml} +3 -3
- package/dist/{cards/workflow_run.rerun_failed.yaml → core/registry/cards/workflow.run.rerun.failed.yaml} +3 -3
- package/dist/{cards/workflow_run.get.yaml → core/registry/cards/workflow.run.view.yaml} +19 -4
- package/dist/core/registry/cards/{workflow_runs.list.yaml → workflow.runs.list.yaml} +1 -1
- package/dist/core/registry/cards/{workflow.get.yaml → workflow.view.yaml} +2 -2
- package/dist/index.d.ts +374 -35
- package/dist/index.js +33 -5
- package/dist/index.js.map +1 -1
- package/dist/issue-mutations-FJNZW7L5.js +668 -0
- package/dist/issue-mutations-FJNZW7L5.js.map +1 -0
- package/dist/issue-queries-GRA4MKPD.js +208 -0
- package/dist/issue-queries-GRA4MKPD.js.map +1 -0
- package/dist/pr-mutations-UG67YOF5.js +344 -0
- package/dist/pr-mutations-UG67YOF5.js.map +1 -0
- package/dist/pr-queries-UOEOXIJQ.js +331 -0
- package/dist/pr-queries-UOEOXIJQ.js.map +1 -0
- package/dist/repo-JDUHFPZF.js +66 -0
- package/dist/repo-JDUHFPZF.js.map +1 -0
- package/package.json +18 -18
- package/skills/using-ghx/SKILL.md +61 -0
- package/dist/agent.d.ts +0 -32
- package/dist/agent.js +0 -38
- package/dist/agent.js.map +0 -1
- package/dist/cards/check_run.annotations.list.yaml +0 -35
- package/dist/cards/issue.assignees.update.yaml +0 -27
- package/dist/cards/issue.labels.update.yaml +0 -27
- package/dist/cards/pr.assignees.update.yaml +0 -38
- package/dist/cards/pr.checks.get_failed.yaml +0 -42
- package/dist/cards/pr.review.submit_comment.yaml +0 -26
- package/dist/cards/pr.review.submit_request_changes.yaml +0 -26
- package/dist/cards/workflow_run.jobs.list.yaml +0 -35
- package/dist/chunk-OL4ARD3R.js +0 -242
- package/dist/chunk-OL4ARD3R.js.map +0 -1
- package/dist/chunk-PJ2JKKQE.js +0 -4148
- package/dist/chunk-PJ2JKKQE.js.map +0 -1
- package/dist/chunk-SCIJMW5P.js +0 -54
- package/dist/chunk-SCIJMW5P.js.map +0 -1
- package/dist/cli/assets/skills/ghx/SKILL.md +0 -57
- package/dist/core/registry/cards/check_run.annotations.list.yaml +0 -35
- package/dist/core/registry/cards/issue.assignees.update.yaml +0 -27
- package/dist/core/registry/cards/issue.labels.update.yaml +0 -27
- package/dist/core/registry/cards/pr.assignees.update.yaml +0 -38
- package/dist/core/registry/cards/pr.checks.get_failed.yaml +0 -42
- package/dist/core/registry/cards/pr.review.submit_approve.yaml +0 -26
- package/dist/core/registry/cards/pr.review.submit_comment.yaml +0 -26
- package/dist/core/registry/cards/pr.review.submit_request_changes.yaml +0 -26
- package/dist/core/registry/cards/workflow_run.jobs.list.yaml +0 -35
- package/dist/envelope-BpF6MNCv.d.ts +0 -55
package/dist/agent.js
DELETED
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
explainCapability,
|
|
3
|
-
listCapabilities
|
|
4
|
-
} from "./chunk-SCIJMW5P.js";
|
|
5
|
-
import "./chunk-OL4ARD3R.js";
|
|
6
|
-
|
|
7
|
-
// src/agent-interface/prompt/main-skill.ts
|
|
8
|
-
var MAIN_SKILL_TEXT = `
|
|
9
|
-
Use execute(capability_id, params) for all GitHub actions.
|
|
10
|
-
Never call gh help and never fetch GraphQL schema/introspection.
|
|
11
|
-
If required params are unknown, call explain(capability_id) or ask the user.
|
|
12
|
-
Treat ResultEnvelope.ok=false as a failure.
|
|
13
|
-
If error.retryable=true, retry once unless user requested otherwise.
|
|
14
|
-
Only reason about ResultEnvelope.data and ResultEnvelope.error.
|
|
15
|
-
`.trim();
|
|
16
|
-
|
|
17
|
-
// src/agent-interface/tools/execute-tool.ts
|
|
18
|
-
function createExecuteTool(deps) {
|
|
19
|
-
return {
|
|
20
|
-
execute(capabilityId, params, options) {
|
|
21
|
-
const request = {
|
|
22
|
-
task: capabilityId,
|
|
23
|
-
input: params,
|
|
24
|
-
...options ? { options } : {}
|
|
25
|
-
};
|
|
26
|
-
return deps.executeTask({
|
|
27
|
-
...request
|
|
28
|
-
});
|
|
29
|
-
}
|
|
30
|
-
};
|
|
31
|
-
}
|
|
32
|
-
export {
|
|
33
|
-
MAIN_SKILL_TEXT,
|
|
34
|
-
createExecuteTool,
|
|
35
|
-
explainCapability,
|
|
36
|
-
listCapabilities
|
|
37
|
-
};
|
|
38
|
-
//# sourceMappingURL=agent.js.map
|
package/dist/agent.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/agent-interface/prompt/main-skill.ts","../src/agent-interface/tools/execute-tool.ts"],"sourcesContent":["export const MAIN_SKILL_TEXT = `\nUse execute(capability_id, params) for all GitHub actions.\nNever call gh help and never fetch GraphQL schema/introspection.\nIf required params are unknown, call explain(capability_id) or ask the user.\nTreat ResultEnvelope.ok=false as a failure.\nIf error.retryable=true, retry once unless user requested otherwise.\nOnly reason about ResultEnvelope.data and ResultEnvelope.error.\n`.trim()\n","import type { ResultEnvelope } from \"../../core/contracts/envelope.js\"\n\ntype ExecuteTaskFn = (request: {\n task: string\n input: Record<string, unknown>\n options?: Record<string, unknown>\n}) => Promise<ResultEnvelope>\n\nexport function createExecuteTool(deps: { executeTask: ExecuteTaskFn }) {\n return {\n execute(\n capabilityId: string,\n params: Record<string, unknown>,\n options?: Record<string, unknown>,\n ): Promise<ResultEnvelope> {\n const request = {\n task: capabilityId,\n input: params,\n ...(options ? { options } : {}),\n }\n\n return deps.executeTask({\n ...request,\n })\n },\n }\n}\n"],"mappings":";;;;;;;AAAO,IAAM,kBAAkB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAO7B,KAAK;;;ACCA,SAAS,kBAAkB,MAAsC;AACtE,SAAO;AAAA,IACL,QACE,cACA,QACA,SACyB;AACzB,YAAM,UAAU;AAAA,QACd,MAAM;AAAA,QACN,OAAO;AAAA,QACP,GAAI,UAAU,EAAE,QAAQ,IAAI,CAAC;AAAA,MAC/B;AAEA,aAAO,KAAK,YAAY;AAAA,QACtB,GAAG;AAAA,MACL,CAAC;AAAA,IACH;AAAA,EACF;AACF;","names":[]}
|
|
@@ -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_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
|
package/dist/chunk-OL4ARD3R.js
DELETED
|
@@ -1,242 +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 { Ajv } from "ajv";
|
|
6
|
-
import { load as parseYaml } from "js-yaml";
|
|
7
|
-
|
|
8
|
-
// src/core/registry/operation-card-schema.ts
|
|
9
|
-
var operationCardSchema = {
|
|
10
|
-
$id: "https://ghx.local/schemas/operation-card.json",
|
|
11
|
-
type: "object",
|
|
12
|
-
required: ["capability_id", "version", "description", "input_schema", "output_schema", "routing"],
|
|
13
|
-
properties: {
|
|
14
|
-
capability_id: { type: "string", minLength: 1 },
|
|
15
|
-
version: { type: "string", minLength: 1 },
|
|
16
|
-
description: { type: "string", minLength: 1 },
|
|
17
|
-
input_schema: { type: "object" },
|
|
18
|
-
output_schema: { type: "object" },
|
|
19
|
-
routing: {
|
|
20
|
-
type: "object",
|
|
21
|
-
required: ["preferred", "fallbacks"],
|
|
22
|
-
properties: {
|
|
23
|
-
preferred: { enum: ["cli", "graphql", "rest"] },
|
|
24
|
-
fallbacks: {
|
|
25
|
-
type: "array",
|
|
26
|
-
items: { enum: ["cli", "graphql", "rest"] }
|
|
27
|
-
},
|
|
28
|
-
suitability: {
|
|
29
|
-
type: "array",
|
|
30
|
-
items: {
|
|
31
|
-
type: "object",
|
|
32
|
-
required: ["when", "predicate", "reason"],
|
|
33
|
-
properties: {
|
|
34
|
-
when: { enum: ["always", "env", "params"] },
|
|
35
|
-
predicate: { type: "string", minLength: 1 },
|
|
36
|
-
reason: { type: "string", minLength: 1 }
|
|
37
|
-
},
|
|
38
|
-
additionalProperties: false
|
|
39
|
-
}
|
|
40
|
-
},
|
|
41
|
-
notes: {
|
|
42
|
-
type: "array",
|
|
43
|
-
items: { type: "string" }
|
|
44
|
-
}
|
|
45
|
-
},
|
|
46
|
-
additionalProperties: false
|
|
47
|
-
},
|
|
48
|
-
graphql: {
|
|
49
|
-
type: "object",
|
|
50
|
-
required: ["operationName", "documentPath"],
|
|
51
|
-
properties: {
|
|
52
|
-
operationName: { type: "string", minLength: 1 },
|
|
53
|
-
documentPath: { type: "string", minLength: 1 },
|
|
54
|
-
variables: { type: "object" },
|
|
55
|
-
limits: {
|
|
56
|
-
type: "object",
|
|
57
|
-
properties: {
|
|
58
|
-
maxPageSize: { type: "number" }
|
|
59
|
-
},
|
|
60
|
-
additionalProperties: false
|
|
61
|
-
}
|
|
62
|
-
},
|
|
63
|
-
additionalProperties: false
|
|
64
|
-
},
|
|
65
|
-
cli: {
|
|
66
|
-
type: "object",
|
|
67
|
-
required: ["command"],
|
|
68
|
-
properties: {
|
|
69
|
-
command: { type: "string", minLength: 1 },
|
|
70
|
-
jsonFields: {
|
|
71
|
-
type: "array",
|
|
72
|
-
items: { type: "string", minLength: 1 }
|
|
73
|
-
},
|
|
74
|
-
jq: { type: "string" },
|
|
75
|
-
limits: {
|
|
76
|
-
type: "object",
|
|
77
|
-
properties: {
|
|
78
|
-
maxItemsPerCall: { type: "number" }
|
|
79
|
-
},
|
|
80
|
-
additionalProperties: false
|
|
81
|
-
}
|
|
82
|
-
},
|
|
83
|
-
additionalProperties: false
|
|
84
|
-
},
|
|
85
|
-
rest: {
|
|
86
|
-
type: "object",
|
|
87
|
-
required: ["endpoints"],
|
|
88
|
-
properties: {
|
|
89
|
-
endpoints: {
|
|
90
|
-
type: "array",
|
|
91
|
-
items: {
|
|
92
|
-
type: "object",
|
|
93
|
-
required: ["method", "path"],
|
|
94
|
-
properties: {
|
|
95
|
-
method: { type: "string" },
|
|
96
|
-
path: { type: "string" }
|
|
97
|
-
},
|
|
98
|
-
additionalProperties: false
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
},
|
|
102
|
-
additionalProperties: false
|
|
103
|
-
},
|
|
104
|
-
examples: {
|
|
105
|
-
type: "array",
|
|
106
|
-
items: {
|
|
107
|
-
type: "object",
|
|
108
|
-
required: ["title", "input"],
|
|
109
|
-
properties: {
|
|
110
|
-
title: { type: "string" },
|
|
111
|
-
input: { type: "object" }
|
|
112
|
-
},
|
|
113
|
-
additionalProperties: false
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
},
|
|
117
|
-
additionalProperties: false
|
|
118
|
-
};
|
|
119
|
-
|
|
120
|
-
// src/core/registry/index.ts
|
|
121
|
-
var ajv = new Ajv({ allErrors: true, strict: false });
|
|
122
|
-
var validateCard = ajv.compile(operationCardSchema);
|
|
123
|
-
function cardDirectory() {
|
|
124
|
-
const currentDir = dirname(fileURLToPath(import.meta.url));
|
|
125
|
-
return join(currentDir, "cards");
|
|
126
|
-
}
|
|
127
|
-
function loadCardsFromYaml() {
|
|
128
|
-
const directory = cardDirectory();
|
|
129
|
-
const preferredOrder = [
|
|
130
|
-
"repo.view",
|
|
131
|
-
"repo.labels.list",
|
|
132
|
-
"repo.issue_types.list",
|
|
133
|
-
"issue.view",
|
|
134
|
-
"issue.list",
|
|
135
|
-
"issue.comments.list",
|
|
136
|
-
"issue.create",
|
|
137
|
-
"issue.update",
|
|
138
|
-
"issue.close",
|
|
139
|
-
"issue.reopen",
|
|
140
|
-
"issue.delete",
|
|
141
|
-
"issue.labels.update",
|
|
142
|
-
"issue.assignees.update",
|
|
143
|
-
"issue.milestone.set",
|
|
144
|
-
"issue.comments.create",
|
|
145
|
-
"issue.linked_prs.list",
|
|
146
|
-
"issue.relations.get",
|
|
147
|
-
"issue.parent.set",
|
|
148
|
-
"issue.parent.remove",
|
|
149
|
-
"issue.blocked_by.add",
|
|
150
|
-
"issue.blocked_by.remove",
|
|
151
|
-
"pr.view",
|
|
152
|
-
"pr.list",
|
|
153
|
-
"pr.comments.list",
|
|
154
|
-
"pr.reviews.list",
|
|
155
|
-
"pr.diff.list_files",
|
|
156
|
-
"pr.status.checks",
|
|
157
|
-
"pr.checks.get_failed",
|
|
158
|
-
"pr.mergeability.view",
|
|
159
|
-
"pr.comment.reply",
|
|
160
|
-
"pr.comment.resolve",
|
|
161
|
-
"pr.comment.unresolve",
|
|
162
|
-
"pr.ready_for_review.set",
|
|
163
|
-
"pr.review.submit_approve",
|
|
164
|
-
"pr.review.submit_request_changes",
|
|
165
|
-
"pr.review.submit_comment",
|
|
166
|
-
"pr.merge.execute",
|
|
167
|
-
"pr.checks.rerun_failed",
|
|
168
|
-
"pr.checks.rerun_all",
|
|
169
|
-
"pr.reviewers.request",
|
|
170
|
-
"pr.assignees.update",
|
|
171
|
-
"pr.branch.update",
|
|
172
|
-
"check_run.annotations.list",
|
|
173
|
-
"workflow_runs.list",
|
|
174
|
-
"workflow_run.jobs.list",
|
|
175
|
-
"workflow_job.logs.get",
|
|
176
|
-
"workflow_job.logs.analyze",
|
|
177
|
-
"workflow.list",
|
|
178
|
-
"workflow.get",
|
|
179
|
-
"workflow_run.get",
|
|
180
|
-
"workflow_run.rerun_all",
|
|
181
|
-
"workflow_run.cancel",
|
|
182
|
-
"workflow_run.artifacts.list",
|
|
183
|
-
"project_v2.org.get",
|
|
184
|
-
"project_v2.user.get",
|
|
185
|
-
"project_v2.fields.list",
|
|
186
|
-
"project_v2.items.list",
|
|
187
|
-
"project_v2.item.add_issue",
|
|
188
|
-
"project_v2.item.field.update",
|
|
189
|
-
"release.list",
|
|
190
|
-
"release.get",
|
|
191
|
-
"release.create_draft",
|
|
192
|
-
"release.update",
|
|
193
|
-
"release.publish_draft",
|
|
194
|
-
"workflow_dispatch.run",
|
|
195
|
-
"workflow_run.rerun_failed"
|
|
196
|
-
];
|
|
197
|
-
const orderMap = new Map(preferredOrder.map((id, index) => [id, index]));
|
|
198
|
-
const entries = readdirSync(directory).filter((entry) => {
|
|
199
|
-
const extension = extname(entry).toLowerCase();
|
|
200
|
-
return extension === ".yaml" || extension === ".yml";
|
|
201
|
-
}).sort((a, b) => {
|
|
202
|
-
const capabilityA = a.replace(/\.ya?ml$/i, "");
|
|
203
|
-
const capabilityB = b.replace(/\.ya?ml$/i, "");
|
|
204
|
-
const orderA = orderMap.get(capabilityA) ?? Number.MAX_SAFE_INTEGER;
|
|
205
|
-
const orderB = orderMap.get(capabilityB) ?? Number.MAX_SAFE_INTEGER;
|
|
206
|
-
if (orderA !== orderB) {
|
|
207
|
-
return orderA - orderB;
|
|
208
|
-
}
|
|
209
|
-
return a.localeCompare(b);
|
|
210
|
-
});
|
|
211
|
-
return entries.map((entry) => {
|
|
212
|
-
const filePath = join(directory, entry);
|
|
213
|
-
const raw = readFileSync(filePath, "utf8");
|
|
214
|
-
const parsed = parseYaml(raw);
|
|
215
|
-
const validation = validateOperationCard(parsed);
|
|
216
|
-
if (!validation.ok) {
|
|
217
|
-
throw new Error(`Invalid operation card '${entry}': ${validation.error}`);
|
|
218
|
-
}
|
|
219
|
-
return parsed;
|
|
220
|
-
});
|
|
221
|
-
}
|
|
222
|
-
function validateOperationCard(card) {
|
|
223
|
-
const valid = validateCard(card);
|
|
224
|
-
if (!valid) {
|
|
225
|
-
const message = validateCard.errors?.[0]?.message ?? "Operation card schema validation failed";
|
|
226
|
-
return { ok: false, error: message };
|
|
227
|
-
}
|
|
228
|
-
return { ok: true };
|
|
229
|
-
}
|
|
230
|
-
var operationCards = loadCardsFromYaml();
|
|
231
|
-
function listOperationCards() {
|
|
232
|
-
return [...operationCards];
|
|
233
|
-
}
|
|
234
|
-
function getOperationCard(capabilityId) {
|
|
235
|
-
return operationCards.find((card) => card.capability_id === capabilityId);
|
|
236
|
-
}
|
|
237
|
-
|
|
238
|
-
export {
|
|
239
|
-
listOperationCards,
|
|
240
|
-
getOperationCard
|
|
241
|
-
};
|
|
242
|
-
//# sourceMappingURL=chunk-OL4ARD3R.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/core/registry/index.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 { Ajv } from \"ajv\"\nimport { load as parseYaml } from \"js-yaml\"\nimport { operationCardSchema } from \"./operation-card-schema.js\"\nimport type { OperationCard } from \"./types.js\"\n\nconst ajv = new Ajv({ allErrors: true, strict: false })\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","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":";AAAA,SAAS,aAAa,oBAAoB;AAC1C,SAAS,SAAS,SAAS,YAAY;AACvC,SAAS,qBAAqB;AAE9B,SAAS,WAAW;AACpB,SAAS,QAAQ,iBAAiB;;;ACL3B,IAAM,sBAAsB;AAAA,EACjC,KAAK;AAAA,EACL,MAAM;AAAA,EACN,UAAU,CAAC,iBAAiB,WAAW,eAAe,gBAAgB,iBAAiB,SAAS;AAAA,EAChG,YAAY;AAAA,IACV,eAAe,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,IAC9C,SAAS,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,IACxC,aAAa,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,IAC5C,cAAc,EAAE,MAAM,SAAS;AAAA,IAC/B,eAAe,EAAE,MAAM,SAAS;AAAA,IAChC,SAAS;AAAA,MACP,MAAM;AAAA,MACN,UAAU,CAAC,aAAa,WAAW;AAAA,MACnC,YAAY;AAAA,QACV,WAAW,EAAE,MAAM,CAAC,OAAO,WAAW,MAAM,EAAE;AAAA,QAC9C,WAAW;AAAA,UACT,MAAM;AAAA,UACN,OAAO,EAAE,MAAM,CAAC,OAAO,WAAW,MAAM,EAAE;AAAA,QAC5C;AAAA,QACA,aAAa;AAAA,UACX,MAAM;AAAA,UACN,OAAO;AAAA,YACL,MAAM;AAAA,YACN,UAAU,CAAC,QAAQ,aAAa,QAAQ;AAAA,YACxC,YAAY;AAAA,cACV,MAAM,EAAE,MAAM,CAAC,UAAU,OAAO,QAAQ,EAAE;AAAA,cAC1C,WAAW,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,cAC1C,QAAQ,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,YACzC;AAAA,YACA,sBAAsB;AAAA,UACxB;AAAA,QACF;AAAA,QACA,OAAO;AAAA,UACL,MAAM;AAAA,UACN,OAAO,EAAE,MAAM,SAAS;AAAA,QAC1B;AAAA,MACF;AAAA,MACA,sBAAsB;AAAA,IACxB;AAAA,IACA,SAAS;AAAA,MACP,MAAM;AAAA,MACN,UAAU,CAAC,iBAAiB,cAAc;AAAA,MAC1C,YAAY;AAAA,QACV,eAAe,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,QAC9C,cAAc,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,QAC7C,WAAW,EAAE,MAAM,SAAS;AAAA,QAC5B,QAAQ;AAAA,UACN,MAAM;AAAA,UACN,YAAY;AAAA,YACV,aAAa,EAAE,MAAM,SAAS;AAAA,UAChC;AAAA,UACA,sBAAsB;AAAA,QACxB;AAAA,MACF;AAAA,MACA,sBAAsB;AAAA,IACxB;AAAA,IACA,KAAK;AAAA,MACH,MAAM;AAAA,MACN,UAAU,CAAC,SAAS;AAAA,MACpB,YAAY;AAAA,QACV,SAAS,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,QACxC,YAAY;AAAA,UACV,MAAM;AAAA,UACN,OAAO,EAAE,MAAM,UAAU,WAAW,EAAE;AAAA,QACxC;AAAA,QACA,IAAI,EAAE,MAAM,SAAS;AAAA,QACrB,QAAQ;AAAA,UACN,MAAM;AAAA,UACN,YAAY;AAAA,YACV,iBAAiB,EAAE,MAAM,SAAS;AAAA,UACpC;AAAA,UACA,sBAAsB;AAAA,QACxB;AAAA,MACF;AAAA,MACA,sBAAsB;AAAA,IACxB;AAAA,IACA,MAAM;AAAA,MACJ,MAAM;AAAA,MACN,UAAU,CAAC,WAAW;AAAA,MACtB,YAAY;AAAA,QACV,WAAW;AAAA,UACT,MAAM;AAAA,UACN,OAAO;AAAA,YACL,MAAM;AAAA,YACN,UAAU,CAAC,UAAU,MAAM;AAAA,YAC3B,YAAY;AAAA,cACV,QAAQ,EAAE,MAAM,SAAS;AAAA,cACzB,MAAM,EAAE,MAAM,SAAS;AAAA,YACzB;AAAA,YACA,sBAAsB;AAAA,UACxB;AAAA,QACF;AAAA,MACF;AAAA,MACA,sBAAsB;AAAA,IACxB;AAAA,IACA,UAAU;AAAA,MACR,MAAM;AAAA,MACN,OAAO;AAAA,QACL,MAAM;AAAA,QACN,UAAU,CAAC,SAAS,OAAO;AAAA,QAC3B,YAAY;AAAA,UACV,OAAO,EAAE,MAAM,SAAS;AAAA,UACxB,OAAO,EAAE,MAAM,SAAS;AAAA,QAC1B;AAAA,QACA,sBAAsB;AAAA,MACxB;AAAA,IACF;AAAA,EACF;AAAA,EACA,sBAAsB;AACxB;;;ADpGA,IAAM,MAAM,IAAI,IAAI,EAAE,WAAW,MAAM,QAAQ,MAAM,CAAC;AACtD,IAAM,eAAe,IAAI,QAAQ,mBAAmB;AAEpD,SAAS,gBAAwB;AAC/B,QAAM,aAAa,QAAQ,cAAc,YAAY,GAAG,CAAC;AACzD,SAAO,KAAK,YAAY,OAAO;AACjC;AAEA,SAAS,oBAAqC;AAC5C,QAAM,YAAY,cAAc;AAChC,QAAM,iBAAiB;AAAA,IACrB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACA,QAAM,WAAW,IAAI,IAAI,eAAe,IAAI,CAAC,IAAI,UAAU,CAAC,IAAI,KAAK,CAAC,CAAC;AAEvE,QAAM,UAAU,YAAY,SAAS,EAClC,OAAO,CAAC,UAAU;AACjB,UAAM,YAAY,QAAQ,KAAK,EAAE,YAAY;AAC7C,WAAO,cAAc,WAAW,cAAc;AAAA,EAChD,CAAC,EACA,KAAK,CAAC,GAAG,MAAM;AACd,UAAM,cAAc,EAAE,QAAQ,aAAa,EAAE;AAC7C,UAAM,cAAc,EAAE,QAAQ,aAAa,EAAE;AAC7C,UAAM,SAAS,SAAS,IAAI,WAAW,KAAK,OAAO;AACnD,UAAM,SAAS,SAAS,IAAI,WAAW,KAAK,OAAO;AAEnD,QAAI,WAAW,QAAQ;AACrB,aAAO,SAAS;AAAA,IAClB;AAEA,WAAO,EAAE,cAAc,CAAC;AAAA,EAC1B,CAAC;AAEH,SAAO,QAAQ,IAAI,CAAC,UAAyB;AAC3C,UAAM,WAAW,KAAK,WAAW,KAAK;AACtC,UAAM,MAAM,aAAa,UAAU,MAAM;AACzC,UAAM,SAAS,UAAU,GAAG;AAC5B,UAAM,aAAa,sBAAsB,MAAM;AAC/C,QAAI,CAAC,WAAW,IAAI;AAClB,YAAM,IAAI,MAAM,2BAA2B,KAAK,MAAM,WAAW,KAAK,EAAE;AAAA,IAC1E;AAEA,WAAO;AAAA,EACT,CAAC;AACH;AAEO,SAAS,sBAAsB,MAA4D;AAChG,QAAM,QAAQ,aAAa,IAAI;AAC/B,MAAI,CAAC,OAAO;AACV,UAAM,UAAU,aAAa,SAAS,CAAC,GAAG,WAAW;AACrD,WAAO,EAAE,IAAI,OAAO,OAAO,QAAQ;AAAA,EACrC;AAEA,SAAO,EAAE,IAAI,KAAK;AACpB;AAEA,IAAM,iBAAiB,kBAAkB;AAElC,SAAS,qBAAsC;AACpD,SAAO,CAAC,GAAG,cAAc;AAC3B;AAEO,SAAS,iBAAiB,cAAiD;AAChF,SAAO,eAAe,KAAK,CAAC,SAAS,KAAK,kBAAkB,YAAY;AAC1E;","names":[]}
|