Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -357,7 +357,6 @@ The following tests are not yet implemented and therefore missing:
- Recommended Test 6.2.34
- Recommended Test 6.2.35
- Recommended Test 6.2.36
- Recommended Test 6.2.37
- Recommended Test 6.2.38
- Recommended Test 6.2.39
- Recommended Test 6.2.40
Expand Down Expand Up @@ -462,6 +461,7 @@ export const recommendedTest_6_2_16: DocumentTest
export const recommendedTest_6_2_17: DocumentTest
export const recommendedTest_6_2_18: DocumentTest
export const recommendedTest_6_2_22: DocumentTest
export const recommendedTest_6_2_37: DocumentTest
```

[(back to top)](#bsi-csaf-validator-lib)
Expand Down
1 change: 1 addition & 0 deletions csaf_2_1/recommendedTests.js
Original file line number Diff line number Diff line change
Expand Up @@ -30,4 +30,5 @@ export { recommendedTest_6_2_22 } from './recommendedTests/recommendedTest_6_2_2
export { recommendedTest_6_2_27 } from './recommendedTests/recommendedTest_6_2_27.js'
export { recommendedTest_6_2_28 } from './recommendedTests/recommendedTest_6_2_28.js'
export { recommendedTest_6_2_29 } from './recommendedTests/recommendedTest_6_2_29.js'
export { recommendedTest_6_2_37 } from './recommendedTests/recommendedTest_6_2_37.js'
export { recommendedTest_6_2_38 } from './recommendedTests/recommendedTest_6_2_38.js'
72 changes: 72 additions & 0 deletions csaf_2_1/recommendedTests/recommendedTest_6_2_37.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
import Ajv from 'ajv/dist/jtd.js'

const ajv = new Ajv()

const inputSchema = /** @type {const} */ ({
additionalProperties: true,
properties: {
vulnerabilities: {
elements: {
additionalProperties: true,
optionalProperties: {
metrics: {
elements: {
additionalProperties: true,
optionalProperties: {
content: {
additionalProperties: true,
optionalProperties: {
ssvc_v1: {
additionalProperties: true,
optionalProperties: {
role: {
type: 'string',
},
},
},
},
},
},
},
},
},
},
},
},
})

const validate = ajv.compile(inputSchema)

/**
* This implements the recommended test 6.2.37 of the CSAF 2.1 standard.
*
* @param {any} doc
*/
export function recommendedTest_6_2_37(doc) {
/** @type {Array<{ message: string; instancePath: string }>} */
const warnings = []
const context = { warnings }

if (!validate(doc)) {
return context
}

/*
* Please note that this list can change
* */
const registeredSsvcRoles = ['Supplier', 'Deployer', 'Coordinator']

doc.vulnerabilities?.forEach((vulnerability, vulnerabilityIndex) => {
vulnerability.metrics?.forEach((metric, metricIndex) => {
const role = metric.content?.ssvc_v1?.role
if (role !== undefined && !registeredSsvcRoles.includes(role)) {
context.warnings.push({
message: `The used role "${role}" is not registered`,
instancePath: `/vulnerabilities/${vulnerabilityIndex}/metrics/${metricIndex}/content/ssvc_v1/role`,
})
}
})
})

return context
}
1 change: 0 additions & 1 deletion tests/csaf_2_1/oasis.js
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,6 @@ const excluded = [
'6.2.34',
'6.2.35',
'6.2.36',
'6.2.37',
'6.2.39.1',
'6.2.39.2',
'6.2.39.3',
Expand Down
11 changes: 11 additions & 0 deletions tests/csaf_2_1/recommendedTest_6_2_37.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import assert from 'node:assert'
import { recommendedTest_6_2_37 } from '../../csaf_2_1/recommendedTests.js'

describe('recommendedTest_6_2_37', function () {
it('only runs on relevant documents', function () {
assert.equal(
recommendedTest_6_2_37({ vulnerabilities: 'mydoc' }).warnings.length,
0
)
})
})