@trustify-da/trustify-da-javascript-client 0.3.0-ea.cb4ae28 → 0.3.0-ea.cdf078c
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 +151 -13
- package/dist/package.json +10 -4
- package/dist/src/analysis.d.ts +16 -0
- package/dist/src/analysis.js +53 -4
- package/dist/src/batch_opts.d.ts +24 -0
- package/dist/src/batch_opts.js +35 -0
- package/dist/src/cli.js +171 -4
- package/dist/src/cyclone_dx_sbom.d.ts +7 -0
- package/dist/src/cyclone_dx_sbom.js +16 -1
- package/dist/src/index.d.ts +74 -1
- package/dist/src/index.js +283 -4
- package/dist/src/oci_image/utils.js +11 -2
- package/dist/src/provider.d.ts +6 -3
- package/dist/src/provider.js +12 -5
- package/dist/src/providers/base_javascript.d.ts +19 -3
- package/dist/src/providers/base_javascript.js +99 -18
- package/dist/src/providers/base_pyproject.d.ts +170 -0
- package/dist/src/providers/base_pyproject.js +338 -0
- package/dist/src/providers/golang_gomodules.d.ts +12 -12
- package/dist/src/providers/golang_gomodules.js +100 -111
- package/dist/src/providers/gomod_parser.d.ts +4 -0
- package/dist/src/providers/gomod_parser.js +16 -0
- package/dist/src/providers/javascript_pnpm.d.ts +1 -1
- package/dist/src/providers/javascript_pnpm.js +2 -2
- package/dist/src/providers/manifest.d.ts +2 -0
- package/dist/src/providers/manifest.js +22 -4
- package/dist/src/providers/processors/yarn_berry_processor.js +82 -3
- package/dist/src/providers/python_pip.js +1 -1
- package/dist/src/providers/python_poetry.d.ts +42 -0
- package/dist/src/providers/python_poetry.js +169 -0
- package/dist/src/providers/python_uv.d.ts +27 -0
- package/dist/src/providers/python_uv.js +146 -0
- package/dist/src/providers/rust_cargo.d.ts +52 -0
- package/dist/src/providers/rust_cargo.js +614 -0
- package/dist/src/providers/tree-sitter-gomod.wasm +0 -0
- package/dist/src/sbom.d.ts +7 -0
- package/dist/src/sbom.js +9 -0
- package/dist/src/workspace.d.ts +61 -0
- package/dist/src/workspace.js +256 -0
- package/package.json +11 -5
package/dist/src/cli.js
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
+
import fs from 'node:fs';
|
|
2
3
|
import * as path from "path";
|
|
3
4
|
import yargs from 'yargs';
|
|
4
5
|
import { hideBin } from 'yargs/helpers';
|
|
5
6
|
import { getProjectLicense, getLicenseDetails } from './license/index.js';
|
|
6
|
-
import client, { selectTrustifyDABackend } from './index.js';
|
|
7
|
+
import client, { selectTrustifyDABackend, generateSbom } from './index.js';
|
|
7
8
|
// command for component analysis take manifest type and content
|
|
8
9
|
const component = {
|
|
9
10
|
command: 'component </path/to/manifest>',
|
|
@@ -12,10 +13,18 @@ const component = {
|
|
|
12
13
|
desc: 'manifest path for analyzing',
|
|
13
14
|
type: 'string',
|
|
14
15
|
normalize: true,
|
|
16
|
+
}).options({
|
|
17
|
+
workspaceDir: {
|
|
18
|
+
alias: 'w',
|
|
19
|
+
desc: 'Workspace root directory (for monorepos; lock file is expected here)',
|
|
20
|
+
type: 'string',
|
|
21
|
+
normalize: true,
|
|
22
|
+
}
|
|
15
23
|
}),
|
|
16
24
|
handler: async (args) => {
|
|
17
25
|
let manifestName = args['/path/to/manifest'];
|
|
18
|
-
|
|
26
|
+
const opts = args.workspaceDir ? { TRUSTIFY_DA_WORKSPACE_DIR: args.workspaceDir } : {};
|
|
27
|
+
let res = await client.componentAnalysis(manifestName, opts);
|
|
19
28
|
console.log(JSON.stringify(res, null, 2));
|
|
20
29
|
}
|
|
21
30
|
};
|
|
@@ -117,15 +126,22 @@ const stack = {
|
|
|
117
126
|
desc: 'For JSON report, get only the \'summary\'',
|
|
118
127
|
type: 'boolean',
|
|
119
128
|
conflicts: 'html'
|
|
129
|
+
},
|
|
130
|
+
workspaceDir: {
|
|
131
|
+
alias: 'w',
|
|
132
|
+
desc: 'Workspace root directory (for monorepos; lock file is expected here)',
|
|
133
|
+
type: 'string',
|
|
134
|
+
normalize: true,
|
|
120
135
|
}
|
|
121
136
|
}),
|
|
122
137
|
handler: async (args) => {
|
|
123
138
|
let manifest = args['/path/to/manifest'];
|
|
124
139
|
let html = args['html'];
|
|
125
140
|
let summary = args['summary'];
|
|
141
|
+
const opts = args.workspaceDir ? { TRUSTIFY_DA_WORKSPACE_DIR: args.workspaceDir } : {};
|
|
126
142
|
let theProvidersSummary = new Map();
|
|
127
143
|
let theProvidersObject = {};
|
|
128
|
-
let res = await client.stackAnalysis(manifest, html);
|
|
144
|
+
let res = await client.stackAnalysis(manifest, html, opts);
|
|
129
145
|
if (summary) {
|
|
130
146
|
for (let provider in res.providers) {
|
|
131
147
|
if (res.providers[provider].sources !== undefined) {
|
|
@@ -143,6 +159,108 @@ const stack = {
|
|
|
143
159
|
console.log(html ? res : JSON.stringify(!html && summary ? theProvidersObject : res, null, 2));
|
|
144
160
|
}
|
|
145
161
|
};
|
|
162
|
+
// command for batch stack analysis (workspace)
|
|
163
|
+
const stackBatch = {
|
|
164
|
+
command: 'stack-batch </path/to/workspace-root> [--html|--summary] [--concurrency <n>] [--ignore <pattern>...] [--metadata] [--fail-fast]',
|
|
165
|
+
desc: 'produce stack report for all packages/crates in a workspace (Cargo or JS/TS)',
|
|
166
|
+
builder: yargs => yargs.positional('/path/to/workspace-root', {
|
|
167
|
+
desc: 'workspace root directory (containing Cargo.toml+Cargo.lock or package.json+lock file)',
|
|
168
|
+
type: 'string',
|
|
169
|
+
normalize: true,
|
|
170
|
+
}).options({
|
|
171
|
+
html: {
|
|
172
|
+
alias: 'r',
|
|
173
|
+
desc: 'Get the report as HTML instead of JSON',
|
|
174
|
+
type: 'boolean',
|
|
175
|
+
conflicts: 'summary'
|
|
176
|
+
},
|
|
177
|
+
summary: {
|
|
178
|
+
alias: 's',
|
|
179
|
+
desc: 'For JSON report, get only the \'summary\' per package',
|
|
180
|
+
type: 'boolean',
|
|
181
|
+
conflicts: 'html'
|
|
182
|
+
},
|
|
183
|
+
concurrency: {
|
|
184
|
+
alias: 'c',
|
|
185
|
+
desc: 'Max parallel SBOM generations (default: 10, env: TRUSTIFY_DA_BATCH_CONCURRENCY)',
|
|
186
|
+
type: 'number',
|
|
187
|
+
},
|
|
188
|
+
ignore: {
|
|
189
|
+
alias: 'i',
|
|
190
|
+
desc: 'Extra glob patterns excluded from workspace discovery (merged with defaults). Repeat flag per pattern. Env: TRUSTIFY_DA_WORKSPACE_DISCOVERY_IGNORE (comma-separated)',
|
|
191
|
+
type: 'string',
|
|
192
|
+
array: true,
|
|
193
|
+
},
|
|
194
|
+
metadata: {
|
|
195
|
+
alias: 'm',
|
|
196
|
+
desc: 'Return { analysis, metadata } with per-manifest errors (env: TRUSTIFY_DA_BATCH_METADATA=true)',
|
|
197
|
+
type: 'boolean',
|
|
198
|
+
default: false,
|
|
199
|
+
},
|
|
200
|
+
failFast: {
|
|
201
|
+
desc: 'Stop on first invalid package.json or SBOM error (env: TRUSTIFY_DA_CONTINUE_ON_ERROR=false)',
|
|
202
|
+
type: 'boolean',
|
|
203
|
+
default: false,
|
|
204
|
+
}
|
|
205
|
+
}),
|
|
206
|
+
handler: async (args) => {
|
|
207
|
+
const workspaceRoot = args['/path/to/workspace-root'];
|
|
208
|
+
const html = args['html'];
|
|
209
|
+
const summary = args['summary'];
|
|
210
|
+
const opts = {};
|
|
211
|
+
if (args.concurrency != null) {
|
|
212
|
+
opts.batchConcurrency = args.concurrency;
|
|
213
|
+
}
|
|
214
|
+
const extraIgnores = Array.isArray(args.ignore) ? args.ignore.filter(p => p != null && String(p).trim()) : [];
|
|
215
|
+
if (extraIgnores.length > 0) {
|
|
216
|
+
opts.workspaceDiscoveryIgnore = extraIgnores;
|
|
217
|
+
}
|
|
218
|
+
if (args.metadata) {
|
|
219
|
+
opts.batchMetadata = true;
|
|
220
|
+
}
|
|
221
|
+
if (args.failFast) {
|
|
222
|
+
opts.continueOnError = false;
|
|
223
|
+
}
|
|
224
|
+
let res = await client.stackAnalysisBatch(workspaceRoot, html, opts);
|
|
225
|
+
const batchAnalysis = res && typeof res === 'object' && res != null && 'analysis' in res ? res.analysis : res;
|
|
226
|
+
if (summary && !html && typeof batchAnalysis === 'object') {
|
|
227
|
+
const summaries = {};
|
|
228
|
+
for (const [purl, report] of Object.entries(batchAnalysis)) {
|
|
229
|
+
if (report?.providers) {
|
|
230
|
+
for (const provider of Object.keys(report.providers)) {
|
|
231
|
+
const sources = report.providers[provider]?.sources;
|
|
232
|
+
if (sources) {
|
|
233
|
+
for (const [source, data] of Object.entries(sources)) {
|
|
234
|
+
if (data?.summary) {
|
|
235
|
+
if (!summaries[purl]) {
|
|
236
|
+
summaries[purl] = {};
|
|
237
|
+
}
|
|
238
|
+
if (!summaries[purl][provider]) {
|
|
239
|
+
summaries[purl][provider] = {};
|
|
240
|
+
}
|
|
241
|
+
summaries[purl][provider][source] = data.summary;
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
if (res && typeof res === 'object' && res != null && 'metadata' in res) {
|
|
249
|
+
res = { analysis: summaries, metadata: res.metadata };
|
|
250
|
+
}
|
|
251
|
+
else {
|
|
252
|
+
res = summaries;
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
if (html) {
|
|
256
|
+
const htmlContent = res && typeof res === 'object' && 'analysis' in res ? res.analysis : res;
|
|
257
|
+
console.log(htmlContent);
|
|
258
|
+
}
|
|
259
|
+
else {
|
|
260
|
+
console.log(JSON.stringify(res, null, 2));
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
};
|
|
146
264
|
// command for license checking
|
|
147
265
|
const license = {
|
|
148
266
|
command: 'license </path/to/manifest>',
|
|
@@ -208,14 +326,63 @@ const license = {
|
|
|
208
326
|
console.log(JSON.stringify(output, null, 2));
|
|
209
327
|
}
|
|
210
328
|
};
|
|
329
|
+
const sbom = {
|
|
330
|
+
command: 'sbom </path/to/manifest> [--output]',
|
|
331
|
+
desc: 'generate a CycloneDX SBOM from a manifest file',
|
|
332
|
+
builder: yargs => yargs.positional('/path/to/manifest', {
|
|
333
|
+
desc: 'manifest path for SBOM generation',
|
|
334
|
+
type: 'string',
|
|
335
|
+
normalize: true,
|
|
336
|
+
}).options({
|
|
337
|
+
output: {
|
|
338
|
+
alias: 'o',
|
|
339
|
+
desc: 'Write SBOM JSON to a file instead of stdout',
|
|
340
|
+
type: 'string',
|
|
341
|
+
normalize: true,
|
|
342
|
+
},
|
|
343
|
+
workspaceDir: {
|
|
344
|
+
alias: 'w',
|
|
345
|
+
desc: 'Workspace root directory (for monorepos; lock file is expected here)',
|
|
346
|
+
type: 'string',
|
|
347
|
+
normalize: true,
|
|
348
|
+
}
|
|
349
|
+
}),
|
|
350
|
+
handler: async (args) => {
|
|
351
|
+
let manifest = args['/path/to/manifest'];
|
|
352
|
+
const opts = args.workspaceDir ? { TRUSTIFY_DA_WORKSPACE_DIR: args.workspaceDir } : {};
|
|
353
|
+
let result;
|
|
354
|
+
try {
|
|
355
|
+
result = await generateSbom(manifest, opts);
|
|
356
|
+
}
|
|
357
|
+
catch (err) {
|
|
358
|
+
console.error(JSON.stringify({ error: `Failed to generate SBOM: ${err.message}` }, null, 2));
|
|
359
|
+
process.exit(1);
|
|
360
|
+
}
|
|
361
|
+
const json = JSON.stringify(result, null, 2);
|
|
362
|
+
if (args.output) {
|
|
363
|
+
try {
|
|
364
|
+
fs.writeFileSync(args.output, json);
|
|
365
|
+
}
|
|
366
|
+
catch (err) {
|
|
367
|
+
console.error(JSON.stringify({ error: `Failed to write output file: ${err.message}` }, null, 2));
|
|
368
|
+
process.exit(1);
|
|
369
|
+
}
|
|
370
|
+
}
|
|
371
|
+
else {
|
|
372
|
+
console.log(json);
|
|
373
|
+
}
|
|
374
|
+
}
|
|
375
|
+
};
|
|
211
376
|
// parse and invoke the command
|
|
212
377
|
yargs(hideBin(process.argv))
|
|
213
|
-
.usage(`Usage: ${process.argv[0].includes("node") ? path.parse(process.argv[1]).base : path.parse(process.argv[0]).base} {component|stack|image|validate-token|license}`)
|
|
378
|
+
.usage(`Usage: ${process.argv[0].includes("node") ? path.parse(process.argv[1]).base : path.parse(process.argv[0]).base} {component|stack|stack-batch|image|validate-token|license|sbom}`)
|
|
214
379
|
.command(stack)
|
|
380
|
+
.command(stackBatch)
|
|
215
381
|
.command(component)
|
|
216
382
|
.command(image)
|
|
217
383
|
.command(validateToken)
|
|
218
384
|
.command(license)
|
|
385
|
+
.command(sbom)
|
|
219
386
|
.scriptName('')
|
|
220
387
|
.version(false)
|
|
221
388
|
.demandCommand(1)
|
|
@@ -70,6 +70,13 @@ export default class CycloneDxSbom {
|
|
|
70
70
|
* @return {boolean}
|
|
71
71
|
*/
|
|
72
72
|
checkIfPackageInsideDependsOnList(component: any, name: string): boolean;
|
|
73
|
+
/**
|
|
74
|
+
* Checks if any entry in the dependsOn list of sourceRef starts with the given purl prefix.
|
|
75
|
+
* @param {PackageURL} sourceRef - The source component
|
|
76
|
+
* @param {string} purlPrefix - The purl prefix to match (e.g. "pkg:npm/minimist@")
|
|
77
|
+
* @return {boolean}
|
|
78
|
+
*/
|
|
79
|
+
checkDependsOnByPurlPrefix(sourceRef: PackageURL, purlPrefix: string): boolean;
|
|
73
80
|
/** Removes the root component from the sbom
|
|
74
81
|
*/
|
|
75
82
|
removeRootComponent(): void;
|
|
@@ -120,6 +120,7 @@ export default class CycloneDxSbom {
|
|
|
120
120
|
getAsJsonString(opts) {
|
|
121
121
|
let manifestType = opts["manifest-type"];
|
|
122
122
|
this.setSourceManifest(opts["source-manifest"]);
|
|
123
|
+
const rootPurl = this.rootComponent?.purl;
|
|
123
124
|
this.sbomObject = {
|
|
124
125
|
"bomFormat": "CycloneDX",
|
|
125
126
|
"specVersion": "1.4",
|
|
@@ -129,7 +130,7 @@ export default class CycloneDxSbom {
|
|
|
129
130
|
"component": this.rootComponent,
|
|
130
131
|
"properties": new Array()
|
|
131
132
|
},
|
|
132
|
-
"components": this.components,
|
|
133
|
+
"components": this.components.filter(c => c.purl !== rootPurl),
|
|
133
134
|
"dependencies": this.dependencies
|
|
134
135
|
};
|
|
135
136
|
if (this.rootComponent === undefined) {
|
|
@@ -241,6 +242,20 @@ export default class CycloneDxSbom {
|
|
|
241
242
|
return false;
|
|
242
243
|
}
|
|
243
244
|
}
|
|
245
|
+
/**
|
|
246
|
+
* Checks if any entry in the dependsOn list of sourceRef starts with the given purl prefix.
|
|
247
|
+
* @param {PackageURL} sourceRef - The source component
|
|
248
|
+
* @param {string} purlPrefix - The purl prefix to match (e.g. "pkg:npm/minimist@")
|
|
249
|
+
* @return {boolean}
|
|
250
|
+
*/
|
|
251
|
+
checkDependsOnByPurlPrefix(sourceRef, purlPrefix) {
|
|
252
|
+
const sourcePurl = sourceRef.toString();
|
|
253
|
+
const depIndex = this.getDependencyIndex(sourcePurl);
|
|
254
|
+
if (depIndex < 0) {
|
|
255
|
+
return false;
|
|
256
|
+
}
|
|
257
|
+
return this.dependencies[depIndex].dependsOn.some(dep => dep.startsWith(purlPrefix));
|
|
258
|
+
}
|
|
244
259
|
/** Removes the root component from the sbom
|
|
245
260
|
*/
|
|
246
261
|
removeRootComponent() {
|
package/dist/src/index.d.ts
CHANGED
|
@@ -13,16 +13,28 @@ export function selectTrustifyDABackend(opts?: {
|
|
|
13
13
|
TRUSTIFY_DA_DEBUG?: string | undefined;
|
|
14
14
|
TRUSTIFY_DA_BACKEND_URL?: string | undefined;
|
|
15
15
|
}): string;
|
|
16
|
+
/**
|
|
17
|
+
* Generate a CycloneDX SBOM from a manifest file. No backend HTTP request is made.
|
|
18
|
+
*
|
|
19
|
+
* @param {string} manifestPath - path to the manifest file (e.g. pom.xml, package.json)
|
|
20
|
+
* @param {Options} [opts={}] - optional options (e.g. workspace dir, tool paths)
|
|
21
|
+
* @returns {Promise<object>} parsed CycloneDX SBOM JSON object
|
|
22
|
+
* @throws {Error} if the manifest is unsupported or SBOM generation fails
|
|
23
|
+
*/
|
|
24
|
+
export function generateSbom(manifestPath: string, opts?: Options): Promise<object>;
|
|
16
25
|
export { parseImageRef } from "./oci_image/utils.js";
|
|
17
26
|
export { ImageRef } from "./oci_image/images.js";
|
|
18
27
|
declare namespace _default {
|
|
19
28
|
export { componentAnalysis };
|
|
20
29
|
export { stackAnalysis };
|
|
30
|
+
export { stackAnalysisBatch };
|
|
21
31
|
export { imageAnalysis };
|
|
22
32
|
export { validateToken };
|
|
33
|
+
export { generateSbom };
|
|
23
34
|
}
|
|
24
35
|
export default _default;
|
|
25
36
|
export type Options = {
|
|
37
|
+
TRUSTIFY_DA_CARGO_PATH?: string | undefined;
|
|
26
38
|
TRUSTIFY_DA_DOCKER_PATH?: string | undefined;
|
|
27
39
|
TRUSTIFY_DA_GO_MVS_LOGIC_ENABLED?: string | undefined;
|
|
28
40
|
TRUSTIFY_DA_GO_PATH?: string | undefined;
|
|
@@ -47,12 +59,45 @@ export type Options = {
|
|
|
47
59
|
TRUSTIFY_DA_SYFT_CONFIG_PATH?: string | undefined;
|
|
48
60
|
TRUSTIFY_DA_SYFT_PATH?: string | undefined;
|
|
49
61
|
TRUSTIFY_DA_YARN_PATH?: string | undefined;
|
|
62
|
+
TRUSTIFY_DA_WORKSPACE_DIR?: string | undefined;
|
|
50
63
|
TRUSTIFY_DA_LICENSE_CHECK?: string | undefined;
|
|
51
64
|
MATCH_MANIFEST_VERSIONS?: string | undefined;
|
|
52
65
|
TRUSTIFY_DA_SOURCE?: string | undefined;
|
|
53
66
|
TRUSTIFY_DA_TOKEN?: string | undefined;
|
|
54
67
|
TRUSTIFY_DA_TELEMETRY_ID?: string | undefined;
|
|
55
|
-
|
|
68
|
+
TRUSTIFY_DA_WORKSPACE_DIR?: string | undefined;
|
|
69
|
+
batchConcurrency?: number | undefined;
|
|
70
|
+
TRUSTIFY_DA_BATCH_CONCURRENCY?: string | undefined;
|
|
71
|
+
workspaceDiscoveryIgnore?: string[] | undefined;
|
|
72
|
+
TRUSTIFY_DA_WORKSPACE_DISCOVERY_IGNORE?: string | undefined;
|
|
73
|
+
continueOnError?: boolean | undefined;
|
|
74
|
+
TRUSTIFY_DA_CONTINUE_ON_ERROR?: string | undefined;
|
|
75
|
+
batchMetadata?: boolean | undefined;
|
|
76
|
+
TRUSTIFY_DA_BATCH_METADATA?: string | undefined;
|
|
77
|
+
TRUSTIFY_DA_UV_PATH?: string | undefined;
|
|
78
|
+
TRUSTIFY_DA_POETRY_PATH?: string | undefined;
|
|
79
|
+
[key: string]: string | number | boolean | string[] | undefined;
|
|
80
|
+
};
|
|
81
|
+
export type BatchAnalysisMetadata = {
|
|
82
|
+
workspaceRoot: string;
|
|
83
|
+
ecosystem: "javascript" | "cargo" | "unknown";
|
|
84
|
+
total: number;
|
|
85
|
+
successful: number;
|
|
86
|
+
failed: number;
|
|
87
|
+
errors: Array<{
|
|
88
|
+
manifestPath: string;
|
|
89
|
+
phase: "validation" | "sbom";
|
|
90
|
+
reason: string;
|
|
91
|
+
}>;
|
|
92
|
+
};
|
|
93
|
+
export type SbomResult = {
|
|
94
|
+
ok: true;
|
|
95
|
+
purl: string;
|
|
96
|
+
sbom: object;
|
|
97
|
+
} | {
|
|
98
|
+
ok: false;
|
|
99
|
+
manifestPath: string;
|
|
100
|
+
reason: string;
|
|
56
101
|
};
|
|
57
102
|
/**
|
|
58
103
|
* Get component analysis report for a manifest content.
|
|
@@ -91,6 +136,26 @@ declare function stackAnalysis(manifest: string, html: false, opts?: Options | u
|
|
|
91
136
|
* or backend request failed
|
|
92
137
|
*/
|
|
93
138
|
declare function stackAnalysis(manifest: string, html?: boolean | undefined, opts?: Options | undefined): Promise<string | import("@trustify-da/trustify-da-api-model/model/v5/AnalysisReport").AnalysisReport>;
|
|
139
|
+
/**
|
|
140
|
+
* Get stack analysis for all workspace packages/crates (batch).
|
|
141
|
+
* Detects ecosystem from workspace root: Cargo (Cargo.toml + Cargo.lock) or JS/TS (package.json + lock file).
|
|
142
|
+
* SBOMs are generated in parallel (see `batchConcurrency`) unless `continueOnError: false` (fail-fast sequential).
|
|
143
|
+
* With `opts.batchMetadata` / `TRUSTIFY_DA_BATCH_METADATA`, returns `{ analysis, metadata }` including validation and SBOM errors.
|
|
144
|
+
*
|
|
145
|
+
* @param {string} workspaceRoot - Path to workspace root (containing lock file and workspace config)
|
|
146
|
+
* @param {boolean} [html=false] - true returns HTML, false returns JSON report
|
|
147
|
+
* @param {Options} [opts={}] - `batchConcurrency`, discovery ignores, `continueOnError` (default true), `batchMetadata` (default false)
|
|
148
|
+
* @returns {Promise<string|Object.<string, import('@trustify-da/trustify-da-api-model/model/v5/AnalysisReport').AnalysisReport>|{ analysis: string|Object.<string, import('@trustify-da/trustify-da-api-model/model/v5/AnalysisReport').AnalysisReport>, metadata: BatchAnalysisMetadata }>}
|
|
149
|
+
* @throws {Error} if workspace root invalid, no manifests found, no packages pass validation, no SBOMs produced, or backend request failed. When `opts.batchMetadata` is set, `error.batchMetadata` may be set on thrown errors.
|
|
150
|
+
*/
|
|
151
|
+
declare function stackAnalysisBatch(workspaceRoot: string, html?: boolean, opts?: Options): Promise<string | {
|
|
152
|
+
[x: string]: import("@trustify-da/trustify-da-api-model/model/v5/AnalysisReport").AnalysisReport;
|
|
153
|
+
} | {
|
|
154
|
+
analysis: string | {
|
|
155
|
+
[x: string]: import("@trustify-da/trustify-da-api-model/model/v5/AnalysisReport").AnalysisReport;
|
|
156
|
+
};
|
|
157
|
+
metadata: BatchAnalysisMetadata;
|
|
158
|
+
}>;
|
|
94
159
|
/**
|
|
95
160
|
* @overload
|
|
96
161
|
* @param {Array<string>} imageRefs
|
|
@@ -131,4 +196,12 @@ declare function imageAnalysis(imageRefs: Array<string>, html?: boolean | undefi
|
|
|
131
196
|
* @throws {Error} if the backend request failed.
|
|
132
197
|
*/
|
|
133
198
|
declare function validateToken(opts?: Options): Promise<object>;
|
|
199
|
+
import { discoverWorkspacePackages } from './workspace.js';
|
|
200
|
+
import { discoverWorkspaceCrates } from './workspace.js';
|
|
201
|
+
import { validatePackageJson } from './workspace.js';
|
|
202
|
+
import { resolveWorkspaceDiscoveryIgnore } from './workspace.js';
|
|
203
|
+
import { filterManifestPathsByDiscoveryIgnore } from './workspace.js';
|
|
204
|
+
import { resolveContinueOnError } from './batch_opts.js';
|
|
205
|
+
import { resolveBatchMetadata } from './batch_opts.js';
|
|
206
|
+
export { discoverWorkspacePackages, discoverWorkspaceCrates, validatePackageJson, resolveWorkspaceDiscoveryIgnore, filterManifestPathsByDiscoveryIgnore, resolveContinueOnError, resolveBatchMetadata };
|
|
134
207
|
export { getProjectLicense, findLicenseFilePath, identifyLicense, getLicenseDetails, licensesFromReport, normalizeLicensesResponse, runLicenseCheck, getCompatibility } from "./license/index.js";
|