cngkit 1.1.6 → 1.1.7
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/README.md +7 -4
- package/dist/{chunk-F6YQGKLK.js → chunk-EQEIX7N5.js} +3 -3
- package/dist/chunk-EQEIX7N5.js.map +1 -0
- package/dist/chunk-HUZZPV5E.js +411 -0
- package/dist/chunk-HUZZPV5E.js.map +1 -0
- package/dist/{chunk-YY2VGJ5N.js → chunk-MLKBG5YJ.js} +2 -2
- package/dist/{chunk-YY2VGJ5N.js.map → chunk-MLKBG5YJ.js.map} +1 -1
- package/dist/{chunk-Z3J7PPZB.js → chunk-QEZQGKFX.js} +13 -1364
- package/dist/{chunk-Z3J7PPZB.js.map → chunk-QEZQGKFX.js.map} +1 -1
- package/dist/chunk-QZEB4VMX.js +32 -0
- package/dist/chunk-QZEB4VMX.js.map +1 -0
- package/dist/chunk-TZKXST4G.js +291 -0
- package/dist/chunk-TZKXST4G.js.map +1 -0
- package/dist/{chunk-SSRUN6G5.js → chunk-VI5XQH3U.js} +3 -18
- package/dist/chunk-VI5XQH3U.js.map +1 -0
- package/dist/chunk-XDXRVTPK.js +18 -0
- package/dist/chunk-XDXRVTPK.js.map +1 -0
- package/dist/{chunk-SNTLRTQ2.js → chunk-Z4DDLEWR.js} +3 -3
- package/dist/chunk-Z4DDLEWR.js.map +1 -0
- package/dist/cli.js +8 -6
- package/dist/cli.js.map +1 -1
- package/dist/commands/coderoom/index.js +6 -5
- package/dist/commands/coderoom/index.js.map +1 -1
- package/dist/commands/coderoom/join.js +6 -5
- package/dist/commands/coderoom/join.js.map +1 -1
- package/dist/commands/coderoom/share.js +6 -5
- package/dist/commands/coderoom/share.js.map +1 -1
- package/dist/commands/index.js +5 -4
- package/dist/commands/index.js.map +1 -1
- package/dist/commands/knowledges/audiences.js +8 -5
- package/dist/commands/knowledges/audiences.js.map +1 -1
- package/dist/commands/knowledges/files.js +8 -5
- package/dist/commands/knowledges/files.js.map +1 -1
- package/dist/commands/knowledges/glob.js +8 -5
- package/dist/commands/knowledges/glob.js.map +1 -1
- package/dist/commands/knowledges/grep.js +8 -5
- package/dist/commands/knowledges/grep.js.map +1 -1
- package/dist/commands/knowledges/index.js +6 -5
- package/dist/commands/knowledges/index.js.map +1 -1
- package/dist/commands/knowledges/list.js +8 -5
- package/dist/commands/knowledges/list.js.map +1 -1
- package/dist/commands/knowledges/read.js +8 -5
- package/dist/commands/knowledges/read.js.map +1 -1
- package/dist/commands/knowledges/search.js +8 -5
- package/dist/commands/knowledges/search.js.map +1 -1
- package/dist/commands/knowledges/status.js +8 -5
- package/dist/commands/knowledges/status.js.map +1 -1
- package/dist/commands/login.js +49 -6
- package/dist/commands/login.js.map +1 -1
- package/dist/commands/scrub.js +256 -7
- package/dist/commands/scrub.js.map +1 -1
- package/dist/commands/transcripts.js +377 -6
- package/dist/commands/transcripts.js.map +1 -1
- package/package.json +1 -1
- package/dist/chunk-F6YQGKLK.js.map +0 -1
- package/dist/chunk-SNTLRTQ2.js.map +0 -1
- package/dist/chunk-SSRUN6G5.js.map +0 -1
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
// src/shared/command-utils.ts
|
|
2
|
+
function coerceLimit(value, defaultValue, maxValue = 100) {
|
|
3
|
+
const normalizedValue = coerceOptionalNumber(value);
|
|
4
|
+
if (normalizedValue === void 0 || Number.isNaN(normalizedValue)) {
|
|
5
|
+
return defaultValue;
|
|
6
|
+
}
|
|
7
|
+
return Math.max(defaultValue === 0 ? 0 : 1, Math.min(maxValue, Math.trunc(normalizedValue)));
|
|
8
|
+
}
|
|
9
|
+
function coerceOptionalNumber(value) {
|
|
10
|
+
if (value === void 0 || value === "") {
|
|
11
|
+
return void 0;
|
|
12
|
+
}
|
|
13
|
+
return Number(value);
|
|
14
|
+
}
|
|
15
|
+
function formatJson(value) {
|
|
16
|
+
return JSON.stringify(value, null, 2);
|
|
17
|
+
}
|
|
18
|
+
function optionalJoinedArgument(values) {
|
|
19
|
+
return values.length > 0 ? values.join(" ") : void 0;
|
|
20
|
+
}
|
|
21
|
+
function singleLine(value) {
|
|
22
|
+
return value.replace(/\s+/g, " ").trim();
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
export {
|
|
26
|
+
coerceLimit,
|
|
27
|
+
coerceOptionalNumber,
|
|
28
|
+
formatJson,
|
|
29
|
+
optionalJoinedArgument,
|
|
30
|
+
singleLine
|
|
31
|
+
};
|
|
32
|
+
//# sourceMappingURL=chunk-QZEB4VMX.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/shared/command-utils.ts"],"sourcesContent":["export type JsonOutputOptions = {\n json?: boolean;\n};\n\nexport type NumberOption = number | string;\n\nexport function coerceLimit(\n value: NumberOption | undefined,\n defaultValue: number,\n maxValue = 100\n): number {\n const normalizedValue = coerceOptionalNumber(value);\n if (normalizedValue === undefined || Number.isNaN(normalizedValue)) {\n return defaultValue;\n }\n return Math.max(defaultValue === 0 ? 0 : 1, Math.min(maxValue, Math.trunc(normalizedValue)));\n}\n\nexport function coerceOptionalNumber(value: NumberOption | undefined): number | undefined {\n if (value === undefined || value === \"\") {\n return undefined;\n }\n return Number(value);\n}\n\nexport function formatJson(value: unknown): string {\n return JSON.stringify(value, null, 2);\n}\n\nexport function optionalJoinedArgument(values: string[]): string | undefined {\n return values.length > 0 ? values.join(\" \") : undefined;\n}\n\nexport function singleLine(value: string): string {\n return value.replace(/\\s+/g, \" \").trim();\n}\n"],"mappings":";AAMO,SAAS,YACd,OACA,cACA,WAAW,KACH;AACR,QAAM,kBAAkB,qBAAqB,KAAK;AAClD,MAAI,oBAAoB,UAAa,OAAO,MAAM,eAAe,GAAG;AAClE,WAAO;AAAA,EACT;AACA,SAAO,KAAK,IAAI,iBAAiB,IAAI,IAAI,GAAG,KAAK,IAAI,UAAU,KAAK,MAAM,eAAe,CAAC,CAAC;AAC7F;AAEO,SAAS,qBAAqB,OAAqD;AACxF,MAAI,UAAU,UAAa,UAAU,IAAI;AACvC,WAAO;AAAA,EACT;AACA,SAAO,OAAO,KAAK;AACrB;AAEO,SAAS,WAAW,OAAwB;AACjD,SAAO,KAAK,UAAU,OAAO,MAAM,CAAC;AACtC;AAEO,SAAS,uBAAuB,QAAsC;AAC3E,SAAO,OAAO,SAAS,IAAI,OAAO,KAAK,GAAG,IAAI;AAChD;AAEO,SAAS,WAAW,OAAuB;AAChD,SAAO,MAAM,QAAQ,QAAQ,GAAG,EAAE,KAAK;AACzC;","names":[]}
|
|
@@ -0,0 +1,291 @@
|
|
|
1
|
+
import {
|
|
2
|
+
coerceLimit,
|
|
3
|
+
coerceOptionalNumber,
|
|
4
|
+
formatJson,
|
|
5
|
+
singleLine
|
|
6
|
+
} from "./chunk-QZEB4VMX.js";
|
|
7
|
+
import {
|
|
8
|
+
createCngApiClient
|
|
9
|
+
} from "./chunk-QEZQGKFX.js";
|
|
10
|
+
|
|
11
|
+
// src/features/knowledges/knowledges-api.ts
|
|
12
|
+
function createKnowledgesApi(options) {
|
|
13
|
+
const client = createCngApiClient(options);
|
|
14
|
+
return {
|
|
15
|
+
getCatalog: () => client.harnessKnowledges.getHarnessKnowledgesCatalog(),
|
|
16
|
+
listAudiences: () => client.harnessKnowledges.listHarnessKnowledgesAudiences(),
|
|
17
|
+
search: (query, limit) => client.harnessKnowledges.searchHarnessKnowledges({
|
|
18
|
+
q: query,
|
|
19
|
+
limit
|
|
20
|
+
}),
|
|
21
|
+
listSubskills: () => client.harnessKnowledges.listHarnessKnowledgesSubskills(),
|
|
22
|
+
listFiles: ({ query, audience, limit }) => client.harnessKnowledges.listHarnessSubskillAssets({
|
|
23
|
+
...query ? { q: query } : {},
|
|
24
|
+
...audience ? { audience } : {},
|
|
25
|
+
limit
|
|
26
|
+
}),
|
|
27
|
+
read: ({ filePath, offset, limit }) => client.harnessFilesystem.getHarnessFilesystemRead({
|
|
28
|
+
file_path: filePath,
|
|
29
|
+
offset,
|
|
30
|
+
limit
|
|
31
|
+
}),
|
|
32
|
+
grep: ({ pattern, path, include, mode, context, ignoreCase }) => client.harnessFilesystem.getHarnessFilesystemGrep({
|
|
33
|
+
pattern,
|
|
34
|
+
path,
|
|
35
|
+
include,
|
|
36
|
+
output_mode: mode,
|
|
37
|
+
context,
|
|
38
|
+
case_insensitive: ignoreCase ? "true" : void 0
|
|
39
|
+
}),
|
|
40
|
+
glob: ({ pattern, path }) => client.harnessFilesystem.getHarnessFilesystemGlob({
|
|
41
|
+
pattern,
|
|
42
|
+
path
|
|
43
|
+
})
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
// src/features/knowledges/knowledges-input.ts
|
|
48
|
+
function normalizeAudienceId(value) {
|
|
49
|
+
if (value === void 0) {
|
|
50
|
+
return void 0;
|
|
51
|
+
}
|
|
52
|
+
switch (value) {
|
|
53
|
+
case "all":
|
|
54
|
+
case "operators":
|
|
55
|
+
case "builders":
|
|
56
|
+
case "researchers":
|
|
57
|
+
case "agent-makers":
|
|
58
|
+
return value;
|
|
59
|
+
default:
|
|
60
|
+
throw new Error(
|
|
61
|
+
`Unknown audience "${value}". Run cngkit knowledges audiences to see supported values.`
|
|
62
|
+
);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
function normalizeCatalogPath(value) {
|
|
66
|
+
const trimmed = value.trim();
|
|
67
|
+
if (trimmed === "/" || trimmed === "") {
|
|
68
|
+
return "skills";
|
|
69
|
+
}
|
|
70
|
+
const relativePath = trimmed.replace(/^\/+/, "");
|
|
71
|
+
if (relativePath.startsWith("skills/knowledges/")) {
|
|
72
|
+
return relativePath;
|
|
73
|
+
}
|
|
74
|
+
const [firstSegment, ...restSegments] = relativePath.split("/");
|
|
75
|
+
if (!firstSegment) {
|
|
76
|
+
return relativePath;
|
|
77
|
+
}
|
|
78
|
+
switch (firstSegment) {
|
|
79
|
+
case "concepts":
|
|
80
|
+
case "domains":
|
|
81
|
+
case "formats":
|
|
82
|
+
case "languages":
|
|
83
|
+
case "libraries":
|
|
84
|
+
case "patterns":
|
|
85
|
+
case "platforms":
|
|
86
|
+
case "procedures":
|
|
87
|
+
case "protocols":
|
|
88
|
+
case "tools":
|
|
89
|
+
return `skills/knowledges/subskills/${firstSegment}${restSegments.length > 0 ? `/${restSegments.join("/")}` : ""}`;
|
|
90
|
+
default:
|
|
91
|
+
return relativePath;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
function normalizeGrepMode(value) {
|
|
95
|
+
if (value === void 0) {
|
|
96
|
+
return "content";
|
|
97
|
+
}
|
|
98
|
+
switch (value) {
|
|
99
|
+
case "content":
|
|
100
|
+
case "files_with_matches":
|
|
101
|
+
case "count":
|
|
102
|
+
return value;
|
|
103
|
+
default:
|
|
104
|
+
throw new Error("Unknown grep mode. Use one of: content, files_with_matches, count.");
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
// src/features/knowledges/run-knowledges-command.ts
|
|
109
|
+
async function runKnowStatusCommand(options, output, dependencies) {
|
|
110
|
+
const api = dependencies?.api ?? createKnowledgesApi(options);
|
|
111
|
+
const response = await api.getCatalog();
|
|
112
|
+
if (options.json) {
|
|
113
|
+
output.info(formatJson(response.data));
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
const latestRun = response.data.latestRun;
|
|
117
|
+
const lines = [
|
|
118
|
+
`Catalog: ${response.data.name}`,
|
|
119
|
+
`Files: ${response.data.files}`,
|
|
120
|
+
`Blobs: ${response.data.blobs}`,
|
|
121
|
+
`Vectorize: ${response.data.vectorize.index} (${response.data.vectorize.binding})`
|
|
122
|
+
];
|
|
123
|
+
if (latestRun) {
|
|
124
|
+
lines.push(`Latest run: ${latestRun.status} (${latestRun.id})`);
|
|
125
|
+
if (latestRun.updated_at) {
|
|
126
|
+
lines.push(`Updated: ${latestRun.updated_at}`);
|
|
127
|
+
}
|
|
128
|
+
} else {
|
|
129
|
+
lines.push("Latest run: none");
|
|
130
|
+
}
|
|
131
|
+
output.info(lines.join("\n"));
|
|
132
|
+
}
|
|
133
|
+
async function runKnowAudiencesCommand(options, output, dependencies) {
|
|
134
|
+
const api = dependencies?.api ?? createKnowledgesApi(options);
|
|
135
|
+
const response = await api.listAudiences();
|
|
136
|
+
if (options.json) {
|
|
137
|
+
output.info(formatJson(response.data));
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
140
|
+
const lines = response.data.audiences.flatMap((audience) => [
|
|
141
|
+
`${audience.id} - ${audience.label}`,
|
|
142
|
+
` ${singleLine(audience.help)}`
|
|
143
|
+
]);
|
|
144
|
+
output.info(lines.length > 0 ? lines.join("\n") : "No audiences available.");
|
|
145
|
+
}
|
|
146
|
+
async function runKnowSearchCommand(query, options, output, dependencies) {
|
|
147
|
+
if (!query) {
|
|
148
|
+
throw new Error("Missing search query. Usage: cngkit knowledges search <query>");
|
|
149
|
+
}
|
|
150
|
+
const api = dependencies?.api ?? createKnowledgesApi(options);
|
|
151
|
+
const response = await api.search(query, coerceLimit(options.limit, 5));
|
|
152
|
+
if (options.json) {
|
|
153
|
+
output.info(formatJson(response.data));
|
|
154
|
+
return;
|
|
155
|
+
}
|
|
156
|
+
const lines = response.data.results.flatMap((result, index) => [
|
|
157
|
+
`${index + 1}. ${result.title} (${result.subskillName})`,
|
|
158
|
+
` score ${result.score.toFixed(3)} | ${result.path}`,
|
|
159
|
+
` ${singleLine(result.description || result.contentPreview)}`
|
|
160
|
+
]);
|
|
161
|
+
output.info(lines.length > 0 ? lines.join("\n") : `No results for "${query}".`);
|
|
162
|
+
}
|
|
163
|
+
async function runKnowListCommand(query, options, output, dependencies) {
|
|
164
|
+
const api = dependencies?.api ?? createKnowledgesApi(options);
|
|
165
|
+
const response = await api.listSubskills();
|
|
166
|
+
const limit = coerceLimit(options.limit, 25);
|
|
167
|
+
const normalizedQuery = query?.toLowerCase();
|
|
168
|
+
const subskills = response.data.subskills.filter((subskill) => {
|
|
169
|
+
if (!normalizedQuery) {
|
|
170
|
+
return true;
|
|
171
|
+
}
|
|
172
|
+
return [subskill.name, subskill.title, subskill.description, subskill.type].join(" ").toLowerCase().includes(normalizedQuery);
|
|
173
|
+
}).slice(0, limit);
|
|
174
|
+
if (options.json) {
|
|
175
|
+
output.info(formatJson({ subskills, total: subskills.length }));
|
|
176
|
+
return;
|
|
177
|
+
}
|
|
178
|
+
const lines = subskills.flatMap((subskill) => [
|
|
179
|
+
`${subskill.name} [${subskill.type}]`,
|
|
180
|
+
` ${subskill.title} | files ${subskill.fileCount} | rating ${subskill.rating}`,
|
|
181
|
+
` ${singleLine(subskill.description)}`
|
|
182
|
+
]);
|
|
183
|
+
output.info(lines.length > 0 ? lines.join("\n") : "No matching subskills.");
|
|
184
|
+
}
|
|
185
|
+
async function runKnowFilesCommand(query, options, output, dependencies) {
|
|
186
|
+
const api = dependencies?.api ?? createKnowledgesApi(options);
|
|
187
|
+
const response = await api.listFiles({
|
|
188
|
+
query,
|
|
189
|
+
audience: normalizeAudienceId(options.audience),
|
|
190
|
+
limit: coerceLimit(options.limit, 25)
|
|
191
|
+
});
|
|
192
|
+
if (options.json) {
|
|
193
|
+
output.info(formatJson(response.data));
|
|
194
|
+
return;
|
|
195
|
+
}
|
|
196
|
+
const lines = response.data.files.map((file) => {
|
|
197
|
+
const title = file.display_title ?? file.title ?? file.subskill_name ?? "Untitled";
|
|
198
|
+
return `${file.path}
|
|
199
|
+
${title}`;
|
|
200
|
+
});
|
|
201
|
+
output.info(lines.length > 0 ? lines.join("\n") : "No matching files.");
|
|
202
|
+
}
|
|
203
|
+
async function runKnowReadCommand(filePath, options, output, dependencies) {
|
|
204
|
+
if (!filePath) {
|
|
205
|
+
throw new Error("Missing file_path. Usage: cngkit knowledges read <file_path>");
|
|
206
|
+
}
|
|
207
|
+
const api = dependencies?.api ?? createKnowledgesApi(options);
|
|
208
|
+
const response = await api.read({
|
|
209
|
+
filePath: normalizeCatalogPath(filePath),
|
|
210
|
+
offset: coerceOptionalNumber(options.offset),
|
|
211
|
+
limit: coerceLimit(options.limit, 200, 2e3)
|
|
212
|
+
});
|
|
213
|
+
if (options.json) {
|
|
214
|
+
output.info(formatJson(response.data));
|
|
215
|
+
return;
|
|
216
|
+
}
|
|
217
|
+
output.info(response.data.content);
|
|
218
|
+
if (response.data.truncated) {
|
|
219
|
+
output.info(
|
|
220
|
+
`[truncated: showing ${response.data.limit} lines from offset ${response.data.offset} of ${response.data.total_lines}]`
|
|
221
|
+
);
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
async function runKnowGrepCommand(pattern, options, output, dependencies) {
|
|
225
|
+
if (!pattern) {
|
|
226
|
+
throw new Error("Missing pattern. Usage: cngkit knowledges grep <pattern>");
|
|
227
|
+
}
|
|
228
|
+
const api = dependencies?.api ?? createKnowledgesApi(options);
|
|
229
|
+
const limit = options.limit !== void 0 ? coerceOptionalNumber(options.limit) : void 0;
|
|
230
|
+
const response = await api.grep({
|
|
231
|
+
pattern,
|
|
232
|
+
path: normalizeCatalogPath(options.path ?? "/"),
|
|
233
|
+
include: options.include ?? "*",
|
|
234
|
+
mode: normalizeGrepMode(options.outputMode),
|
|
235
|
+
context: coerceLimit(options.context, 0, 20),
|
|
236
|
+
ignoreCase: options.caseInsensitive === true
|
|
237
|
+
});
|
|
238
|
+
if (options.json) {
|
|
239
|
+
output.info(formatJson(response.data));
|
|
240
|
+
return;
|
|
241
|
+
}
|
|
242
|
+
if (response.data.mode === "files_with_matches") {
|
|
243
|
+
const files = limit ? response.data.files.slice(0, limit) : response.data.files;
|
|
244
|
+
output.info(files.length > 0 ? files.join("\n") : `No files matched "${pattern}".`);
|
|
245
|
+
return;
|
|
246
|
+
}
|
|
247
|
+
if (response.data.mode === "count") {
|
|
248
|
+
const counts = limit ? response.data.counts.slice(0, limit) : response.data.counts;
|
|
249
|
+
const lines2 = counts.map((count) => `${count.file_path}: ${count.match_count}`);
|
|
250
|
+
output.info(lines2.length > 0 ? lines2.join("\n") : `No matches for "${pattern}".`);
|
|
251
|
+
return;
|
|
252
|
+
}
|
|
253
|
+
const matches = limit ? response.data.matches.slice(0, limit) : response.data.matches;
|
|
254
|
+
const lines = matches.flatMap((match) => [
|
|
255
|
+
`${match.file_path}:${match.line_number}`,
|
|
256
|
+
...match.context_before.map((line) => ` ${line}`),
|
|
257
|
+
`> ${match.line}`,
|
|
258
|
+
...match.context_after.map((line) => ` ${line}`)
|
|
259
|
+
]);
|
|
260
|
+
output.info(lines.length > 0 ? lines.join("\n") : `No matches for "${pattern}".`);
|
|
261
|
+
}
|
|
262
|
+
async function runKnowGlobCommand(pattern, options, output, dependencies) {
|
|
263
|
+
const api = dependencies?.api ?? createKnowledgesApi(options);
|
|
264
|
+
const limit = options.limit !== void 0 ? coerceOptionalNumber(options.limit) : void 0;
|
|
265
|
+
const response = await api.glob({
|
|
266
|
+
pattern: pattern ?? "**/*.md",
|
|
267
|
+
path: normalizeCatalogPath(options.path ?? "/")
|
|
268
|
+
});
|
|
269
|
+
if (options.json) {
|
|
270
|
+
output.info(formatJson(response.data));
|
|
271
|
+
return;
|
|
272
|
+
}
|
|
273
|
+
const files = limit ? response.data.files.slice(0, limit) : response.data.files;
|
|
274
|
+
const wasClientTruncated = limit ? response.data.files.length > limit : false;
|
|
275
|
+
output.info(files.length > 0 ? files.join("\n") : "No matching files.");
|
|
276
|
+
if (response.data.truncated || wasClientTruncated) {
|
|
277
|
+
output.info(`[truncated: ${response.data.total_files} total files]`);
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
|
|
281
|
+
export {
|
|
282
|
+
runKnowStatusCommand,
|
|
283
|
+
runKnowAudiencesCommand,
|
|
284
|
+
runKnowSearchCommand,
|
|
285
|
+
runKnowListCommand,
|
|
286
|
+
runKnowFilesCommand,
|
|
287
|
+
runKnowReadCommand,
|
|
288
|
+
runKnowGrepCommand,
|
|
289
|
+
runKnowGlobCommand
|
|
290
|
+
};
|
|
291
|
+
//# sourceMappingURL=chunk-TZKXST4G.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/features/knowledges/knowledges-api.ts","../src/features/knowledges/knowledges-input.ts","../src/features/knowledges/run-knowledges-command.ts"],"sourcesContent":["import type { CngApi } from \"@cng/client\";\n\nimport { createCngApiClient } from \"../../shared/api-client.js\";\nimport type { GlobalCommandOptions } from \"../../shared/config.js\";\n\nexport type KnowCommandDependencies = {\n api?: KnowledgesApi;\n};\n\nexport type KnowledgesApi = {\n getCatalog(): Promise<CngApi.HarnessCatalogSummaryApiResponse>;\n listAudiences(): Promise<CngApi.HarnessAudiencesApiResponse>;\n search(query: string, limit: number): Promise<CngApi.HarnessSemanticSearchApiResponse>;\n listSubskills(): Promise<CngApi.HarnessSubskillsApiResponse>;\n listFiles(options: {\n query?: string;\n audience?: CngApi.HarnessAudienceId;\n limit: number;\n }): Promise<CngApi.HarnessSubskillAssetsApiResponse>;\n read(options: {\n filePath: string;\n offset?: number;\n limit: number;\n }): Promise<CngApi.HarnessReadApiResponse>;\n grep(options: {\n pattern: string;\n path: string;\n include: string;\n mode: CngApi.HarnessGrepOutputMode;\n context: number;\n ignoreCase: boolean;\n }): Promise<CngApi.HarnessGrepApiResponse>;\n glob(options: { pattern: string; path: string }): Promise<CngApi.HarnessGlobApiResponse>;\n};\n\nexport function createKnowledgesApi(options: GlobalCommandOptions): KnowledgesApi {\n const client = createCngApiClient(options);\n\n return {\n getCatalog: () => client.harnessKnowledges.getHarnessKnowledgesCatalog(),\n listAudiences: () => client.harnessKnowledges.listHarnessKnowledgesAudiences(),\n search: (query, limit) =>\n client.harnessKnowledges.searchHarnessKnowledges({\n q: query,\n limit,\n }),\n listSubskills: () => client.harnessKnowledges.listHarnessKnowledgesSubskills(),\n listFiles: ({ query, audience, limit }) =>\n client.harnessKnowledges.listHarnessSubskillAssets({\n ...(query ? { q: query } : {}),\n ...(audience ? { audience } : {}),\n limit,\n }),\n read: ({ filePath, offset, limit }) =>\n client.harnessFilesystem.getHarnessFilesystemRead({\n file_path: filePath,\n offset,\n limit,\n }),\n grep: ({ pattern, path, include, mode, context, ignoreCase }) =>\n client.harnessFilesystem.getHarnessFilesystemGrep({\n pattern,\n path,\n include,\n output_mode: mode,\n context,\n case_insensitive: ignoreCase ? \"true\" : undefined,\n }),\n glob: ({ pattern, path }) =>\n client.harnessFilesystem.getHarnessFilesystemGlob({\n pattern,\n path,\n }),\n };\n}\n","import type { CngApi } from \"@cng/client\";\n\nexport function normalizeAudienceId(value: string | undefined): CngApi.HarnessAudienceId | undefined {\n if (value === undefined) {\n return undefined;\n }\n\n switch (value) {\n case \"all\":\n case \"operators\":\n case \"builders\":\n case \"researchers\":\n case \"agent-makers\":\n return value;\n default:\n throw new Error(\n `Unknown audience \"${value}\". Run cngkit knowledges audiences to see supported values.`\n );\n }\n}\n\nexport function normalizeCatalogPath(value: string): string {\n const trimmed = value.trim();\n if (trimmed === \"/\" || trimmed === \"\") {\n return \"skills\";\n }\n\n const relativePath = trimmed.replace(/^\\/+/, \"\");\n if (relativePath.startsWith(\"skills/knowledges/\")) {\n return relativePath;\n }\n\n const [firstSegment, ...restSegments] = relativePath.split(\"/\");\n if (!firstSegment) {\n return relativePath;\n }\n\n switch (firstSegment) {\n case \"concepts\":\n case \"domains\":\n case \"formats\":\n case \"languages\":\n case \"libraries\":\n case \"patterns\":\n case \"platforms\":\n case \"procedures\":\n case \"protocols\":\n case \"tools\":\n return `skills/knowledges/subskills/${firstSegment}${restSegments.length > 0 ? `/${restSegments.join(\"/\")}` : \"\"}`;\n default:\n return relativePath;\n }\n}\n\nexport function normalizeGrepMode(value: string | undefined): CngApi.HarnessGrepOutputMode {\n if (value === undefined) {\n return \"content\";\n }\n\n switch (value) {\n case \"content\":\n case \"files_with_matches\":\n case \"count\":\n return value;\n default:\n throw new Error(\"Unknown grep mode. Use one of: content, files_with_matches, count.\");\n }\n}\n","import { formatKnowledgesHelp } from \"../../cli/help-specs.js\";\nimport {\n coerceLimit,\n coerceOptionalNumber,\n formatJson,\n optionalJoinedArgument,\n singleLine,\n type JsonOutputOptions,\n type NumberOption,\n} from \"../../shared/command-utils.js\";\nimport type { GlobalCommandOptions } from \"../../shared/config.js\";\nimport type { CommandOutput } from \"../../shared/output.js\";\nimport { createKnowledgesApi, type KnowCommandDependencies } from \"./knowledges-api.js\";\nimport { normalizeAudienceId, normalizeCatalogPath, normalizeGrepMode } from \"./knowledges-input.js\";\n\nexport type KnowStatusCommandOptions = GlobalCommandOptions & JsonOutputOptions;\n\nexport type KnowAudiencesCommandOptions = GlobalCommandOptions & JsonOutputOptions;\n\nexport type KnowSearchCommandOptions = GlobalCommandOptions &\n JsonOutputOptions & {\n limit?: NumberOption;\n };\n\nexport type KnowListCommandOptions = GlobalCommandOptions &\n JsonOutputOptions & {\n limit?: NumberOption;\n };\n\nexport type KnowFilesCommandOptions = GlobalCommandOptions &\n JsonOutputOptions & {\n audience?: string;\n limit?: NumberOption;\n };\n\nexport type KnowReadCommandOptions = GlobalCommandOptions &\n JsonOutputOptions & {\n offset?: NumberOption;\n limit?: NumberOption;\n };\n\nexport type KnowGrepCommandOptions = GlobalCommandOptions &\n JsonOutputOptions & {\n path?: string;\n include?: string;\n outputMode?: string;\n context?: NumberOption;\n caseInsensitive?: boolean;\n limit?: NumberOption;\n };\n\nexport type KnowGlobCommandOptions = GlobalCommandOptions &\n JsonOutputOptions & {\n path?: string;\n limit?: NumberOption;\n };\n\nexport type KnowledgesCliOptions = KnowFilesCommandOptions &\n KnowGlobCommandOptions &\n KnowGrepCommandOptions &\n KnowReadCommandOptions &\n KnowSearchCommandOptions;\n\nexport async function runKnowledgesCommand(\n args: string[] | undefined,\n options: KnowledgesCliOptions,\n output: CommandOutput,\n dependencies?: KnowCommandDependencies\n): Promise<void> {\n const [subcommand, ...subcommandArgs] = args ?? [];\n\n if (subcommand === undefined || subcommand === \"help\") {\n output.info(formatKnowledgesHelp(subcommandArgs[0]));\n return;\n }\n\n switch (subcommand) {\n case \"status\":\n return runKnowStatusCommand(options, output, dependencies);\n case \"audiences\":\n return runKnowAudiencesCommand(options, output, dependencies);\n case \"search\":\n return runKnowSearchCommand(optionalJoinedArgument(subcommandArgs), options, output, dependencies);\n case \"list\":\n return runKnowListCommand(optionalJoinedArgument(subcommandArgs), options, output, dependencies);\n case \"files\":\n return runKnowFilesCommand(optionalJoinedArgument(subcommandArgs), options, output, dependencies);\n case \"read\":\n return runKnowReadCommand(subcommandArgs[0], options, output, dependencies);\n case \"grep\":\n return runKnowGrepCommand(optionalJoinedArgument(subcommandArgs), options, output, dependencies);\n case \"glob\":\n return runKnowGlobCommand(optionalJoinedArgument(subcommandArgs), options, output, dependencies);\n default:\n throw new Error(\n \"Missing knowledges command. Usage: cngkit knowledges <status|audiences|search|list|files|read|grep|glob>\"\n );\n }\n}\n\nexport async function runKnowStatusCommand(\n options: KnowStatusCommandOptions,\n output: CommandOutput,\n dependencies?: KnowCommandDependencies\n): Promise<void> {\n const api = dependencies?.api ?? createKnowledgesApi(options);\n const response = await api.getCatalog();\n\n if (options.json) {\n output.info(formatJson(response.data));\n return;\n }\n\n const latestRun = response.data.latestRun;\n const lines = [\n `Catalog: ${response.data.name}`,\n `Files: ${response.data.files}`,\n `Blobs: ${response.data.blobs}`,\n `Vectorize: ${response.data.vectorize.index} (${response.data.vectorize.binding})`,\n ];\n\n if (latestRun) {\n lines.push(`Latest run: ${latestRun.status} (${latestRun.id})`);\n if (latestRun.updated_at) {\n lines.push(`Updated: ${latestRun.updated_at}`);\n }\n } else {\n lines.push(\"Latest run: none\");\n }\n\n output.info(lines.join(\"\\n\"));\n}\n\nexport async function runKnowAudiencesCommand(\n options: KnowAudiencesCommandOptions,\n output: CommandOutput,\n dependencies?: KnowCommandDependencies\n): Promise<void> {\n const api = dependencies?.api ?? createKnowledgesApi(options);\n const response = await api.listAudiences();\n\n if (options.json) {\n output.info(formatJson(response.data));\n return;\n }\n\n const lines = response.data.audiences.flatMap((audience) => [\n `${audience.id} - ${audience.label}`,\n ` ${singleLine(audience.help)}`,\n ]);\n\n output.info(lines.length > 0 ? lines.join(\"\\n\") : \"No audiences available.\");\n}\n\nexport async function runKnowSearchCommand(\n query: string | undefined,\n options: KnowSearchCommandOptions,\n output: CommandOutput,\n dependencies?: KnowCommandDependencies\n): Promise<void> {\n if (!query) {\n throw new Error(\"Missing search query. Usage: cngkit knowledges search <query>\");\n }\n\n const api = dependencies?.api ?? createKnowledgesApi(options);\n const response = await api.search(query, coerceLimit(options.limit, 5));\n\n if (options.json) {\n output.info(formatJson(response.data));\n return;\n }\n\n const lines = response.data.results.flatMap((result, index) => [\n `${index + 1}. ${result.title} (${result.subskillName})`,\n ` score ${result.score.toFixed(3)} | ${result.path}`,\n ` ${singleLine(result.description || result.contentPreview)}`,\n ]);\n\n output.info(lines.length > 0 ? lines.join(\"\\n\") : `No results for \"${query}\".`);\n}\n\nexport async function runKnowListCommand(\n query: string | undefined,\n options: KnowListCommandOptions,\n output: CommandOutput,\n dependencies?: KnowCommandDependencies\n): Promise<void> {\n const api = dependencies?.api ?? createKnowledgesApi(options);\n const response = await api.listSubskills();\n const limit = coerceLimit(options.limit, 25);\n const normalizedQuery = query?.toLowerCase();\n const subskills = response.data.subskills\n .filter((subskill) => {\n if (!normalizedQuery) {\n return true;\n }\n return [subskill.name, subskill.title, subskill.description, subskill.type]\n .join(\" \")\n .toLowerCase()\n .includes(normalizedQuery);\n })\n .slice(0, limit);\n\n if (options.json) {\n output.info(formatJson({ subskills, total: subskills.length }));\n return;\n }\n\n const lines = subskills.flatMap((subskill) => [\n `${subskill.name} [${subskill.type}]`,\n ` ${subskill.title} | files ${subskill.fileCount} | rating ${subskill.rating}`,\n ` ${singleLine(subskill.description)}`,\n ]);\n\n output.info(lines.length > 0 ? lines.join(\"\\n\") : \"No matching subskills.\");\n}\n\nexport async function runKnowFilesCommand(\n query: string | undefined,\n options: KnowFilesCommandOptions,\n output: CommandOutput,\n dependencies?: KnowCommandDependencies\n): Promise<void> {\n const api = dependencies?.api ?? createKnowledgesApi(options);\n const response = await api.listFiles({\n query,\n audience: normalizeAudienceId(options.audience),\n limit: coerceLimit(options.limit, 25),\n });\n\n if (options.json) {\n output.info(formatJson(response.data));\n return;\n }\n\n const lines = response.data.files.map((file) => {\n const title = file.display_title ?? file.title ?? file.subskill_name ?? \"Untitled\";\n return `${file.path}\\n ${title}`;\n });\n\n output.info(lines.length > 0 ? lines.join(\"\\n\") : \"No matching files.\");\n}\n\nexport async function runKnowReadCommand(\n filePath: string | undefined,\n options: KnowReadCommandOptions,\n output: CommandOutput,\n dependencies?: KnowCommandDependencies\n): Promise<void> {\n if (!filePath) {\n throw new Error(\"Missing file_path. Usage: cngkit knowledges read <file_path>\");\n }\n\n const api = dependencies?.api ?? createKnowledgesApi(options);\n const response = await api.read({\n filePath: normalizeCatalogPath(filePath),\n offset: coerceOptionalNumber(options.offset),\n limit: coerceLimit(options.limit, 200, 2000),\n });\n\n if (options.json) {\n output.info(formatJson(response.data));\n return;\n }\n\n output.info(response.data.content);\n if (response.data.truncated) {\n output.info(\n `[truncated: showing ${response.data.limit} lines from offset ${response.data.offset} of ${response.data.total_lines}]`\n );\n }\n}\n\nexport async function runKnowGrepCommand(\n pattern: string | undefined,\n options: KnowGrepCommandOptions,\n output: CommandOutput,\n dependencies?: KnowCommandDependencies\n): Promise<void> {\n if (!pattern) {\n throw new Error(\"Missing pattern. Usage: cngkit knowledges grep <pattern>\");\n }\n\n const api = dependencies?.api ?? createKnowledgesApi(options);\n const limit = options.limit !== undefined ? coerceOptionalNumber(options.limit) : undefined;\n const response = await api.grep({\n pattern,\n path: normalizeCatalogPath(options.path ?? \"/\"),\n include: options.include ?? \"*\",\n mode: normalizeGrepMode(options.outputMode),\n context: coerceLimit(options.context, 0, 20),\n ignoreCase: options.caseInsensitive === true,\n });\n\n if (options.json) {\n output.info(formatJson(response.data));\n return;\n }\n\n if (response.data.mode === \"files_with_matches\") {\n const files = limit ? response.data.files.slice(0, limit) : response.data.files;\n output.info(files.length > 0 ? files.join(\"\\n\") : `No files matched \"${pattern}\".`);\n return;\n }\n\n if (response.data.mode === \"count\") {\n const counts = limit ? response.data.counts.slice(0, limit) : response.data.counts;\n const lines = counts.map((count) => `${count.file_path}: ${count.match_count}`);\n output.info(lines.length > 0 ? lines.join(\"\\n\") : `No matches for \"${pattern}\".`);\n return;\n }\n\n const matches = limit ? response.data.matches.slice(0, limit) : response.data.matches;\n const lines = matches.flatMap((match) => [\n `${match.file_path}:${match.line_number}`,\n ...match.context_before.map((line) => ` ${line}`),\n `> ${match.line}`,\n ...match.context_after.map((line) => ` ${line}`),\n ]);\n\n output.info(lines.length > 0 ? lines.join(\"\\n\") : `No matches for \"${pattern}\".`);\n}\n\nexport async function runKnowGlobCommand(\n pattern: string | undefined,\n options: KnowGlobCommandOptions,\n output: CommandOutput,\n dependencies?: KnowCommandDependencies\n): Promise<void> {\n const api = dependencies?.api ?? createKnowledgesApi(options);\n const limit = options.limit !== undefined ? coerceOptionalNumber(options.limit) : undefined;\n const response = await api.glob({\n pattern: pattern ?? \"**/*.md\",\n path: normalizeCatalogPath(options.path ?? \"/\"),\n });\n\n if (options.json) {\n output.info(formatJson(response.data));\n return;\n }\n\n const files = limit ? response.data.files.slice(0, limit) : response.data.files;\n const wasClientTruncated = limit ? response.data.files.length > limit : false;\n\n output.info(files.length > 0 ? files.join(\"\\n\") : \"No matching files.\");\n if (response.data.truncated || wasClientTruncated) {\n output.info(`[truncated: ${response.data.total_files} total files]`);\n }\n}\n"],"mappings":";;;;;;;;;;;AAmCO,SAAS,oBAAoB,SAA8C;AAChF,QAAM,SAAS,mBAAmB,OAAO;AAEzC,SAAO;AAAA,IACL,YAAY,MAAM,OAAO,kBAAkB,4BAA4B;AAAA,IACvE,eAAe,MAAM,OAAO,kBAAkB,+BAA+B;AAAA,IAC7E,QAAQ,CAAC,OAAO,UACd,OAAO,kBAAkB,wBAAwB;AAAA,MAC/C,GAAG;AAAA,MACH;AAAA,IACF,CAAC;AAAA,IACH,eAAe,MAAM,OAAO,kBAAkB,+BAA+B;AAAA,IAC7E,WAAW,CAAC,EAAE,OAAO,UAAU,MAAM,MACnC,OAAO,kBAAkB,0BAA0B;AAAA,MACjD,GAAI,QAAQ,EAAE,GAAG,MAAM,IAAI,CAAC;AAAA,MAC5B,GAAI,WAAW,EAAE,SAAS,IAAI,CAAC;AAAA,MAC/B;AAAA,IACF,CAAC;AAAA,IACH,MAAM,CAAC,EAAE,UAAU,QAAQ,MAAM,MAC/B,OAAO,kBAAkB,yBAAyB;AAAA,MAChD,WAAW;AAAA,MACX;AAAA,MACA;AAAA,IACF,CAAC;AAAA,IACH,MAAM,CAAC,EAAE,SAAS,MAAM,SAAS,MAAM,SAAS,WAAW,MACzD,OAAO,kBAAkB,yBAAyB;AAAA,MAChD;AAAA,MACA;AAAA,MACA;AAAA,MACA,aAAa;AAAA,MACb;AAAA,MACA,kBAAkB,aAAa,SAAS;AAAA,IAC1C,CAAC;AAAA,IACH,MAAM,CAAC,EAAE,SAAS,KAAK,MACrB,OAAO,kBAAkB,yBAAyB;AAAA,MAChD;AAAA,MACA;AAAA,IACF,CAAC;AAAA,EACL;AACF;;;ACxEO,SAAS,oBAAoB,OAAiE;AACnG,MAAI,UAAU,QAAW;AACvB,WAAO;AAAA,EACT;AAEA,UAAQ,OAAO;AAAA,IACb,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AACH,aAAO;AAAA,IACT;AACE,YAAM,IAAI;AAAA,QACR,qBAAqB,KAAK;AAAA,MAC5B;AAAA,EACJ;AACF;AAEO,SAAS,qBAAqB,OAAuB;AAC1D,QAAM,UAAU,MAAM,KAAK;AAC3B,MAAI,YAAY,OAAO,YAAY,IAAI;AACrC,WAAO;AAAA,EACT;AAEA,QAAM,eAAe,QAAQ,QAAQ,QAAQ,EAAE;AAC/C,MAAI,aAAa,WAAW,oBAAoB,GAAG;AACjD,WAAO;AAAA,EACT;AAEA,QAAM,CAAC,cAAc,GAAG,YAAY,IAAI,aAAa,MAAM,GAAG;AAC9D,MAAI,CAAC,cAAc;AACjB,WAAO;AAAA,EACT;AAEA,UAAQ,cAAc;AAAA,IACpB,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AACH,aAAO,+BAA+B,YAAY,GAAG,aAAa,SAAS,IAAI,IAAI,aAAa,KAAK,GAAG,CAAC,KAAK,EAAE;AAAA,IAClH;AACE,aAAO;AAAA,EACX;AACF;AAEO,SAAS,kBAAkB,OAAyD;AACzF,MAAI,UAAU,QAAW;AACvB,WAAO;AAAA,EACT;AAEA,UAAQ,OAAO;AAAA,IACb,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AACH,aAAO;AAAA,IACT;AACE,YAAM,IAAI,MAAM,oEAAoE;AAAA,EACxF;AACF;;;ACiCA,eAAsB,qBACpB,SACA,QACA,cACe;AACf,QAAM,MAAM,cAAc,OAAO,oBAAoB,OAAO;AAC5D,QAAM,WAAW,MAAM,IAAI,WAAW;AAEtC,MAAI,QAAQ,MAAM;AAChB,WAAO,KAAK,WAAW,SAAS,IAAI,CAAC;AACrC;AAAA,EACF;AAEA,QAAM,YAAY,SAAS,KAAK;AAChC,QAAM,QAAQ;AAAA,IACZ,YAAY,SAAS,KAAK,IAAI;AAAA,IAC9B,UAAU,SAAS,KAAK,KAAK;AAAA,IAC7B,UAAU,SAAS,KAAK,KAAK;AAAA,IAC7B,cAAc,SAAS,KAAK,UAAU,KAAK,KAAK,SAAS,KAAK,UAAU,OAAO;AAAA,EACjF;AAEA,MAAI,WAAW;AACb,UAAM,KAAK,eAAe,UAAU,MAAM,KAAK,UAAU,EAAE,GAAG;AAC9D,QAAI,UAAU,YAAY;AACxB,YAAM,KAAK,YAAY,UAAU,UAAU,EAAE;AAAA,IAC/C;AAAA,EACF,OAAO;AACL,UAAM,KAAK,kBAAkB;AAAA,EAC/B;AAEA,SAAO,KAAK,MAAM,KAAK,IAAI,CAAC;AAC9B;AAEA,eAAsB,wBACpB,SACA,QACA,cACe;AACf,QAAM,MAAM,cAAc,OAAO,oBAAoB,OAAO;AAC5D,QAAM,WAAW,MAAM,IAAI,cAAc;AAEzC,MAAI,QAAQ,MAAM;AAChB,WAAO,KAAK,WAAW,SAAS,IAAI,CAAC;AACrC;AAAA,EACF;AAEA,QAAM,QAAQ,SAAS,KAAK,UAAU,QAAQ,CAAC,aAAa;AAAA,IAC1D,GAAG,SAAS,EAAE,MAAM,SAAS,KAAK;AAAA,IAClC,KAAK,WAAW,SAAS,IAAI,CAAC;AAAA,EAChC,CAAC;AAED,SAAO,KAAK,MAAM,SAAS,IAAI,MAAM,KAAK,IAAI,IAAI,yBAAyB;AAC7E;AAEA,eAAsB,qBACpB,OACA,SACA,QACA,cACe;AACf,MAAI,CAAC,OAAO;AACV,UAAM,IAAI,MAAM,+DAA+D;AAAA,EACjF;AAEA,QAAM,MAAM,cAAc,OAAO,oBAAoB,OAAO;AAC5D,QAAM,WAAW,MAAM,IAAI,OAAO,OAAO,YAAY,QAAQ,OAAO,CAAC,CAAC;AAEtE,MAAI,QAAQ,MAAM;AAChB,WAAO,KAAK,WAAW,SAAS,IAAI,CAAC;AACrC;AAAA,EACF;AAEA,QAAM,QAAQ,SAAS,KAAK,QAAQ,QAAQ,CAAC,QAAQ,UAAU;AAAA,IAC7D,GAAG,QAAQ,CAAC,KAAK,OAAO,KAAK,KAAK,OAAO,YAAY;AAAA,IACrD,YAAY,OAAO,MAAM,QAAQ,CAAC,CAAC,MAAM,OAAO,IAAI;AAAA,IACpD,MAAM,WAAW,OAAO,eAAe,OAAO,cAAc,CAAC;AAAA,EAC/D,CAAC;AAED,SAAO,KAAK,MAAM,SAAS,IAAI,MAAM,KAAK,IAAI,IAAI,mBAAmB,KAAK,IAAI;AAChF;AAEA,eAAsB,mBACpB,OACA,SACA,QACA,cACe;AACf,QAAM,MAAM,cAAc,OAAO,oBAAoB,OAAO;AAC5D,QAAM,WAAW,MAAM,IAAI,cAAc;AACzC,QAAM,QAAQ,YAAY,QAAQ,OAAO,EAAE;AAC3C,QAAM,kBAAkB,OAAO,YAAY;AAC3C,QAAM,YAAY,SAAS,KAAK,UAC7B,OAAO,CAAC,aAAa;AACpB,QAAI,CAAC,iBAAiB;AACpB,aAAO;AAAA,IACT;AACA,WAAO,CAAC,SAAS,MAAM,SAAS,OAAO,SAAS,aAAa,SAAS,IAAI,EACvE,KAAK,GAAG,EACR,YAAY,EACZ,SAAS,eAAe;AAAA,EAC7B,CAAC,EACA,MAAM,GAAG,KAAK;AAEjB,MAAI,QAAQ,MAAM;AAChB,WAAO,KAAK,WAAW,EAAE,WAAW,OAAO,UAAU,OAAO,CAAC,CAAC;AAC9D;AAAA,EACF;AAEA,QAAM,QAAQ,UAAU,QAAQ,CAAC,aAAa;AAAA,IAC5C,GAAG,SAAS,IAAI,KAAK,SAAS,IAAI;AAAA,IAClC,KAAK,SAAS,KAAK,YAAY,SAAS,SAAS,aAAa,SAAS,MAAM;AAAA,IAC7E,KAAK,WAAW,SAAS,WAAW,CAAC;AAAA,EACvC,CAAC;AAED,SAAO,KAAK,MAAM,SAAS,IAAI,MAAM,KAAK,IAAI,IAAI,wBAAwB;AAC5E;AAEA,eAAsB,oBACpB,OACA,SACA,QACA,cACe;AACf,QAAM,MAAM,cAAc,OAAO,oBAAoB,OAAO;AAC5D,QAAM,WAAW,MAAM,IAAI,UAAU;AAAA,IACnC;AAAA,IACA,UAAU,oBAAoB,QAAQ,QAAQ;AAAA,IAC9C,OAAO,YAAY,QAAQ,OAAO,EAAE;AAAA,EACtC,CAAC;AAED,MAAI,QAAQ,MAAM;AAChB,WAAO,KAAK,WAAW,SAAS,IAAI,CAAC;AACrC;AAAA,EACF;AAEA,QAAM,QAAQ,SAAS,KAAK,MAAM,IAAI,CAAC,SAAS;AAC9C,UAAM,QAAQ,KAAK,iBAAiB,KAAK,SAAS,KAAK,iBAAiB;AACxE,WAAO,GAAG,KAAK,IAAI;AAAA,IAAO,KAAK;AAAA,EACjC,CAAC;AAED,SAAO,KAAK,MAAM,SAAS,IAAI,MAAM,KAAK,IAAI,IAAI,oBAAoB;AACxE;AAEA,eAAsB,mBACpB,UACA,SACA,QACA,cACe;AACf,MAAI,CAAC,UAAU;AACb,UAAM,IAAI,MAAM,8DAA8D;AAAA,EAChF;AAEA,QAAM,MAAM,cAAc,OAAO,oBAAoB,OAAO;AAC5D,QAAM,WAAW,MAAM,IAAI,KAAK;AAAA,IAC9B,UAAU,qBAAqB,QAAQ;AAAA,IACvC,QAAQ,qBAAqB,QAAQ,MAAM;AAAA,IAC3C,OAAO,YAAY,QAAQ,OAAO,KAAK,GAAI;AAAA,EAC7C,CAAC;AAED,MAAI,QAAQ,MAAM;AAChB,WAAO,KAAK,WAAW,SAAS,IAAI,CAAC;AACrC;AAAA,EACF;AAEA,SAAO,KAAK,SAAS,KAAK,OAAO;AACjC,MAAI,SAAS,KAAK,WAAW;AAC3B,WAAO;AAAA,MACL,uBAAuB,SAAS,KAAK,KAAK,sBAAsB,SAAS,KAAK,MAAM,OAAO,SAAS,KAAK,WAAW;AAAA,IACtH;AAAA,EACF;AACF;AAEA,eAAsB,mBACpB,SACA,SACA,QACA,cACe;AACf,MAAI,CAAC,SAAS;AACZ,UAAM,IAAI,MAAM,0DAA0D;AAAA,EAC5E;AAEA,QAAM,MAAM,cAAc,OAAO,oBAAoB,OAAO;AAC5D,QAAM,QAAQ,QAAQ,UAAU,SAAY,qBAAqB,QAAQ,KAAK,IAAI;AAClF,QAAM,WAAW,MAAM,IAAI,KAAK;AAAA,IAC9B;AAAA,IACA,MAAM,qBAAqB,QAAQ,QAAQ,GAAG;AAAA,IAC9C,SAAS,QAAQ,WAAW;AAAA,IAC5B,MAAM,kBAAkB,QAAQ,UAAU;AAAA,IAC1C,SAAS,YAAY,QAAQ,SAAS,GAAG,EAAE;AAAA,IAC3C,YAAY,QAAQ,oBAAoB;AAAA,EAC1C,CAAC;AAED,MAAI,QAAQ,MAAM;AAChB,WAAO,KAAK,WAAW,SAAS,IAAI,CAAC;AACrC;AAAA,EACF;AAEA,MAAI,SAAS,KAAK,SAAS,sBAAsB;AAC/C,UAAM,QAAQ,QAAQ,SAAS,KAAK,MAAM,MAAM,GAAG,KAAK,IAAI,SAAS,KAAK;AAC1E,WAAO,KAAK,MAAM,SAAS,IAAI,MAAM,KAAK,IAAI,IAAI,qBAAqB,OAAO,IAAI;AAClF;AAAA,EACF;AAEA,MAAI,SAAS,KAAK,SAAS,SAAS;AAClC,UAAM,SAAS,QAAQ,SAAS,KAAK,OAAO,MAAM,GAAG,KAAK,IAAI,SAAS,KAAK;AAC5E,UAAMA,SAAQ,OAAO,IAAI,CAAC,UAAU,GAAG,MAAM,SAAS,KAAK,MAAM,WAAW,EAAE;AAC9E,WAAO,KAAKA,OAAM,SAAS,IAAIA,OAAM,KAAK,IAAI,IAAI,mBAAmB,OAAO,IAAI;AAChF;AAAA,EACF;AAEA,QAAM,UAAU,QAAQ,SAAS,KAAK,QAAQ,MAAM,GAAG,KAAK,IAAI,SAAS,KAAK;AAC9E,QAAM,QAAQ,QAAQ,QAAQ,CAAC,UAAU;AAAA,IACvC,GAAG,MAAM,SAAS,IAAI,MAAM,WAAW;AAAA,IACvC,GAAG,MAAM,eAAe,IAAI,CAAC,SAAS,KAAK,IAAI,EAAE;AAAA,IACjD,KAAK,MAAM,IAAI;AAAA,IACf,GAAG,MAAM,cAAc,IAAI,CAAC,SAAS,KAAK,IAAI,EAAE;AAAA,EAClD,CAAC;AAED,SAAO,KAAK,MAAM,SAAS,IAAI,MAAM,KAAK,IAAI,IAAI,mBAAmB,OAAO,IAAI;AAClF;AAEA,eAAsB,mBACpB,SACA,SACA,QACA,cACe;AACf,QAAM,MAAM,cAAc,OAAO,oBAAoB,OAAO;AAC5D,QAAM,QAAQ,QAAQ,UAAU,SAAY,qBAAqB,QAAQ,KAAK,IAAI;AAClF,QAAM,WAAW,MAAM,IAAI,KAAK;AAAA,IAC9B,SAAS,WAAW;AAAA,IACpB,MAAM,qBAAqB,QAAQ,QAAQ,GAAG;AAAA,EAChD,CAAC;AAED,MAAI,QAAQ,MAAM;AAChB,WAAO,KAAK,WAAW,SAAS,IAAI,CAAC;AACrC;AAAA,EACF;AAEA,QAAM,QAAQ,QAAQ,SAAS,KAAK,MAAM,MAAM,GAAG,KAAK,IAAI,SAAS,KAAK;AAC1E,QAAM,qBAAqB,QAAQ,SAAS,KAAK,MAAM,SAAS,QAAQ;AAExE,SAAO,KAAK,MAAM,SAAS,IAAI,MAAM,KAAK,IAAI,IAAI,oBAAoB;AACtE,MAAI,SAAS,KAAK,aAAa,oBAAoB;AACjD,WAAO,KAAK,eAAe,SAAS,KAAK,WAAW,eAAe;AAAA,EACrE;AACF;","names":["lines"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
// src/help-specs.ts
|
|
1
|
+
// src/cli/help-specs.ts
|
|
2
2
|
var commandList = [
|
|
3
3
|
"`cngkit login` - open Curly.ng login.",
|
|
4
4
|
"`cngkit coderoom ...` - unite developers in a live shared code room.",
|
|
@@ -502,23 +502,8 @@ function normalizeHelpTopicName(value) {
|
|
|
502
502
|
return value?.trim().toLowerCase().replace(/\s+/g, "-") ?? "";
|
|
503
503
|
}
|
|
504
504
|
|
|
505
|
-
// src/output.ts
|
|
506
|
-
var consoleOutput = {
|
|
507
|
-
info(message) {
|
|
508
|
-
console.log(message);
|
|
509
|
-
},
|
|
510
|
-
error(message) {
|
|
511
|
-
console.error(message);
|
|
512
|
-
}
|
|
513
|
-
};
|
|
514
|
-
function formatError(error) {
|
|
515
|
-
return error instanceof Error ? error.message : String(error);
|
|
516
|
-
}
|
|
517
|
-
|
|
518
505
|
export {
|
|
519
506
|
formatCngkitHelp,
|
|
520
|
-
formatKnowledgesHelp
|
|
521
|
-
consoleOutput,
|
|
522
|
-
formatError
|
|
507
|
+
formatKnowledgesHelp
|
|
523
508
|
};
|
|
524
|
-
//# sourceMappingURL=chunk-
|
|
509
|
+
//# sourceMappingURL=chunk-VI5XQH3U.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/cli/help-specs.ts"],"sourcesContent":["type HelpTopic = {\n title: string;\n aliases: string[];\n body: string;\n};\n\nconst commandList = [\n \"`cngkit login` - open Curly.ng login.\",\n \"`cngkit coderoom ...` - unite developers in a live shared code room.\",\n \"`cngkit scrub [path]` - scan for secrets and optionally mask them inline.\",\n \"`cngkit transcripts ...` - list, read, and grep local Claude/Codex transcripts.\",\n \"`cngkit knowledges ...` - read the hosted Harness catalog.\",\n].join(\"\\n\");\n\nconst coderoomCommandList = [\n \"`share [room-code]` - start a live room from the current directory.\",\n \"`join <room-code>` - join another developer's live room from the current directory.\",\n].join(\"\\n\");\n\nconst knowledgesCommandList = [\n \"`status` - print remote catalog state.\",\n \"`audiences` - list valid audience filters.\",\n \"`search <query>` - semantic search over Cloudflare Vectorize-backed records.\",\n \"`list [query]` - list known subskills.\",\n \"`files [query]` - list uploaded catalog files.\",\n \"`read <file-path>` - Claude-style file read.\",\n \"`grep <pattern>` - Claude-style content search.\",\n \"`glob [pattern]` - Claude-style file discovery.\",\n].join(\"\\n\");\n\nconst helpTopics: HelpTopic[] = [\n {\n title: \"cngkit\",\n aliases: [\"\", \"overview\", \"help\"],\n body: `# cngkit\n\nCurly.ng operator CLI for backend-connected repo sync, secret scrubbing, and Harness knowledges access.\n\n## Usage\n\n\\`\\`\\`bash\ncngkit <command> [options]\n\\`\\`\\`\n\n## Commands\n\n${commandList}\n\n## Progressive Help\n\n\\`\\`\\`bash\ncngkit <command> --help\ncngkit coderoom --help\ncngkit coderoom <subcommand> --help\ncngkit transcripts --help\ncngkit knowledges --help\ncngkit knowledges <subcommand> --help\n\\`\\`\\`\n\nThe CLI intentionally prints plain Markdown or line-oriented text with no color-only state, tables that require terminal width, or hidden interactive prompts. Add \\`--json\\` to read-only knowledges commands when another agent or tool needs structured backend data.\n\n## Backend\n\nDefault API: \\`https://curly.ng\\`\n\nOverride with:\n\n\\`\\`\\`bash\ncngkit --api-base-url <url> ...\nCNGKIT_API_BASE_URL=<url> cngkit ...\n\\`\\`\\`\n`,\n },\n {\n title: \"login\",\n aliases: [\"login\"],\n body: `# cngkit login\n\nOpen Curly.ng login in a browser. In headless environments, print the URL so an agent can surface it to the operator.\n\n## Usage\n\n\\`\\`\\`bash\ncngkit login\n\\`\\`\\`\n\n## Output Contract\n\n- First line names the login URL being opened.\n- If no local browser opener exists, the CLI prints a direct URL.\n- No credentials are printed or persisted by this command.\n`,\n },\n {\n title: \"transcripts\",\n aliases: [\"transcripts\", \"transcript\"],\n body: `# cngkit transcripts\n\nRead local agent transcript JSONL files from \\`~/.codex/sessions\\`, \\`~/.codex/archived_sessions\\`, \\`~/.claude/projects\\`, and \\`~/.claude/history.jsonl\\`.\n\nThis is local operator tooling. It does not call the Curly backend and it does not upload transcript content.\n\n## Usage\n\n\\`\\`\\`bash\ncngkit transcripts list [--source all|codex|claude] [--limit <n>] [--json]\ncngkit transcripts read <path-or-session-id> [--source all|codex|claude] [--limit <n>] [--include-internal] [--json]\ncngkit transcripts grep <query> [--source all|codex|claude] [--limit <n>] [--file-limit <n>] [--include-internal] [--json]\n\\`\\`\\`\n\n## Defaults\n\n- \\`list\\`: newest 12 transcript files.\n- \\`read\\`: newest 80 user/assistant entries from the selected file.\n- \\`grep\\`: first 80 matching user/assistant entries from the newest 60 files.\n- \\`--source\\`: \\`all\\`.\n\n## Output Contract\n\n- Text mode prints source, role, timestamp when available, and extracted message text.\n- Internal developer/system payloads and hook/tool noise are skipped unless \\`--include-internal\\` is passed.\n- Direct file paths, home-relative paths, and partial session ids are accepted by \\`read\\`.\n`,\n },\n {\n title: \"coderoom\",\n aliases: [\"coderoom\", \"code-room\", \"repo-sync\"],\n body: `# cngkit coderoom\n\nCoderoom is the fast way to unite developers around one working tree. It gives a pair or team a temporary shared room over the Curly backend so one developer can share local file changes and another can join from their own machine.\n\nIt is intentionally closer to a Drive-like project room than a raw socket command: the room code is the shared folder link, each connected machine is a collaborator, and the file stream is the activity feed. The browser experience at \\`/coderoom\\` provides the helper surface for copying commands and explaining the room model.\n\n## Usage\n\n\\`\\`\\`bash\ncngkit coderoom <subcommand> [options]\n\\`\\`\\`\n\n## Subcommands\n\n${coderoomCommandList}\n\n## Common Flow\n\n\\`\\`\\`bash\ncngkit coderoom share\ncngkit coderoom join <room-code>\n\\`\\`\\`\n\n## Backend Contract\n\n- Connects to \\`/api/cng/sync/:roomCode\\` on the configured Curly backend.\n- Uses WebSocket transport backed by the \\`CngSyncRoom\\` Durable Object.\n- Sends an initial snapshot, then file and delete events.\n- Last received change wins.\n- Current rooms are live relays, not durable cloud storage. The Drive-like frontend is the collaboration shell around that live primitive.\n`,\n },\n {\n title: \"coderoom share\",\n aliases: [\"coderoom-share\"],\n body: `# cngkit coderoom share\n\nStart a real-time repository sync room from the current directory.\n\n## Usage\n\n\\`\\`\\`bash\ncngkit coderoom share [room-code]\n\\`\\`\\`\n\n## Backend Contract\n\n- Connects to \\`/api/cng/sync/:roomCode\\` on the configured Curly backend.\n- Uses WebSocket transport backed by the \\`CngSyncRoom\\` Durable Object.\n- Sends an initial snapshot, then file and delete events.\n- Last received change wins.\n\n## Filesystem Contract\n\n- Preserves \\`.git/\\`.\n- Preserves files ignored by the repo's \\`.gitignore\\`.\n- Sends regular files as base64 payloads in the sync protocol.\n\n## Output Contract\n\n- Prints room code, repo root, peer id, backend health, and concise sync events.\n- Keeps running until the socket closes or the process receives a termination signal.\n`,\n },\n {\n title: \"coderoom join\",\n aliases: [\"coderoom-join\"],\n body: `# cngkit coderoom join\n\nJoin an existing real-time repository sync room in the current directory.\n\n## Usage\n\n\\`\\`\\`bash\ncngkit coderoom join <room-code>\n\\`\\`\\`\n\n## Backend Contract\n\nSame transport and filesystem contract as \\`cngkit coderoom share\\`. The supplied room code selects the Durable Object room.\n\n## Output Contract\n\n- Prints backend health, room code, repo root, peer id, and concise sync events.\n- Missing room code exits with a usage error.\n`,\n },\n {\n title: \"scrub\",\n aliases: [\"scrub\"],\n body: `# cngkit scrub\n\nScan a file or directory for secrets with TruffleHog. Report-only is the default. Inline masking requires \\`--yes\\`.\n\n## Usage\n\n\\`\\`\\`bash\ncngkit scrub [path]\ncngkit scrub [path] --yes\n\\`\\`\\`\n\n## Requirements\n\n- \\`trufflehog\\` must be available on \\`PATH\\`.\n\n## Safety Contract\n\n- Default mode does not rewrite files.\n- \\`--yes\\` rewrites detected secret values inline with \\`[CNGKIT_SECRET:<detector>:<verified|unverified>]\\` placeholders.\n- \\`--mask\\` is accepted as a compatibility alias, but still requires \\`--yes\\`.\n- Raw and redacted secret values are never printed in the report.\n`,\n },\n {\n title: \"knowledges\",\n aliases: [\"knowledges\", \"knowledge\"],\n body: `# cngkit knowledges\n\nRead the hosted Harness knowledges catalog from the Curly backend. These commands are read-only and use the generated \\`@cng/client\\` SDK against public backend routes.\n\n## Usage\n\n\\`\\`\\`bash\ncngkit knowledges <subcommand> [options]\n\\`\\`\\`\n\n## Subcommands\n\n${knowledgesCommandList}\n\n## Progressive Help\n\n\\`\\`\\`bash\ncngkit knowledges <subcommand> --help\ncngkit knowledges read --help\ncngkit knowledges grep --help\ncngkit knowledges glob --help\n\\`\\`\\`\n\n## Common Examples\n\n\\`\\`\\`bash\ncngkit knowledges search \"cloudflare backend\" --limit 3\ncngkit knowledges read /libraries/lib-cloudflare/SUBSKILL.md --limit 80\ncngkit knowledges grep Cloudflare --path /libraries/lib-cloudflare --output-mode files_with_matches\ncngkit knowledges glob \"**/*.md\" --path /libraries/lib-cloudflare\n\\`\\`\\`\n\n## AI-Friendly Output\n\n- Default output is line-oriented and intended to be directly usable by agents.\n- \\`read\\` prints file content with no wrapper before any truncation note.\n- \\`grep --output-mode content\\` prints \\`path:line\\` blocks.\n- \\`grep --output-mode files_with_matches\\` and \\`glob\\` print one path per line.\n- \\`--json\\` prints the typed backend data payload for machine consumption.\n`,\n },\n {\n title: \"knowledges status\",\n aliases: [\"knowledges-status\", \"status\"],\n body: `# cngkit knowledges status\n\nPrint remote Harness catalog state from \\`GET /api/harness/knowledges/catalog\\`.\n\n## Usage\n\n\\`\\`\\`bash\ncngkit knowledges status [--json]\n\\`\\`\\`\n\n## Output Contract\n\n- Text mode prints catalog name, file count, blob count, Vectorize binding, and latest run when present.\n- \\`--json\\` prints the backend data payload.\n`,\n },\n {\n title: \"knowledges audiences\",\n aliases: [\"knowledges-audiences\", \"audiences\"],\n body: `# cngkit knowledges audiences\n\nList valid audience filters from \\`GET /api/harness/knowledges/audiences\\`.\n\n## Usage\n\n\\`\\`\\`bash\ncngkit knowledges audiences [--json]\n\\`\\`\\`\n\nUse this before \\`cngkit knowledges files --audience <id>\\`.\n`,\n },\n {\n title: \"knowledges search\",\n aliases: [\"knowledges-search\", \"search\"],\n body: `# cngkit knowledges search\n\nRun semantic search against the Cloudflare Vectorize-backed Harness index.\n\n## Usage\n\n\\`\\`\\`bash\ncngkit knowledges search <query> [--limit <n>] [--json]\n\\`\\`\\`\n\n## Defaults\n\n- \\`--limit\\`: \\`5\\`\n\n## Example\n\n\\`\\`\\`bash\ncngkit knowledges search \"cloudflare backend\" --limit 3\n\\`\\`\\`\n`,\n },\n {\n title: \"knowledges list\",\n aliases: [\"knowledges-list\", \"list\"],\n body: `# cngkit knowledges list\n\nList known subskills from \\`GET /api/harness/knowledges/subskills\\`, optionally filtered locally by query.\n\n## Usage\n\n\\`\\`\\`bash\ncngkit knowledges list [query] [--limit <n>] [--json]\n\\`\\`\\`\n\n## Defaults\n\n- \\`--limit\\`: \\`25\\`\n`,\n },\n {\n title: \"knowledges files\",\n aliases: [\"knowledges-files\", \"files\"],\n body: `# cngkit knowledges files\n\nList uploaded catalog files from \\`GET /api/harness/knowledges/files\\`.\n\n## Usage\n\n\\`\\`\\`bash\ncngkit knowledges files [query] [--audience <id>] [--limit <n>] [--json]\n\\`\\`\\`\n\n## Defaults\n\n- \\`--limit\\`: \\`25\\`\n- \\`--audience\\`: omitted\n\nRun \\`cngkit knowledges audiences\\` to discover supported audience ids.\n`,\n },\n {\n title: \"knowledges read\",\n aliases: [\"knowledges-read\", \"read\"],\n body: `# cngkit knowledges read\n\nClaude-style read tool for hosted Harness catalog files. Backed by \\`GET /api/harness/filesystem/read\\` and \\`HarnessReadQuerySchema\\`.\n\n## Usage\n\n\\`\\`\\`bash\ncngkit knowledges read <file-path> [--offset <n>] [--limit <n>] [--json]\n\\`\\`\\`\n\n## Inputs\n\n- \\`file-path\\`: normalized catalog path. Shorthand paths such as \\`/libraries/lib-cloudflare/SUBSKILL.md\\` are expanded to \\`skills/knowledges/subskills/libraries/lib-cloudflare/SUBSKILL.md\\`.\n- \\`--offset\\`: zero-based starting line. Default: \\`0\\`.\n- \\`--limit\\`: maximum lines. Default in CLI: \\`200\\`. Backend max: \\`2000\\`.\n\n## Output Contract\n\n- Text mode prints only the returned file content first.\n- If truncated, a final bracketed truncation note is printed after the content.\n- \\`--json\\` prints \\`{ file_path, content, total_lines, offset, limit, truncated }\\`.\n\n## Example\n\n\\`\\`\\`bash\ncngkit knowledges read /libraries/lib-cloudflare/SUBSKILL.md --limit 80\n\\`\\`\\`\n`,\n },\n {\n title: \"knowledges grep\",\n aliases: [\"knowledges-grep\", \"grep\"],\n body: `# cngkit knowledges grep\n\nClaude-style grep tool for hosted Harness catalog files. Backed by \\`GET /api/harness/filesystem/grep\\` and \\`HarnessGrepQuerySchema\\`.\n\n## Usage\n\n\\`\\`\\`bash\ncngkit knowledges grep <pattern> [--path <path>] [--include <glob>] [--output-mode <mode>] [--context <n>] [--case-insensitive] [--json]\n\\`\\`\\`\n\n## Inputs\n\n- \\`pattern\\`: JavaScript regular expression source.\n- \\`--path\\`: catalog path prefix. Default: \\`/\\`.\n- \\`--include\\`: filename include filter. Default: \\`*\\`.\n- Modes: content, files_with_matches, or count.\n- \\`--output-mode\\`: \\`content\\`, \\`files_with_matches\\`, or \\`count\\`. Default: \\`content\\`.\n- \\`--context\\`: context lines around content matches. Default: \\`0\\`. Backend max: \\`20\\`.\n- \\`--case-insensitive\\`: maps to backend \\`case_insensitive=true\\`.\n\n## Output Contract\n\n- \\`content\\`: prints blocks as \\`file_path:line_number\\`, optional context lines, then \\`> matching line\\`.\n- \\`files_with_matches\\`: prints one matching file path per line.\n- \\`count\\`: prints \\`file_path: match_count\\` lines.\n- \\`--json\\` prints the typed backend response union.\n\n## Examples\n\n\\`\\`\\`bash\ncngkit knowledges grep Cloudflare --path /libraries/lib-cloudflare --output-mode files_with_matches\ncngkit knowledges grep \"Vectorize|D1\" --path /libraries/lib-cloudflare --context 2\n\\`\\`\\`\n`,\n },\n {\n title: \"knowledges glob\",\n aliases: [\"knowledges-glob\", \"glob\"],\n body: `# cngkit knowledges glob\n\nClaude-style glob tool for hosted Harness catalog files. Backed by \\`GET /api/harness/filesystem/glob\\` and \\`HarnessGlobQuerySchema\\`.\n\n## Usage\n\n\\`\\`\\`bash\ncngkit knowledges glob [pattern] [--path <path>] [--json]\n\\`\\`\\`\n\n## Inputs\n\n- \\`pattern\\`: supported glob pattern. CLI default: \\`**/*.md\\`.\n- \\`--path\\`: catalog path prefix. Default: \\`/\\`.\n\n## Supported Patterns\n\n- \\`**/*.md\\`\n- \\`**/*.SUBSKILL.md\\`\n- \\`**/SKILL.md\\`\n- \\`*.md\\`\n- \\`*.SUBSKILL.md\\`\n- \\`SKILL.md\\`\n\n## Output Contract\n\n- Text mode prints one file path per line.\n- If truncated, a final bracketed truncation note is printed.\n- \\`--json\\` prints \\`{ files, total_files, truncated }\\`.\n\n## Example\n\n\\`\\`\\`bash\ncngkit knowledges glob \"**/*.md\" --path /libraries/lib-cloudflare\n\\`\\`\\`\n`,\n },\n];\n\nconst helpTopicByAlias = new Map<string, HelpTopic>();\n\nfor (const topic of helpTopics) {\n for (const alias of topic.aliases) {\n helpTopicByAlias.set(alias, topic);\n }\n}\n\nexport function formatCngkitHelp(topicName?: string): string {\n const normalizedTopicName = normalizeHelpTopicName(topicName);\n return (helpTopicByAlias.get(normalizedTopicName) ?? helpTopicByAlias.get(\"\"))?.body.trim() ?? \"\";\n}\n\nexport function formatKnowledgesHelp(topicName?: string): string {\n const normalizedTopicName = normalizeHelpTopicName(topicName);\n const topicKey = normalizedTopicName ? `knowledges-${normalizedTopicName}` : \"knowledges\";\n return formatCngkitHelp(topicKey);\n}\n\nfunction normalizeHelpTopicName(value: string | undefined): string {\n return value?.trim().toLowerCase().replace(/\\s+/g, \"-\") ?? \"\";\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
// src/shared/output.ts
|
|
2
|
+
var consoleOutput = {
|
|
3
|
+
info(message) {
|
|
4
|
+
console.log(message);
|
|
5
|
+
},
|
|
6
|
+
error(message) {
|
|
7
|
+
console.error(message);
|
|
8
|
+
}
|
|
9
|
+
};
|
|
10
|
+
function formatError(error) {
|
|
11
|
+
return error instanceof Error ? error.message : String(error);
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export {
|
|
15
|
+
consoleOutput,
|
|
16
|
+
formatError
|
|
17
|
+
};
|
|
18
|
+
//# sourceMappingURL=chunk-XDXRVTPK.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/shared/output.ts"],"sourcesContent":["export type CommandOutput = {\n info(message: string): void;\n error(message: string): void;\n};\n\nexport const consoleOutput: CommandOutput = {\n info(message) {\n console.log(message);\n },\n error(message) {\n console.error(message);\n },\n};\n\nexport function formatError(error: unknown): string {\n return error instanceof Error ? error.message : String(error);\n}\n"],"mappings":";AAKO,IAAM,gBAA+B;AAAA,EAC1C,KAAK,SAAS;AACZ,YAAQ,IAAI,OAAO;AAAA,EACrB;AAAA,EACA,MAAM,SAAS;AACb,YAAQ,MAAM,OAAO;AAAA,EACvB;AACF;AAEO,SAAS,YAAY,OAAwB;AAClD,SAAO,iBAAiB,QAAQ,MAAM,UAAU,OAAO,KAAK;AAC9D;","names":[]}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import {
|
|
2
2
|
formatError
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-XDXRVTPK.js";
|
|
4
4
|
|
|
5
|
-
// src/
|
|
5
|
+
// src/cli/command-runner.tsx
|
|
6
6
|
import { useEffect } from "react";
|
|
7
7
|
import { useApp } from "ink";
|
|
8
8
|
function CommandRunner({ run }) {
|
|
@@ -31,4 +31,4 @@ function CommandRunner({ run }) {
|
|
|
31
31
|
export {
|
|
32
32
|
CommandRunner
|
|
33
33
|
};
|
|
34
|
-
//# sourceMappingURL=chunk-
|
|
34
|
+
//# sourceMappingURL=chunk-Z4DDLEWR.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/cli/command-runner.tsx"],"sourcesContent":["import { useEffect } from \"react\";\nimport { useApp } from \"ink\";\n\nimport { formatError, type CommandOutput } from \"../shared/output.js\";\n\ntype CommandRunnerProps = {\n readonly run: (output: CommandOutput) => Promise<void>;\n};\n\nexport function CommandRunner({ run }: CommandRunnerProps) {\n const { exit } = useApp();\n\n useEffect(() => {\n const output: CommandOutput = {\n info(message) {\n process.stdout.write(`${message}\\n`);\n },\n error(message) {\n process.stderr.write(`${message}\\n`);\n },\n };\n\n void run(output)\n .catch((error: unknown) => {\n process.exitCode = 1;\n output.error(formatError(error));\n })\n .finally(() => {\n exit();\n });\n }, [exit, run]);\n\n return null;\n}\n"],"mappings":";;;;;AAAA,SAAS,iBAAiB;AAC1B,SAAS,cAAc;AAQhB,SAAS,cAAc,EAAE,IAAI,GAAuB;AACzD,QAAM,EAAE,KAAK,IAAI,OAAO;AAExB,YAAU,MAAM;AACd,UAAM,SAAwB;AAAA,MAC5B,KAAK,SAAS;AACZ,gBAAQ,OAAO,MAAM,GAAG,OAAO;AAAA,CAAI;AAAA,MACrC;AAAA,MACA,MAAM,SAAS;AACb,gBAAQ,OAAO,MAAM,GAAG,OAAO;AAAA,CAAI;AAAA,MACrC;AAAA,IACF;AAEA,SAAK,IAAI,MAAM,EACZ,MAAM,CAAC,UAAmB;AACzB,cAAQ,WAAW;AACnB,aAAO,MAAM,YAAY,KAAK,CAAC;AAAA,IACjC,CAAC,EACA,QAAQ,MAAM;AACb,WAAK;AAAA,IACP,CAAC;AAAA,EACL,GAAG,CAAC,MAAM,GAAG,CAAC;AAEd,SAAO;AACT;","names":[]}
|
package/dist/cli.js
CHANGED
|
@@ -1,20 +1,22 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
+
import {
|
|
3
|
+
formatCngkitHelp,
|
|
4
|
+
formatKnowledgesHelp
|
|
5
|
+
} from "./chunk-VI5XQH3U.js";
|
|
2
6
|
import {
|
|
3
7
|
packageVersion
|
|
4
|
-
} from "./chunk-
|
|
8
|
+
} from "./chunk-EQEIX7N5.js";
|
|
5
9
|
import {
|
|
6
10
|
consoleOutput,
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
formatKnowledgesHelp
|
|
10
|
-
} from "./chunk-SSRUN6G5.js";
|
|
11
|
+
formatError
|
|
12
|
+
} from "./chunk-XDXRVTPK.js";
|
|
11
13
|
import "./chunk-PZ5AY32C.js";
|
|
12
14
|
|
|
13
15
|
// src/cli.ts
|
|
14
16
|
import process from "process";
|
|
15
17
|
import Pastel from "pastel";
|
|
16
18
|
|
|
17
|
-
// src/cli
|
|
19
|
+
// src/cli/help.ts
|
|
18
20
|
function printMarkdownHelpIfRequested(argv, output = consoleOutput) {
|
|
19
21
|
const commandName = argv[2];
|
|
20
22
|
if (commandName === void 0 || commandName === "--help" || commandName === "-h") {
|
package/dist/cli.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/cli.ts","../src/cli
|
|
1
|
+
{"version":3,"sources":["../src/cli.ts","../src/cli/help.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport process from \"node:process\";\n\nimport Pastel from \"pastel\";\n\nimport { printMarkdownHelpIfRequested } from \"./cli/help.js\";\nimport { packageVersion } from \"./shared/config.js\";\nimport { formatError } from \"./shared/output.js\";\n\nconst normalizedArgv = normalizeGlobalOptions(process.argv);\n\nif (printMarkdownHelpIfRequested(normalizedArgv)) {\n process.exit(0);\n}\n\nconst app = new Pastel({\n importMeta: import.meta,\n name: \"cngkit\",\n version: packageVersion,\n description: \"Opinionated Curly.ng CLI kit for Coderoom collaboration and website tooling.\",\n});\n\ntry {\n await app.run(normalizedArgv);\n} catch (error) {\n console.error(formatError(error));\n process.exitCode = 1;\n}\n\nfunction normalizeGlobalOptions(argv: string[]): string[] {\n const normalizedArgv = [...argv];\n\n for (let index = 2; index < normalizedArgv.length; index += 1) {\n const argument = normalizedArgv[index];\n\n if (argument === \"--api-base-url\") {\n const value = normalizedArgv[index + 1];\n if (!value || value.startsWith(\"-\")) {\n throw new Error(\"Missing value for --api-base-url\");\n }\n\n process.env.CNGKIT_API_BASE_URL = value;\n normalizedArgv.splice(index, 2);\n index -= 1;\n continue;\n }\n\n if (argument.startsWith(\"--api-base-url=\")) {\n process.env.CNGKIT_API_BASE_URL = argument.slice(\"--api-base-url=\".length);\n normalizedArgv.splice(index, 1);\n index -= 1;\n }\n }\n\n return normalizedArgv;\n}\n","import { formatCngkitHelp, formatKnowledgesHelp } from \"./help-specs.js\";\nimport { consoleOutput, type CommandOutput } from \"../shared/output.js\";\n\nexport function printMarkdownHelpIfRequested(\n argv: string[],\n output: CommandOutput = consoleOutput\n): boolean {\n const commandName = argv[2];\n\n if (commandName === undefined || commandName === \"--help\" || commandName === \"-h\") {\n output.info(formatCngkitHelp());\n return true;\n }\n\n if (commandName === \"help\") {\n const [topicName, subtopicName] = argv.slice(3);\n const topic =\n (topicName === \"knowledges\" || topicName === \"coderoom\") && subtopicName\n ? `${topicName}-${subtopicName}`\n : topicName;\n output.info(formatCngkitHelp(topic));\n return true;\n }\n\n const commandArgs = argv.slice(3);\n const helpIndex = commandArgs.findIndex((argument) => argument === \"--help\" || argument === \"-h\");\n\n if (helpIndex < 0) {\n return false;\n }\n\n if (commandName === \"knowledges\") {\n const topic = commandArgs.find((argument, index) => index !== helpIndex && !argument.startsWith(\"-\"));\n output.info(formatKnowledgesHelp(topic));\n return true;\n }\n\n if (commandName === \"coderoom\") {\n const topic = commandArgs.find((argument, index) => index !== helpIndex && !argument.startsWith(\"-\"));\n output.info(formatCngkitHelp(topic ? `coderoom-${topic}` : \"coderoom\"));\n return true;\n }\n\n output.info(formatCngkitHelp(commandName));\n return true;\n}\n"],"mappings":";;;;;;;;;;;;;;;AAEA,OAAO,aAAa;AAEpB,OAAO,YAAY;;;ACDZ,SAAS,6BACd,MACA,SAAwB,eACf;AACT,QAAM,cAAc,KAAK,CAAC;AAE1B,MAAI,gBAAgB,UAAa,gBAAgB,YAAY,gBAAgB,MAAM;AACjF,WAAO,KAAK,iBAAiB,CAAC;AAC9B,WAAO;AAAA,EACT;AAEA,MAAI,gBAAgB,QAAQ;AAC1B,UAAM,CAAC,WAAW,YAAY,IAAI,KAAK,MAAM,CAAC;AAC9C,UAAM,SACH,cAAc,gBAAgB,cAAc,eAAe,eACxD,GAAG,SAAS,IAAI,YAAY,KAC5B;AACN,WAAO,KAAK,iBAAiB,KAAK,CAAC;AACnC,WAAO;AAAA,EACT;AAEA,QAAM,cAAc,KAAK,MAAM,CAAC;AAChC,QAAM,YAAY,YAAY,UAAU,CAAC,aAAa,aAAa,YAAY,aAAa,IAAI;AAEhG,MAAI,YAAY,GAAG;AACjB,WAAO;AAAA,EACT;AAEA,MAAI,gBAAgB,cAAc;AAChC,UAAM,QAAQ,YAAY,KAAK,CAAC,UAAU,UAAU,UAAU,aAAa,CAAC,SAAS,WAAW,GAAG,CAAC;AACpG,WAAO,KAAK,qBAAqB,KAAK,CAAC;AACvC,WAAO;AAAA,EACT;AAEA,MAAI,gBAAgB,YAAY;AAC9B,UAAM,QAAQ,YAAY,KAAK,CAAC,UAAU,UAAU,UAAU,aAAa,CAAC,SAAS,WAAW,GAAG,CAAC;AACpG,WAAO,KAAK,iBAAiB,QAAQ,YAAY,KAAK,KAAK,UAAU,CAAC;AACtE,WAAO;AAAA,EACT;AAEA,SAAO,KAAK,iBAAiB,WAAW,CAAC;AACzC,SAAO;AACT;;;ADnCA,IAAM,iBAAiB,uBAAuB,QAAQ,IAAI;AAE1D,IAAI,6BAA6B,cAAc,GAAG;AAChD,UAAQ,KAAK,CAAC;AAChB;AAEA,IAAM,MAAM,IAAI,OAAO;AAAA,EACrB,YAAY;AAAA,EACZ,MAAM;AAAA,EACN,SAAS;AAAA,EACT,aAAa;AACf,CAAC;AAED,IAAI;AACF,QAAM,IAAI,IAAI,cAAc;AAC9B,SAAS,OAAO;AACd,UAAQ,MAAM,YAAY,KAAK,CAAC;AAChC,UAAQ,WAAW;AACrB;AAEA,SAAS,uBAAuB,MAA0B;AACxD,QAAMA,kBAAiB,CAAC,GAAG,IAAI;AAE/B,WAAS,QAAQ,GAAG,QAAQA,gBAAe,QAAQ,SAAS,GAAG;AAC7D,UAAM,WAAWA,gBAAe,KAAK;AAErC,QAAI,aAAa,kBAAkB;AACjC,YAAM,QAAQA,gBAAe,QAAQ,CAAC;AACtC,UAAI,CAAC,SAAS,MAAM,WAAW,GAAG,GAAG;AACnC,cAAM,IAAI,MAAM,kCAAkC;AAAA,MACpD;AAEA,cAAQ,IAAI,sBAAsB;AAClC,MAAAA,gBAAe,OAAO,OAAO,CAAC;AAC9B,eAAS;AACT;AAAA,IACF;AAEA,QAAI,SAAS,WAAW,iBAAiB,GAAG;AAC1C,cAAQ,IAAI,sBAAsB,SAAS,MAAM,kBAAkB,MAAM;AACzE,MAAAA,gBAAe,OAAO,OAAO,CAAC;AAC9B,eAAS;AAAA,IACX;AAAA,EACF;AAEA,SAAOA;AACT;","names":["normalizedArgv"]}
|
|
@@ -1,12 +1,13 @@
|
|
|
1
|
+
import {
|
|
2
|
+
formatCngkitHelp
|
|
3
|
+
} from "../../chunk-VI5XQH3U.js";
|
|
1
4
|
import {
|
|
2
5
|
GlobalOptionsSchema
|
|
3
|
-
} from "../../chunk-
|
|
6
|
+
} from "../../chunk-MLKBG5YJ.js";
|
|
4
7
|
import {
|
|
5
8
|
CommandRunner
|
|
6
|
-
} from "../../chunk-
|
|
7
|
-
import
|
|
8
|
-
formatCngkitHelp
|
|
9
|
-
} from "../../chunk-SSRUN6G5.js";
|
|
9
|
+
} from "../../chunk-Z4DDLEWR.js";
|
|
10
|
+
import "../../chunk-XDXRVTPK.js";
|
|
10
11
|
import "../../chunk-PZ5AY32C.js";
|
|
11
12
|
|
|
12
13
|
// src/commands/coderoom/index.tsx
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/commands/coderoom/index.tsx"],"sourcesContent":["import { GlobalOptionsSchema } from \"../../cli
|
|
1
|
+
{"version":3,"sources":["../../../src/commands/coderoom/index.tsx"],"sourcesContent":["import { GlobalOptionsSchema } from \"../../cli/options.js\";\nimport { formatCngkitHelp } from \"../../cli/help-specs.js\";\nimport { CommandRunner } from \"../../cli/command-runner.js\";\n\nexport const description = \"Start or join a real-time repo sync room\";\nexport const options = GlobalOptionsSchema;\n\nexport default function CoderoomCommand() {\n return <CommandRunner run={async (output) => output.info(formatCngkitHelp(\"coderoom\"))} />;\n}\n"],"mappings":";;;;;;;;;;;;;AAQS;AAJF,IAAM,cAAc;AACpB,IAAM,UAAU;AAER,SAAR,kBAAmC;AACxC,SAAO,oBAAC,iBAAc,KAAK,OAAO,WAAW,OAAO,KAAK,iBAAiB,UAAU,CAAC,GAAG;AAC1F;","names":[]}
|
|
@@ -1,15 +1,16 @@
|
|
|
1
1
|
import {
|
|
2
2
|
runJoinCommand
|
|
3
|
-
} from "../../chunk-
|
|
4
|
-
import "../../chunk-
|
|
3
|
+
} from "../../chunk-HUZZPV5E.js";
|
|
4
|
+
import "../../chunk-QEZQGKFX.js";
|
|
5
|
+
import "../../chunk-EQEIX7N5.js";
|
|
5
6
|
import {
|
|
6
7
|
GlobalOptionsSchema,
|
|
7
8
|
RequiredRoomCodeArgsSchema
|
|
8
|
-
} from "../../chunk-
|
|
9
|
+
} from "../../chunk-MLKBG5YJ.js";
|
|
9
10
|
import {
|
|
10
11
|
CommandRunner
|
|
11
|
-
} from "../../chunk-
|
|
12
|
-
import "../../chunk-
|
|
12
|
+
} from "../../chunk-Z4DDLEWR.js";
|
|
13
|
+
import "../../chunk-XDXRVTPK.js";
|
|
13
14
|
import "../../chunk-PZ5AY32C.js";
|
|
14
15
|
|
|
15
16
|
// src/commands/coderoom/join.tsx
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/commands/coderoom/join.tsx"],"sourcesContent":["import { GlobalOptionsSchema, RequiredRoomCodeArgsSchema } from \"../../cli
|
|
1
|
+
{"version":3,"sources":["../../../src/commands/coderoom/join.tsx"],"sourcesContent":["import { GlobalOptionsSchema, RequiredRoomCodeArgsSchema } from \"../../cli/options.js\";\nimport { runJoinCommand } from \"../../features/coderoom/run-coderoom-command.js\";\nimport type { GlobalCommandOptions } from \"../../shared/config.js\";\nimport { CommandRunner } from \"../../cli/command-runner.js\";\n\nexport const description = \"Join another developer's live room from the current directory\";\nexport const args = RequiredRoomCodeArgsSchema;\nexport const options = GlobalOptionsSchema;\n\ntype JoinCommandProps = {\n readonly args: [string];\n readonly options: GlobalCommandOptions;\n};\n\nexport default function JoinCommand({ args, options }: JoinCommandProps) {\n return <CommandRunner run={(output) => runJoinCommand(args[0], options, output)} />;\n}\n"],"mappings":";;;;;;;;;;;;;;;;AAeS;AAVF,IAAM,cAAc;AACpB,IAAM,OAAO;AACb,IAAM,UAAU;AAOR,SAAR,YAA6B,EAAE,MAAAA,OAAM,SAAAC,SAAQ,GAAqB;AACvE,SAAO,oBAAC,iBAAc,KAAK,CAAC,WAAW,eAAeD,MAAK,CAAC,GAAGC,UAAS,MAAM,GAAG;AACnF;","names":["args","options"]}
|