Skip to content
Draft
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 @@ -355,7 +355,6 @@ The following tests are not yet implemented and therefore missing:
- Recommended Test 6.2.32
- Recommended Test 6.2.33
- 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
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_35: 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_35 } from './recommendedTests/recommendedTest_6_2_35.js'
export { recommendedTest_6_2_38 } from './recommendedTests/recommendedTest_6_2_38.js'
100 changes: 100 additions & 0 deletions csaf_2_1/recommendedTests/recommendedTest_6_2_35.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,100 @@
import Ajv from 'ajv/dist/jtd.js'

const ajv = new Ajv()

const inputSchema = /** @type {const} */ ({
additionalProperties: true,
properties: {
document: {
additionalProperties: true,
properties: {
distribution: {
additionalProperties: true,
properties: {
tlp: {
additionalProperties: true,
properties: {
label: { type: 'string' },
},
},
},
},
},
},
vulnerabilities: {
elements: {
additionalProperties: true,
optionalProperties: {
metrics: {
elements: {
additionalProperties: true,
optionalProperties: {
content: {
additionalProperties: true,
optionalProperties: {
ssvc_v1: {
additionalProperties: true,
optionalProperties: {
selections: {
elements: {
additionalProperties: true,
optionalProperties: {
namespace: {
type: 'string',
},
},
},
},
},
},
},
},
},
},
},
},
},
},
},
})

const validate = ajv.compile(inputSchema)

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

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

/*
* According to https://certcc.github.io/SSVC/data/schema/v1/Decision_Point-1-0-1.schema.json#/$defs/decision_point/properties/namespace
* a private namespace starts with "x_"
* */

if (doc.document.distribution.tlp.label !== 'CLEAR') {
return context
}
doc.vulnerabilities?.forEach((vulnerability, vulnerabilityIndex) => {
vulnerability.metrics?.forEach((metric, metricIndex) => {
const selections = metric.content?.ssvc_v1?.selections || []
selections.forEach((selection, selectionIndex) => {
if (selection.namespace?.startsWith('x_')) {
context.warnings.push({
message: `The namespace "${selection.namespace}" is a private namespace`,
instancePath: `/vulnerabilities/${vulnerabilityIndex}/metrics/${metricIndex}/content/ssvc_v1/selections/${selectionIndex}/namespace`,
})
}
})
})
})

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 @@ -53,7 +53,6 @@ const excluded = [
'6.2.32',
'6.2.33',
'6.2.34',
'6.2.35',
'6.2.36',
'6.2.37',
'6.2.39.1',
Expand Down
51 changes: 51 additions & 0 deletions tests/csaf_2_1/recommendedTest_6_2_35.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
import assert from 'node:assert'
import { recommendedTest_6_2_35 } from '../../csaf_2_1/recommendedTests.js'

describe('recommendedTest_6_2_35', function () {
it('only runs on relevant documents', function () {
assert.equal(
recommendedTest_6_2_35({ vulnerabilities: 'mydoc' }).warnings.length,
0
)
})
it('skips empty objects', function () {
assert.equal(
recommendedTest_6_2_35({
document: {
distribution: {
tlp: {
label: 'CLEAR',
},
},
},
vulnerabilities: [
{
metrics: [
{
content: {
ssvc_v1: {}, // should be ignored
},
},
],
},
{
metrics: [
{
content: {
ssvc_v1: {
selections: [
{
namespace: 'x_custom',
},
],
},
},
},
],
},
],
}).warnings.length,
1
)
})
})