@synctek/forgeos 2.0.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/LICENSE +21 -0
- package/README.md +386 -0
- package/dist/cli/commands/analyze.d.ts +14 -0
- package/dist/cli/commands/analyze.d.ts.map +1 -0
- package/dist/cli/commands/analyze.js +94 -0
- package/dist/cli/commands/analyze.js.map +1 -0
- package/dist/cli/commands/build.d.ts +11 -0
- package/dist/cli/commands/build.d.ts.map +1 -0
- package/dist/cli/commands/build.js +86 -0
- package/dist/cli/commands/build.js.map +1 -0
- package/dist/cli/commands/changeset.d.ts +13 -0
- package/dist/cli/commands/changeset.d.ts.map +1 -0
- package/dist/cli/commands/changeset.js +174 -0
- package/dist/cli/commands/changeset.js.map +1 -0
- package/dist/cli/commands/evidence.d.ts +12 -0
- package/dist/cli/commands/evidence.d.ts.map +1 -0
- package/dist/cli/commands/evidence.js +94 -0
- package/dist/cli/commands/evidence.js.map +1 -0
- package/dist/cli/commands/federation.d.ts +13 -0
- package/dist/cli/commands/federation.d.ts.map +1 -0
- package/dist/cli/commands/federation.js +127 -0
- package/dist/cli/commands/federation.js.map +1 -0
- package/dist/cli/commands/gate.d.ts +15 -0
- package/dist/cli/commands/gate.d.ts.map +1 -0
- package/dist/cli/commands/gate.js +178 -0
- package/dist/cli/commands/gate.js.map +1 -0
- package/dist/cli/commands/initiative.d.ts +13 -0
- package/dist/cli/commands/initiative.d.ts.map +1 -0
- package/dist/cli/commands/initiative.js +130 -0
- package/dist/cli/commands/initiative.js.map +1 -0
- package/dist/cli/commands/mind.d.ts +16 -0
- package/dist/cli/commands/mind.d.ts.map +1 -0
- package/dist/cli/commands/mind.js +139 -0
- package/dist/cli/commands/mind.js.map +1 -0
- package/dist/cli/commands/outcome.d.ts +12 -0
- package/dist/cli/commands/outcome.d.ts.map +1 -0
- package/dist/cli/commands/outcome.js +85 -0
- package/dist/cli/commands/outcome.js.map +1 -0
- package/dist/cli/commands/project.d.ts +13 -0
- package/dist/cli/commands/project.d.ts.map +1 -0
- package/dist/cli/commands/project.js +128 -0
- package/dist/cli/commands/project.js.map +1 -0
- package/dist/cli/commands/review.d.ts +15 -0
- package/dist/cli/commands/review.d.ts.map +1 -0
- package/dist/cli/commands/review.js +167 -0
- package/dist/cli/commands/review.js.map +1 -0
- package/dist/cli/commands/score.d.ts +17 -0
- package/dist/cli/commands/score.d.ts.map +1 -0
- package/dist/cli/commands/score.js +168 -0
- package/dist/cli/commands/score.js.map +1 -0
- package/dist/cli/commands/session.d.ts +13 -0
- package/dist/cli/commands/session.d.ts.map +1 -0
- package/dist/cli/commands/session.js +133 -0
- package/dist/cli/commands/session.js.map +1 -0
- package/dist/cli/commands/trust.d.ts +16 -0
- package/dist/cli/commands/trust.d.ts.map +1 -0
- package/dist/cli/commands/trust.js +261 -0
- package/dist/cli/commands/trust.js.map +1 -0
- package/dist/cli/index.d.ts +19 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +99 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/output.d.ts +48 -0
- package/dist/cli/output.d.ts.map +1 -0
- package/dist/cli/output.js +139 -0
- package/dist/cli/output.js.map +1 -0
- package/dist/client.d.ts +46 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +146 -0
- package/dist/client.js.map +1 -0
- package/dist/handlers.d.ts +11 -0
- package/dist/handlers.d.ts.map +1 -0
- package/dist/handlers.js +424 -0
- package/dist/handlers.js.map +1 -0
- package/dist/http-server.d.ts +25 -0
- package/dist/http-server.d.ts.map +1 -0
- package/dist/http-server.js +246 -0
- package/dist/http-server.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +40 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp/handlers.d.ts +11 -0
- package/dist/mcp/handlers.d.ts.map +1 -0
- package/dist/mcp/handlers.js +553 -0
- package/dist/mcp/handlers.js.map +1 -0
- package/dist/mcp/http-server.d.ts +25 -0
- package/dist/mcp/http-server.d.ts.map +1 -0
- package/dist/mcp/http-server.js +246 -0
- package/dist/mcp/http-server.js.map +1 -0
- package/dist/mcp/index.d.ts +3 -0
- package/dist/mcp/index.d.ts.map +1 -0
- package/dist/mcp/index.js +40 -0
- package/dist/mcp/index.js.map +1 -0
- package/dist/mcp/tools.d.ts +944 -0
- package/dist/mcp/tools.d.ts.map +1 -0
- package/dist/mcp/tools.js +531 -0
- package/dist/mcp/tools.js.map +1 -0
- package/dist/shared/client.d.ts +59 -0
- package/dist/shared/client.d.ts.map +1 -0
- package/dist/shared/client.js +171 -0
- package/dist/shared/client.js.map +1 -0
- package/dist/shared/errors.d.ts +25 -0
- package/dist/shared/errors.d.ts.map +1 -0
- package/dist/shared/errors.js +44 -0
- package/dist/shared/errors.js.map +1 -0
- package/dist/shared/types.d.ts +111 -0
- package/dist/shared/types.d.ts.map +1 -0
- package/dist/shared/types.js +10 -0
- package/dist/shared/types.js.map +1 -0
- package/dist/tools.d.ts +944 -0
- package/dist/tools.d.ts.map +1 -0
- package/dist/tools.js +513 -0
- package/dist/tools.js.map +1 -0
- package/dist/trust/chain.d.ts +86 -0
- package/dist/trust/chain.d.ts.map +1 -0
- package/dist/trust/chain.js +176 -0
- package/dist/trust/chain.js.map +1 -0
- package/dist/trust/git-binding.d.ts +61 -0
- package/dist/trust/git-binding.d.ts.map +1 -0
- package/dist/trust/git-binding.js +133 -0
- package/dist/trust/git-binding.js.map +1 -0
- package/dist/trust/index.d.ts +20 -0
- package/dist/trust/index.d.ts.map +1 -0
- package/dist/trust/index.js +17 -0
- package/dist/trust/index.js.map +1 -0
- package/dist/trust/ledger.d.ts +144 -0
- package/dist/trust/ledger.d.ts.map +1 -0
- package/dist/trust/ledger.js +351 -0
- package/dist/trust/ledger.js.map +1 -0
- package/dist/trust/signing.d.ts +134 -0
- package/dist/trust/signing.d.ts.map +1 -0
- package/dist/trust/signing.js +249 -0
- package/dist/trust/signing.js.map +1 -0
- package/dist/trust/transmission.d.ts +129 -0
- package/dist/trust/transmission.d.ts.map +1 -0
- package/dist/trust/transmission.js +390 -0
- package/dist/trust/transmission.js.map +1 -0
- package/dist/types.d.ts +183 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +3 -0
- package/dist/types.js.map +1 -0
- package/package.json +61 -0
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `forge changeset` — Changeset operations.
|
|
3
|
+
*
|
|
4
|
+
* Subcommands:
|
|
5
|
+
* forge changeset propose --project <pid> --description <desc> [--modules m1,m2] [--files f1,f2]
|
|
6
|
+
* forge changeset list --project <pid>
|
|
7
|
+
* forge changeset show --project <pid> <id>
|
|
8
|
+
* forge changeset warnings --project <pid> <id>
|
|
9
|
+
*/
|
|
10
|
+
import { formatTable, formatJSON, formatSuccess, formatWarning, formatError, formatStatus, } from "../output.js";
|
|
11
|
+
export function registerChangesetCommands(parent, client) {
|
|
12
|
+
const changeset = parent
|
|
13
|
+
.command("changeset")
|
|
14
|
+
.description("Manage changesets");
|
|
15
|
+
// -------------------------------------------------------------------------
|
|
16
|
+
// changeset propose
|
|
17
|
+
// -------------------------------------------------------------------------
|
|
18
|
+
changeset
|
|
19
|
+
.command("propose")
|
|
20
|
+
.description("Propose a new changeset")
|
|
21
|
+
.requiredOption("-p, --project <pid>", "Project ID")
|
|
22
|
+
.requiredOption("--description <desc>", "What changed and why")
|
|
23
|
+
.option("--initiative <iid>", "Initiative ID this changeset belongs to")
|
|
24
|
+
.option("--modules <modules>", "Comma-separated list of affected modules", "")
|
|
25
|
+
.option("--files <files>", "Comma-separated list of changed files", "")
|
|
26
|
+
.option("--branch <branch>", "Git branch name")
|
|
27
|
+
.option("--json", "Output raw JSON")
|
|
28
|
+
.action(async (opts) => {
|
|
29
|
+
try {
|
|
30
|
+
const body = {
|
|
31
|
+
description: opts.description,
|
|
32
|
+
modules_affected: opts.modules
|
|
33
|
+
? opts.modules.split(",").map((s) => s.trim()).filter(Boolean)
|
|
34
|
+
: [],
|
|
35
|
+
files_changed: opts.files
|
|
36
|
+
? opts.files.split(",").map((s) => s.trim()).filter(Boolean)
|
|
37
|
+
: [],
|
|
38
|
+
};
|
|
39
|
+
if (opts.initiative)
|
|
40
|
+
body.initiative_id = opts.initiative;
|
|
41
|
+
if (opts.branch)
|
|
42
|
+
body.branch = opts.branch;
|
|
43
|
+
const data = (await client.post(`/api/projects/${opts.project}/changesets`, body));
|
|
44
|
+
if (opts.json) {
|
|
45
|
+
console.log(formatJSON(data));
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
const csId = data.id ?? data.changeset_id ?? "—";
|
|
49
|
+
console.log(formatSuccess(`Changeset proposed: ${csId}`));
|
|
50
|
+
console.log(formatTable(["Field", "Value"], [
|
|
51
|
+
["ID", csId],
|
|
52
|
+
["Description", data.description],
|
|
53
|
+
["Risk Score", String(data.risk_score ?? "—")],
|
|
54
|
+
[
|
|
55
|
+
"Modules",
|
|
56
|
+
(data.modules_affected ?? []).join(", ") || "—",
|
|
57
|
+
],
|
|
58
|
+
[
|
|
59
|
+
"Files",
|
|
60
|
+
(data.files_changed ?? []).join(", ") || "—",
|
|
61
|
+
],
|
|
62
|
+
]));
|
|
63
|
+
}
|
|
64
|
+
catch (err) {
|
|
65
|
+
console.error(formatError(err));
|
|
66
|
+
process.exit(1);
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
// -------------------------------------------------------------------------
|
|
70
|
+
// changeset list
|
|
71
|
+
// -------------------------------------------------------------------------
|
|
72
|
+
changeset
|
|
73
|
+
.command("list")
|
|
74
|
+
.description("List changesets for a project")
|
|
75
|
+
.requiredOption("-p, --project <pid>", "Project ID")
|
|
76
|
+
.option("--json", "Output raw JSON")
|
|
77
|
+
.action(async (opts) => {
|
|
78
|
+
try {
|
|
79
|
+
const data = await client.get(`/api/projects/${opts.project}/changesets`);
|
|
80
|
+
if (opts.json) {
|
|
81
|
+
console.log(formatJSON(data));
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
const items = Array.isArray(data)
|
|
85
|
+
? data
|
|
86
|
+
: (data.changesets ?? []);
|
|
87
|
+
if (items.length === 0) {
|
|
88
|
+
console.log("No changesets found.");
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
91
|
+
console.log(formatTable(["ID", "Description", "Risk Score"], items.map((c) => [
|
|
92
|
+
c.id ?? c.changeset_id ?? "—",
|
|
93
|
+
c.description.length > 60
|
|
94
|
+
? c.description.substring(0, 57) + "..."
|
|
95
|
+
: c.description,
|
|
96
|
+
String(c.risk_score ?? "—"),
|
|
97
|
+
])));
|
|
98
|
+
}
|
|
99
|
+
catch (err) {
|
|
100
|
+
console.error(formatError(err));
|
|
101
|
+
process.exit(1);
|
|
102
|
+
}
|
|
103
|
+
});
|
|
104
|
+
// -------------------------------------------------------------------------
|
|
105
|
+
// changeset show <id>
|
|
106
|
+
// -------------------------------------------------------------------------
|
|
107
|
+
changeset
|
|
108
|
+
.command("show <id>")
|
|
109
|
+
.description("Show changeset details")
|
|
110
|
+
.requiredOption("-p, --project <pid>", "Project ID")
|
|
111
|
+
.option("--json", "Output raw JSON")
|
|
112
|
+
.action(async (id, opts) => {
|
|
113
|
+
try {
|
|
114
|
+
const data = (await client.get(`/api/projects/${opts.project}/changesets/${id}`));
|
|
115
|
+
if (opts.json) {
|
|
116
|
+
console.log(formatJSON(data));
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
119
|
+
const csId = data.id ?? data.changeset_id ?? id;
|
|
120
|
+
console.log(formatTable(["Field", "Value"], [
|
|
121
|
+
["ID", csId],
|
|
122
|
+
["Description", data.description],
|
|
123
|
+
["Risk Score", String(data.risk_score ?? "—")],
|
|
124
|
+
["Modules", (data.modules_affected ?? []).join(", ") || "—"],
|
|
125
|
+
["Files", (data.files_changed ?? []).join(", ") || "—"],
|
|
126
|
+
]));
|
|
127
|
+
}
|
|
128
|
+
catch (err) {
|
|
129
|
+
console.error(formatError(err));
|
|
130
|
+
process.exit(1);
|
|
131
|
+
}
|
|
132
|
+
});
|
|
133
|
+
// -------------------------------------------------------------------------
|
|
134
|
+
// changeset warnings <id>
|
|
135
|
+
// -------------------------------------------------------------------------
|
|
136
|
+
changeset
|
|
137
|
+
.command("warnings <id>")
|
|
138
|
+
.description("Show quality warnings for a changeset")
|
|
139
|
+
.requiredOption("-p, --project <pid>", "Project ID")
|
|
140
|
+
.option("--json", "Output raw JSON")
|
|
141
|
+
.action(async (id, opts) => {
|
|
142
|
+
try {
|
|
143
|
+
const data = await client.get(`/api/projects/${opts.project}/changesets/${id}/quality-warnings`);
|
|
144
|
+
if (opts.json) {
|
|
145
|
+
console.log(formatJSON(data));
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
148
|
+
const warnings = Array.isArray(data)
|
|
149
|
+
? data
|
|
150
|
+
: (data.warnings ?? []);
|
|
151
|
+
if (warnings.length === 0) {
|
|
152
|
+
console.log(formatStatus("Quality warnings", "none", "green"));
|
|
153
|
+
return;
|
|
154
|
+
}
|
|
155
|
+
console.log(formatTable(["Type", "Severity", "Message", "Source"], warnings.map((w) => [
|
|
156
|
+
w.type,
|
|
157
|
+
w.severity,
|
|
158
|
+
w.message.length > 50
|
|
159
|
+
? w.message.substring(0, 47) + "..."
|
|
160
|
+
: w.message,
|
|
161
|
+
w.source,
|
|
162
|
+
])));
|
|
163
|
+
const highs = warnings.filter((w) => ["high", "error", "critical"].includes(w.severity.toLowerCase()));
|
|
164
|
+
if (highs.length > 0) {
|
|
165
|
+
console.log(formatWarning(`${highs.length} high-severity warning(s) found.`));
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
catch (err) {
|
|
169
|
+
console.error(formatError(err));
|
|
170
|
+
process.exit(1);
|
|
171
|
+
}
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
//# sourceMappingURL=changeset.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"changeset.js","sourceRoot":"","sources":["../../../src/cli/commands/changeset.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `forge evidence` — Evidence management commands.
|
|
3
|
+
*
|
|
4
|
+
* Subcommands:
|
|
5
|
+
* forge evidence submit --project <pid> --changeset <cid> --gate <gid>
|
|
6
|
+
* --type <type> --content <content>
|
|
7
|
+
* forge evidence list --project <pid> --changeset <cid> --gate <gid>
|
|
8
|
+
*/
|
|
9
|
+
import { Command } from "commander";
|
|
10
|
+
import { ForgeOSClient } from "../../shared/client.js";
|
|
11
|
+
export declare function registerEvidenceCommands(parent: Command, client: ForgeOSClient): void;
|
|
12
|
+
//# sourceMappingURL=evidence.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"evidence.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/evidence.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAUvD,wBAAgB,wBAAwB,CACtC,MAAM,EAAE,OAAO,EACf,MAAM,EAAE,aAAa,GACpB,IAAI,CA2GN"}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `forge evidence` — Evidence management commands.
|
|
3
|
+
*
|
|
4
|
+
* Subcommands:
|
|
5
|
+
* forge evidence submit --project <pid> --changeset <cid> --gate <gid>
|
|
6
|
+
* --type <type> --content <content>
|
|
7
|
+
* forge evidence list --project <pid> --changeset <cid> --gate <gid>
|
|
8
|
+
*/
|
|
9
|
+
import { formatTable, formatJSON, formatSuccess, formatError, } from "../output.js";
|
|
10
|
+
export function registerEvidenceCommands(parent, client) {
|
|
11
|
+
const evidence = parent
|
|
12
|
+
.command("evidence")
|
|
13
|
+
.description("Manage gate evidence");
|
|
14
|
+
// -------------------------------------------------------------------------
|
|
15
|
+
// evidence submit
|
|
16
|
+
// -------------------------------------------------------------------------
|
|
17
|
+
evidence
|
|
18
|
+
.command("submit")
|
|
19
|
+
.description("Submit evidence for a gate")
|
|
20
|
+
.requiredOption("-p, --project <pid>", "Project ID")
|
|
21
|
+
.requiredOption("--changeset <cid>", "Changeset ID")
|
|
22
|
+
.requiredOption("--gate <gid>", "Gate ID")
|
|
23
|
+
.requiredOption("--type <type>", "Evidence type (e.g. unit_test, lint, security_scan)")
|
|
24
|
+
.requiredOption("--content <content>", "Evidence content / summary")
|
|
25
|
+
.option("--file-refs <refs>", "Comma-separated file references", "")
|
|
26
|
+
.option("--json", "Output raw JSON")
|
|
27
|
+
.action(async (opts) => {
|
|
28
|
+
try {
|
|
29
|
+
const body = {
|
|
30
|
+
type: opts.type,
|
|
31
|
+
summary: opts.content,
|
|
32
|
+
file_refs: opts.fileRefs
|
|
33
|
+
? opts.fileRefs.split(",").map((s) => s.trim()).filter(Boolean)
|
|
34
|
+
: [],
|
|
35
|
+
};
|
|
36
|
+
const data = (await client.post(`/api/projects/${opts.project}/changesets/${opts.changeset}/gates/${opts.gate}/evidence`, body));
|
|
37
|
+
if (opts.json) {
|
|
38
|
+
console.log(formatJSON(data));
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
const evidenceId = data.id ?? "—";
|
|
42
|
+
console.log(formatSuccess(`Evidence submitted: ${evidenceId}`));
|
|
43
|
+
console.log(formatTable(["Field", "Value"], [
|
|
44
|
+
["ID", evidenceId],
|
|
45
|
+
["Type", data.type ?? opts.type],
|
|
46
|
+
["Summary", data.summary ?? opts.content],
|
|
47
|
+
["Submitted By", data.submitted_by ?? "—"],
|
|
48
|
+
]));
|
|
49
|
+
}
|
|
50
|
+
catch (err) {
|
|
51
|
+
console.error(formatError(err));
|
|
52
|
+
process.exit(1);
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
// -------------------------------------------------------------------------
|
|
56
|
+
// evidence list
|
|
57
|
+
// -------------------------------------------------------------------------
|
|
58
|
+
evidence
|
|
59
|
+
.command("list")
|
|
60
|
+
.description("List evidence for a gate")
|
|
61
|
+
.requiredOption("-p, --project <pid>", "Project ID")
|
|
62
|
+
.requiredOption("--changeset <cid>", "Changeset ID")
|
|
63
|
+
.requiredOption("--gate <gid>", "Gate ID")
|
|
64
|
+
.option("--json", "Output raw JSON")
|
|
65
|
+
.action(async (opts) => {
|
|
66
|
+
try {
|
|
67
|
+
const data = await client.get(`/api/projects/${opts.project}/changesets/${opts.changeset}/gates/${opts.gate}/evidence`);
|
|
68
|
+
if (opts.json) {
|
|
69
|
+
console.log(formatJSON(data));
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
const items = Array.isArray(data)
|
|
73
|
+
? data
|
|
74
|
+
: (data.evidence ?? []);
|
|
75
|
+
if (items.length === 0) {
|
|
76
|
+
console.log("No evidence submitted for this gate.");
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
console.log(formatTable(["ID", "Type", "Summary", "Submitted By"], items.map((e) => [
|
|
80
|
+
e.id,
|
|
81
|
+
e.type,
|
|
82
|
+
e.summary.length > 50
|
|
83
|
+
? e.summary.substring(0, 47) + "..."
|
|
84
|
+
: e.summary,
|
|
85
|
+
e.submitted_by,
|
|
86
|
+
])));
|
|
87
|
+
}
|
|
88
|
+
catch (err) {
|
|
89
|
+
console.error(formatError(err));
|
|
90
|
+
process.exit(1);
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
//# sourceMappingURL=evidence.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"evidence.js","sourceRoot":"","sources":["../../../src/cli/commands/evidence.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `forge federation` — Federation operations.
|
|
3
|
+
*
|
|
4
|
+
* Subcommands:
|
|
5
|
+
* forge federation status --project <pid>
|
|
6
|
+
* forge federation enable --project <pid>
|
|
7
|
+
* forge federation push --project <pid>
|
|
8
|
+
* forge federation ingest --project <pid>
|
|
9
|
+
*/
|
|
10
|
+
import { Command } from "commander";
|
|
11
|
+
import { ForgeOSClient } from "../../shared/client.js";
|
|
12
|
+
export declare function registerFederationCommands(parent: Command, client: ForgeOSClient): void;
|
|
13
|
+
//# sourceMappingURL=federation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"federation.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/federation.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAavD,wBAAgB,0BAA0B,CACxC,MAAM,EAAE,OAAO,EACf,MAAM,EAAE,aAAa,GACpB,IAAI,CAsIN"}
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `forge federation` — Federation operations.
|
|
3
|
+
*
|
|
4
|
+
* Subcommands:
|
|
5
|
+
* forge federation status --project <pid>
|
|
6
|
+
* forge federation enable --project <pid>
|
|
7
|
+
* forge federation push --project <pid>
|
|
8
|
+
* forge federation ingest --project <pid>
|
|
9
|
+
*/
|
|
10
|
+
import { formatTable, formatJSON, formatSuccess, formatError, green, red, } from "../output.js";
|
|
11
|
+
export function registerFederationCommands(parent, client) {
|
|
12
|
+
const fed = parent
|
|
13
|
+
.command("federation")
|
|
14
|
+
.description("Manage ForgeOS federation");
|
|
15
|
+
// -------------------------------------------------------------------------
|
|
16
|
+
// federation status
|
|
17
|
+
// -------------------------------------------------------------------------
|
|
18
|
+
fed
|
|
19
|
+
.command("status")
|
|
20
|
+
.description("Show federation status for a project")
|
|
21
|
+
.requiredOption("-p, --project <pid>", "Project ID")
|
|
22
|
+
.option("--json", "Output raw JSON")
|
|
23
|
+
.action(async (opts) => {
|
|
24
|
+
try {
|
|
25
|
+
const data = (await client.get(`/v1/federation/status`));
|
|
26
|
+
if (opts.json) {
|
|
27
|
+
console.log(formatJSON(data));
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
console.log(formatTable(["Field", "Value"], [
|
|
31
|
+
["Enabled", data.enabled ? green("yes") : red("no")],
|
|
32
|
+
["Hub URL", data.hub_url ?? "—"],
|
|
33
|
+
["Instance ID", data.instance_id ?? "—"],
|
|
34
|
+
["Last Push", data.last_push ?? "—"],
|
|
35
|
+
["Last Pull", data.last_pull ?? "—"],
|
|
36
|
+
]));
|
|
37
|
+
}
|
|
38
|
+
catch (err) {
|
|
39
|
+
console.error(formatError(err));
|
|
40
|
+
process.exit(1);
|
|
41
|
+
}
|
|
42
|
+
});
|
|
43
|
+
// -------------------------------------------------------------------------
|
|
44
|
+
// federation enable
|
|
45
|
+
// -------------------------------------------------------------------------
|
|
46
|
+
fed
|
|
47
|
+
.command("enable")
|
|
48
|
+
.description("Enable federation for a project")
|
|
49
|
+
.requiredOption("-p, --project <pid>", "Project ID")
|
|
50
|
+
.option("--hub-url <url>", "Federation hub URL")
|
|
51
|
+
.option("--consent-analytics", "Consent to analytics sharing", false)
|
|
52
|
+
.option("--consent-patterns", "Consent to pattern sharing", false)
|
|
53
|
+
.option("--json", "Output raw JSON")
|
|
54
|
+
.action(async (opts) => {
|
|
55
|
+
try {
|
|
56
|
+
const body = {
|
|
57
|
+
project_id: opts.project,
|
|
58
|
+
consent_analytics: opts.consentAnalytics,
|
|
59
|
+
consent_patterns: opts.consentPatterns,
|
|
60
|
+
};
|
|
61
|
+
if (opts.hubUrl)
|
|
62
|
+
body.hub_url = opts.hubUrl;
|
|
63
|
+
const data = await client.post(`/v1/federation/configure`, body);
|
|
64
|
+
if (opts.json) {
|
|
65
|
+
console.log(formatJSON(data));
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
console.log(formatSuccess("Federation enabled."));
|
|
69
|
+
console.log(formatJSON(data));
|
|
70
|
+
}
|
|
71
|
+
catch (err) {
|
|
72
|
+
console.error(formatError(err));
|
|
73
|
+
process.exit(1);
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
// -------------------------------------------------------------------------
|
|
77
|
+
// federation push
|
|
78
|
+
// -------------------------------------------------------------------------
|
|
79
|
+
fed
|
|
80
|
+
.command("push")
|
|
81
|
+
.description("Push local data to the federation hub")
|
|
82
|
+
.requiredOption("-p, --project <pid>", "Project ID")
|
|
83
|
+
.option("--json", "Output raw JSON")
|
|
84
|
+
.action(async (opts) => {
|
|
85
|
+
try {
|
|
86
|
+
const data = await client.post(`/v1/federation/push`, {
|
|
87
|
+
project_id: opts.project,
|
|
88
|
+
});
|
|
89
|
+
if (opts.json) {
|
|
90
|
+
console.log(formatJSON(data));
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
console.log(formatSuccess("Federation push initiated."));
|
|
94
|
+
console.log(formatJSON(data));
|
|
95
|
+
}
|
|
96
|
+
catch (err) {
|
|
97
|
+
console.error(formatError(err));
|
|
98
|
+
process.exit(1);
|
|
99
|
+
}
|
|
100
|
+
});
|
|
101
|
+
// -------------------------------------------------------------------------
|
|
102
|
+
// federation ingest
|
|
103
|
+
// -------------------------------------------------------------------------
|
|
104
|
+
fed
|
|
105
|
+
.command("ingest")
|
|
106
|
+
.description("Ingest updates from the federation hub")
|
|
107
|
+
.requiredOption("-p, --project <pid>", "Project ID")
|
|
108
|
+
.option("--json", "Output raw JSON")
|
|
109
|
+
.action(async (opts) => {
|
|
110
|
+
try {
|
|
111
|
+
const data = await client.post(`/v1/federation/ingest`, {
|
|
112
|
+
project_id: opts.project,
|
|
113
|
+
});
|
|
114
|
+
if (opts.json) {
|
|
115
|
+
console.log(formatJSON(data));
|
|
116
|
+
return;
|
|
117
|
+
}
|
|
118
|
+
console.log(formatSuccess("Federation ingest complete."));
|
|
119
|
+
console.log(formatJSON(data));
|
|
120
|
+
}
|
|
121
|
+
catch (err) {
|
|
122
|
+
console.error(formatError(err));
|
|
123
|
+
process.exit(1);
|
|
124
|
+
}
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
//# sourceMappingURL=federation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"federation.js","sourceRoot":"","sources":["../../../src/cli/commands/federation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `forge gate` — Gate management commands.
|
|
3
|
+
*
|
|
4
|
+
* Subcommands:
|
|
5
|
+
* forge gate status --project <pid> <changeset_id>
|
|
6
|
+
* forge gate promote --project <pid> <changeset_id> <gate_id>
|
|
7
|
+
* forge gate reject --project <pid> <changeset_id> <gate_id> --reason <reason>
|
|
8
|
+
* forge gate skip --project <pid> <changeset_id> <gate_id> [--reason <reason>]
|
|
9
|
+
* forge gate recommend --project <pid> <changeset_id>
|
|
10
|
+
* forge gate presets
|
|
11
|
+
*/
|
|
12
|
+
import { Command } from "commander";
|
|
13
|
+
import { ForgeOSClient } from "../../shared/client.js";
|
|
14
|
+
export declare function registerGateCommands(parent: Command, client: ForgeOSClient): void;
|
|
15
|
+
//# sourceMappingURL=gate.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gate.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/gate.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAsBvD,wBAAgB,oBAAoB,CAClC,MAAM,EAAE,OAAO,EACf,MAAM,EAAE,aAAa,GACpB,IAAI,CAgMN"}
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `forge gate` — Gate management commands.
|
|
3
|
+
*
|
|
4
|
+
* Subcommands:
|
|
5
|
+
* forge gate status --project <pid> <changeset_id>
|
|
6
|
+
* forge gate promote --project <pid> <changeset_id> <gate_id>
|
|
7
|
+
* forge gate reject --project <pid> <changeset_id> <gate_id> --reason <reason>
|
|
8
|
+
* forge gate skip --project <pid> <changeset_id> <gate_id> [--reason <reason>]
|
|
9
|
+
* forge gate recommend --project <pid> <changeset_id>
|
|
10
|
+
* forge gate presets
|
|
11
|
+
*/
|
|
12
|
+
import { formatTable, formatJSON, formatSuccess, formatError, formatStatus, green, yellow, red, } from "../output.js";
|
|
13
|
+
function gateStatusColor(status) {
|
|
14
|
+
const s = status.toLowerCase();
|
|
15
|
+
if (s === "passed" || s === "approved")
|
|
16
|
+
return green(status);
|
|
17
|
+
if (s === "pending" || s === "in_progress")
|
|
18
|
+
return yellow(status);
|
|
19
|
+
if (s === "failed" || s === "rejected")
|
|
20
|
+
return red(status);
|
|
21
|
+
return status;
|
|
22
|
+
}
|
|
23
|
+
export function registerGateCommands(parent, client) {
|
|
24
|
+
const gate = parent
|
|
25
|
+
.command("gate")
|
|
26
|
+
.description("Manage governance gates");
|
|
27
|
+
// -------------------------------------------------------------------------
|
|
28
|
+
// gate status <changeset_id>
|
|
29
|
+
// -------------------------------------------------------------------------
|
|
30
|
+
gate
|
|
31
|
+
.command("status <changeset_id>")
|
|
32
|
+
.description("Show gate pipeline status for a changeset")
|
|
33
|
+
.requiredOption("-p, --project <pid>", "Project ID")
|
|
34
|
+
.option("--json", "Output raw JSON")
|
|
35
|
+
.action(async (changesetId, opts) => {
|
|
36
|
+
try {
|
|
37
|
+
const data = await client.get(`/api/projects/${opts.project}/changesets/${changesetId}/gates`);
|
|
38
|
+
if (opts.json) {
|
|
39
|
+
console.log(formatJSON(data));
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
const gates = Array.isArray(data)
|
|
43
|
+
? data
|
|
44
|
+
: (data.gates ?? []);
|
|
45
|
+
if (gates.length === 0) {
|
|
46
|
+
console.log("No gates found for this changeset.");
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
console.log(formatTable(["Order", "Gate ID", "Gate Name", "Status", "Required Evidence"], gates.map((g) => [
|
|
50
|
+
String(g.order ?? "—"),
|
|
51
|
+
g.gate_id,
|
|
52
|
+
g.gate_name,
|
|
53
|
+
gateStatusColor(g.status),
|
|
54
|
+
(g.required_evidence ?? []).join(", ") || "—",
|
|
55
|
+
])));
|
|
56
|
+
}
|
|
57
|
+
catch (err) {
|
|
58
|
+
console.error(formatError(err));
|
|
59
|
+
process.exit(1);
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
// -------------------------------------------------------------------------
|
|
63
|
+
// gate promote <changeset_id> <gate_id>
|
|
64
|
+
// -------------------------------------------------------------------------
|
|
65
|
+
gate
|
|
66
|
+
.command("promote <changeset_id> <gate_id>")
|
|
67
|
+
.description("Promote a gate to passed")
|
|
68
|
+
.requiredOption("-p, --project <pid>", "Project ID")
|
|
69
|
+
.option("--promoted-by <actor>", "Who is promoting", "local_agent")
|
|
70
|
+
.option("--json", "Output raw JSON")
|
|
71
|
+
.action(async (changesetId, gateId, opts) => {
|
|
72
|
+
try {
|
|
73
|
+
const data = await client.post(`/api/projects/${opts.project}/changesets/${changesetId}/gates/${gateId}/promote`, { promoted_by: opts.promotedBy });
|
|
74
|
+
if (opts.json) {
|
|
75
|
+
console.log(formatJSON(data));
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
console.log(formatSuccess(`Gate ${gateId} promoted.`));
|
|
79
|
+
}
|
|
80
|
+
catch (err) {
|
|
81
|
+
console.error(formatError(err));
|
|
82
|
+
process.exit(1);
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
// -------------------------------------------------------------------------
|
|
86
|
+
// gate reject <changeset_id> <gate_id>
|
|
87
|
+
// -------------------------------------------------------------------------
|
|
88
|
+
gate
|
|
89
|
+
.command("reject <changeset_id> <gate_id>")
|
|
90
|
+
.description("Reject a gate")
|
|
91
|
+
.requiredOption("-p, --project <pid>", "Project ID")
|
|
92
|
+
.requiredOption("--reason <reason>", "Reason for rejection")
|
|
93
|
+
.option("--json", "Output raw JSON")
|
|
94
|
+
.action(async (changesetId, gateId, opts) => {
|
|
95
|
+
try {
|
|
96
|
+
const data = await client.post(`/api/projects/${opts.project}/changesets/${changesetId}/gates/${gateId}/reject`, { reason: opts.reason });
|
|
97
|
+
if (opts.json) {
|
|
98
|
+
console.log(formatJSON(data));
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
console.log(formatStatus("Gate", `${gateId} rejected`, "red"));
|
|
102
|
+
}
|
|
103
|
+
catch (err) {
|
|
104
|
+
console.error(formatError(err));
|
|
105
|
+
process.exit(1);
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
// -------------------------------------------------------------------------
|
|
109
|
+
// gate skip <changeset_id> <gate_id>
|
|
110
|
+
// -------------------------------------------------------------------------
|
|
111
|
+
gate
|
|
112
|
+
.command("skip <changeset_id> <gate_id>")
|
|
113
|
+
.description("Skip a gate (with optional reason)")
|
|
114
|
+
.requiredOption("-p, --project <pid>", "Project ID")
|
|
115
|
+
.option("--reason <reason>", "Reason for skipping")
|
|
116
|
+
.option("--json", "Output raw JSON")
|
|
117
|
+
.action(async (changesetId, gateId, opts) => {
|
|
118
|
+
try {
|
|
119
|
+
const body = {};
|
|
120
|
+
if (opts.reason)
|
|
121
|
+
body.reason = opts.reason;
|
|
122
|
+
const data = await client.post(`/api/projects/${opts.project}/changesets/${changesetId}/gates/${gateId}/skip`, body);
|
|
123
|
+
if (opts.json) {
|
|
124
|
+
console.log(formatJSON(data));
|
|
125
|
+
return;
|
|
126
|
+
}
|
|
127
|
+
console.log(formatSuccess(`Gate ${gateId} skipped.`));
|
|
128
|
+
}
|
|
129
|
+
catch (err) {
|
|
130
|
+
console.error(formatError(err));
|
|
131
|
+
process.exit(1);
|
|
132
|
+
}
|
|
133
|
+
});
|
|
134
|
+
// -------------------------------------------------------------------------
|
|
135
|
+
// gate recommend <changeset_id>
|
|
136
|
+
// -------------------------------------------------------------------------
|
|
137
|
+
gate
|
|
138
|
+
.command("recommend <changeset_id>")
|
|
139
|
+
.description("Get gate recommendations for a changeset based on risk")
|
|
140
|
+
.requiredOption("-p, --project <pid>", "Project ID")
|
|
141
|
+
.option("--json", "Output raw JSON")
|
|
142
|
+
.action(async (changesetId, opts) => {
|
|
143
|
+
try {
|
|
144
|
+
const data = await client.post(`/api/projects/${opts.project}/changesets/${changesetId}/recommend-gates`);
|
|
145
|
+
if (opts.json) {
|
|
146
|
+
console.log(formatJSON(data));
|
|
147
|
+
return;
|
|
148
|
+
}
|
|
149
|
+
console.log(formatJSON(data));
|
|
150
|
+
}
|
|
151
|
+
catch (err) {
|
|
152
|
+
console.error(formatError(err));
|
|
153
|
+
process.exit(1);
|
|
154
|
+
}
|
|
155
|
+
});
|
|
156
|
+
// -------------------------------------------------------------------------
|
|
157
|
+
// gate presets
|
|
158
|
+
// -------------------------------------------------------------------------
|
|
159
|
+
gate
|
|
160
|
+
.command("presets")
|
|
161
|
+
.description("List available governance gate presets")
|
|
162
|
+
.option("--json", "Output raw JSON")
|
|
163
|
+
.action(async (opts) => {
|
|
164
|
+
try {
|
|
165
|
+
const data = await client.get("/api/gate-presets");
|
|
166
|
+
if (opts.json) {
|
|
167
|
+
console.log(formatJSON(data));
|
|
168
|
+
return;
|
|
169
|
+
}
|
|
170
|
+
console.log(formatJSON(data));
|
|
171
|
+
}
|
|
172
|
+
catch (err) {
|
|
173
|
+
console.error(formatError(err));
|
|
174
|
+
process.exit(1);
|
|
175
|
+
}
|
|
176
|
+
});
|
|
177
|
+
}
|
|
178
|
+
//# sourceMappingURL=gate.js.map
|