@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.
Files changed (143) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +386 -0
  3. package/dist/cli/commands/analyze.d.ts +14 -0
  4. package/dist/cli/commands/analyze.d.ts.map +1 -0
  5. package/dist/cli/commands/analyze.js +94 -0
  6. package/dist/cli/commands/analyze.js.map +1 -0
  7. package/dist/cli/commands/build.d.ts +11 -0
  8. package/dist/cli/commands/build.d.ts.map +1 -0
  9. package/dist/cli/commands/build.js +86 -0
  10. package/dist/cli/commands/build.js.map +1 -0
  11. package/dist/cli/commands/changeset.d.ts +13 -0
  12. package/dist/cli/commands/changeset.d.ts.map +1 -0
  13. package/dist/cli/commands/changeset.js +174 -0
  14. package/dist/cli/commands/changeset.js.map +1 -0
  15. package/dist/cli/commands/evidence.d.ts +12 -0
  16. package/dist/cli/commands/evidence.d.ts.map +1 -0
  17. package/dist/cli/commands/evidence.js +94 -0
  18. package/dist/cli/commands/evidence.js.map +1 -0
  19. package/dist/cli/commands/federation.d.ts +13 -0
  20. package/dist/cli/commands/federation.d.ts.map +1 -0
  21. package/dist/cli/commands/federation.js +127 -0
  22. package/dist/cli/commands/federation.js.map +1 -0
  23. package/dist/cli/commands/gate.d.ts +15 -0
  24. package/dist/cli/commands/gate.d.ts.map +1 -0
  25. package/dist/cli/commands/gate.js +178 -0
  26. package/dist/cli/commands/gate.js.map +1 -0
  27. package/dist/cli/commands/initiative.d.ts +13 -0
  28. package/dist/cli/commands/initiative.d.ts.map +1 -0
  29. package/dist/cli/commands/initiative.js +130 -0
  30. package/dist/cli/commands/initiative.js.map +1 -0
  31. package/dist/cli/commands/mind.d.ts +16 -0
  32. package/dist/cli/commands/mind.d.ts.map +1 -0
  33. package/dist/cli/commands/mind.js +139 -0
  34. package/dist/cli/commands/mind.js.map +1 -0
  35. package/dist/cli/commands/outcome.d.ts +12 -0
  36. package/dist/cli/commands/outcome.d.ts.map +1 -0
  37. package/dist/cli/commands/outcome.js +85 -0
  38. package/dist/cli/commands/outcome.js.map +1 -0
  39. package/dist/cli/commands/project.d.ts +13 -0
  40. package/dist/cli/commands/project.d.ts.map +1 -0
  41. package/dist/cli/commands/project.js +128 -0
  42. package/dist/cli/commands/project.js.map +1 -0
  43. package/dist/cli/commands/review.d.ts +15 -0
  44. package/dist/cli/commands/review.d.ts.map +1 -0
  45. package/dist/cli/commands/review.js +167 -0
  46. package/dist/cli/commands/review.js.map +1 -0
  47. package/dist/cli/commands/score.d.ts +17 -0
  48. package/dist/cli/commands/score.d.ts.map +1 -0
  49. package/dist/cli/commands/score.js +168 -0
  50. package/dist/cli/commands/score.js.map +1 -0
  51. package/dist/cli/commands/session.d.ts +13 -0
  52. package/dist/cli/commands/session.d.ts.map +1 -0
  53. package/dist/cli/commands/session.js +133 -0
  54. package/dist/cli/commands/session.js.map +1 -0
  55. package/dist/cli/commands/trust.d.ts +16 -0
  56. package/dist/cli/commands/trust.d.ts.map +1 -0
  57. package/dist/cli/commands/trust.js +261 -0
  58. package/dist/cli/commands/trust.js.map +1 -0
  59. package/dist/cli/index.d.ts +19 -0
  60. package/dist/cli/index.d.ts.map +1 -0
  61. package/dist/cli/index.js +99 -0
  62. package/dist/cli/index.js.map +1 -0
  63. package/dist/cli/output.d.ts +48 -0
  64. package/dist/cli/output.d.ts.map +1 -0
  65. package/dist/cli/output.js +139 -0
  66. package/dist/cli/output.js.map +1 -0
  67. package/dist/client.d.ts +46 -0
  68. package/dist/client.d.ts.map +1 -0
  69. package/dist/client.js +146 -0
  70. package/dist/client.js.map +1 -0
  71. package/dist/handlers.d.ts +11 -0
  72. package/dist/handlers.d.ts.map +1 -0
  73. package/dist/handlers.js +424 -0
  74. package/dist/handlers.js.map +1 -0
  75. package/dist/http-server.d.ts +25 -0
  76. package/dist/http-server.d.ts.map +1 -0
  77. package/dist/http-server.js +246 -0
  78. package/dist/http-server.js.map +1 -0
  79. package/dist/index.d.ts +3 -0
  80. package/dist/index.d.ts.map +1 -0
  81. package/dist/index.js +40 -0
  82. package/dist/index.js.map +1 -0
  83. package/dist/mcp/handlers.d.ts +11 -0
  84. package/dist/mcp/handlers.d.ts.map +1 -0
  85. package/dist/mcp/handlers.js +553 -0
  86. package/dist/mcp/handlers.js.map +1 -0
  87. package/dist/mcp/http-server.d.ts +25 -0
  88. package/dist/mcp/http-server.d.ts.map +1 -0
  89. package/dist/mcp/http-server.js +246 -0
  90. package/dist/mcp/http-server.js.map +1 -0
  91. package/dist/mcp/index.d.ts +3 -0
  92. package/dist/mcp/index.d.ts.map +1 -0
  93. package/dist/mcp/index.js +40 -0
  94. package/dist/mcp/index.js.map +1 -0
  95. package/dist/mcp/tools.d.ts +944 -0
  96. package/dist/mcp/tools.d.ts.map +1 -0
  97. package/dist/mcp/tools.js +531 -0
  98. package/dist/mcp/tools.js.map +1 -0
  99. package/dist/shared/client.d.ts +59 -0
  100. package/dist/shared/client.d.ts.map +1 -0
  101. package/dist/shared/client.js +171 -0
  102. package/dist/shared/client.js.map +1 -0
  103. package/dist/shared/errors.d.ts +25 -0
  104. package/dist/shared/errors.d.ts.map +1 -0
  105. package/dist/shared/errors.js +44 -0
  106. package/dist/shared/errors.js.map +1 -0
  107. package/dist/shared/types.d.ts +111 -0
  108. package/dist/shared/types.d.ts.map +1 -0
  109. package/dist/shared/types.js +10 -0
  110. package/dist/shared/types.js.map +1 -0
  111. package/dist/tools.d.ts +944 -0
  112. package/dist/tools.d.ts.map +1 -0
  113. package/dist/tools.js +513 -0
  114. package/dist/tools.js.map +1 -0
  115. package/dist/trust/chain.d.ts +86 -0
  116. package/dist/trust/chain.d.ts.map +1 -0
  117. package/dist/trust/chain.js +176 -0
  118. package/dist/trust/chain.js.map +1 -0
  119. package/dist/trust/git-binding.d.ts +61 -0
  120. package/dist/trust/git-binding.d.ts.map +1 -0
  121. package/dist/trust/git-binding.js +133 -0
  122. package/dist/trust/git-binding.js.map +1 -0
  123. package/dist/trust/index.d.ts +20 -0
  124. package/dist/trust/index.d.ts.map +1 -0
  125. package/dist/trust/index.js +17 -0
  126. package/dist/trust/index.js.map +1 -0
  127. package/dist/trust/ledger.d.ts +144 -0
  128. package/dist/trust/ledger.d.ts.map +1 -0
  129. package/dist/trust/ledger.js +351 -0
  130. package/dist/trust/ledger.js.map +1 -0
  131. package/dist/trust/signing.d.ts +134 -0
  132. package/dist/trust/signing.d.ts.map +1 -0
  133. package/dist/trust/signing.js +249 -0
  134. package/dist/trust/signing.js.map +1 -0
  135. package/dist/trust/transmission.d.ts +129 -0
  136. package/dist/trust/transmission.d.ts.map +1 -0
  137. package/dist/trust/transmission.js +390 -0
  138. package/dist/trust/transmission.js.map +1 -0
  139. package/dist/types.d.ts +183 -0
  140. package/dist/types.d.ts.map +1 -0
  141. package/dist/types.js +3 -0
  142. package/dist/types.js.map +1 -0
  143. 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":"AAAA;;;;;;;GAOG;AAMH,OAAO,EACL,WAAW,EACX,UAAU,EACV,aAAa,EACb,WAAW,GACZ,MAAM,cAAc,CAAC;AAEtB,MAAM,UAAU,wBAAwB,CACtC,MAAe,EACf,MAAqB;IAErB,MAAM,QAAQ,GAAG,MAAM;SACpB,OAAO,CAAC,UAAU,CAAC;SACnB,WAAW,CAAC,sBAAsB,CAAC,CAAC;IAEvC,4EAA4E;IAC5E,kBAAkB;IAClB,4EAA4E;IAE5E,QAAQ;SACL,OAAO,CAAC,QAAQ,CAAC;SACjB,WAAW,CAAC,4BAA4B,CAAC;SACzC,cAAc,CAAC,qBAAqB,EAAE,YAAY,CAAC;SACnD,cAAc,CAAC,mBAAmB,EAAE,cAAc,CAAC;SACnD,cAAc,CAAC,cAAc,EAAE,SAAS,CAAC;SACzC,cAAc,CAAC,eAAe,EAAE,qDAAqD,CAAC;SACtF,cAAc,CAAC,qBAAqB,EAAE,4BAA4B,CAAC;SACnE,MAAM,CAAC,oBAAoB,EAAE,iCAAiC,EAAE,EAAE,CAAC;SACnE,MAAM,CAAC,QAAQ,EAAE,iBAAiB,CAAC;SACnC,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;QACrB,IAAI,CAAC;YACH,MAAM,IAAI,GAA4B;gBACpC,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,OAAO,EAAE,IAAI,CAAC,OAAO;gBACrB,SAAS,EAAE,IAAI,CAAC,QAAQ;oBACtB,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC;oBACvE,CAAC,CAAC,EAAE;aACP,CAAC;YAEF,MAAM,IAAI,GAAG,CAAC,MAAM,MAAM,CAAC,IAAI,CAC7B,iBAAiB,IAAI,CAAC,OAAO,eAAe,IAAI,CAAC,SAAS,UAAU,IAAI,CAAC,IAAI,WAAW,EACxF,IAAI,CACL,CAAa,CAAC;YAEf,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;gBACd,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;gBAC9B,OAAO;YACT,CAAC;YAED,MAAM,UAAU,GAAG,IAAI,CAAC,EAAE,IAAI,GAAG,CAAC;YAClC,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,uBAAuB,UAAU,EAAE,CAAC,CAAC,CAAC;YAChE,OAAO,CAAC,GAAG,CACT,WAAW,CACT,CAAC,OAAO,EAAE,OAAO,CAAC,EAClB;gBACE,CAAC,IAAI,EAAE,UAAU,CAAC;gBAClB,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC;gBAChC,CAAC,SAAS,EAAE,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC;gBACzC,CAAC,cAAc,EAAE,IAAI,CAAC,YAAY,IAAI,GAAG,CAAC;aAC3C,CACF,CACF,CAAC;QACJ,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,GAA4B,CAAC,CAAC,CAAC;YACzD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,CAAC;IACH,CAAC,CAAC,CAAC;IAEL,4EAA4E;IAC5E,gBAAgB;IAChB,4EAA4E;IAE5E,QAAQ;SACL,OAAO,CAAC,MAAM,CAAC;SACf,WAAW,CAAC,0BAA0B,CAAC;SACvC,cAAc,CAAC,qBAAqB,EAAE,YAAY,CAAC;SACnD,cAAc,CAAC,mBAAmB,EAAE,cAAc,CAAC;SACnD,cAAc,CAAC,cAAc,EAAE,SAAS,CAAC;SACzC,MAAM,CAAC,QAAQ,EAAE,iBAAiB,CAAC;SACnC,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;QACrB,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,MAAM,MAAM,CAAC,GAAG,CAC3B,iBAAiB,IAAI,CAAC,OAAO,eAAe,IAAI,CAAC,SAAS,UAAU,IAAI,CAAC,IAAI,WAAW,CACzF,CAAC;YAEF,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;gBACd,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;gBAC9B,OAAO;YACT,CAAC;YAED,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC;gBAC/B,CAAC,CAAE,IAAmB;gBACtB,CAAC,CAAC,CAAE,IAAkC,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC;YAEzD,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACvB,OAAO,CAAC,GAAG,CAAC,sCAAsC,CAAC,CAAC;gBACpD,OAAO;YACT,CAAC;YAED,OAAO,CAAC,GAAG,CACT,WAAW,CACT,CAAC,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,cAAc,CAAC,EACzC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;gBACf,CAAC,CAAC,EAAE;gBACJ,CAAC,CAAC,IAAI;gBACN,CAAC,CAAC,OAAO,CAAC,MAAM,GAAG,EAAE;oBACnB,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,KAAK;oBACpC,CAAC,CAAC,CAAC,CAAC,OAAO;gBACb,CAAC,CAAC,YAAY;aACf,CAAC,CACH,CACF,CAAC;QACJ,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,GAA4B,CAAC,CAAC,CAAC;YACzD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -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