From 4c07c78d54fc298e18fe3e8b697a620a5171bd60 Mon Sep 17 00:00:00 2001 From: Stefan Hagen Date: Sun, 13 Aug 2023 18:12:38 +0200 Subject: [PATCH 01/74] documentary: Documented the plan - created root folder vor CSAF v2.1 - added documentation on the goals as top-level README.md in that folder Signed-off-by: Stefan Hagen --- csaf_2.1/README.md | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) create mode 100644 csaf_2.1/README.md diff --git a/csaf_2.1/README.md b/csaf_2.1/README.md new file mode 100644 index 000000000..ac17c2406 --- /dev/null +++ b/csaf_2.1/README.md @@ -0,0 +1,16 @@ +# Seeding the next version of CSAF + +This folder serves as a showcase of an improved way +to edit, verify, and validate the next version of CSAF. + +The main goals are (for now): + +- extract examples to ensure validation +- refactor the source markdown into smaller chunks (per sections) +- set uo a binder text file that declares the order of concatenation of these source files +- automatically derive the section numbering from the order and an AST traversal +- generate the single elephant GFM+gh_cosmetics user facing delivery item from these source +- empower the editors by enfocing semantic references +- use vale for developer documentation spell checks +- use markdownlint to validate the sourc emarkdown files +- use pandoc and filters to generate html and pdf user facing delivery items From 6343455c09e835dc91ffe687ec4fa1391d361a68 Mon Sep 17 00:00:00 2001 From: Stefan Hagen Date: Sun, 13 Aug 2023 18:39:18 +0200 Subject: [PATCH 02/74] config: amended git ignores and added editor config as well as git attributes - added editor config for ease of collaboration - added git attributes file for cross platform ease - amended git ignores by typical needed artifacts that should stay local Signed-off-by: Stefan Hagen --- .editorconfig | 60 ++++++++++++++++++++++++++++++++++++++++++++++++++ .gitattributes | 1 + .gitignore | 21 +++++++++++++++++- 3 files changed, 81 insertions(+), 1 deletion(-) create mode 100644 .editorconfig create mode 100644 .gitattributes diff --git a/.editorconfig b/.editorconfig new file mode 100644 index 000000000..00557f49f --- /dev/null +++ b/.editorconfig @@ -0,0 +1,60 @@ +.editorconfig # Editor config +# http://EditorConfig.org + +# This EditorConfig overrides any parent EditorConfigs +root = true + +# Default rules applied to all file types +[*] + +# Trim trailing spaces, newline at EOF +charset = utf-8 +trim_trailing_whitespace = true +insert_final_newline = true +end_of_line = lf + +# 2 space indentation +indent_style = space +indent_size = 2 + +# Makefiles require tabs +[Makefile] +indent_style = tab +indent_size = 4 +max_line_length = 256 + +# 4 space indentation +[*.{py,java,r,R}] +indent_style = space +indent_size = 4 +max_line_length = 120 + +# 2 space indentation +[*.{json,y{a,}ml,html,cwl}] +indent_style = space +indent_size = 2 + +[*.{md,Rmd,rst}] +trim_trailing_whitespace = false +indent_style = space +indent_size = 2 + +# JavaScript-specific settings +[*.{js,ts}] +quote_type = single +indent_style = space +indent_size = 2 +continuation_indent_size = 2 +curly_bracket_next_line = false +indent_brace_style = BSD +spaces_around_operators = true +spaces_around_brackets = none +max_line_length = 150 + +[*.rs] +end_of_line = lf +charset = utf-8 +trim_trailing_whitespace = true +indent_style = space +indent_size = 4 +max_line_length = 120 diff --git a/.gitattributes b/.gitattributes new file mode 100644 index 000000000..6313b56c5 --- /dev/null +++ b/.gitattributes @@ -0,0 +1 @@ +* text=auto eol=lf diff --git a/.gitignore b/.gitignore index f351ae57c..e13420f64 100644 --- a/.gitignore +++ b/.gitignore @@ -1,6 +1,25 @@ - +# Original ignores (before csaf_2.1 branch off) meeting_minutes/.DS_Store .DS_Store *_strict_schema.json official-cpe-dictionary_v2.3.* official-cpe-dictionary_v2.2.* + +# pyenv +.python-version + +# Environments +.env +.venv +env/ +venv/ +ENV/ +env.bak/ +venv.bak/ + +# Other local development artifacts +*~ +.idea +local* +.vscode/ +build/ From 95c8ff174ae4546a67cedc467d75692ec3d6b62b Mon Sep 17 00:00:00 2001 From: Stefan Hagen Date: Sun, 13 Aug 2023 18:42:42 +0200 Subject: [PATCH 03/74] seed: created seeding copies of v2.0 for v2.1 spec version - copied all relevant files needed to ease tracing the final v2.1 seed data back to the v2.0 origins - note: everything besides the submit/README.md is unchanged (content wise) and the csaf_2.1/prose/csaf-v2.1-editor-draft.md is a copy of the csaf_2.0/prose/csaf-v2-editor-draft.md file Signed-off-by: Stefan Hagen --- csaf_2.1/LICENSE.md | 15 + .../examples/ROLIE/example-01-category.json | 12 + .../ROLIE/example-01-feed-tlp-white.json | 52 + .../examples/ROLIE/example-01-service.json | 23 + .../examples/ROLIE/example-02-service.json | 60 + .../aggregator/example-01-aggregator.json | 36 + .../aggregator/example-02-aggregator.json | 42 + csaf_2.1/examples/csaf/bsi-2022-0001.json | 214 + .../examples/csaf/cisco-sa-20180328-smi2.json | 3315 ++++++++ .../csaf/csaf_vex/2022-evd-uc-01-a-001.json | 90 + .../csaf/csaf_vex/2022-evd-uc-01-f-001.json | 81 + .../csaf/csaf_vex/2022-evd-uc-01-na-001.json | 90 + .../csaf/csaf_vex/2022-evd-uc-01-ui-001.json | 81 + .../csaf/csaf_vex/2022-evd-uc-02-na-001.json | 522 ++ .../csaf/csaf_vex/2022-evd-uc-03-ms-001.json | 450 ++ .../csaf/csaf_vex/2022-evd-uc-04-001.json | 140 + .../csaf/csaf_vex/2022-evd-uc-05-001.json | 81 + .../csaf/csaf_vex/2022-evd-uc-06-001.json | 215 + .../csaf/csaf_vex/2022-evd-uc-07-001.json | 266 + .../csaf/csaf_vex/2022-evd-uc-08-001.json | 402 + .../csaf/csaf_vex/2022-evd-uc-09-001.json | 240 + csaf_2.1/examples/csaf/csaf_vex/README.md | 24 + .../csaf/csaf_vex/sec-vex-2022-0001.json | 200 + csaf_2.1/examples/csaf/rhsa-2019_1862.json | 103 + csaf_2.1/examples/csaf/rhsa-2021_5186.json | 319 + csaf_2.1/examples/csaf/rhsa-2021_5217.json | 185 + csaf_2.1/examples/csaf/rhsa-2022_0011.json | 427 + .../example-01-provider-metadata.json | 32 + csaf_2.1/json_schema/NOTES.md | 107 + .../json_schema/aggregator_json_schema.json | 215 + csaf_2.1/json_schema/csaf_json_schema.json | 1414 ++++ .../json_schema/provider_json_schema.json | 211 + csaf_2.1/prose/csaf-v2.1-editor-draft.md | 7146 +++++++++++++++++ csaf_2.1/submit/README.md | 3 + csaf_2.1/test/aggregator_schema/run_tests.sh | 45 + csaf_2.1/test/cpe/run_tests.sh | 61 + csaf_2.1/test/cpe/test-regex.js | 26 + csaf_2.1/test/csaf_schema/run_tests.sh | 43 + .../OASIS_CSAF_TC-CSAF_2.0-2021-5-1-01.json | 26 + ...asis-open_csaf_tc-csaf_20-2021-5-1-02.json | 26 + ...oasis____csaf_tc-csaf_2_0-2021-5-1-03.json | 26 + .../oasis_csaf_tc-csaf_2_0-2021-5-1-11.json | 26 + .../oasis_csaf_tc-csaf_2_0-2021-5-1-12.json | 26 + .../oasis_csaf_tc-csaf_2_0-2021-5-1-13.json | 26 + csaf_2.1/test/filenames/run_invalid_tests.sh | 24 + csaf_2.1/test/filenames/run_tests.sh | 24 + csaf_2.1/test/generate_strict_schema.py | 23 + csaf_2.1/test/provider_schema/run_tests.sh | 44 + csaf_2.1/test/validator.py | 34 + csaf_2.1/test/validator/check_testcases.sh | 55 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-01-01.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-01-02.json | 84 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-01-11.json | 56 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-01-12.json | 96 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-02-01.json | 51 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-02-02.json | 81 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-02-11.json | 51 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-02-12.json | 81 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-03-01.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-03-02.json | 38 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-03-11.json | 32 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-03-12.json | 40 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-04-01.json | 32 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-04-02.json | 44 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-04-11.json | 36 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-04-12.json | 52 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-05-01.json | 47 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-06-01.json | 32 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-06-02.json | 34 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-06-11.json | 32 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-07-01.json | 33 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-07-11.json | 33 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-08-01.json | 33 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-08-11.json | 33 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-09-01.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-09-02.json | 58 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-09-03.json | 58 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-09-04.json | 58 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-09-05.json | 100 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-09-06.json | 70 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-09-11.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-09-12.json | 64 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-09-13.json | 70 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-09-14.json | 64 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-09-15.json | 112 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-10-01.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-10-11.json | 66 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-11-01.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-3-11-11.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-01-01.json | 37 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-02-01.json | 38 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-03-01.json | 45 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-04-01.json | 47 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-05-01.json | 58 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-06-01.json | 46 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-06-02.json | 46 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-06-03.json | 46 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-06-04.json | 56 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-06-05.json | 67 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-06-11.json | 46 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-06-12.json | 46 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-06-13.json | 46 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-06-14.json | 56 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-06-15.json | 67 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-07-01.json | 62 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-07-11.json | 66 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-07-12.json | 56 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-08-01.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-09-01.json | 51 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-10-01.json | 59 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-11-01.json | 34 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-12-01.json | 27 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-13-01.json | 37 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-14-01.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-15-01.json | 26 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-01.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-02.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-03.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-04.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-05.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-06.json | 71 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-07.json | 76 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-08.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-11.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-12.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-13.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-14.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-15.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-16.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-17.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-18.json | 71 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-19.json | 76 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-16-31.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-17-01.json | 26 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-18-01.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-19-01.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-19-02.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-20-01.json | 26 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-21-01.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-21-02.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-21-11.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-21-12.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-21-13.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-22-01.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-23-01.json | 34 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-24-01.json | 43 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-24-02.json | 43 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-24-11.json | 47 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-24-12.json | 47 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-25-01.json | 51 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-26-01.json | 26 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-01-01.json | 33 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-02-01.json | 33 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-03-01.json | 31 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-04-01.json | 31 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-05-01.json | 31 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-06-01.json | 31 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-07-01.json | 50 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-08-01.json | 31 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-09-01.json | 79 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-09-02.json | 78 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-09-03.json | 71 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-09-04.json | 70 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-09-05.json | 78 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-09-06.json | 148 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-09-11.json | 82 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-09-12.json | 81 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-09-13.json | 72 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-09-14.json | 71 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-09-15.json | 79 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-09-16.json | 149 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-10-01.json | 73 + ...is_csaf_tc-csaf_2_0-2021-6-1-27-11-01.json | 34 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-28-01.json | 28 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-28-11.json | 28 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-29-01.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-29-11.json | 53 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-29-12.json | 44 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-30-01.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-30-11.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-31-01.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-31-02.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-31-03.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-31-04.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-31-05.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-31-06.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-31-07.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-31-08.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-31-09.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-31-11.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-31-12.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-32-01.json | 49 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-32-11.json | 52 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-33-01.json | 72 + ...oasis_csaf_tc-csaf_2_0-2021-6-1-33-11.json | 82 + .../oasis_csaf_tc-csaf_2_0-2021-TEMPLATE.json | 26 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-01-01.json | 34 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-01-11.json | 47 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-02-01.json | 43 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-03-01.json | 43 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-04-01.json | 26 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-05-01.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-06-01.json | 31 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-07-01.json | 36 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-08-01.json | 47 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-08-02.json | 51 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-09-01.json | 47 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-09-02.json | 51 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-10-01.json | 29 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-11-01.json | 33 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-11-11.json | 33 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-12-01.json | 26 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-13-01.json | 26 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-14-01.json | 27 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-14-02.json | 28 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-14-03.json | 28 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-14-04.json | 27 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-14-05.json | 27 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-14-06.json | 27 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-14-07.json | 27 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-14-08.json | 27 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-14-11.json | 27 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-14-12.json | 28 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-15-01.json | 27 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-15-02.json | 28 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-15-11.json | 27 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-16-01.json | 43 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-16-02.json | 59 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-16-11.json | 48 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-17-01.json | 36 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-17-11.json | 36 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-18-01.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-18-11.json | 50 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-19-01.json | 56 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-19-02.json | 58 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-19-03.json | 56 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-19-04.json | 55 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-19-05.json | 56 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-19-06.json | 58 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-19-11.json | 56 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-19-12.json | 59 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-19-13.json | 56 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-19-14.json | 55 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-19-15.json | 56 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-19-16.json | 59 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-19-17.json | 56 + ...oasis_csaf_tc-csaf_2_0-2021-6-2-20-01.json | 27 + csaf_2.1/test/validator/data/testcases.json | 1294 +++ csaf_2.1/test/validator/run_tests.sh | 52 + .../test/validator/testcases_json_schema.json | 103 + 250 files changed, 28101 insertions(+) create mode 100644 csaf_2.1/LICENSE.md create mode 100644 csaf_2.1/examples/ROLIE/example-01-category.json create mode 100644 csaf_2.1/examples/ROLIE/example-01-feed-tlp-white.json create mode 100644 csaf_2.1/examples/ROLIE/example-01-service.json create mode 100644 csaf_2.1/examples/ROLIE/example-02-service.json create mode 100644 csaf_2.1/examples/aggregator/example-01-aggregator.json create mode 100644 csaf_2.1/examples/aggregator/example-02-aggregator.json create mode 100644 csaf_2.1/examples/csaf/bsi-2022-0001.json create mode 100644 csaf_2.1/examples/csaf/cisco-sa-20180328-smi2.json create mode 100644 csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-01-a-001.json create mode 100644 csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-01-f-001.json create mode 100644 csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-01-na-001.json create mode 100644 csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-01-ui-001.json create mode 100644 csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-02-na-001.json create mode 100644 csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-03-ms-001.json create mode 100644 csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-04-001.json create mode 100644 csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-05-001.json create mode 100644 csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-06-001.json create mode 100644 csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-07-001.json create mode 100644 csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-08-001.json create mode 100644 csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-09-001.json create mode 100644 csaf_2.1/examples/csaf/csaf_vex/README.md create mode 100644 csaf_2.1/examples/csaf/csaf_vex/sec-vex-2022-0001.json create mode 100644 csaf_2.1/examples/csaf/rhsa-2019_1862.json create mode 100644 csaf_2.1/examples/csaf/rhsa-2021_5186.json create mode 100644 csaf_2.1/examples/csaf/rhsa-2021_5217.json create mode 100644 csaf_2.1/examples/csaf/rhsa-2022_0011.json create mode 100644 csaf_2.1/examples/provider-metadata/example-01-provider-metadata.json create mode 100644 csaf_2.1/json_schema/NOTES.md create mode 100644 csaf_2.1/json_schema/aggregator_json_schema.json create mode 100644 csaf_2.1/json_schema/csaf_json_schema.json create mode 100644 csaf_2.1/json_schema/provider_json_schema.json create mode 100644 csaf_2.1/prose/csaf-v2.1-editor-draft.md create mode 100644 csaf_2.1/submit/README.md create mode 100755 csaf_2.1/test/aggregator_schema/run_tests.sh create mode 100755 csaf_2.1/test/cpe/run_tests.sh create mode 100644 csaf_2.1/test/cpe/test-regex.js create mode 100755 csaf_2.1/test/csaf_schema/run_tests.sh create mode 100644 csaf_2.1/test/filenames/data/invalid/OASIS_CSAF_TC-CSAF_2.0-2021-5-1-01.json create mode 100644 csaf_2.1/test/filenames/data/invalid/oasis-open_csaf_tc-csaf_20-2021-5-1-02.json create mode 100644 csaf_2.1/test/filenames/data/invalid/oasis____csaf_tc-csaf_2_0-2021-5-1-03.json create mode 100644 csaf_2.1/test/filenames/data/valid/oasis_csaf_tc-csaf_2_0-2021-5-1-11.json create mode 100644 csaf_2.1/test/filenames/data/valid/oasis_csaf_tc-csaf_2_0-2021-5-1-12.json create mode 100644 csaf_2.1/test/filenames/data/valid/oasis_csaf_tc-csaf_2_0-2021-5-1-13.json create mode 100755 csaf_2.1/test/filenames/run_invalid_tests.sh create mode 100755 csaf_2.1/test/filenames/run_tests.sh create mode 100644 csaf_2.1/test/generate_strict_schema.py create mode 100755 csaf_2.1/test/provider_schema/run_tests.sh create mode 100644 csaf_2.1/test/validator.py create mode 100755 csaf_2.1/test/validator/check_testcases.sh create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-01.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-02.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-11.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-12.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-01.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-02.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-11.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-12.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-01.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-02.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-11.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-12.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-01.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-02.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-11.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-12.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-05-01.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-06-01.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-06-02.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-06-11.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-07-01.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-07-11.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-08-01.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-08-11.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-01.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-02.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-03.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-04.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-05.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-06.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-11.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-12.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-13.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-14.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-15.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-10-01.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-10-11.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-11-01.json create mode 100644 csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-11-11.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-01-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-02-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-03-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-04-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-05-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-02.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-03.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-04.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-05.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-11.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-12.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-13.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-14.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-15.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-07-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-07-11.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-07-12.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-08-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-09-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-10-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-11-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-12-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-13-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-14-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-15-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-02.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-03.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-04.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-05.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-06.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-07.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-08.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-11.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-12.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-13.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-14.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-15.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-16.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-17.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-18.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-19.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-31.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-17-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-18-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-19-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-19-02.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-20-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-02.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-11.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-12.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-13.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-22-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-23-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-02.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-11.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-12.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-25-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-26-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-01-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-02-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-03-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-04-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-05-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-06-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-07-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-08-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-02.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-03.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-04.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-05.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-06.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-11.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-12.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-13.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-14.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-15.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-16.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-10-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-11-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-28-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-28-11.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-29-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-29-11.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-29-12.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-30-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-30-11.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-02.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-03.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-04.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-05.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-06.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-07.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-08.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-09.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-11.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-12.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-32-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-32-11.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-33-01.json create mode 100644 csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-33-11.json create mode 100644 csaf_2.1/test/validator/data/oasis_csaf_tc-csaf_2_0-2021-TEMPLATE.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-01-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-01-11.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-02-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-03-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-04-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-05-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-06-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-07-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-08-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-08-02.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-09-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-09-02.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-10-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-11-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-11-11.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-12-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-13-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-02.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-03.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-04.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-05.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-06.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-07.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-08.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-11.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-12.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-15-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-15-02.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-15-11.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-16-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-16-02.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-16-11.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-17-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-17-11.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-18-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-18-11.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-01.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-02.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-03.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-04.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-05.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-06.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-11.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-12.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-13.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-14.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-15.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-16.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-17.json create mode 100644 csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-20-01.json create mode 100644 csaf_2.1/test/validator/data/testcases.json create mode 100755 csaf_2.1/test/validator/run_tests.sh create mode 100644 csaf_2.1/test/validator/testcases_json_schema.json diff --git a/csaf_2.1/LICENSE.md b/csaf_2.1/LICENSE.md new file mode 100644 index 000000000..abab86397 --- /dev/null +++ b/csaf_2.1/LICENSE.md @@ -0,0 +1,15 @@ +# License Terms + +Content in this GitHub code repository has been [contributed](https://www.oasis-open.org/policies-guidelines/ipr#def-contribution) +by OASIS TC Members, and is governed by the OASIS policies, including the +[Intellectual Property Rights (IPR) Policy](https://www.oasis-open.org/policies-guidelines/ipr), +the [Technical Committee (TC) Process](https://www.oasis-open.org/policies-guidelines/tc-process), +[Bylaws](https://www.oasis-open.org/policies-guidelines/bylaws), +and the Technical Committee's choice of [IPR Mode](https://www.oasis-open.org/policies-guidelines/ipr#def-ipr-mode) +(*viz*, [Non-Assertion Mode](https://www.oasis-open.org/policies-guidelines/ipr#Non-Assertion-Mode)), +including any applicable [declarations](https://www.oasis-open.org/committees/csaf/ipr.php). +Feedback from non-TC members, if any, +is governed by the terms of the [OASIS Feedback License](https://www.oasis-open.org/policies-guidelines/ipr#appendixa). + +Description of this repository is presented in the [README](https://github.com/oasis-tcs/csaf/blob/master/README.md) file, +and guidelines for contribution/participation are given in the [CONTRIBUTING](https://github.com/oasis-tcs/csaf/blob/master/CONTRIBUTING.md) file. diff --git a/csaf_2.1/examples/ROLIE/example-01-category.json b/csaf_2.1/examples/ROLIE/example-01-category.json new file mode 100644 index 000000000..2f835f3ef --- /dev/null +++ b/csaf_2.1/examples/ROLIE/example-01-category.json @@ -0,0 +1,12 @@ +{ + "categories": { + "category": [ + { + "term": "Example Company Product A" + }, + { + "term": "Example Company Product B" + } + ] + } +} diff --git a/csaf_2.1/examples/ROLIE/example-01-feed-tlp-white.json b/csaf_2.1/examples/ROLIE/example-01-feed-tlp-white.json new file mode 100644 index 000000000..533ad0535 --- /dev/null +++ b/csaf_2.1/examples/ROLIE/example-01-feed-tlp-white.json @@ -0,0 +1,52 @@ +{ + "feed": { + "id": "example-csaf-feed-tlp-white", + "title": "Example CSAF feed (TLP:WHITE)", + "link": [ + { + "rel": "self", + "href": "https://psirt.domain.tld/advisories/csaf/feed-tlp-white.json" + } + ], + "category": [ + { + "scheme": "urn:ietf:params:rolie:category:information-type", + "term": "csaf" + } + ], + "updated": "2021-01-01T12:00:00.000Z", + "entry": [ + { + "id": "2020-ESA-001", + "title": "Example Security Advisory 001", + "link": [ + { + "rel": "self", + "href": "https://psirt.domain.tld/advisories/csaf/2020/2020-ESA-001.json" + }, + { + "rel": "hash", + "href": "https://psirt.domain.tld/advisories/csaf/2020/2020-ESA-001.json.sha512" + }, + { + "rel": "signature", + "href": "https://psirt.domain.tld/advisories/csaf/2020/2020-ESA-001.json.asc" + } + ], + "published": "2021-01-01T11:00:00.000Z", + "updated": "2021-01-01T12:00:00.000Z", + "summary": { + "content": "Vulnerabilities fixed in ABC 0.0.1" + }, + "content": { + "type": "application/json", + "src": "https://psirt.domain.tld/advisories/csaf/2020/2020-ESA-001.json" + }, + "format": { + "schema": "https://docs.oasis-open.org/csaf/csaf/v2.0/csaf_json_schema.json", + "version": "2.0" + } + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/examples/ROLIE/example-01-service.json b/csaf_2.1/examples/ROLIE/example-01-service.json new file mode 100644 index 000000000..e6001f6e9 --- /dev/null +++ b/csaf_2.1/examples/ROLIE/example-01-service.json @@ -0,0 +1,23 @@ +{ + "service": { + "workspace": [ + { + "title": "Public CSAF feed", + "collection": [ + { + "title": "Example CSAF feed (TLP:WHITE)", + "href": "https://psirt.domain.tld/advisories/csaf/feed-tlp-white.json", + "categories": { + "category": [ + { + "scheme": "urn:ietf:params:rolie:category:information-type", + "term": "csaf" + } + ] + } + } + ] + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/examples/ROLIE/example-02-service.json b/csaf_2.1/examples/ROLIE/example-02-service.json new file mode 100644 index 000000000..0ff7dacd3 --- /dev/null +++ b/csaf_2.1/examples/ROLIE/example-02-service.json @@ -0,0 +1,60 @@ +{ + "service": { + "workspace": [ + { + "title": "Public CSAF feed", + "collection": [ + { + "title": "Example CSAF feed (TLP:WHITE)", + "href": "https://psirt.domain.tld/advisories/csaf/feed-tlp-white.json", + "categories": { + "category": [ + { + "scheme": "urn:ietf:params:rolie:category:information-type", + "term": "csaf" + } + ] + } + } + ] + }, + { + "title": "Private CSAF feeds", + "collection": [ + { + "title": "Example CSAF feed (TLP:AMBER)", + "href": "https://psirt.domain.tld/advisories/tlp-amber/csaf/feed-tlp-amber.json", + "categories": { + "category": [ + { + "scheme": "urn:ietf:params:rolie:category:information-type", + "term": "csaf" + }, + { + "scheme": "https://www.first.org/tlp/", + "term": "AMBER" + } + ] + } + }, + { + "title": "Example CSAF feed (TLP:RED)", + "href": "https://psirt.domain.tld/advisories/tlp-red/csaf/feed-tlp-red.json", + "categories": { + "category": [ + { + "scheme": "urn:ietf:params:rolie:category:information-type", + "term": "csaf" + }, + { + "scheme": "https://www.first.org/tlp/", + "term": "RED" + } + ] + } + } + ] + } + ] + } +} diff --git a/csaf_2.1/examples/aggregator/example-01-aggregator.json b/csaf_2.1/examples/aggregator/example-01-aggregator.json new file mode 100644 index 000000000..8b5e785ac --- /dev/null +++ b/csaf_2.1/examples/aggregator/example-01-aggregator.json @@ -0,0 +1,36 @@ +{ + "aggregator": { + "category": "lister", + "contact_details": "Example CSAF Lister can be reached at contact_us@lister.example, or via our website at https://lister.example/security/csaf/aggregator/contact.", + "issuing_authority": "This service is provided as it is. It is free for everybody.", + "name": "Example CSAF Lister", + "namespace": "https://lister.example" + }, + "aggregator_version": "2.0", + "canonical_url": "https://aggregator.example/.well-known/csaf-aggregator/aggregator.json", + "csaf_providers": [ + { + "metadata": { + "last_updated": "2021-07-12T20:20:56.169Z", + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "url": "https://www.example.com/.well-known/csaf/provider-metadata.json" + } + }, + { + "metadata": { + "last_updated": "2021-07-12T21:35:38.000Z", + "publisher": { + "category": "coordinator", + "name": "Example Coordinator CERT", + "namespace": "https://cert.example" + }, + "url": "https://cert.example/advisories/csaf/provider-metadata.json" + } + } + ], + "last_updated":"2021-07-12T22:35:38.978Z" +} \ No newline at end of file diff --git a/csaf_2.1/examples/aggregator/example-02-aggregator.json b/csaf_2.1/examples/aggregator/example-02-aggregator.json new file mode 100644 index 000000000..859be76fe --- /dev/null +++ b/csaf_2.1/examples/aggregator/example-02-aggregator.json @@ -0,0 +1,42 @@ +{ + "aggregator": { + "category": "aggregator", + "contact_details": "Example Aggregator can be reached at contact_us@aggregator.example, or via our website at https://aggregator.example/security/csaf/aggregator/contact.", + "issuing_authority": "This service is provided as it is. It is free for everybody.", + "name": "Example Aggregator", + "namespace": "https://aggregator.example" + }, + "aggregator_version": "2.0", + "canonical_url": "https://aggregator.example/.well-known/csaf-aggregator/aggregator.json", + "csaf_providers": [ + { + "metadata": { + "last_updated": "2021-07-12T20:20:56.169Z", + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "url": "https://www.example.com/.well-known/csaf/provider-metadata.json" + }, + "mirrors": [ + "https://aggregator.example/.well-known/csaf-aggregator/Example_Company_ProductCERT/provider-metadata.json" + ] + }, + { + "metadata": { + "last_updated": "2021-07-12T21:35:38.000Z", + "publisher": { + "category": "coordinator", + "name": "Example Coordinator CERT", + "namespace": "https://cert.example" + }, + "url": "https://cert.example/advisories/csaf/provider-metadata.json" + }, + "mirrors": [ + "https://aggregator.example/.well-known/csaf-aggregator/Example_Coordinator_CERT/provider-metadata.json" + ] + } + ], + "last_updated":"2021-07-12T22:35:38.978Z" +} diff --git a/csaf_2.1/examples/csaf/bsi-2022-0001.json b/csaf_2.1/examples/csaf/bsi-2022-0001.json new file mode 100644 index 000000000..3ea1cd3f0 --- /dev/null +++ b/csaf_2.1/examples/csaf/bsi-2022-0001.json @@ -0,0 +1,214 @@ +{ + "document": { + "aggregate_severity": { + "text": "Moderate" + }, + "category": "csaf_security_advisory", + "csaf_version": "2.0", + "distribution": { + "tlp": { + "label": "WHITE", + "url": "https://www.first.org/tlp/" + } + }, + "lang": "en-US", + "publisher": { + "category": "coordinator", + "name": "Bundesamt für Sicherheit in der Informationstechnik", + "namespace": "https://www.bsi.bund.de" + }, + "title": "CVRF-CSAF-Converter: XML External Entities Vulnerability", + "tracking": { + "current_release_date": "2022-03-17T13:03:42.105Z", + "generator": { + "date": "2022-03-17T13:09:42.105Z", + "engine": { + "name": "Secvisogram", + "version": "1.12.1" + } + }, + "id": "BSI-2022-0001", + "initial_release_date": "2022-03-17T13:03:42.105Z", + "revision_history": [ + { + "date": "2022-03-17T13:03:42.105Z", + "number": "1", + "summary": "Initial revision" + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "branches": [ + { + "category": "product_version", + "name": "1.0.0-alpha", + "product": { + "name": "CSAF Tools CVRF-CSAF-Converter 1.0.0-alpha", + "product_id": "CSAFPID-0001", + "product_identification_helper": { + "cpe": "cpe:/a:csaf-tools:cvrf-csaf-converter:1.0.0-alpha" + } + } + }, + { + "category": "product_version", + "name": "1.0.0-dev1", + "product": { + "name": "CSAF Tools CVRF-CSAF-Converter 1.0.0-dev1", + "product_id": "CSAFPID-0002", + "product_identification_helper": { + "cpe": "cpe:/a:csaf-tools:cvrf-csaf-converter:1.0.0-dev1" + } + } + }, + { + "category": "product_version", + "name": "1.0.0-dev2", + "product": { + "name": "CSAF Tools CVRF-CSAF-Converter 1.0.0-dev2", + "product_id": "CSAFPID-0003", + "product_identification_helper": { + "cpe": "cpe:/a:csaf-tools:cvrf-csaf-converter:1.0.0-dev2" + } + } + }, + { + "category": "product_version", + "name": "1.0.0-dev3", + "product": { + "name": "CSAF Tools CVRF-CSAF-Converter 1.0.0-dev3", + "product_id": "CSAFPID-0004", + "product_identification_helper": { + "cpe": "cpe:/a:csaf-tools:cvrf-csaf-converter:1.0.0-dev3" + } + } + }, + { + "category": "product_version", + "name": "1.0.0-rc1", + "product": { + "name": "CSAF Tools CVRF-CSAF-Converter 1.0.0-rc1", + "product_id": "CSAFPID-0005", + "product_identification_helper": { + "cpe": "cpe:/a:csaf-tools:cvrf-csaf-converter:1.0.0-rc1" + } + } + }, + { + "category": "product_version", + "name": "1.0.0-rc2", + "product": { + "name": "CSAF Tools CVRF-CSAF-Converter 1.0.0-rc2", + "product_id": "CSAFPID-0006", + "product_identification_helper": { + "cpe": "cpe:/a:csaf-tools:cvrf-csaf-converter:1.0.0-rc2" + } + } + } + ], + "category": "product_name", + "name": "CVRF-CSAF-Converter" + } + ], + "category": "vendor", + "name": "CSAF Tools" + } + ] + }, + "vulnerabilities": [ + { + "acknowledgments": [ + { + "names": [ + "Damian Pfammatter" + ], + "organization": "Cyber-Defense Campus", + "summary": "Finding and reporting the vulnerability" + } + ], + "cve": "CVE-2022-27193", + "cwe": { + "id": "CWE-611", + "name": "Improper Restriction of XML External Entity Reference" + }, + "ids": [ + { + "system_name": "Github Issue", + "text": "csaf-tools/CVRF-CSAF-Converter#78" + } + ], + "notes": [ + { + "category": "description", + "text": "CSAF Tools CVRF-CSAF-Converter 1.0.0-rc1 resolves XML External Entities (XXE). This leads to the inclusion of arbitrary (local) file content into the generated output document. An attacker can exploit this to disclose information from the system running the converter.", + "title": "Vulnerability description" + } + ], + "product_status": { + "first_fixed": [ + "CSAFPID-0006" + ], + "fixed": [ + "CSAFPID-0006" + ], + "known_affected": [ + "CSAFPID-0001", + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004", + "CSAFPID-0005" + ] + }, + "remediations": [ + { + "category": "vendor_fix", + "date": "2022-03-14T13:10:55.000+01:00", + "details": "Update to the latest version of the product. At least version 1.0.0-rc2", + "product_ids": [ + "CSAFPID-0001", + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004", + "CSAFPID-0005" + ], + "url": "https://github.com/csaf-tools/CVRF-CSAF-Converter/releases/tag/1.0.0-rc2" + } + ], + "scores": [ + { + "cvss_v3": { + "attackComplexity": "LOW", + "attackVector": "LOCAL", + "availabilityImpact": "LOW", + "baseScore": 6.1, + "baseSeverity": "MEDIUM", + "confidentialityImpact": "HIGH", + "exploitCodeMaturity": "FUNCTIONAL", + "integrityImpact": "NONE", + "privilegesRequired": "NONE", + "remediationLevel": "OFFICIAL_FIX", + "reportConfidence": "CONFIRMED", + "scope": "UNCHANGED", + "userInteraction": "REQUIRED", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:N/UI:R/S:U/C:H/I:N/A:L/E:F/RL:O/RC:C", + "version": "3.1" + }, + "products": [ + "CSAFPID-0001", + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004", + "CSAFPID-0005" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/examples/csaf/cisco-sa-20180328-smi2.json b/csaf_2.1/examples/csaf/cisco-sa-20180328-smi2.json new file mode 100644 index 000000000..dad5ba7b1 --- /dev/null +++ b/csaf_2.1/examples/csaf/cisco-sa-20180328-smi2.json @@ -0,0 +1,3315 @@ +{ + "document": { + "title": "Cisco IOS and IOS XE Software Smart Install Remote Code Execution Vulnerability", + "category": "Cisco Security Advisory", + "csaf_version": "2.0", + "publisher": { + "category": "vendor", + "contact_details": "Emergency Support:\n+1 877 228 7302 (toll-free within North America)\n+1 408 525 6532 (International direct-dial)\nNon-emergency Support:\nEmail: psirt@cisco.com\nSupport requests that are received via e-mail are typically acknowledged within 48 hours.", + "issuing_authority": "Cisco product security incident response is the responsibility of the Cisco Product Security Incident Response Team (PSIRT). The Cisco PSIRT is a dedicated, global team that manages the receipt, investigation, and public reporting of security vulnerability information that is related to Cisco products and networks. The on-call Cisco PSIRT works 24x7 with Cisco customers, independent security researchers, consultants, industry organizations, and other vendors to identify possible security issues with Cisco products and networks.\nMore information can be found in Cisco Security Vulnerability Policy available at http://www.cisco.com/web/about/security/psirt/security_vulnerability_policy.html", + "name": "Cisco PSIRT", + "namespace": "https://www.cisco.com" + }, + "tracking": { + "id": "cisco-sa-20180328-smi2", + "status": "final", + "version": "3.0.0", + "revision_history": [ + { + "number": "1.0.0", + "date": "2018-03-28T15:17:05Z", + "summary": "Initial public release." + }, + { + "number": "1.1.0", + "date": "2018-03-29T17:13:23Z", + "summary": "Added the researcher's company name." + }, + { + "number": "1.2.0", + "date": "2018-04-02T13:18:01Z", + "summary": "Metadata update." + }, + { + "number": "1.3.0", + "date": "2018-04-06T19:35:44Z", + "summary": "Added more details to the Workarounds section." + }, + { + "number": "1.4.0", + "date": "2018-04-09T14:20:12Z", + "summary": "Emphasized that Smart Install is enabled by default. Added a link to the list of devices that support Smart Install." + }, + { + "number": "2.0.0", + "date": "2018-04-16T18:21:34Z", + "summary": "Updated IOS Software Checker with products found to be non-vulnerable." + }, + { + "number": "3.0.0", + "date": "2018-04-17T15:08:41Z", + "summary": "Updated IOS Software Checker with products found to be vulnerable." + } + ], + "initial_release_date": "2018-03-28T16:00:00Z", + "current_release_date": "2018-04-17T15:08:41Z", + "generator": { + "engine": { + "name": "TVCE" + } + } + }, + "notes": [ + { + "title": "Summary", + "category": "summary", + "text": "A vulnerability in the Smart Install feature of Cisco IOS Software and Cisco IOS XE Software could allow an unauthenticated, remote attacker to trigger a reload of an affected device, resulting in a denial of service (DoS) condition, or to execute arbitrary code on an affected device.\n\nThe vulnerability is due to improper validation of packet data. An attacker could exploit this vulnerability by sending a crafted Smart Install message to an affected device on TCP port 4786. A successful exploit could allow the attacker to cause a buffer overflow on the affected device, which could have the following impacts:\n\nTriggering a reload of the device\nAllowing the attacker to execute arbitrary code on the device\nCausing an indefinite loop on the affected device that triggers a watchdog crash\n\nCisco has released software updates that address this vulnerability. There are no workarounds that address this vulnerability.\n\nSmart Install client functionality is enabled by default on switches that are running Cisco IOS Software releases that have not been updated to address Cisco bug ID CSCvd36820 [\"https://bst.cloudapps.cisco.com/bugsearch/bug/CSCvd36820\"].\n\nThis advisory is available at the following link:\nhttps://tools.cisco.com/security/center/content/CiscoSecurityAdvisory/cisco-sa-20180328-smi2 [\"https://tools.cisco.com/security/center/content/CiscoSecurityAdvisory/cisco-sa-20180328-smi2\"]\n\nThis advisory is part of the March 28, 2018, release of the Cisco IOS and IOS XE Software Security Advisory Bundled Publication, which includes 20 Cisco Security Advisories that describe 22 vulnerabilities. For a complete list of the advisories and links to them, see Cisco Event Response: March 2018 Semiannual Cisco IOS and IOS XE Software Security Advisory Bundled Publication [\"https://tools.cisco.com/security/center/viewErp.x?alertId=ERP-66682\"]." + }, + { + "title": "Vulnerable Products", + "category": "general", + "text": "This vulnerability affects Cisco devices that are running a vulnerable release of Cisco IOS or IOS XE Software and have the Smart Install client feature enabled.\n\nOnly Smart Install client switches are affected by the vulnerability that is described in this advisory. Cisco devices that are configured as a Smart Install director are not affected by this vulnerability.\n\nFor a list of devices that support Smart Install, see Smart Install Configuration Guide - Supported Devices [\"https://www.cisco.com/c/en/us/td/docs/switches/lan/smart_install/configuration/guide/smart_install/supported_devices.html\"].\n\nFor information about which Cisco IOS and IOS XE Software releases are vulnerable, see the Fixed Software [\"#fixed\"] section of this advisory.\n Notes Regarding Specific Releases\nSmart Install client functionality is enabled by default on switches that are running Cisco IOS Software releases that have not been updated to address Cisco bug ID CSCvd36820 [\"https://bst.cloudapps.cisco.com/bugsearch/bug/CSCvd36820\"].\n\nSwitches that are running releases earlier than Cisco IOS Software Release 12.2(52)SE are not capable of running Smart Install, but they can be Smart Install clients if they support the archive download-sw privileged EXEC command.\n Determining Whether the Smart Install Client Feature Is Enabled\nTo determine whether a device is configured with the Smart Install client feature enabled, use the show vstack config privileged EXEC command on the Smart Install client. An output of Role: Client and Oper Mode: Enabled or Role: Client (SmartInstall enabled) from the show vstack config command confirms that the feature is enabled on the device.\n\nThe following examples show the output of the show vstack config command on Cisco Catalyst Switches that are configured as Smart Install clients:\n\n\nswitch1# show vstack config\nRole: Client (SmartInstall enabled)\n.\n.\n.\n\nswitch2# show vstack config\nCapability: Client\nOper Mode: Enabled\nRole: Client\n.\n.\n.\nDetermining the Cisco IOS Software Release\nTo determine which Cisco IOS Software release is running on a device, administrators can log in to the device, use the show version command in the CLI, and then refer to the system banner that appears. If the device is running Cisco IOS Software, the system banner displays text similar to Cisco Internetwork Operating System Software or Cisco IOS Software. The banner also displays the installed image name in parentheses, followed by the Cisco IOS Software release number and release name. Some Cisco devices do not support the show version command or may provide different output.\n\nThe following example shows the output of the command for a device that is running Cisco IOS Software Release 15.5(2)T1 and has an installed image name of C2951-UNIVERSALK9-M:\n\n\nRouter> show version\n Cisco IOS Software, C2951 Software (C2951-UNIVERSALK9-M), Version 15.5(2)T1, RELEASE SOFTWARE (fc1) Technical Support: http://www.cisco.com/techsupport Copyright (c) 1986-2015 by Cisco Systems, Inc. Compiled Mon 22-Jun-15 09:32 by prod_rel_team . . .\n\nFor information about the naming and numbering conventions for Cisco IOS Software releases, see the Cisco IOS and NX-OS Software Reference Guide [\"https://www.cisco.com/c/en/us/about/security-center/ios-nx-os-reference-guide.html\"].\nDetermining the Cisco IOS XE Software Release\nTo determine which Cisco IOS XE Software release is running on a device, administrators can log in to the device, use the show version command in the CLI, and then refer to the system banner that appears. If the device is running Cisco IOS XE Software, the system banner displays Cisco IOS Software, Cisco IOS XE Software, or similar text.\n\nThe following example shows the output of the command for a device that is running Cisco IOS XE Software Release 16.2.1 and has an installed image name of CAT3K_CAA-UNIVERSALK9-M:\n\n\nios-xe-device# show version\n Cisco IOS Software, Catalyst L3 Switch Software (CAT3K_CAA-UNIVERSALK9-M), Version Denali 16.2.1, RELEASE SOFTWARE (fc1) Technical Support: http://www.cisco.com/techsupport Copyright (c) 1986-2016 by Cisco Systems, Inc. Compiled Sun 27-Mar-16 21:47 by mcpre . . .\n\nFor information about the naming and numbering conventions for Cisco IOS XE Software releases, see the Cisco IOS and NX-OS Software Reference Guide [\"https://www.cisco.com/c/en/us/about/security-center/ios-nx-os-reference-guide.html\"]." + }, + { + "title": "Products Confirmed Not Vulnerable", + "category": "general", + "text": "No other Cisco products are currently known to be affected by this vulnerability.\n\nCisco has confirmed that this vulnerability does not affect Cisco IOS XR Software or Cisco NX-OS Software." + }, + { + "title": "Details", + "category": "general", + "text": "Cisco Smart Install is a ?plug-and-play? configuration and image-management feature that provides zero-touch deployment for new (typically access layer) switches. The feature allows a customer to ship a Cisco switch to any location, install it in the network, and power it on without additional configuration requirements. The Smart Install feature incorporates no authentication by design.\n\nA Smart Install network consists of exactly one Smart Install director switch or router, also known as an integrated branch director (IBD), and one or more Smart Install client switches, also known as integrated branch clients (IBCs). A client switch does not need to be directly connected to the director; the client switch can be up to seven hops away.\n\nThe director provides a single management point for images and configuration of client switches. When a client switch is first installed in the network, the director automatically detects the new switch and identifies the correct Cisco IOS Software image and the configuration file for downloading. The director can also allocate an IP address and hostname to a client." + }, + { + "title": "Workarounds", + "category": "general", + "text": "There are no workarounds that address this vulnerability for customers who require the use of Cisco Smart Install. For customers not requiring Cisco Smart Install, the feature can be disabled with the no vstack command. In software releases that are associated with Cisco Bug ID CSCvd36820 [\"https://bst.cloudapps.cisco.com/bugsearch/bug/CSCvd36820\"], Cisco Smart Install will auto-disable if not in use.\n\nAdministrators are encouraged to consult the informational security advisory on Cisco Smart Install Protocol Misuse [\"https://tools.cisco.com/security/center/content/CiscoSecurityAdvisory/cisco-sa-20170214-smi\"] and the Smart Install Configuration Guide [\"http://www.cisco.com/c/en/us/td/docs/switches/lan/smart_install/configuration/guide/smart_install/concepts.html#23355\"]." + }, + { + "title": "Fixed Software", + "category": "general", + "text": "Cisco has released free software updates that address the vulnerability described in this advisory. Customers may only install and expect support for software versions and feature sets for which they have purchased a license. By installing, downloading, accessing, or otherwise using such software upgrades, customers agree to follow the terms of the Cisco software license:\nhttps://www.cisco.com/c/en/us/products/end-user-license-agreement.html [\"https://www.cisco.com/c/en/us/products/end-user-license-agreement.html\"]\n\nAdditionally, customers may only download software for which they have a valid license, procured from Cisco directly, or through a Cisco authorized reseller or partner. In most cases this will be a maintenance upgrade to software that was previously purchased. Free security software updates do not entitle customers to a new software license, additional software feature sets, or major revision upgrades.\n\nWhen considering software upgrades, customers are advised to regularly consult the advisories for Cisco products, which are available from the Cisco Security Advisories and Alerts page [\"https://www.cisco.com/go/psirt\"], to determine exposure and a complete upgrade solution.\n\nIn all cases, customers should ensure that the devices to be upgraded contain sufficient memory and confirm that current hardware and software configurations will continue to be supported properly by the new release. If the information is not clear, customers are advised to contact the Cisco Technical Assistance Center (TAC) or their contracted maintenance providers.\n\nCustomers Without Service Contracts\n\nCustomers who purchase directly from Cisco but do not hold a Cisco service contract and customers who make purchases through third-party vendors but are unsuccessful in obtaining fixed software through their point of sale should obtain upgrades by contacting the Cisco TAC:\nhttps://www.cisco.com/c/en/us/support/web/tsd-cisco-worldwide-contacts.html [\"https://www.cisco.com/c/en/us/support/web/tsd-cisco-worldwide-contacts.html\"]\n\nCustomers should have the product serial number available and be prepared to provide the URL of this advisory as evidence of entitlement to a free upgrade.\n Cisco IOS and IOS XE Software\nTo help customers determine their exposure to vulnerabilities in Cisco IOS and IOS XE Software, Cisco provides a tool, the Cisco IOS Software Checker [\"https://tools.cisco.com/security/center/softwarechecker.x\"], that identifies any Cisco Security Advisories that impact a specific software release and the earliest release that fixes the vulnerabilities described in each advisory (?First Fixed?). If applicable, the tool also returns the earliest release that fixes all the vulnerabilities described in all the advisories identified (?Combined First Fixed?).\n\nCustomers can use this tool to perform the following tasks:\n\nInitiate a search by choosing one or more releases from a drop-down list or uploading a file from a local system for the tool to parse\nEnter the output of the show version command for the tool to parse\nCreate a custom search by including all previously published Cisco Security Advisories, a specific advisory, or all advisories in the most recent bundled publication\n\nTo determine whether a release is affected by any published Cisco Security Advisory, use the Cisco IOS Software Checker [\"https://tools.cisco.com/security/center/softwarechecker.x\"] on Cisco.com or enter a Cisco IOS Software or Cisco IOS XE Software release?for example, 15.1(4)M2 or 3.13.8S?in the following field:\n\n\n\n\n\nFor a mapping of Cisco IOS XE Software releases to Cisco IOS Software releases, refer to the Cisco IOS XE 2 Release Notes [\"https://www.cisco.com/c/en/us/td/docs/ios/ios_xe/2/release/notes/rnasr21/rnasr21_gen.html#wp3000032\"], Cisco IOS XE 3S Release Notes [\"https://www.cisco.com/c/en/us/td/docs/ios/ios_xe/3/release/notes/asr1k_rn_3s_rel_notes/asr1k_rn_3s_sys_req.html#wp3069754\"], or Cisco IOS XE 3SG Release Notes [\"https://www.cisco.com/c/en/us/td/docs/switches/lan/catalyst4500/release/note/OL_24726.html#pgfId-2570252\"], depending on the Cisco IOS XE Software release." + }, + { + "title": "Vulnerability Policy", + "category": "general", + "text": "To learn about Cisco security vulnerability disclosure policies and publications, see the Security Vulnerability Policy [\"http://www.cisco.com/web/about/security/psirt/security_vulnerability_policy.html\"]. This document also contains instructions for obtaining fixed software and receiving security vulnerability information from Cisco." + }, + { + "title": "Exploitation and Public Announcements", + "category": "general", + "text": "The Cisco Product Security Incident Response Team (PSIRT) is not aware of any public announcements or malicious use of the vulnerability that is described in this advisory." + }, + { + "title": "Source", + "category": "general", + "text": "Cisco would like to thank George Nosenko from Embedi for reporting this vulnerability via GeekPwn." + }, + { + "title": "Legal Disclaimer", + "category": "legal_disclaimer", + "text": "THIS DOCUMENT IS PROVIDED ON AN \"AS IS\" BASIS AND DOES NOT IMPLY ANY KIND OF GUARANTEE OR WARRANTY, INCLUDING THE WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR USE. YOUR USE OF THE INFORMATION ON THE DOCUMENT OR MATERIALS LINKED FROM THE DOCUMENT IS AT YOUR OWN RISK. CISCO RESERVES THE RIGHT TO CHANGE OR UPDATE THIS DOCUMENT AT ANY TIME.\n\nA standalone copy or paraphrase of the text of this document that omits the distribution URL is an uncontrolled copy and may lack important information or contain factual errors. The information in this document is intended for end users of Cisco products." + } + ], + "references": [ + { + "url": "https://tools.cisco.com/security/center/content/CiscoSecurityAdvisory/cisco-sa-20180328-smi2", + "summary": "Cisco IOS and IOS XE Software Smart Install Remote Code Execution Vulnerability" + }, + { + "url": "https://tools.cisco.com/security/center/content/CiscoSecurityBundle/cisco-sa-20180328-bundle", + "summary": "Summary of the Semiannual Cisco IOS and IOS XE Software Security Advisory Bundled Publication, March 28, 2018" + }, + { + "url": "http://tools.cisco.com/security/center/viewErp.x?alertId=ERP-66682", + "summary": "Cisco Event Response: March 2018 Semiannual Cisco IOS and IOS XE Software Security Advisory Bundled Publication" + }, + { + "url": "https://tools.cisco.com/security/center/content/CiscoSecurityBundle/cisco-sa-20180328-bundle", + "summary": "Summary of the Semiannual Cisco IOS and IOS XE Software Security Advisory Bundled Publication, March 28, 2018" + }, + { + "url": "http://tools.cisco.com/security/center/viewErp.x?alertId=ERP-66682", + "summary": "Cisco Event Response: March 2018 Semiannual Cisco IOS and IOS XE Software Security Advisory Bundled Publication" + } + ] + }, + "product_tree": { + "branches": [ + { + "name": "Cisco", + "category": "vendor", + "branches": [ + { + "name": "IOS", + "category": "product_name", + "branches": [ + { + "name": "12.2SE", + "category": "product_version", + "branches": [ + { + "name": "12.2(55)SE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-103763", + "name": "Cisco IOS 12.2SE 12.2(55)SE" + } + }, + { + "name": "12.2(55)SE3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-105394", + "name": "Cisco IOS 12.2SE 12.2(55)SE3" + } + }, + { + "name": "12.2(55)SE2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-105689", + "name": "Cisco IOS 12.2SE 12.2(55)SE2" + } + }, + { + "name": "12.2(58)SE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-105987", + "name": "Cisco IOS 12.2SE 12.2(58)SE" + } + }, + { + "name": "12.2(55)SE1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-106029", + "name": "Cisco IOS 12.2SE 12.2(55)SE1" + } + }, + { + "name": "12.2(58)SE1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-109098", + "name": "Cisco IOS 12.2SE 12.2(58)SE1" + } + }, + { + "name": "12.2(55)SE4", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-109439", + "name": "Cisco IOS 12.2SE 12.2(55)SE4" + } + }, + { + "name": "12.2(58)SE2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-109808", + "name": "Cisco IOS 12.2SE 12.2(58)SE2" + } + }, + { + "name": "12.2(55)SE5", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-111674", + "name": "Cisco IOS 12.2SE 12.2(55)SE5" + } + }, + { + "name": "12.2(55)SE6", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-114665", + "name": "Cisco IOS 12.2SE 12.2(55)SE6" + } + }, + { + "name": "12.2(55)SE7", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-184125", + "name": "Cisco IOS 12.2SE 12.2(55)SE7" + } + }, + { + "name": "12.2(55)SE8", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-189187", + "name": "Cisco IOS 12.2SE 12.2(55)SE8" + } + }, + { + "name": "12.2(55)SE9", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-192911", + "name": "Cisco IOS 12.2SE 12.2(55)SE9" + } + }, + { + "name": "12.2(55)SE10", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-198542", + "name": "Cisco IOS 12.2SE 12.2(55)SE10" + } + }, + { + "name": "12.2(55)SE11", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-210732", + "name": "Cisco IOS 12.2SE 12.2(55)SE11" + } + }, + { + "name": "12.2(55)SE12", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-228057", + "name": "Cisco IOS 12.2SE 12.2(55)SE12" + } + }, + { + "name": "12.2(55)SE13", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-230962", + "name": "Cisco IOS 12.2SE 12.2(55)SE13" + } + } + ] + }, + { + "name": "12.2EX", + "category": "product_version", + "branches": [ + { + "name": "12.2(55)EX", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-106674", + "name": "Cisco IOS 12.2EX 12.2(55)EX" + } + }, + { + "name": "12.2(55)EX1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-108306", + "name": "Cisco IOS 12.2EX 12.2(55)EX1" + } + }, + { + "name": "12.2(55)EX2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-109760", + "name": "Cisco IOS 12.2EX 12.2(55)EX2" + } + }, + { + "name": "12.2(55)EX3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-111019", + "name": "Cisco IOS 12.2EX 12.2(55)EX3" + } + } + ] + }, + { + "name": "12.2EY", + "category": "product_version", + "branches": [ + { + "name": "12.2(55)EY", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-103559", + "name": "Cisco IOS 12.2EY 12.2(55)EY" + } + } + ] + }, + { + "name": "12.2EZ", + "category": "product_version", + "branches": [ + { + "name": "12.2(55)EZ", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-107283", + "name": "Cisco IOS 12.2EZ 12.2(55)EZ" + } + } + ] + }, + { + "name": "15.0EY", + "category": "product_version", + "branches": [ + { + "name": "15.0(1)EY", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-104376", + "name": "Cisco IOS 15.0EY 15.0(1)EY" + } + }, + { + "name": "15.0(1)EY2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-187269", + "name": "Cisco IOS 15.0EY 15.0(1)EY2" + } + } + ] + }, + { + "name": "15.1M", + "category": "product_version", + "branches": [ + { + "name": "15.1(4)M12c", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-233143", + "name": "Cisco IOS 15.1M 15.1(4)M12c" + } + } + ] + }, + { + "name": "15.0SE", + "category": "product_version", + "branches": [ + { + "name": "15.0(1)SE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-105660", + "name": "Cisco IOS 15.0SE 15.0(1)SE" + } + }, + { + "name": "15.0(2)SE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-107852", + "name": "Cisco IOS 15.0SE 15.0(2)SE" + } + }, + { + "name": "15.0(1)SE1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-111010", + "name": "Cisco IOS 15.0SE 15.0(1)SE1" + } + }, + { + "name": "15.0(1)SE2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-113961", + "name": "Cisco IOS 15.0SE 15.0(1)SE2" + } + }, + { + "name": "15.0(1)SE3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-115832", + "name": "Cisco IOS 15.0SE 15.0(1)SE3" + } + }, + { + "name": "15.0(2)SE1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-115939", + "name": "Cisco IOS 15.0SE 15.0(2)SE1" + } + }, + { + "name": "15.0(2)SE2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-116083", + "name": "Cisco IOS 15.0SE 15.0(2)SE2" + } + }, + { + "name": "15.0(2)SE3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-189455", + "name": "Cisco IOS 15.0SE 15.0(2)SE3" + } + }, + { + "name": "15.0(2)SE4", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-190635", + "name": "Cisco IOS 15.0SE 15.0(2)SE4" + } + }, + { + "name": "15.0(2)SE5", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-192706", + "name": "Cisco IOS 15.0SE 15.0(2)SE5" + } + }, + { + "name": "15.0(2)SE6", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-195770", + "name": "Cisco IOS 15.0SE 15.0(2)SE6" + } + }, + { + "name": "15.0(2)SE7", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-204097", + "name": "Cisco IOS 15.0SE 15.0(2)SE7" + } + }, + { + "name": "15.0(2)SE8", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209028", + "name": "Cisco IOS 15.0SE 15.0(2)SE8" + } + }, + { + "name": "15.0(2)SE9", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209029", + "name": "Cisco IOS 15.0SE 15.0(2)SE9" + } + }, + { + "name": "15.0(2a)SE9", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-212329", + "name": "Cisco IOS 15.0SE 15.0(2a)SE9" + } + }, + { + "name": "15.0(2)SE10", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-213788", + "name": "Cisco IOS 15.0SE 15.0(2)SE10" + } + }, + { + "name": "15.0(2)SE11", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-220466", + "name": "Cisco IOS 15.0SE 15.0(2)SE11" + } + }, + { + "name": "15.0(2)SE10a", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-222342", + "name": "Cisco IOS 15.0SE 15.0(2)SE10a" + } + }, + { + "name": "15.0(2)SE12", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-234926", + "name": "Cisco IOS 15.0SE 15.0(2)SE12" + } + } + ] + }, + { + "name": "15.1SG", + "category": "product_version", + "branches": [ + { + "name": "15.1(2)SG", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-115477", + "name": "Cisco IOS 15.1SG 15.1(2)SG" + } + }, + { + "name": "15.1(2)SG1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-188035", + "name": "Cisco IOS 15.1SG 15.1(2)SG1" + } + }, + { + "name": "15.1(2)SG2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-193283", + "name": "Cisco IOS 15.1SG 15.1(2)SG2" + } + }, + { + "name": "15.1(2)SG3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-194741", + "name": "Cisco IOS 15.1SG 15.1(2)SG3" + } + }, + { + "name": "15.1(2)SG4", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-195489", + "name": "Cisco IOS 15.1SG 15.1(2)SG4" + } + }, + { + "name": "15.1(2)SG5", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-197465", + "name": "Cisco IOS 15.1SG 15.1(2)SG5" + } + }, + { + "name": "15.1(2)SG6", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-204187", + "name": "Cisco IOS 15.1SG 15.1(2)SG6" + } + }, + { + "name": "15.1(2)SG7", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209034", + "name": "Cisco IOS 15.1SG 15.1(2)SG7" + } + }, + { + "name": "15.1(2)SG8", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-214992", + "name": "Cisco IOS 15.1SG 15.1(2)SG8" + } + }, + { + "name": "15.1(2)SG8a", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-233796", + "name": "Cisco IOS 15.1SG 15.1(2)SG8a" + } + } + ] + }, + { + "name": "15.0EX", + "category": "product_version", + "branches": [ + { + "name": "15.0(2)EX", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-189064", + "name": "Cisco IOS 15.0EX 15.0(2)EX" + } + }, + { + "name": "15.0(2)EX1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-189115", + "name": "Cisco IOS 15.0EX 15.0(2)EX1" + } + }, + { + "name": "15.0(2)EX2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-192910", + "name": "Cisco IOS 15.0EX 15.0(2)EX2" + } + }, + { + "name": "15.0(2)EX3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-194540", + "name": "Cisco IOS 15.0EX 15.0(2)EX3" + } + }, + { + "name": "15.0(2)EX4", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-194913", + "name": "Cisco IOS 15.0EX 15.0(2)EX4" + } + }, + { + "name": "15.0(2)EX5", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-195943", + "name": "Cisco IOS 15.0EX 15.0(2)EX5" + } + }, + { + "name": "15.0(2)EX6", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-200496", + "name": "Cisco IOS 15.0EX 15.0(2)EX6" + } + }, + { + "name": "15.0(2)EX7", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-201366", + "name": "Cisco IOS 15.0EX 15.0(2)EX7" + } + }, + { + "name": "15.0(2)EX8", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-204831", + "name": "Cisco IOS 15.0EX 15.0(2)EX8" + } + }, + { + "name": "15.0(2a)EX5", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-205064", + "name": "Cisco IOS 15.0EX 15.0(2a)EX5" + } + }, + { + "name": "15.0(2)EX10", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-211570", + "name": "Cisco IOS 15.0EX 15.0(2)EX10" + } + }, + { + "name": "15.0(2)EX11", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-214797", + "name": "Cisco IOS 15.0EX 15.0(2)EX11" + } + }, + { + "name": "15.0(2)EX13", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-225160", + "name": "Cisco IOS 15.0EX 15.0(2)EX13" + } + }, + { + "name": "15.0(2)EX12", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-230965", + "name": "Cisco IOS 15.0EX 15.0(2)EX12" + } + } + ] + }, + { + "name": "15.1SY", + "category": "product_version", + "branches": [ + { + "name": "15.1(1)SY", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-112489", + "name": "Cisco IOS 15.1SY 15.1(1)SY" + } + }, + { + "name": "15.1(1)SY1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-115285", + "name": "Cisco IOS 15.1SY 15.1(1)SY1" + } + }, + { + "name": "15.1(2)SY", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-184932", + "name": "Cisco IOS 15.1SY 15.1(2)SY" + } + }, + { + "name": "15.1(2)SY1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-188061", + "name": "Cisco IOS 15.1SY 15.1(2)SY1" + } + }, + { + "name": "15.1(2)SY2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-189219", + "name": "Cisco IOS 15.1SY 15.1(2)SY2" + } + }, + { + "name": "15.1(1)SY2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-191635", + "name": "Cisco IOS 15.1SY 15.1(1)SY2" + } + }, + { + "name": "15.1(1)SY3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-194944", + "name": "Cisco IOS 15.1SY 15.1(1)SY3" + } + }, + { + "name": "15.1(2)SY3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-198059", + "name": "Cisco IOS 15.1SY 15.1(2)SY3" + } + }, + { + "name": "15.1(1)SY4", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-198426", + "name": "Cisco IOS 15.1SY 15.1(1)SY4" + } + }, + { + "name": "15.1(2)SY4", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-201019", + "name": "Cisco IOS 15.1SY 15.1(2)SY4" + } + }, + { + "name": "15.1(1)SY5", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-204109", + "name": "Cisco IOS 15.1SY 15.1(1)SY5" + } + }, + { + "name": "15.1(2)SY5", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-204110", + "name": "Cisco IOS 15.1SY 15.1(2)SY5" + } + }, + { + "name": "15.1(2)SY4a", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-204832", + "name": "Cisco IOS 15.1SY 15.1(2)SY4a" + } + }, + { + "name": "15.1(1)SY6", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209043", + "name": "Cisco IOS 15.1SY 15.1(1)SY6" + } + }, + { + "name": "15.1(2)SY6", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209044", + "name": "Cisco IOS 15.1SY 15.1(2)SY6" + } + }, + { + "name": "15.1(2)SY7", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-210406", + "name": "Cisco IOS 15.1SY 15.1(2)SY7" + } + }, + { + "name": "15.1(2)SY8", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-214052", + "name": "Cisco IOS 15.1SY 15.1(2)SY8" + } + }, + { + "name": "15.1(2)SY9", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-220440", + "name": "Cisco IOS 15.1SY 15.1(2)SY9" + } + }, + { + "name": "15.1(2)SY10", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-222650", + "name": "Cisco IOS 15.1SY 15.1(2)SY10" + } + }, + { + "name": "15.1(2)SY11", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-227307", + "name": "Cisco IOS 15.1SY 15.1(2)SY11" + } + } + ] + }, + { + "name": "12.4JAN", + "category": "product_version", + "branches": [ + { + "name": "12.4(25e)JAN2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-192702", + "name": "Cisco IOS 12.4JAN 12.4(25e)JAN2" + } + } + ] + }, + { + "name": "15.2E", + "category": "product_version", + "branches": [ + { + "name": "15.2(1)E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-183811", + "name": "Cisco IOS 15.2E 15.2(1)E" + } + }, + { + "name": "15.2(2)E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-187057", + "name": "Cisco IOS 15.2E 15.2(2)E" + } + }, + { + "name": "15.2(1)E1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-195469", + "name": "Cisco IOS 15.2E 15.2(1)E1" + } + }, + { + "name": "15.2(3)E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-197483", + "name": "Cisco IOS 15.2E 15.2(3)E" + } + }, + { + "name": "15.2(1)E2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-198060", + "name": "Cisco IOS 15.2E 15.2(1)E2" + } + }, + { + "name": "15.2(1)E3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-200488", + "name": "Cisco IOS 15.2E 15.2(1)E3" + } + }, + { + "name": "15.2(2)E1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-201074", + "name": "Cisco IOS 15.2E 15.2(2)E1" + } + }, + { + "name": "15.2(2b)E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-204102", + "name": "Cisco IOS 15.2E 15.2(2b)E" + } + }, + { + "name": "15.2(4)E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-204108", + "name": "Cisco IOS 15.2E 15.2(4)E" + } + }, + { + "name": "15.2(3)E1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-204186", + "name": "Cisco IOS 15.2E 15.2(3)E1" + } + }, + { + "name": "15.2(2)E2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-204228", + "name": "Cisco IOS 15.2E 15.2(2)E2" + } + }, + { + "name": "15.2(2a)E1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-204818", + "name": "Cisco IOS 15.2E 15.2(2a)E1" + } + }, + { + "name": "15.2(2)E3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-205672", + "name": "Cisco IOS 15.2E 15.2(2)E3" + } + }, + { + "name": "15.2(2a)E2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209045", + "name": "Cisco IOS 15.2E 15.2(2a)E2" + } + }, + { + "name": "15.2(3)E2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209046", + "name": "Cisco IOS 15.2E 15.2(3)E2" + } + }, + { + "name": "15.2(3a)E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209047", + "name": "Cisco IOS 15.2E 15.2(3a)E" + } + }, + { + "name": "15.2(3)E3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209358", + "name": "Cisco IOS 15.2E 15.2(3)E3" + } + }, + { + "name": "15.2(3m)E2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209359", + "name": "Cisco IOS 15.2E 15.2(3m)E2" + } + }, + { + "name": "15.2(4)E1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209887", + "name": "Cisco IOS 15.2E 15.2(4)E1" + } + }, + { + "name": "15.2(2)E4", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-210766", + "name": "Cisco IOS 15.2E 15.2(2)E4" + } + }, + { + "name": "15.2(2)E5", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-211296", + "name": "Cisco IOS 15.2E 15.2(2)E5" + } + }, + { + "name": "15.2(4)E2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-213610", + "name": "Cisco IOS 15.2E 15.2(4)E2" + } + }, + { + "name": "15.2(4m)E1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-214072", + "name": "Cisco IOS 15.2E 15.2(4m)E1" + } + }, + { + "name": "15.2(3)E4", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-214078", + "name": "Cisco IOS 15.2E 15.2(3)E4" + } + }, + { + "name": "15.2(5)E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-214556", + "name": "Cisco IOS 15.2E 15.2(5)E" + } + }, + { + "name": "15.2(3m)E7", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-216295", + "name": "Cisco IOS 15.2E 15.2(3m)E7" + } + }, + { + "name": "15.2(4)E3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-217805", + "name": "Cisco IOS 15.2E 15.2(4)E3" + } + }, + { + "name": "15.2(2)E6", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-218891", + "name": "Cisco IOS 15.2E 15.2(2)E6" + } + }, + { + "name": "15.2(5a)E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-218995", + "name": "Cisco IOS 15.2E 15.2(5a)E" + } + }, + { + "name": "15.2(5)E1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-220441", + "name": "Cisco IOS 15.2E 15.2(5)E1" + } + }, + { + "name": "15.2(5b)E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-220457", + "name": "Cisco IOS 15.2E 15.2(5b)E" + } + }, + { + "name": "15.2(4m)E3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-220664", + "name": "Cisco IOS 15.2E 15.2(4m)E3" + } + }, + { + "name": "15.2(3m)E8", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-220689", + "name": "Cisco IOS 15.2E 15.2(3m)E8" + } + }, + { + "name": "15.2(2)E5a", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-221033", + "name": "Cisco IOS 15.2E 15.2(2)E5a" + } + }, + { + "name": "15.2(5c)E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-221137", + "name": "Cisco IOS 15.2E 15.2(5c)E" + } + }, + { + "name": "15.2(3)E5", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-222275", + "name": "Cisco IOS 15.2E 15.2(3)E5" + } + }, + { + "name": "15.2(2)E5b", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-222436", + "name": "Cisco IOS 15.2E 15.2(2)E5b" + } + }, + { + "name": "15.2(4n)E2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-222500", + "name": "Cisco IOS 15.2E 15.2(4n)E2" + } + }, + { + "name": "15.2(4o)E2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-222924", + "name": "Cisco IOS 15.2E 15.2(4o)E2" + } + }, + { + "name": "15.2(5a)E1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-223143", + "name": "Cisco IOS 15.2E 15.2(5a)E1" + } + }, + { + "name": "15.2(4)E4", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-224553", + "name": "Cisco IOS 15.2E 15.2(4)E4" + } + }, + { + "name": "15.2(2)E7", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-224868", + "name": "Cisco IOS 15.2E 15.2(2)E7" + } + }, + { + "name": "15.2(5)E2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-225740", + "name": "Cisco IOS 15.2E 15.2(5)E2" + } + }, + { + "name": "15.2(4p)E1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-226077", + "name": "Cisco IOS 15.2E 15.2(4p)E1" + } + }, + { + "name": "15.2(6)E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-227598", + "name": "Cisco IOS 15.2E 15.2(6)E" + } + }, + { + "name": "15.2(5)E2b", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-227754", + "name": "Cisco IOS 15.2E 15.2(5)E2b" + } + }, + { + "name": "15.2(4)E5", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-227959", + "name": "Cisco IOS 15.2E 15.2(4)E5" + } + }, + { + "name": "15.2(5)E2c", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-228151", + "name": "Cisco IOS 15.2E 15.2(5)E2c" + } + }, + { + "name": "15.2(4m)E2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-230588", + "name": "Cisco IOS 15.2E 15.2(4m)E2" + } + }, + { + "name": "15.2(4o)E3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-230589", + "name": "Cisco IOS 15.2E 15.2(4o)E3" + } + }, + { + "name": "15.2(4q)E1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-230590", + "name": "Cisco IOS 15.2E 15.2(4q)E1" + } + }, + { + "name": "15.2(6)E0a", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-230591", + "name": "Cisco IOS 15.2E 15.2(6)E0a" + } + }, + { + "name": "15.2(6)E0b", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-230623", + "name": "Cisco IOS 15.2E 15.2(6)E0b" + } + }, + { + "name": "15.2(2)E7b", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-230990", + "name": "Cisco IOS 15.2E 15.2(2)E7b" + } + }, + { + "name": "15.2(4)E5a", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-231074", + "name": "Cisco IOS 15.2E 15.2(4)E5a" + } + }, + { + "name": "15.2(6)E0c", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-231245", + "name": "Cisco IOS 15.2E 15.2(6)E0c" + } + } + ] + }, + { + "name": "15.0EZ", + "category": "product_version", + "branches": [ + { + "name": "15.0(2)EZ", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-190637", + "name": "Cisco IOS 15.0EZ 15.0(2)EZ" + } + } + ] + }, + { + "name": "15.2EY", + "category": "product_version", + "branches": [ + { + "name": "15.2(1)EY", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-191928", + "name": "Cisco IOS 15.2EY 15.2(1)EY" + } + } + ] + }, + { + "name": "15.0EJ", + "category": "product_version", + "branches": [ + { + "name": "15.0(2)EJ", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-191948", + "name": "Cisco IOS 15.0EJ 15.0(2)EJ" + } + }, + { + "name": "15.0(2)EJ1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-197471", + "name": "Cisco IOS 15.0EJ 15.0(2)EJ1" + } + } + ] + }, + { + "name": "15.2SY", + "category": "product_version", + "branches": [ + { + "name": "15.2(1)SY", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-192726", + "name": "Cisco IOS 15.2SY 15.2(1)SY" + } + }, + { + "name": "15.2(1)SY1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-204828", + "name": "Cisco IOS 15.2SY 15.2(1)SY1" + } + }, + { + "name": "15.2(1)SY0a", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209063", + "name": "Cisco IOS 15.2SY 15.2(1)SY0a" + } + }, + { + "name": "15.2(1)SY2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209064", + "name": "Cisco IOS 15.2SY 15.2(1)SY2" + } + }, + { + "name": "15.2(2)SY", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209065", + "name": "Cisco IOS 15.2SY 15.2(2)SY" + } + }, + { + "name": "15.2(1)SY1a", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209439", + "name": "Cisco IOS 15.2SY 15.2(1)SY1a" + } + }, + { + "name": "15.2(2)SY1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-211976", + "name": "Cisco IOS 15.2SY 15.2(2)SY1" + } + }, + { + "name": "15.2(2)SY2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-214053", + "name": "Cisco IOS 15.2SY 15.2(2)SY2" + } + }, + { + "name": "15.2(1)SY3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-216259", + "name": "Cisco IOS 15.2SY 15.2(1)SY3" + } + }, + { + "name": "15.2(1)SY4", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-222651", + "name": "Cisco IOS 15.2SY 15.2(1)SY4" + } + }, + { + "name": "15.2(2)SY3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-227285", + "name": "Cisco IOS 15.2SY 15.2(2)SY3" + } + }, + { + "name": "15.2(1)SY5", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-227308", + "name": "Cisco IOS 15.2SY 15.2(1)SY5" + } + } + ] + }, + { + "name": "15.2EX", + "category": "product_version", + "branches": [ + { + "name": "15.2(5)EX", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-222530", + "name": "Cisco IOS 15.2EX 15.2(5)EX" + } + } + ] + }, + { + "name": "15.1SVG", + "category": "product_version", + "branches": [ + { + "name": "15.1(3)SVG3d", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-232957", + "name": "Cisco IOS 15.1SVG 15.1(3)SVG3d" + } + } + ] + }, + { + "name": "15.2EB", + "category": "product_version", + "branches": [ + { + "name": "15.2(2)EB", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-197462", + "name": "Cisco IOS 15.2EB 15.2(2)EB" + } + }, + { + "name": "15.2(2)EB1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209839", + "name": "Cisco IOS 15.2EB 15.2(2)EB1" + } + }, + { + "name": "15.2(2)EB2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-214218", + "name": "Cisco IOS 15.2EB 15.2(2)EB2" + } + } + ] + }, + { + "name": "15.3SY", + "category": "product_version", + "branches": [ + { + "name": "15.3(1)SY", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-209532", + "name": "Cisco IOS 15.3SY 15.3(1)SY" + } + }, + { + "name": "15.3(0)SY", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-212701", + "name": "Cisco IOS 15.3SY 15.3(0)SY" + } + }, + { + "name": "15.3(1)SY1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-216258", + "name": "Cisco IOS 15.3SY 15.3(1)SY1" + } + }, + { + "name": "15.3(1)SY2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-220444", + "name": "Cisco IOS 15.3SY 15.3(1)SY2" + } + }, + { + "name": "15.3(1)SY3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-230607", + "name": "Cisco IOS 15.3SY 15.3(1)SY3" + } + } + ] + }, + { + "name": "15.6SP", + "category": "product_version", + "branches": [ + { + "name": "15.6(2)SP3b", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-231824", + "name": "Cisco IOS 15.6SP 15.6(2)SP3b" + } + } + ] + }, + { + "name": "15.2EC", + "category": "product_version", + "branches": [ + { + "name": "15.2(4)EC1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-220461", + "name": "Cisco IOS 15.2EC 15.2(4)EC1" + } + }, + { + "name": "15.2(4)EC2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-223086", + "name": "Cisco IOS 15.2EC 15.2(4)EC2" + } + } + ] + }, + { + "name": "15.4SY", + "category": "product_version", + "branches": [ + { + "name": "15.4(1)SY", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-217807", + "name": "Cisco IOS 15.4SY 15.4(1)SY" + } + }, + { + "name": "15.4(1)SY1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-220594", + "name": "Cisco IOS 15.4SY 15.4(1)SY1" + } + }, + { + "name": "15.4(1)SY2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-224611", + "name": "Cisco IOS 15.4SY 15.4(1)SY2" + } + }, + { + "name": "15.4(1)SY3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-228056", + "name": "Cisco IOS 15.4SY 15.4(1)SY3" + } + } + ] + }, + { + "name": "15.5SY", + "category": "product_version", + "branches": [ + { + "name": "15.5(1)SY", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-225786", + "name": "Cisco IOS 15.5SY 15.5(1)SY" + } + } + ] + } + ] + }, + { + "name": "Cisco IOS XE Software", + "category": "product_name", + "branches": [ + { + "name": "3.2SE", + "category": "product_version", + "branches": [ + { + "name": "3.2.0SE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-196216", + "name": "Cisco IOS XE Software 3.2SE 3.2.0SE" + } + }, + { + "name": "3.2.1SE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-196221", + "name": "Cisco IOS XE Software 3.2SE 3.2.1SE" + } + }, + { + "name": "3.2.2SE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-196222", + "name": "Cisco IOS XE Software 3.2SE 3.2.2SE" + } + }, + { + "name": "3.2.3SE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-196223", + "name": "Cisco IOS XE Software 3.2SE 3.2.3SE" + } + } + ] + }, + { + "name": "3.3SE", + "category": "product_version", + "branches": [ + { + "name": "3.3.0SE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-196218", + "name": "Cisco IOS XE Software 3.3SE 3.3.0SE" + } + }, + { + "name": "3.3.1SE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-196925", + "name": "Cisco IOS XE Software 3.3SE 3.3.1SE" + } + }, + { + "name": "3.3.2SE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-206200", + "name": "Cisco IOS XE Software 3.3SE 3.3.2SE" + } + }, + { + "name": "3.3.3SE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-206201", + "name": "Cisco IOS XE Software 3.3SE 3.3.3SE" + } + }, + { + "name": "3.3.4SE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-206202", + "name": "Cisco IOS XE Software 3.3SE 3.3.4SE" + } + }, + { + "name": "3.3.5SE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-206203", + "name": "Cisco IOS XE Software 3.3SE 3.3.5SE" + } + } + ] + }, + { + "name": "3.3XO", + "category": "product_version", + "branches": [ + { + "name": "3.3.0XO", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-196220", + "name": "Cisco IOS XE Software 3.3XO 3.3.0XO" + } + }, + { + "name": "3.3.1XO", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-206163", + "name": "Cisco IOS XE Software 3.3XO 3.3.1XO" + } + }, + { + "name": "3.3.2XO", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-206164", + "name": "Cisco IOS XE Software 3.3XO 3.3.2XO" + } + } + ] + }, + { + "name": "3.4SG", + "category": "product_version", + "branches": [ + { + "name": "3.4.0SG", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-196230", + "name": "Cisco IOS XE Software 3.4SG 3.4.0SG" + } + }, + { + "name": "3.4.2SG", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-196231", + "name": "Cisco IOS XE Software 3.4SG 3.4.2SG" + } + }, + { + "name": "3.4.1SG", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-196288", + "name": "Cisco IOS XE Software 3.4SG 3.4.1SG" + } + }, + { + "name": "3.4.3SG", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-206165", + "name": "Cisco IOS XE Software 3.4SG 3.4.3SG" + } + }, + { + "name": "3.4.4SG", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-206166", + "name": "Cisco IOS XE Software 3.4SG 3.4.4SG" + } + }, + { + "name": "3.4.5SG", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-206167", + "name": "Cisco IOS XE Software 3.4SG 3.4.5SG" + } + }, + { + "name": "3.4.6SG", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-210070", + "name": "Cisco IOS XE Software 3.4SG 3.4.6SG" + } + }, + { + "name": "3.4.7SG", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-213785", + "name": "Cisco IOS XE Software 3.4SG 3.4.7SG" + } + }, + { + "name": "3.4.8SG", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-221185", + "name": "Cisco IOS XE Software 3.4SG 3.4.8SG" + } + } + ] + }, + { + "name": "3.5E", + "category": "product_version", + "branches": [ + { + "name": "3.5.0E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-197145", + "name": "Cisco IOS XE Software 3.5E 3.5.0E" + } + }, + { + "name": "3.5.1E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-206168", + "name": "Cisco IOS XE Software 3.5E 3.5.1E" + } + }, + { + "name": "3.5.2E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-206169", + "name": "Cisco IOS XE Software 3.5E 3.5.2E" + } + }, + { + "name": "3.5.3E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-206170", + "name": "Cisco IOS XE Software 3.5E 3.5.3E" + } + } + ] + }, + { + "name": "3.6E", + "category": "product_version", + "branches": [ + { + "name": "3.6.0E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-206172", + "name": "Cisco IOS XE Software 3.6E 3.6.0E" + } + }, + { + "name": "3.6.1E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-206173", + "name": "Cisco IOS XE Software 3.6E 3.6.1E" + } + }, + { + "name": "3.6.0aE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-210073", + "name": "Cisco IOS XE Software 3.6E 3.6.0aE" + } + }, + { + "name": "3.6.0bE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-210074", + "name": "Cisco IOS XE Software 3.6E 3.6.0bE" + } + }, + { + "name": "3.6.2aE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-210075", + "name": "Cisco IOS XE Software 3.6E 3.6.2aE" + } + }, + { + "name": "3.6.2E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-210264", + "name": "Cisco IOS XE Software 3.6E 3.6.2E" + } + }, + { + "name": "3.6.3E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-212674", + "name": "Cisco IOS XE Software 3.6E 3.6.3E" + } + }, + { + "name": "3.6.4E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-213790", + "name": "Cisco IOS XE Software 3.6E 3.6.4E" + } + }, + { + "name": "3.6.5E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-217279", + "name": "Cisco IOS XE Software 3.6E 3.6.5E" + } + }, + { + "name": "3.6.6E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-220357", + "name": "Cisco IOS XE Software 3.6E 3.6.6E" + } + }, + { + "name": "3.6.5aE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-221108", + "name": "Cisco IOS XE Software 3.6E 3.6.5aE" + } + }, + { + "name": "3.6.5bE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-222435", + "name": "Cisco IOS XE Software 3.6E 3.6.5bE" + } + }, + { + "name": "3.6.7E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-224840", + "name": "Cisco IOS XE Software 3.6E 3.6.7E" + } + }, + { + "name": "3.6.7aE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-230240", + "name": "Cisco IOS XE Software 3.6E 3.6.7aE" + } + }, + { + "name": "3.6.7bE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-230998", + "name": "Cisco IOS XE Software 3.6E 3.6.7bE" + } + } + ] + }, + { + "name": "3.7E", + "category": "product_version", + "branches": [ + { + "name": "3.7.0E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-206211", + "name": "Cisco IOS XE Software 3.7E 3.7.0E" + } + }, + { + "name": "3.7.1E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-210076", + "name": "Cisco IOS XE Software 3.7E 3.7.1E" + } + }, + { + "name": "3.7.2E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-210077", + "name": "Cisco IOS XE Software 3.7E 3.7.2E" + } + }, + { + "name": "3.7.3E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-213797", + "name": "Cisco IOS XE Software 3.7E 3.7.3E" + } + }, + { + "name": "3.7.4E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-217280", + "name": "Cisco IOS XE Software 3.7E 3.7.4E" + } + }, + { + "name": "3.7.5E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-220290", + "name": "Cisco IOS XE Software 3.7E 3.7.5E" + } + } + ] + }, + { + "name": "16.1", + "category": "product_version", + "branches": [ + { + "name": "16.1.1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-212436", + "name": "Cisco IOS XE Software 16.1 16.1.1" + } + }, + { + "name": "16.1.2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-213100", + "name": "Cisco IOS XE Software 16.1 16.1.2" + } + }, + { + "name": "16.1.3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-214993", + "name": "Cisco IOS XE Software 16.1 16.1.3" + } + } + ] + }, + { + "name": "3.2JA", + "category": "product_version", + "branches": [ + { + "name": "3.2.0JA", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-213783", + "name": "Cisco IOS XE Software 3.2JA 3.2.0JA" + } + } + ] + }, + { + "name": "16.2", + "category": "product_version", + "branches": [ + { + "name": "16.2.1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-213809", + "name": "Cisco IOS XE Software 16.2 16.2.1" + } + }, + { + "name": "16.2.2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-217253", + "name": "Cisco IOS XE Software 16.2 16.2.2" + } + } + ] + }, + { + "name": "3.8E", + "category": "product_version", + "branches": [ + { + "name": "3.8.0E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-213811", + "name": "Cisco IOS XE Software 3.8E 3.8.0E" + } + }, + { + "name": "3.8.1E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-213812", + "name": "Cisco IOS XE Software 3.8E 3.8.1E" + } + }, + { + "name": "3.8.2E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-217283", + "name": "Cisco IOS XE Software 3.8E 3.8.2E" + } + }, + { + "name": "3.8.3E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-220489", + "name": "Cisco IOS XE Software 3.8E 3.8.3E" + } + }, + { + "name": "3.8.4E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-222695", + "name": "Cisco IOS XE Software 3.8E 3.8.4E" + } + }, + { + "name": "3.8.5E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-226331", + "name": "Cisco IOS XE Software 3.8E 3.8.5E" + } + }, + { + "name": "3.8.5aE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-231004", + "name": "Cisco IOS XE Software 3.8E 3.8.5aE" + } + } + ] + }, + { + "name": "16.3", + "category": "product_version", + "branches": [ + { + "name": "16.3.1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-213960", + "name": "Cisco IOS XE Software 16.3 16.3.1" + } + }, + { + "name": "16.3.2", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-217255", + "name": "Cisco IOS XE Software 16.3 16.3.2" + } + }, + { + "name": "16.3.3", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-217256", + "name": "Cisco IOS XE Software 16.3 16.3.3" + } + }, + { + "name": "16.3.1a", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-220802", + "name": "Cisco IOS XE Software 16.3 16.3.1a" + } + }, + { + "name": "16.3.4", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-222711", + "name": "Cisco IOS XE Software 16.3 16.3.4" + } + }, + { + "name": "16.3.5", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-229124", + "name": "Cisco IOS XE Software 16.3 16.3.5" + } + }, + { + "name": "16.3.5b", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-231187", + "name": "Cisco IOS XE Software 16.3 16.3.5b" + } + } + ] + }, + { + "name": "16.4", + "category": "product_version", + "branches": [ + { + "name": "16.4.1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-214051", + "name": "Cisco IOS XE Software 16.4 16.4.1" + } + } + ] + }, + { + "name": "16.5", + "category": "product_version", + "branches": [ + { + "name": "16.5.1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-217259", + "name": "Cisco IOS XE Software 16.5 16.5.1" + } + }, + { + "name": "16.5.1a", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-225784", + "name": "Cisco IOS XE Software 16.5 16.5.1a" + } + } + ] + }, + { + "name": "3.9E", + "category": "product_version", + "branches": [ + { + "name": "3.9.0E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-217282", + "name": "Cisco IOS XE Software 3.9E 3.9.0E" + } + }, + { + "name": "3.9.1E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-222483", + "name": "Cisco IOS XE Software 3.9E 3.9.1E" + } + }, + { + "name": "3.9.2E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-226158", + "name": "Cisco IOS XE Software 3.9E 3.9.2E" + } + }, + { + "name": "3.9.2bE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-227755", + "name": "Cisco IOS XE Software 3.9E 3.9.2bE" + } + } + ] + }, + { + "name": "16.6", + "category": "product_version", + "branches": [ + { + "name": "16.6.1", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-218901", + "name": "Cisco IOS XE Software 16.6 16.6.1" + } + }, + { + "name": "16.6.4", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-233155", + "name": "Cisco IOS XE Software 16.6 16.6.4" + } + } + ] + }, + { + "name": "16.8", + "category": "product_version", + "branches": [ + { + "name": "16.8.1s", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-236834", + "name": "Cisco IOS XE Software 16.8 16.8.1s" + } + } + ] + }, + { + "name": "3.10E", + "category": "product_version", + "branches": [ + { + "name": "3.10.0E", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-227555", + "name": "Cisco IOS XE Software 3.10E 3.10.0E" + } + }, + { + "name": "3.10.0cE", + "category": "service_pack", + "product": { + "product_id": "CVRFPID-231246", + "name": "Cisco IOS XE Software 3.10E 3.10.0cE" + } + } + ] + } + ] + } + ] + } + ] + }, + "vulnerabilities": [ + { + "title": "Cisco IOS and IOS XE Software Smart Install Remote Code Execution Vulnerability", + "ids": [ + { + "system_name": "Cisco Bug ID", + "text": "CSCvg76186" + } + ], + "notes": [ + { + "title": "Summary", + "category": "summary", + "text": "A vulnerability in the Smart Install feature of Cisco IOS Software and Cisco IOS XE Software could allow an unauthenticated, remote attacker to trigger a reload of an affected device, resulting in a denial of service (DoS) condition, or to execute arbitrary code on an affected device.\n\n\n\nThe vulnerability is due to improper validation of packet data. An attacker could exploit this vulnerability by sending a crafted Smart Install message to an affected device on TCP port 4786. A successful exploit could allow the attacker to cause a buffer overflow on the affected device, which could have the following impacts:\n\n\n Triggering a reload of the device\n Allowing the attacker to execute arbitrary code on the device\n Causing an indefinite loop on the affected device that triggers a watchdog crash" + }, + { + "title": "Cisco Bug IDs", + "category": "other", + "text": "CSCvg76186" + } + ], + "cve": "CVE-2018-0171", + "product_status": { + "known_affected": [ + "CVRFPID-103559", + "CVRFPID-103763", + "CVRFPID-104376", + "CVRFPID-105394", + "CVRFPID-105660", + "CVRFPID-105689", + "CVRFPID-105987", + "CVRFPID-106029", + "CVRFPID-106674", + "CVRFPID-107283", + "CVRFPID-107852", + "CVRFPID-108306", + "CVRFPID-109098", + "CVRFPID-109439", + "CVRFPID-109760", + "CVRFPID-109808", + "CVRFPID-111010", + "CVRFPID-111019", + "CVRFPID-111674", + "CVRFPID-112489", + "CVRFPID-113961", + "CVRFPID-114665", + "CVRFPID-115285", + "CVRFPID-115477", + "CVRFPID-115832", + "CVRFPID-115939", + "CVRFPID-116083", + "CVRFPID-183811", + "CVRFPID-184125", + "CVRFPID-184932", + "CVRFPID-187057", + "CVRFPID-187269", + "CVRFPID-188035", + "CVRFPID-188061", + "CVRFPID-189064", + "CVRFPID-189115", + "CVRFPID-189187", + "CVRFPID-189219", + "CVRFPID-189455", + "CVRFPID-190635", + "CVRFPID-190637", + "CVRFPID-191635", + "CVRFPID-191928", + "CVRFPID-191948", + "CVRFPID-192702", + "CVRFPID-192706", + "CVRFPID-192726", + "CVRFPID-192910", + "CVRFPID-192911", + "CVRFPID-193283", + "CVRFPID-194540", + "CVRFPID-194741", + "CVRFPID-194913", + "CVRFPID-194944", + "CVRFPID-195469", + "CVRFPID-195489", + "CVRFPID-195770", + "CVRFPID-195943", + "CVRFPID-197462", + "CVRFPID-197465", + "CVRFPID-197471", + "CVRFPID-197483", + "CVRFPID-198059", + "CVRFPID-198060", + "CVRFPID-198426", + "CVRFPID-198542", + "CVRFPID-200488", + "CVRFPID-200496", + "CVRFPID-201019", + "CVRFPID-201074", + "CVRFPID-201366", + "CVRFPID-204097", + "CVRFPID-204102", + "CVRFPID-204108", + "CVRFPID-204109", + "CVRFPID-204110", + "CVRFPID-204186", + "CVRFPID-204187", + "CVRFPID-204228", + "CVRFPID-204818", + "CVRFPID-204828", + "CVRFPID-204831", + "CVRFPID-204832", + "CVRFPID-205064", + "CVRFPID-205672", + "CVRFPID-209028", + "CVRFPID-209029", + "CVRFPID-209034", + "CVRFPID-209043", + "CVRFPID-209044", + "CVRFPID-209045", + "CVRFPID-209046", + "CVRFPID-209047", + "CVRFPID-209063", + "CVRFPID-209064", + "CVRFPID-209065", + "CVRFPID-209358", + "CVRFPID-209359", + "CVRFPID-209439", + "CVRFPID-209532", + "CVRFPID-209839", + "CVRFPID-209887", + "CVRFPID-210406", + "CVRFPID-210732", + "CVRFPID-210766", + "CVRFPID-211296", + "CVRFPID-211570", + "CVRFPID-211976", + "CVRFPID-212329", + "CVRFPID-212701", + "CVRFPID-213610", + "CVRFPID-213788", + "CVRFPID-214052", + "CVRFPID-214053", + "CVRFPID-214072", + "CVRFPID-214078", + "CVRFPID-214218", + "CVRFPID-214556", + "CVRFPID-214797", + "CVRFPID-214992", + "CVRFPID-216258", + "CVRFPID-216259", + "CVRFPID-216295", + "CVRFPID-217805", + "CVRFPID-217807", + "CVRFPID-218891", + "CVRFPID-218995", + "CVRFPID-220440", + "CVRFPID-220441", + "CVRFPID-220444", + "CVRFPID-220457", + "CVRFPID-220461", + "CVRFPID-220466", + "CVRFPID-220594", + "CVRFPID-220664", + "CVRFPID-220689", + "CVRFPID-221033", + "CVRFPID-221137", + "CVRFPID-222275", + "CVRFPID-222342", + "CVRFPID-222436", + "CVRFPID-222500", + "CVRFPID-222530", + "CVRFPID-222650", + "CVRFPID-222651", + "CVRFPID-222924", + "CVRFPID-223086", + "CVRFPID-223143", + "CVRFPID-224553", + "CVRFPID-224611", + "CVRFPID-224868", + "CVRFPID-225160", + "CVRFPID-225740", + "CVRFPID-225786", + "CVRFPID-226077", + "CVRFPID-227285", + "CVRFPID-227307", + "CVRFPID-227308", + "CVRFPID-227598", + "CVRFPID-227754", + "CVRFPID-227959", + "CVRFPID-228056", + "CVRFPID-228057", + "CVRFPID-228151", + "CVRFPID-230588", + "CVRFPID-230589", + "CVRFPID-230590", + "CVRFPID-230591", + "CVRFPID-230607", + "CVRFPID-230623", + "CVRFPID-230962", + "CVRFPID-230965", + "CVRFPID-230990", + "CVRFPID-231074", + "CVRFPID-231245", + "CVRFPID-231824", + "CVRFPID-232957", + "CVRFPID-233143", + "CVRFPID-233796", + "CVRFPID-234926", + "CVRFPID-196216", + "CVRFPID-196218", + "CVRFPID-196220", + "CVRFPID-196221", + "CVRFPID-196222", + "CVRFPID-196223", + "CVRFPID-196230", + "CVRFPID-196231", + "CVRFPID-196288", + "CVRFPID-196925", + "CVRFPID-197145", + "CVRFPID-206163", + "CVRFPID-206164", + "CVRFPID-206165", + "CVRFPID-206166", + "CVRFPID-206167", + "CVRFPID-206168", + "CVRFPID-206169", + "CVRFPID-206170", + "CVRFPID-206172", + "CVRFPID-206173", + "CVRFPID-206200", + "CVRFPID-206201", + "CVRFPID-206202", + "CVRFPID-206203", + "CVRFPID-206211", + "CVRFPID-210070", + "CVRFPID-210073", + "CVRFPID-210074", + "CVRFPID-210075", + "CVRFPID-210076", + "CVRFPID-210077", + "CVRFPID-210264", + "CVRFPID-212436", + "CVRFPID-212674", + "CVRFPID-213100", + "CVRFPID-213783", + "CVRFPID-213785", + "CVRFPID-213790", + "CVRFPID-213797", + "CVRFPID-213809", + "CVRFPID-213811", + "CVRFPID-213812", + "CVRFPID-213960", + "CVRFPID-214051", + "CVRFPID-214993", + "CVRFPID-217253", + "CVRFPID-217255", + "CVRFPID-217256", + "CVRFPID-217259", + "CVRFPID-217279", + "CVRFPID-217280", + "CVRFPID-217282", + "CVRFPID-217283", + "CVRFPID-218901", + "CVRFPID-220290", + "CVRFPID-220357", + "CVRFPID-220489", + "CVRFPID-220802", + "CVRFPID-221108", + "CVRFPID-221185", + "CVRFPID-222435", + "CVRFPID-222483", + "CVRFPID-222695", + "CVRFPID-222711", + "CVRFPID-224840", + "CVRFPID-225784", + "CVRFPID-226158", + "CVRFPID-226331", + "CVRFPID-227555", + "CVRFPID-227755", + "CVRFPID-229124", + "CVRFPID-230240", + "CVRFPID-230998", + "CVRFPID-231004", + "CVRFPID-231187", + "CVRFPID-231246", + "CVRFPID-233155", + "CVRFPID-236834" + ] + }, + "scores": [ + { + "products": [ + "CVRFPID-103559", + "CVRFPID-103763", + "CVRFPID-104376", + "CVRFPID-105394", + "CVRFPID-105660", + "CVRFPID-105689", + "CVRFPID-105987", + "CVRFPID-106029", + "CVRFPID-106674", + "CVRFPID-107283", + "CVRFPID-107852", + "CVRFPID-108306", + "CVRFPID-109098", + "CVRFPID-109439", + "CVRFPID-109760", + "CVRFPID-109808", + "CVRFPID-111010", + "CVRFPID-111019", + "CVRFPID-111674", + "CVRFPID-112489", + "CVRFPID-113961", + "CVRFPID-114665", + "CVRFPID-115285", + "CVRFPID-115477", + "CVRFPID-115832", + "CVRFPID-115939", + "CVRFPID-116083", + "CVRFPID-183811", + "CVRFPID-184125", + "CVRFPID-184932", + "CVRFPID-187057", + "CVRFPID-187269", + "CVRFPID-188035", + "CVRFPID-188061", + "CVRFPID-189064", + "CVRFPID-189115", + "CVRFPID-189187", + "CVRFPID-189219", + "CVRFPID-189455", + "CVRFPID-190635", + "CVRFPID-190637", + "CVRFPID-191635", + "CVRFPID-191928", + "CVRFPID-191948", + "CVRFPID-192702", + "CVRFPID-192706", + "CVRFPID-192726", + "CVRFPID-192910", + "CVRFPID-192911", + "CVRFPID-193283", + "CVRFPID-194540", + "CVRFPID-194741", + "CVRFPID-194913", + "CVRFPID-194944", + "CVRFPID-195469", + "CVRFPID-195489", + "CVRFPID-195770", + "CVRFPID-195943", + "CVRFPID-197462", + "CVRFPID-197465", + "CVRFPID-197471", + "CVRFPID-197483", + "CVRFPID-198059", + "CVRFPID-198060", + "CVRFPID-198426", + "CVRFPID-198542", + "CVRFPID-200488", + "CVRFPID-200496", + "CVRFPID-201019", + "CVRFPID-201074", + "CVRFPID-201366", + "CVRFPID-204097", + "CVRFPID-204102", + "CVRFPID-204108", + "CVRFPID-204109", + "CVRFPID-204110", + "CVRFPID-204186", + "CVRFPID-204187", + "CVRFPID-204228", + "CVRFPID-204818", + "CVRFPID-204828", + "CVRFPID-204831", + "CVRFPID-204832", + "CVRFPID-205064", + "CVRFPID-205672", + "CVRFPID-209028", + "CVRFPID-209029", + "CVRFPID-209034", + "CVRFPID-209043", + "CVRFPID-209044", + "CVRFPID-209045", + "CVRFPID-209046", + "CVRFPID-209047", + "CVRFPID-209063", + "CVRFPID-209064", + "CVRFPID-209065", + "CVRFPID-209358", + "CVRFPID-209359", + "CVRFPID-209439", + "CVRFPID-209532", + "CVRFPID-209839", + "CVRFPID-209887", + "CVRFPID-210406", + "CVRFPID-210732", + "CVRFPID-210766", + "CVRFPID-211296", + "CVRFPID-211570", + "CVRFPID-211976", + "CVRFPID-212329", + "CVRFPID-212701", + "CVRFPID-213610", + "CVRFPID-213788", + "CVRFPID-214052", + "CVRFPID-214053", + "CVRFPID-214072", + "CVRFPID-214078", + "CVRFPID-214218", + "CVRFPID-214556", + "CVRFPID-214797", + "CVRFPID-214992", + "CVRFPID-216258", + "CVRFPID-216259", + "CVRFPID-216295", + "CVRFPID-217805", + "CVRFPID-217807", + "CVRFPID-218891", + "CVRFPID-218995", + "CVRFPID-220440", + "CVRFPID-220441", + "CVRFPID-220444", + "CVRFPID-220457", + "CVRFPID-220461", + "CVRFPID-220466", + "CVRFPID-220594", + "CVRFPID-220664", + "CVRFPID-220689", + "CVRFPID-221033", + "CVRFPID-221137", + "CVRFPID-222275", + "CVRFPID-222342", + "CVRFPID-222436", + "CVRFPID-222500", + "CVRFPID-222530", + "CVRFPID-222650", + "CVRFPID-222651", + "CVRFPID-222924", + "CVRFPID-223086", + "CVRFPID-223143", + "CVRFPID-224553", + "CVRFPID-224611", + "CVRFPID-224868", + "CVRFPID-225160", + "CVRFPID-225740", + "CVRFPID-225786", + "CVRFPID-226077", + "CVRFPID-227285", + "CVRFPID-227307", + "CVRFPID-227308", + "CVRFPID-227598", + "CVRFPID-227754", + "CVRFPID-227959", + "CVRFPID-228056", + "CVRFPID-228057", + "CVRFPID-228151", + "CVRFPID-230588", + "CVRFPID-230589", + "CVRFPID-230590", + "CVRFPID-230591", + "CVRFPID-230607", + "CVRFPID-230623", + "CVRFPID-230962", + "CVRFPID-230965", + "CVRFPID-230990", + "CVRFPID-231074", + "CVRFPID-231245", + "CVRFPID-231824", + "CVRFPID-232957", + "CVRFPID-233143", + "CVRFPID-233796", + "CVRFPID-234926", + "CVRFPID-196216", + "CVRFPID-196218", + "CVRFPID-196220", + "CVRFPID-196221", + "CVRFPID-196222", + "CVRFPID-196223", + "CVRFPID-196230", + "CVRFPID-196231", + "CVRFPID-196288", + "CVRFPID-196925", + "CVRFPID-197145", + "CVRFPID-206163", + "CVRFPID-206164", + "CVRFPID-206165", + "CVRFPID-206166", + "CVRFPID-206167", + "CVRFPID-206168", + "CVRFPID-206169", + "CVRFPID-206170", + "CVRFPID-206172", + "CVRFPID-206173", + "CVRFPID-206200", + "CVRFPID-206201", + "CVRFPID-206202", + "CVRFPID-206203", + "CVRFPID-206211", + "CVRFPID-210070", + "CVRFPID-210073", + "CVRFPID-210074", + "CVRFPID-210075", + "CVRFPID-210076", + "CVRFPID-210077", + "CVRFPID-210264", + "CVRFPID-212436", + "CVRFPID-212674", + "CVRFPID-213100", + "CVRFPID-213783", + "CVRFPID-213785", + "CVRFPID-213790", + "CVRFPID-213797", + "CVRFPID-213809", + "CVRFPID-213811", + "CVRFPID-213812", + "CVRFPID-213960", + "CVRFPID-214051", + "CVRFPID-214993", + "CVRFPID-217253", + "CVRFPID-217255", + "CVRFPID-217256", + "CVRFPID-217259", + "CVRFPID-217279", + "CVRFPID-217280", + "CVRFPID-217282", + "CVRFPID-217283", + "CVRFPID-218901", + "CVRFPID-220290", + "CVRFPID-220357", + "CVRFPID-220489", + "CVRFPID-220802", + "CVRFPID-221108", + "CVRFPID-221185", + "CVRFPID-222435", + "CVRFPID-222483", + "CVRFPID-222695", + "CVRFPID-222711", + "CVRFPID-224840", + "CVRFPID-225784", + "CVRFPID-226158", + "CVRFPID-226331", + "CVRFPID-227555", + "CVRFPID-227755", + "CVRFPID-229124", + "CVRFPID-230240", + "CVRFPID-230998", + "CVRFPID-231004", + "CVRFPID-231187", + "CVRFPID-231246", + "CVRFPID-233155", + "CVRFPID-236834" + ], + "cvss_v3": + { + "version": "3.0", + "baseScore": 9.8, + "baseSeverity": "CRITICAL", + "vectorString": "CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H" + } + } + ], + "remediations": [ + { + "details": "There are no workarounds that address this vulnerability for customers who require the use of Cisco Smart Install. For customers not requiring Cisco Smart Install, the feature can be disabled with the no vstack command. In software releases that are associated with Cisco Bug ID CSCvd36820 [\"https://bst.cloudapps.cisco.com/bugsearch/bug/CSCvd36820\"], Cisco Smart Install will auto-disable if not in use.\n\nAdministrators are encouraged to consult the informational security advisory on Cisco Smart Install Protocol Misuse [\"https://tools.cisco.com/security/center/content/CiscoSecurityAdvisory/cisco-sa-20170214-smi\"] and the Smart Install Configuration Guide [\"http://www.cisco.com/c/en/us/td/docs/switches/lan/smart_install/configuration/guide/smart_install/concepts.html#23355\"].", + "category": "workaround", + "product_ids": [ + "CVRFPID-103559", + "CVRFPID-103763", + "CVRFPID-104376", + "CVRFPID-105394", + "CVRFPID-105660", + "CVRFPID-105689", + "CVRFPID-105987", + "CVRFPID-106029", + "CVRFPID-106674", + "CVRFPID-107283", + "CVRFPID-107852", + "CVRFPID-108306", + "CVRFPID-109098", + "CVRFPID-109439", + "CVRFPID-109760", + "CVRFPID-109808", + "CVRFPID-111010", + "CVRFPID-111019", + "CVRFPID-111674", + "CVRFPID-112489", + "CVRFPID-113961", + "CVRFPID-114665", + "CVRFPID-115285", + "CVRFPID-115477", + "CVRFPID-115832", + "CVRFPID-115939", + "CVRFPID-116083", + "CVRFPID-183811", + "CVRFPID-184125", + "CVRFPID-184932", + "CVRFPID-187057", + "CVRFPID-187269", + "CVRFPID-188035", + "CVRFPID-188061", + "CVRFPID-189064", + "CVRFPID-189115", + "CVRFPID-189187", + "CVRFPID-189219", + "CVRFPID-189455", + "CVRFPID-190635", + "CVRFPID-190637", + "CVRFPID-191635", + "CVRFPID-191928", + "CVRFPID-191948", + "CVRFPID-192702", + "CVRFPID-192706", + "CVRFPID-192726", + "CVRFPID-192910", + "CVRFPID-192911", + "CVRFPID-193283", + "CVRFPID-194540", + "CVRFPID-194741", + "CVRFPID-194913", + "CVRFPID-194944", + "CVRFPID-195469", + "CVRFPID-195489", + "CVRFPID-195770", + "CVRFPID-195943", + "CVRFPID-197462", + "CVRFPID-197465", + "CVRFPID-197471", + "CVRFPID-197483", + "CVRFPID-198059", + "CVRFPID-198060", + "CVRFPID-198426", + "CVRFPID-198542", + "CVRFPID-200488", + "CVRFPID-200496", + "CVRFPID-201019", + "CVRFPID-201074", + "CVRFPID-201366", + "CVRFPID-204097", + "CVRFPID-204102", + "CVRFPID-204108", + "CVRFPID-204109", + "CVRFPID-204110", + "CVRFPID-204186", + "CVRFPID-204187", + "CVRFPID-204228", + "CVRFPID-204818", + "CVRFPID-204828", + "CVRFPID-204831", + "CVRFPID-204832", + "CVRFPID-205064", + "CVRFPID-205672", + "CVRFPID-209028", + "CVRFPID-209029", + "CVRFPID-209034", + "CVRFPID-209043", + "CVRFPID-209044", + "CVRFPID-209045", + "CVRFPID-209046", + "CVRFPID-209047", + "CVRFPID-209063", + "CVRFPID-209064", + "CVRFPID-209065", + "CVRFPID-209358", + "CVRFPID-209359", + "CVRFPID-209439", + "CVRFPID-209532", + "CVRFPID-209839", + "CVRFPID-209887", + "CVRFPID-210406", + "CVRFPID-210732", + "CVRFPID-210766", + "CVRFPID-211296", + "CVRFPID-211570", + "CVRFPID-211976", + "CVRFPID-212329", + "CVRFPID-212701", + "CVRFPID-213610", + "CVRFPID-213788", + "CVRFPID-214052", + "CVRFPID-214053", + "CVRFPID-214072", + "CVRFPID-214078", + "CVRFPID-214218", + "CVRFPID-214556", + "CVRFPID-214797", + "CVRFPID-214992", + "CVRFPID-216258", + "CVRFPID-216259", + "CVRFPID-216295", + "CVRFPID-217805", + "CVRFPID-217807", + "CVRFPID-218891", + "CVRFPID-218995", + "CVRFPID-220440", + "CVRFPID-220441", + "CVRFPID-220444", + "CVRFPID-220457", + "CVRFPID-220461", + "CVRFPID-220466", + "CVRFPID-220594", + "CVRFPID-220664", + "CVRFPID-220689", + "CVRFPID-221033", + "CVRFPID-221137", + "CVRFPID-222275", + "CVRFPID-222342", + "CVRFPID-222436", + "CVRFPID-222500", + "CVRFPID-222530", + "CVRFPID-222650", + "CVRFPID-222651", + "CVRFPID-222924", + "CVRFPID-223086", + "CVRFPID-223143", + "CVRFPID-224553", + "CVRFPID-224611", + "CVRFPID-224868", + "CVRFPID-225160", + "CVRFPID-225740", + "CVRFPID-225786", + "CVRFPID-226077", + "CVRFPID-227285", + "CVRFPID-227307", + "CVRFPID-227308", + "CVRFPID-227598", + "CVRFPID-227754", + "CVRFPID-227959", + "CVRFPID-228056", + "CVRFPID-228057", + "CVRFPID-228151", + "CVRFPID-230588", + "CVRFPID-230589", + "CVRFPID-230590", + "CVRFPID-230591", + "CVRFPID-230607", + "CVRFPID-230623", + "CVRFPID-230962", + "CVRFPID-230965", + "CVRFPID-230990", + "CVRFPID-231074", + "CVRFPID-231245", + "CVRFPID-231824", + "CVRFPID-232957", + "CVRFPID-233143", + "CVRFPID-233796", + "CVRFPID-234926", + "CVRFPID-196216", + "CVRFPID-196218", + "CVRFPID-196220", + "CVRFPID-196221", + "CVRFPID-196222", + "CVRFPID-196223", + "CVRFPID-196230", + "CVRFPID-196231", + "CVRFPID-196288", + "CVRFPID-196925", + "CVRFPID-197145", + "CVRFPID-206163", + "CVRFPID-206164", + "CVRFPID-206165", + "CVRFPID-206166", + "CVRFPID-206167", + "CVRFPID-206168", + "CVRFPID-206169", + "CVRFPID-206170", + "CVRFPID-206172", + "CVRFPID-206173", + "CVRFPID-206200", + "CVRFPID-206201", + "CVRFPID-206202", + "CVRFPID-206203", + "CVRFPID-206211", + "CVRFPID-210070", + "CVRFPID-210073", + "CVRFPID-210074", + "CVRFPID-210075", + "CVRFPID-210076", + "CVRFPID-210077", + "CVRFPID-210264", + "CVRFPID-212436", + "CVRFPID-212674", + "CVRFPID-213100", + "CVRFPID-213783", + "CVRFPID-213785", + "CVRFPID-213790", + "CVRFPID-213797", + "CVRFPID-213809", + "CVRFPID-213811", + "CVRFPID-213812", + "CVRFPID-213960", + "CVRFPID-214051", + "CVRFPID-214993", + "CVRFPID-217253", + "CVRFPID-217255", + "CVRFPID-217256", + "CVRFPID-217259", + "CVRFPID-217279", + "CVRFPID-217280", + "CVRFPID-217282", + "CVRFPID-217283", + "CVRFPID-218901", + "CVRFPID-220290", + "CVRFPID-220357", + "CVRFPID-220489", + "CVRFPID-220802", + "CVRFPID-221108", + "CVRFPID-221185", + "CVRFPID-222435", + "CVRFPID-222483", + "CVRFPID-222695", + "CVRFPID-222711", + "CVRFPID-224840", + "CVRFPID-225784", + "CVRFPID-226158", + "CVRFPID-226331", + "CVRFPID-227555", + "CVRFPID-227755", + "CVRFPID-229124", + "CVRFPID-230240", + "CVRFPID-230998", + "CVRFPID-231004", + "CVRFPID-231187", + "CVRFPID-231246", + "CVRFPID-233155", + "CVRFPID-236834" + ] + } + ], + "references": [ + { + "url": "https://tools.cisco.com/security/center/content/CiscoSecurityAdvisory/cisco-sa-20180328-smi2", + "summary": "Cisco IOS and IOS XE Software Smart Install Remote Code Execution Vulnerability" + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-01-a-001.json b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-01-a-001.json new file mode 100644 index 000000000..480c3b761 --- /dev/null +++ b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-01-a-001.json @@ -0,0 +1,90 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "notes": [ + { + "category": "summary", + "text": "Example Company VEX document. Unofficial content for demonstration purposes only.", + "title": "Author comment" + } + ], + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "title": "Example VEX Document Use Case 1 - Affected", + "tracking": { + "current_release_date": "2022-03-03T11:00:00.000Z", + "generator": { + "date": "2022-03-03T11:00:00.000Z", + "engine": { + "name": "Secvisogram", + "version": "1.11.0" + } + }, + "id": "2022-EVD-UC-01-A-001", + "initial_release_date": "2022-03-03T11:00:00.000Z", + "revision_history": [ + { + "date": "2022-03-03T11:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "branches": [ + { + "category": "product_version", + "name": "1.0", + "product": { + "name": "Example Company DEF 1.0", + "product_id": "CSAFPID-0001" + } + } + ], + "category": "product_name", + "name": "DEF" + } + ], + "category": "vendor", + "name": "Example Company" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2021-44228", + "notes": [ + { + "category": "description", + "text": "Apache Log4j2 2.0-beta9 through 2.15.0 (excluding security releases 2.12.2, 2.12.3, and 2.3.1) JNDI features used in configuration, log messages, and parameters do not protect against attacker controlled LDAP and other JNDI related endpoints. An attacker who can control log messages or log message parameters can execute arbitrary code loaded from LDAP servers when message lookup substitution is enabled. From log4j 2.15.0, this behavior has been disabled by default. From version 2.16.0 (along with 2.12.2, 2.12.3, and 2.3.1), this functionality has been completely removed. Note that this vulnerability is specific to log4j-core and does not affect log4net, log4cxx, or other Apache Logging Services projects.", + "title": "CVE description" + } + ], + "product_status": { + "known_affected": [ + "CSAFPID-0001" + ] + }, + "remediations": [ + { + "category": "vendor_fix", + "details": "Customers should update to version 1.1 of product DEF which fixes the issue.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-01-f-001.json b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-01-f-001.json new file mode 100644 index 000000000..f0ca478fc --- /dev/null +++ b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-01-f-001.json @@ -0,0 +1,81 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "notes": [ + { + "category": "summary", + "text": "Example Company VEX document. Unofficial content for demonstration purposes only.", + "title": "Author comment" + } + ], + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "title": "Example VEX Document Use Case 1 - Fixed", + "tracking": { + "current_release_date": "2022-03-03T11:00:00.000Z", + "generator": { + "date": "2022-03-03T11:00:00.000Z", + "engine": { + "name": "Secvisogram", + "version": "1.11.0" + } + }, + "id": "2022-EVD-UC-01-F-001", + "initial_release_date": "2022-03-03T11:00:00.000Z", + "revision_history": [ + { + "date": "2022-03-03T11:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "branches": [ + { + "category": "product_version", + "name": "1.1", + "product": { + "name": "Example Company DEF 1.1", + "product_id": "CSAFPID-0001" + } + } + ], + "category": "product_name", + "name": "DEF" + } + ], + "category": "vendor", + "name": "Example Company" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2021-44228", + "notes": [ + { + "category": "description", + "text": "Apache Log4j2 2.0-beta9 through 2.15.0 (excluding security releases 2.12.2, 2.12.3, and 2.3.1) JNDI features used in configuration, log messages, and parameters do not protect against attacker controlled LDAP and other JNDI related endpoints. An attacker who can control log messages or log message parameters can execute arbitrary code loaded from LDAP servers when message lookup substitution is enabled. From log4j 2.15.0, this behavior has been disabled by default. From version 2.16.0 (along with 2.12.2, 2.12.3, and 2.3.1), this functionality has been completely removed. Note that this vulnerability is specific to log4j-core and does not affect log4net, log4cxx, or other Apache Logging Services projects.", + "title": "CVE description" + } + ], + "product_status": { + "fixed": [ + "CSAFPID-0001" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-01-na-001.json b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-01-na-001.json new file mode 100644 index 000000000..328ca2468 --- /dev/null +++ b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-01-na-001.json @@ -0,0 +1,90 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "notes": [ + { + "category": "summary", + "text": "Example Company VEX document. Unofficial content for demonstration purposes only.", + "title": "Author comment" + } + ], + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "title": "Example VEX Document Use Case 1 - Not Affected", + "tracking": { + "current_release_date": "2022-03-03T11:00:00.000Z", + "generator": { + "date": "2022-03-03T11:00:00.000Z", + "engine": { + "name": "Secvisogram", + "version": "1.11.0" + } + }, + "id": "2022-EVD-UC-01-NA-001", + "initial_release_date": "2022-03-03T11:00:00.000Z", + "revision_history": [ + { + "date": "2022-03-03T11:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "branches": [ + { + "category": "product_version", + "name": "4.2", + "product": { + "name": "Example Company ABC 4.2", + "product_id": "CSAFPID-0001" + } + } + ], + "category": "product_name", + "name": "ABC" + } + ], + "category": "vendor", + "name": "Example Company" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2021-44228", + "notes": [ + { + "category": "description", + "text": "Apache Log4j2 2.0-beta9 through 2.15.0 (excluding security releases 2.12.2, 2.12.3, and 2.3.1) JNDI features used in configuration, log messages, and parameters do not protect against attacker controlled LDAP and other JNDI related endpoints. An attacker who can control log messages or log message parameters can execute arbitrary code loaded from LDAP servers when message lookup substitution is enabled. From log4j 2.15.0, this behavior has been disabled by default. From version 2.16.0 (along with 2.12.2, 2.12.3, and 2.3.1), this functionality has been completely removed. Note that this vulnerability is specific to log4j-core and does not affect log4net, log4cxx, or other Apache Logging Services projects.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Class with vulnerable code was removed before shipping.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-01-ui-001.json b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-01-ui-001.json new file mode 100644 index 000000000..5ceb3691b --- /dev/null +++ b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-01-ui-001.json @@ -0,0 +1,81 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "notes": [ + { + "category": "summary", + "text": "Example Company VEX document. Unofficial content for demonstration purposes only.", + "title": "Author comment" + } + ], + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "title": "Example VEX Document Use Case 1 - Under Investigation", + "tracking": { + "current_release_date": "2022-03-03T11:00:00.000Z", + "generator": { + "date": "2022-03-03T11:00:00.000Z", + "engine": { + "name": "Secvisogram", + "version": "1.11.0" + } + }, + "id": "2022-EVD-UC-01-UI-001", + "initial_release_date": "2022-03-03T11:00:00.000Z", + "revision_history": [ + { + "date": "2022-03-03T11:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "branches": [ + { + "category": "product_version", + "name": "17.4", + "product": { + "name": "Example Company GHI 17.4", + "product_id": "CSAFPID-0001" + } + } + ], + "category": "product_name", + "name": "GHI" + } + ], + "category": "vendor", + "name": "Example Company" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2021-44228", + "notes": [ + { + "category": "description", + "text": "Apache Log4j2 2.0-beta9 through 2.15.0 (excluding security releases 2.12.2, 2.12.3, and 2.3.1) JNDI features used in configuration, log messages, and parameters do not protect against attacker controlled LDAP and other JNDI related endpoints. An attacker who can control log messages or log message parameters can execute arbitrary code loaded from LDAP servers when message lookup substitution is enabled. From log4j 2.15.0, this behavior has been disabled by default. From version 2.16.0 (along with 2.12.2, 2.12.3, and 2.3.1), this functionality has been completely removed. Note that this vulnerability is specific to log4j-core and does not affect log4net, log4cxx, or other Apache Logging Services projects.", + "title": "CVE description" + } + ], + "product_status": { + "under_investigation": [ + "CSAFPID-0001" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-02-na-001.json b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-02-na-001.json new file mode 100644 index 000000000..dcbc9d388 --- /dev/null +++ b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-02-na-001.json @@ -0,0 +1,522 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "notes": [ + { + "category": "summary", + "text": "Example Company VEX document. Unofficial content for demonstration purposes only.", + "title": "Author comment" + } + ], + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "title": "Example VEX Document Use Case 2 - Not Affected", + "tracking": { + "current_release_date": "2022-03-03T11:00:00.000Z", + "generator": { + "date": "2022-03-03T11:00:00.000Z", + "engine": { + "name": "Secvisogram", + "version": "1.11.0" + } + }, + "id": "2022-EVD-UC-02-NA-001", + "initial_release_date": "2022-03-03T11:00:00.000Z", + "revision_history": [ + { + "date": "2022-03-03T11:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "branches": [ + { + "category": "product_version", + "name": "4.2", + "product": { + "name": "Example Company ABC 4.2", + "product_id": "CSAFPID-0001" + } + } + ], + "category": "product_name", + "name": "ABC" + } + ], + "category": "vendor", + "name": "Example Company" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2020-11896", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 allows Remote Code Execution, related to IPv4 tunneling.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11897", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 5.0.1.35 has an Out-of-Bounds Write via multiple malformed IPv6 packets.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11898", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 improperly handles an IPv4/ICMPv4 Length Parameter Inconsistency, which might allow remote attackers to trigger an information leak.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11899", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has an IPv6 Out-of-bounds Read.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11900", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.41 has an IPv4 tunneling Double Free.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11901", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 allows Remote Code execution via a single invalid DNS response.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11902", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has an IPv6OverIPv4 tunneling Out-of-bounds Read.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11903", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.28 has a DHCP Out-of-bounds Read.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11904", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has an Integer Overflow during Memory Allocation that causes an Out-of-Bounds Write.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11905", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has a DHCPv6 Out-of-bounds Read.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11906", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has an Ethernet Link Layer Integer Underflow.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11907", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 improperly handles a Length Parameter Inconsistency in TCP.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11908", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 4.7.1.27 mishandles '\\0' termination in DHCP.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11909", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has an IPv4 Integer Underflow.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11910", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has an ICMPv4 Out-of-bounds Read.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11911", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has Improper ICMPv4 Access Control.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11912", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has a TCP Out-of-bounds Read.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11913", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has an IPv6 Out-of-bounds Read.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11914", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has an ARP Out-of-bounds Read.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "Linux TCP/IP used and therefore not vulnerable.\n", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-03-ms-001.json b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-03-ms-001.json new file mode 100644 index 000000000..7264ffffc --- /dev/null +++ b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-03-ms-001.json @@ -0,0 +1,450 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "notes": [ + { + "category": "summary", + "text": "Example Company VEX document. Unofficial content for demonstration purposes only.", + "title": "Author comment" + } + ], + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "title": "Example VEX Document Use Case 3 - Multiple statuses", + "tracking": { + "current_release_date": "2022-03-03T11:00:00.000Z", + "generator": { + "date": "2022-03-03T11:00:00.000Z", + "engine": { + "name": "Secvisogram", + "version": "1.11.0" + } + }, + "id": "2022-EVD-UC-03-MS-001", + "initial_release_date": "2022-03-03T11:00:00.000Z", + "revision_history": [ + { + "date": "2022-03-03T11:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "branches": [ + { + "category": "product_version", + "name": "17.4", + "product": { + "name": "Example Company GHI 17.4", + "product_id": "CSAFPID-0001" + } + } + ], + "category": "product_name", + "name": "GHI" + } + ], + "category": "vendor", + "name": "Example Company" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2020-11896", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 allows Remote Code Execution, related to IPv4 tunneling.", + "title": "CVE description" + } + ], + "product_status": { + "under_investigation": [ + "CSAFPID-0001" + ] + } + }, + { + "cve": "CVE-2020-11897", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 5.0.1.35 has an Out-of-Bounds Write via multiple malformed IPv6 packets.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "IPv6 is not supported and code is not present.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11898", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 improperly handles an IPv4/ICMPv4 Length Parameter Inconsistency, which might allow remote attackers to trigger an information leak.", + "title": "CVE description" + } + ], + "product_status": { + "known_affected": [ + "CSAFPID-0001" + ] + }, + "remediations": [ + { + "category": "none_available", + "details": "We are working to integrate the upstream patches in our code.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11899", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has an IPv6 Out-of-bounds Read.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "IPv6 is not supported and code is not present.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11900", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.41 has an IPv4 tunneling Double Free.", + "title": "CVE description" + } + ], + "product_status": { + "under_investigation": [ + "CSAFPID-0001" + ] + } + }, + { + "cve": "CVE-2020-11901", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 allows Remote Code execution via a single invalid DNS response.", + "title": "CVE description" + } + ], + "product_status": { + "fixed": [ + "CSAFPID-0001" + ] + } + }, + { + "cve": "CVE-2020-11902", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has an IPv6OverIPv4 tunneling Out-of-bounds Read.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "IPv6 is not supported and code is not present.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11903", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.28 has a DHCP Out-of-bounds Read.", + "title": "CVE description" + } + ], + "product_status": { + "under_investigation": [ + "CSAFPID-0001" + ] + } + }, + { + "cve": "CVE-2020-11904", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has an Integer Overflow during Memory Allocation that causes an Out-of-Bounds Write.", + "title": "CVE description" + } + ], + "product_status": { + "under_investigation": [ + "CSAFPID-0001" + ] + } + }, + { + "cve": "CVE-2020-11905", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has a DHCPv6 Out-of-bounds Read.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "IPv6 is not supported and code is not present.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11906", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has an Ethernet Link Layer Integer Underflow.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "This code was re-written. The vulnerable code is not present.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11907", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 improperly handles a Length Parameter Inconsistency in TCP.", + "title": "CVE description" + } + ], + "product_status": { + "known_affected": [ + "CSAFPID-0001" + ] + }, + "remediations": [ + { + "category": "none_available", + "details": "We are working to integrate the upstream patches in our code.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11908", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 4.7.1.27 mishandles '\\0' termination in DHCP.", + "title": "CVE description" + } + ], + "product_status": { + "under_investigation": [ + "CSAFPID-0001" + ] + } + }, + { + "cve": "CVE-2020-11909", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has an IPv4 Integer Underflow.", + "title": "CVE description" + } + ], + "product_status": { + "known_affected": [ + "CSAFPID-0001" + ] + }, + "remediations": [ + { + "category": "none_available", + "details": "We are working to integrate the upstream patches in our code.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11910", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has an ICMPv4 Out-of-bounds Read.", + "title": "CVE description" + } + ], + "product_status": { + "known_affected": [ + "CSAFPID-0001" + ] + }, + "remediations": [ + { + "category": "none_available", + "details": "We are working to integrate the upstream patches in our code.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11911", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has Improper ICMPv4 Access Control.", + "title": "CVE description" + } + ], + "product_status": { + "known_affected": [ + "CSAFPID-0001" + ] + }, + "remediations": [ + { + "category": "none_available", + "details": "We are working to integrate the upstream patches in our code.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11912", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has a TCP Out-of-bounds Read.", + "title": "CVE description" + } + ], + "product_status": { + "fixed": [ + "CSAFPID-0001" + ] + } + }, + { + "cve": "CVE-2020-11913", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has an IPv6 Out-of-bounds Read.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "threats": [ + { + "category": "impact", + "details": "IPv6 is not supported and code is not present.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2020-11914", + "notes": [ + { + "category": "description", + "text": "The Treck TCP/IP stack before 6.0.1.66 has an ARP Out-of-bounds Read.", + "title": "CVE description" + } + ], + "product_status": { + "fixed": [ + "CSAFPID-0001" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-04-001.json b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-04-001.json new file mode 100644 index 000000000..ad1269be6 --- /dev/null +++ b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-04-001.json @@ -0,0 +1,140 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "notes": [ + { + "category": "summary", + "text": "Example Company VEX document. Unofficial content for demonstration purposes only.", + "title": "Author comment" + } + ], + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "title": "Example VEX Document Use Case 4", + "tracking": { + "current_release_date": "2022-03-03T11:00:00.000Z", + "generator": { + "date": "2022-03-03T11:00:00.000Z", + "engine": { + "name": "Secvisogram", + "version": "1.11.0" + } + }, + "id": "2022-EVD-UC-04-001", + "initial_release_date": "2022-03-03T11:00:00.000Z", + "revision_history": [ + { + "date": "2022-03-03T11:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "branches": [ + { + "category": "product_version", + "name": "2.4", + "product": { + "name": "Example Company ABC 2.4", + "product_id": "CSAFPID-0002" + } + }, + { + "category": "product_version", + "name": "2.6", + "product": { + "name": "Example Company ABC 2.6", + "product_id": "CSAFPID-0003" + } + }, + { + "category": "product_version_range", + "name": "vers:generic/>=2.9|<=4.1", + "product": { + "name": "Example Company ABC >=2.9|<=4.1", + "product_id": "CSAFPID-0004" + } + } + ], + "category": "product_name", + "name": "ABC" + } + ], + "category": "vendor", + "name": "Example Company" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2021-44228", + "notes": [ + { + "category": "description", + "text": "Apache Log4j2 2.0-beta9 through 2.15.0 (excluding security releases 2.12.2, 2.12.3, and 2.3.1) JNDI features used in configuration, log messages, and parameters do not protect against attacker controlled LDAP and other JNDI related endpoints. An attacker who can control log messages or log message parameters can execute arbitrary code loaded from LDAP servers when message lookup substitution is enabled. From log4j 2.15.0, this behavior has been disabled by default. From version 2.16.0 (along with 2.12.2, 2.12.3, and 2.3.1), this functionality has been completely removed. Note that this vulnerability is specific to log4j-core and does not affect log4net, log4cxx, or other Apache Logging Services projects.", + "title": "CVE description" + } + ], + "product_status": { + "known_affected": [ + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004" + ] + }, + "references": [ + { + "category": "external", + "summary": "NVD - CVE-2021-44228", + "url": "https://nvd.nist.gov/vuln/detail/CVE-2021-44228" + } + ], + "remediations": [ + { + "category": "vendor_fix", + "details": "Update to version 4.2 or later.", + "product_ids": [ + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004" + ] + } + ], + "scores": [ + { + "cvss_v3": { + "attackComplexity": "LOW", + "attackVector": "NETWORK", + "availabilityImpact": "HIGH", + "baseScore": 10, + "baseSeverity": "CRITICAL", + "confidentialityImpact": "HIGH", + "integrityImpact": "HIGH", + "privilegesRequired": "NONE", + "scope": "CHANGED", + "userInteraction": "NONE", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H", + "version": "3.1" + }, + "products": [ + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-05-001.json b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-05-001.json new file mode 100644 index 000000000..a500c0fdc --- /dev/null +++ b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-05-001.json @@ -0,0 +1,81 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "notes": [ + { + "category": "summary", + "text": "Example Company VEX document. Unofficial content for demonstration purposes only.", + "title": "Author comment" + } + ], + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "title": "Example VEX Document Use Case 5", + "tracking": { + "current_release_date": "2022-03-03T11:00:00.000Z", + "generator": { + "date": "2022-03-03T11:00:00.000Z", + "engine": { + "name": "Secvisogram", + "version": "1.11.0" + } + }, + "id": "2022-EVD-UC-05-001", + "initial_release_date": "2022-03-03T11:00:00.000Z", + "revision_history": [ + { + "date": "2022-03-03T11:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "branches": [ + { + "category": "product_version_range", + "name": "vers:all/*", + "product": { + "name": "Example Company XYZ all versions", + "product_id": "CSAFPID-0001" + } + } + ], + "category": "product_name", + "name": "XYZ" + } + ], + "category": "vendor", + "name": "Example Company" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2021-44228", + "notes": [ + { + "category": "description", + "text": "Apache Log4j2 2.0-beta9 through 2.15.0 (excluding security releases 2.12.2, 2.12.3, and 2.3.1) JNDI features used in configuration, log messages, and parameters do not protect against attacker controlled LDAP and other JNDI related endpoints. An attacker who can control log messages or log message parameters can execute arbitrary code loaded from LDAP servers when message lookup substitution is enabled. From log4j 2.15.0, this behavior has been disabled by default. From version 2.16.0 (along with 2.12.2, 2.12.3, and 2.3.1), this functionality has been completely removed. Note that this vulnerability is specific to log4j-core and does not affect log4net, log4cxx, or other Apache Logging Services projects.", + "title": "CVE description" + } + ], + "product_status": { + "under_investigation": [ + "CSAFPID-0001" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-06-001.json b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-06-001.json new file mode 100644 index 000000000..170713827 --- /dev/null +++ b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-06-001.json @@ -0,0 +1,215 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "notes": [ + { + "category": "summary", + "text": "Example Company VEX document. Unofficial content for demonstration purposes only.", + "title": "Author comment" + } + ], + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "title": "Example VEX Document Use Case 6", + "tracking": { + "current_release_date": "2022-03-03T11:00:00.000Z", + "generator": { + "date": "2022-03-03T11:00:00.000Z", + "engine": { + "name": "Secvisogram", + "version": "1.11.0" + } + }, + "id": "2022-EVD-UC-06-001", + "initial_release_date": "2022-03-03T11:00:00.000Z", + "revision_history": [ + { + "date": "2022-03-03T11:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "branches": [ + { + "category": "product_version", + "name": "4.2", + "product": { + "name": "Example Company ABC 4.2", + "product_id": "CSAFPID-0001" + } + }, + { + "category": "product_version", + "name": "2.4", + "product": { + "product_id": "CSAFPID-0002", + "name": "Example Company ABC 2.4" + } + }, + { + "category": "product_version", + "name": "2.6", + "product": { + "product_id": "CSAFPID-0003", + "name": "Example Company ABC 2.6" + } + }, + { + "category": "product_version_range", + "name": "vers:generic/>=2.9|<=4.1", + "product": { + "product_id": "CSAFPID-0004", + "name": "Example Company ABC >=2.9|<=4.1" + } + }, + { + "category": "product_version_range", + "name": "vers:generic/>=1.0|<=2.3", + "product": { + "product_id": "CSAFPID-0005", + "name": "Example Company ABC >=1.0|<=2.3" + } + }, + { + "category": "product_version", + "name": "2.5", + "product": { + "product_id": "CSAFPID-0006", + "name": "Example Company ABC 2.5" + } + }, + { + "category": "product_version_range", + "name": "vers:generic/>=2.7|<=2.8", + "product": { + "product_id": "CSAFPID-0007", + "name": "Example Company ABC >=2.7|<=2.8" + } + } + ], + "category": "product_name", + "name": "ABC" + } + ], + "category": "vendor", + "name": "Example Company" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2021-44228", + "notes": [ + { + "category": "description", + "text": "Apache Log4j2 2.0-beta9 through 2.15.0 (excluding security releases 2.12.2, 2.12.3, and 2.3.1) JNDI features used in configuration, log messages, and parameters do not protect against attacker controlled LDAP and other JNDI related endpoints. An attacker who can control log messages or log message parameters can execute arbitrary code loaded from LDAP servers when message lookup substitution is enabled. From log4j 2.15.0, this behavior has been disabled by default. From version 2.16.0 (along with 2.12.2, 2.12.3, and 2.3.1), this functionality has been completely removed. Note that this vulnerability is specific to log4j-core and does not affect log4net, log4cxx, or other Apache Logging Services projects.", + "title": "CVE description" + } + ], + "product_status": { + "known_affected": [ + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004" + ], + "known_not_affected": [ + "CSAFPID-0001", + "CSAFPID-0005", + "CSAFPID-0006", + "CSAFPID-0007" + ] + }, + "references": [ + { + "category": "external", + "summary": "NVD - CVE-2021-44228", + "url": "https://nvd.nist.gov/vuln/detail/CVE-2021-44228" + } + ], + "remediations": [ + { + "category": "vendor_fix", + "details": "Update to version 4.2 or later.", + "product_ids": [ + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004" + ] + } + ], + "scores": [ + { + "cvss_v3": { + "attackComplexity": "LOW", + "attackVector": "NETWORK", + "availabilityImpact": "HIGH", + "baseScore": 10, + "baseSeverity": "CRITICAL", + "confidentialityImpact": "HIGH", + "integrityImpact": "HIGH", + "privilegesRequired": "NONE", + "scope": "CHANGED", + "userInteraction": "NONE", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H", + "version": "3.1" + }, + "products": [ + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004" + ] + }, + { + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H/MC:N/MI:N/MA:N", + "baseScore": 10, + "baseSeverity": "CRITICAL", + "attackVector": "NETWORK", + "attackComplexity": "LOW", + "privilegesRequired": "NONE", + "userInteraction": "NONE", + "scope": "CHANGED", + "confidentialityImpact": "HIGH", + "integrityImpact": "HIGH", + "availabilityImpact": "HIGH", + "modifiedConfidentialityImpact": "NONE", + "modifiedIntegrityImpact": "NONE", + "modifiedAvailabilityImpact": "NONE" + }, + "products": [ + "CSAFPID-0001", + "CSAFPID-0005", + "CSAFPID-0006", + "CSAFPID-0007" + ] + } + ], + "threats": [ + { + "category": "impact", + "details": "Class with vulnerable code was removed before shipping.", + "product_ids": [ + "CSAFPID-0001", + "CSAFPID-0005", + "CSAFPID-0006", + "CSAFPID-0007" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-07-001.json b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-07-001.json new file mode 100644 index 000000000..d2c25b994 --- /dev/null +++ b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-07-001.json @@ -0,0 +1,266 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "notes": [ + { + "category": "summary", + "text": "Example Company VEX document. Unofficial content for demonstration purposes only.", + "title": "Author comment" + } + ], + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "title": "Example VEX Document Use Case 7", + "tracking": { + "current_release_date": "2022-03-03T11:00:00.000Z", + "generator": { + "date": "2022-03-03T11:00:00.000Z", + "engine": { + "name": "Secvisogram", + "version": "1.11.0" + } + }, + "id": "2022-EVD-UC-07-001", + "initial_release_date": "2022-03-03T11:00:00.000Z", + "revision_history": [ + { + "date": "2022-03-03T11:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "branches": [ + { + "category": "product_version", + "name": "4.2", + "product": { + "name": "Example Company ABC 4.2", + "product_id": "CSAFPID-0001" + } + }, + { + "category": "product_version", + "name": "2.4", + "product": { + "product_id": "CSAFPID-0002", + "name": "Example Company ABC 2.4" + } + }, + { + "category": "product_version", + "name": "2.6", + "product": { + "product_id": "CSAFPID-0003", + "name": "Example Company ABC 2.6" + } + }, + { + "category": "product_version_range", + "name": "vers:generic/>=2.9|<=4.1", + "product": { + "product_id": "CSAFPID-0004", + "name": "Example Company ABC >=2.9|<=4.1" + } + }, + { + "category": "product_version_range", + "name": "vers:generic/>=1.0|<=2.3", + "product": { + "product_id": "CSAFPID-0005", + "name": "Example Company ABC >=1.0|<=2.3" + } + }, + { + "category": "product_version", + "name": "2.5", + "product": { + "product_id": "CSAFPID-0006", + "name": "Example Company ABC 2.5" + } + }, + { + "category": "product_version_range", + "name": "vers:generic/>=2.7|<=2.8", + "product": { + "product_id": "CSAFPID-0007", + "name": "Example Company ABC >=2.7|<=2.8" + } + } + ], + "category": "product_name", + "name": "ABC" + }, + { + "branches": [ + { + "category": "product_version_range", + "name": "vers:generic/>=4.5|<=5.0", + "product": { + "name": "Example Company JKL >=4.5|<=5.0", + "product_id": "CSAFPID-0008" + } + }, + { + "category": "product_version_range", + "name": "vers:generic/>=1.0|<=4.4", + "product": { + "name": "Example Company JKL >=1.0|<=4.4", + "product_id": "CSAFPID-0009" + } + }, + { + "category": "product_version", + "name": "5.1", + "product": { + "product_id": "CSAFPID-0010", + "name": "Example Company JKL 5.1" + } + } + ], + "category": "product_name", + "name": "JKL" + } + ], + "category": "vendor", + "name": "Example Company" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2021-44228", + "notes": [ + { + "category": "description", + "text": "Apache Log4j2 2.0-beta9 through 2.15.0 (excluding security releases 2.12.2, 2.12.3, and 2.3.1) JNDI features used in configuration, log messages, and parameters do not protect against attacker controlled LDAP and other JNDI related endpoints. An attacker who can control log messages or log message parameters can execute arbitrary code loaded from LDAP servers when message lookup substitution is enabled. From log4j 2.15.0, this behavior has been disabled by default. From version 2.16.0 (along with 2.12.2, 2.12.3, and 2.3.1), this functionality has been completely removed. Note that this vulnerability is specific to log4j-core and does not affect log4net, log4cxx, or other Apache Logging Services projects.", + "title": "CVE description" + } + ], + "product_status": { + "fixed": [ + "CSAFPID-0010" + ], + "known_affected": [ + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004", + "CSAFPID-0008" + ], + "known_not_affected": [ + "CSAFPID-0001", + "CSAFPID-0005", + "CSAFPID-0006", + "CSAFPID-0007", + "CSAFPID-0009" + ] + }, + "references": [ + { + "category": "external", + "summary": "NVD - CVE-2021-44228", + "url": "https://nvd.nist.gov/vuln/detail/CVE-2021-44228" + } + ], + "remediations": [ + { + "category": "vendor_fix", + "details": "Update to version 4.2 or later.", + "product_ids": [ + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004" + ] + }, + { + "category": "vendor_fix", + "details": "Update to the new version 5.1 or later.", + "product_ids": [ + "CSAFPID-0008" + ] + } + ], + "scores": [ + { + "cvss_v3": { + "attackComplexity": "LOW", + "attackVector": "NETWORK", + "availabilityImpact": "HIGH", + "baseScore": 10, + "baseSeverity": "CRITICAL", + "confidentialityImpact": "HIGH", + "integrityImpact": "HIGH", + "privilegesRequired": "NONE", + "scope": "CHANGED", + "userInteraction": "NONE", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H", + "version": "3.1" + }, + "products": [ + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004", + "CSAFPID-0008" + ] + }, + { + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H/MC:N/MI:N/MA:N", + "baseScore": 10, + "baseSeverity": "CRITICAL", + "attackVector": "NETWORK", + "attackComplexity": "LOW", + "privilegesRequired": "NONE", + "userInteraction": "NONE", + "scope": "CHANGED", + "confidentialityImpact": "HIGH", + "integrityImpact": "HIGH", + "availabilityImpact": "HIGH", + "modifiedConfidentialityImpact": "NONE", + "modifiedIntegrityImpact": "NONE", + "modifiedAvailabilityImpact": "NONE" + }, + "products": [ + "CSAFPID-0001", + "CSAFPID-0005", + "CSAFPID-0006", + "CSAFPID-0007", + "CSAFPID-0009" + ] + } + ], + "threats": [ + { + "category": "impact", + "details": "Class with vulnerable code was removed before shipping.", + "product_ids": [ + "CSAFPID-0001", + "CSAFPID-0005", + "CSAFPID-0006", + "CSAFPID-0007" + ] + }, + { + "category": "impact", + "details": "Log4j was not included in those versions at all.", + "product_ids": [ + "CSAFPID-0009" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-08-001.json b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-08-001.json new file mode 100644 index 000000000..bb1c1547e --- /dev/null +++ b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-08-001.json @@ -0,0 +1,402 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "notes": [ + { + "category": "summary", + "text": "Example Company VEX document. Unofficial content for demonstration purposes only.", + "title": "Author comment" + } + ], + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "title": "Example VEX Document Use Case 8", + "tracking": { + "current_release_date": "2022-03-03T11:00:00.000Z", + "generator": { + "date": "2022-03-03T11:00:00.000Z", + "engine": { + "name": "Secvisogram", + "version": "1.11.0" + } + }, + "id": "2022-EVD-UC-08-001", + "initial_release_date": "2022-03-03T11:00:00.000Z", + "revision_history": [ + { + "date": "2022-03-03T11:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "branches": [ + { + "category": "product_version", + "name": "4.2", + "product": { + "name": "Example Company ABC 4.2", + "product_id": "CSAFPID-0001" + } + }, + { + "category": "product_version", + "name": "2.4", + "product": { + "product_id": "CSAFPID-0002", + "name": "Example Company ABC 2.4" + } + }, + { + "category": "product_version", + "name": "2.6", + "product": { + "product_id": "CSAFPID-0003", + "name": "Example Company ABC 2.6" + } + }, + { + "category": "product_version_range", + "name": "vers:generic/>=2.9|<=4.1", + "product": { + "product_id": "CSAFPID-0004", + "name": "Example Company ABC >=2.9|<=4.1" + } + }, + { + "category": "product_version_range", + "name": "vers:generic/>=1.0|<=2.3", + "product": { + "product_id": "CSAFPID-0005", + "name": "Example Company ABC >=1.0|<=2.3" + } + }, + { + "category": "product_version", + "name": "2.5", + "product": { + "product_id": "CSAFPID-0006", + "name": "Example Company ABC 2.5" + } + }, + { + "category": "product_version_range", + "name": "vers:generic/>=2.7|<=2.8", + "product": { + "product_id": "CSAFPID-0007", + "name": "Example Company ABC >=2.7|<=2.8" + } + } + ], + "category": "product_name", + "name": "ABC" + }, + { + "branches": [ + { + "category": "product_version_range", + "name": "vers:generic/>=4.5|<=5.0", + "product": { + "name": "Example Company JKL >=4.5|<=5.0", + "product_id": "CSAFPID-0008" + } + }, + { + "category": "product_version_range", + "name": "vers:generic/>=1.0|<=4.4", + "product": { + "name": "Example Company JKL >=1.0|<=4.4", + "product_id": "CSAFPID-0009" + } + }, + { + "category": "product_version", + "name": "5.1", + "product": { + "product_id": "CSAFPID-0010", + "name": "Example Company JKL 5.1" + } + }, + { + "category": "product_version", + "name": "5.2", + "product": { + "product_id": "CSAFPID-0011", + "name": "Example Company JKL 5.2" + } + } + ], + "category": "product_name", + "name": "JKL" + } + ], + "category": "vendor", + "name": "Example Company" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2021-44228", + "notes": [ + { + "category": "description", + "text": "Apache Log4j2 2.0-beta9 through 2.15.0 (excluding security releases 2.12.2, 2.12.3, and 2.3.1) JNDI features used in configuration, log messages, and parameters do not protect against attacker controlled LDAP and other JNDI related endpoints. An attacker who can control log messages or log message parameters can execute arbitrary code loaded from LDAP servers when message lookup substitution is enabled. From log4j 2.15.0, this behavior has been disabled by default. From version 2.16.0 (along with 2.12.2, 2.12.3, and 2.3.1), this functionality has been completely removed. Note that this vulnerability is specific to log4j-core and does not affect log4net, log4cxx, or other Apache Logging Services projects.", + "title": "CVE description" + } + ], + "product_status": { + "fixed": [ + "CSAFPID-0010", + "CSAFPID-0011" + ], + "known_affected": [ + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004", + "CSAFPID-0008" + ], + "known_not_affected": [ + "CSAFPID-0001", + "CSAFPID-0005", + "CSAFPID-0006", + "CSAFPID-0007", + "CSAFPID-0009" + ], + "recommended": [ + "CSAFPID-0011" + ] + }, + "references": [ + { + "category": "external", + "summary": "NVD - CVE-2021-44228", + "url": "https://nvd.nist.gov/vuln/detail/CVE-2021-44228" + } + ], + "remediations": [ + { + "category": "vendor_fix", + "details": "Update to version 4.2 or later.", + "product_ids": [ + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004" + ] + }, + { + "category": "vendor_fix", + "details": "Update to the new version 5.2 or later.", + "product_ids": [ + "CSAFPID-0008" + ] + } + ], + "scores": [ + { + "cvss_v3": { + "attackComplexity": "LOW", + "attackVector": "NETWORK", + "availabilityImpact": "HIGH", + "baseScore": 10, + "baseSeverity": "CRITICAL", + "confidentialityImpact": "HIGH", + "integrityImpact": "HIGH", + "privilegesRequired": "NONE", + "scope": "CHANGED", + "userInteraction": "NONE", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H", + "version": "3.1" + }, + "products": [ + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004", + "CSAFPID-0008" + ] + }, + { + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H/MC:N/MI:N/MA:N", + "baseScore": 10, + "baseSeverity": "CRITICAL", + "attackVector": "NETWORK", + "attackComplexity": "LOW", + "privilegesRequired": "NONE", + "userInteraction": "NONE", + "scope": "CHANGED", + "confidentialityImpact": "HIGH", + "integrityImpact": "HIGH", + "availabilityImpact": "HIGH", + "modifiedConfidentialityImpact": "NONE", + "modifiedIntegrityImpact": "NONE", + "modifiedAvailabilityImpact": "NONE" + }, + "products": [ + "CSAFPID-0001", + "CSAFPID-0005", + "CSAFPID-0006", + "CSAFPID-0007", + "CSAFPID-0009" + ] + } + ], + "threats": [ + { + "category": "impact", + "details": "Class with vulnerable code was removed before shipping.", + "product_ids": [ + "CSAFPID-0001", + "CSAFPID-0005", + "CSAFPID-0006", + "CSAFPID-0007" + ] + }, + { + "category": "impact", + "details": "Log4j was not included in those versions at all.", + "product_ids": [ + "CSAFPID-0009" + ] + } + ] + }, + { + "cve": "CVE-2021-45105", + "notes": [ + { + "category": "description", + "text": "Apache Log4j2 versions 2.0-alpha1 through 2.16.0 (excluding 2.12.3 and 2.3.1) did not protect from uncontrolled recursion from self-referential lookups. This allows an attacker with control over Thread Context Map data to cause a denial of service when a crafted string is interpreted. This issue was fixed in Log4j 2.17.0, 2.12.3, and 2.3.1.", + "title": "CVE description" + } + ], + "product_status": { + "fixed": [ + "CSAFPID-0011" + ], + "known_affected": [ + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004", + "CSAFPID-0010" + ], + "known_not_affected": [ + "CSAFPID-0001", + "CSAFPID-0005", + "CSAFPID-0006", + "CSAFPID-0007", + "CSAFPID-0009" + ] + }, + "references": [ + { + "category": "external", + "summary": "NVD - CVE-2021-45105", + "url": "https://nvd.nist.gov/vuln/detail/CVE-2021-45105" + } + ], + "remediations": [ + { + "category": "vendor_fix", + "details": "Update to version 4.2 or later.", + "product_ids": [ + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004" + ] + }, + { + "category": "vendor_fix", + "details": "Update to the new version 5.2 or later.", + "product_ids": [ + "CSAFPID-0008", + "CSAFPID-0010" + ] + } + ], + "scores": [ + { + "cvss_v3": { + "attackComplexity": "HIGH", + "attackVector": "NETWORK", + "availabilityImpact": "HIGH", + "baseScore": 5.9, + "baseSeverity": "MEDIUM", + "confidentialityImpact": "NONE", + "integrityImpact": "NONE", + "privilegesRequired": "NONE", + "scope": "UNCHANGED", + "userInteraction": "NONE", + "vectorString": "CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:N/I:N/A:H", + "version": "3.1" + }, + "products": [ + "CSAFPID-0002", + "CSAFPID-0003", + "CSAFPID-0004", + "CSAFPID-0008", + "CSAFPID-0010" + ] + }, + { + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:N/I:N/A:H/MC:N/MI:N/MA:N", + "baseScore": 5.9, + "baseSeverity": "MEDIUM", + "attackVector": "NETWORK", + "attackComplexity": "HIGH", + "privilegesRequired": "NONE", + "userInteraction": "NONE", + "scope": "UNCHANGED", + "confidentialityImpact": "NONE", + "integrityImpact": "NONE", + "availabilityImpact": "HIGH", + "modifiedConfidentialityImpact": "NONE", + "modifiedIntegrityImpact": "NONE", + "modifiedAvailabilityImpact": "NONE" + }, + "products": [ + "CSAFPID-0001", + "CSAFPID-0005", + "CSAFPID-0006", + "CSAFPID-0007", + "CSAFPID-0009" + ] + } + ], + "threats": [ + { + "category": "impact", + "details": "Class with vulnerable code was removed before shipping.", + "product_ids": [ + "CSAFPID-0001", + "CSAFPID-0005", + "CSAFPID-0006", + "CSAFPID-0007" + ] + }, + { + "category": "impact", + "details": "Log4j was not included in those versions at all.", + "product_ids": [ + "CSAFPID-0009" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-09-001.json b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-09-001.json new file mode 100644 index 000000000..fccce0bc2 --- /dev/null +++ b/csaf_2.1/examples/csaf/csaf_vex/2022-evd-uc-09-001.json @@ -0,0 +1,240 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "notes": [ + { + "category": "summary", + "text": "Example Company VEX document. Unofficial content for demonstration purposes only.", + "title": "Author comment" + } + ], + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "title": "Example VEX Document Use Case 9", + "tracking": { + "current_release_date": "2022-03-03T11:00:00.000Z", + "generator": { + "date": "2022-03-03T11:00:00.000Z", + "engine": { + "name": "Secvisogram", + "version": "1.11.0" + } + }, + "id": "2022-EVD-UC-09-001", + "initial_release_date": "2022-03-03T11:00:00.000Z", + "revision_history": [ + { + "date": "2022-03-03T11:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "category": "product_family", + "name": "PROD_ALPHA", + "product": { + "name": "Example Company PROD_ALPHA", + "product_id": "CSAFPID-0001" + } + }, + { + "category": "product_family", + "name": "PROD_BETA", + "product": { + "name": "Example Company PROD_BETA", + "product_id": "CSAFPID-0002" + } + } + ], + "category": "vendor", + "name": "Example Company" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2021-44228", + "notes": [ + { + "category": "description", + "text": "Apache Log4j2 2.0-beta9 through 2.15.0 (excluding security releases 2.12.2, 2.12.3, and 2.3.1) JNDI features used in configuration, log messages, and parameters do not protect against attacker controlled LDAP and other JNDI related endpoints. An attacker who can control log messages or log message parameters can execute arbitrary code loaded from LDAP servers when message lookup substitution is enabled. From log4j 2.15.0, this behavior has been disabled by default. From version 2.16.0 (along with 2.12.2, 2.12.3, and 2.3.1), this functionality has been completely removed. Note that this vulnerability is specific to log4j-core and does not affect log4net, log4cxx, or other Apache Logging Services projects.", + "title": "CVE description" + } + ], + "product_status": { + "known_affected": [ + "CSAFPID-0002" + ], + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "references": [ + { + "category": "external", + "summary": "NVD - CVE-2021-44228", + "url": "https://nvd.nist.gov/vuln/detail/CVE-2021-44228" + } + ], + "remediations": [ + { + "category": "none_available", + "details": "Example Company is currently working on a fix which is expected to be ready in 06/2022.", + "product_ids": [ + "CSAFPID-0002" + ] + } + ], + "scores": [ + { + "cvss_v3": { + "attackComplexity": "LOW", + "attackVector": "NETWORK", + "availabilityImpact": "HIGH", + "baseScore": 10, + "baseSeverity": "CRITICAL", + "confidentialityImpact": "HIGH", + "integrityImpact": "HIGH", + "privilegesRequired": "NONE", + "scope": "CHANGED", + "userInteraction": "NONE", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H", + "version": "3.1" + }, + "products": [ + "CSAFPID-0002" + ] + }, + { + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H/MC:N/MI:N/MA:N", + "baseScore": 10, + "baseSeverity": "CRITICAL", + "attackVector": "NETWORK", + "attackComplexity": "LOW", + "privilegesRequired": "NONE", + "userInteraction": "NONE", + "scope": "CHANGED", + "confidentialityImpact": "HIGH", + "integrityImpact": "HIGH", + "availabilityImpact": "HIGH", + "modifiedConfidentialityImpact": "NONE", + "modifiedIntegrityImpact": "NONE", + "modifiedAvailabilityImpact": "NONE" + }, + "products": [ + "CSAFPID-0001" + ] + } + ], + "threats": [ + { + "category": "impact", + "details": "These products do not use Java at all.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2021-45105", + "notes": [ + { + "category": "description", + "text": "Apache Log4j2 versions 2.0-alpha1 through 2.16.0 (excluding 2.12.3 and 2.3.1) did not protect from uncontrolled recursion from self-referential lookups. This allows an attacker with control over Thread Context Map data to cause a denial of service when a crafted string is interpreted. This issue was fixed in Log4j 2.17.0, 2.12.3, and 2.3.1.", + "title": "CVE description" + } + ], + "product_status": { + "known_affected": [ + "CSAFPID-0002" + ], + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "references": [ + { + "category": "external", + "summary": "NVD - CVE-2021-45105", + "url": "https://nvd.nist.gov/vuln/detail/CVE-2021-45105" + } + ], + "remediations": [ + { + "category": "none_available", + "details": "Example Company is currently working on a fix which is expected to be ready in 06/2022.", + "product_ids": [ + "CSAFPID-0002" + ] + } + ], + "scores": [ + { + "cvss_v3": { + "attackComplexity": "HIGH", + "attackVector": "NETWORK", + "availabilityImpact": "HIGH", + "baseScore": 5.9, + "baseSeverity": "MEDIUM", + "confidentialityImpact": "NONE", + "integrityImpact": "NONE", + "privilegesRequired": "NONE", + "scope": "UNCHANGED", + "userInteraction": "NONE", + "vectorString": "CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:N/I:N/A:H", + "version": "3.1" + }, + "products": [ + "CSAFPID-0002" + ] + }, + { + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:N/I:N/A:H/MC:N/MI:N/MA:N", + "baseScore": 5.9, + "baseSeverity": "MEDIUM", + "attackVector": "NETWORK", + "attackComplexity": "HIGH", + "privilegesRequired": "NONE", + "userInteraction": "NONE", + "scope": "UNCHANGED", + "confidentialityImpact": "NONE", + "integrityImpact": "NONE", + "availabilityImpact": "HIGH", + "modifiedConfidentialityImpact": "NONE", + "modifiedIntegrityImpact": "NONE", + "modifiedAvailabilityImpact": "NONE" + }, + "products": [ + "CSAFPID-0001" + ] + } + ], + "threats": [ + { + "category": "impact", + "details": "These products do not use Java at all.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/examples/csaf/csaf_vex/README.md b/csaf_2.1/examples/csaf/csaf_vex/README.md new file mode 100644 index 000000000..4f2f54fa8 --- /dev/null +++ b/csaf_2.1/examples/csaf/csaf_vex/README.md @@ -0,0 +1,24 @@ +# Example CSAF VEX Documents + +The following are several example of CSAF VEX documents. As documented in [the NTIA’s one-page VEX overview document](https://ntia.gov/files/ntia/publications/vex_one-page_summary.pdf), a VEX document can have any of the following “statuses”: + +- Not affected: No remediation is required regarding this vulnerability. +- Affected: Actions are recommended to remediate or address this vulnerability. +- Fixed: Represents that these product versions contain a fix for the vulnerability. +- Under Investigation: It is not yet known whether these product versions are affected by the vulnerability. An update will be provided in a later release. + +The following CSAF documents include examples for each of the supported VEX "statuses": + +- [Use case 1: Disclosing known affected vulnerabilities](https://github.com/oasis-tcs/csaf/blob/master/csaf_2.0/examples/csaf/csaf_vex/2022-evd-uc-01-a-001.json) +- [Use case 1: Disclosing fixed vulnerabilities](https://github.com/oasis-tcs/csaf/blob/master/csaf_2.0/examples/csaf/csaf_vex/2022-evd-uc-01-f-001.json) +- [Use case 1: Confirming not affected](https://github.com/oasis-tcs/csaf/blob/master/csaf_2.0/examples/csaf/csaf_vex/2022-evd-uc-01-na-001.json) +- [Use case 1: Vulnerability under investigation](https://github.com/oasis-tcs/csaf/blob/master/csaf_2.0/examples/csaf/csaf_vex/2022-evd-uc-01-ui-001.json) +- [Use case 2: Confirming not affected](https://github.com/oasis-tcs/csaf/blob/master/csaf_2.0/examples/csaf/csaf_vex/2022-evd-uc-02-na-001.json) +- [Multiple vulnerability statuses](https://github.com/oasis-tcs/csaf/blob/master/csaf_2.0/examples/csaf/csaf_vex/2022-evd-uc-03-ms-001.json) +- [Example VEX Document Use Case 4](https://github.com/oasis-tcs/csaf/blob/master/csaf_2.0/examples/csaf/csaf_vex/2022-evd-uc-04-001.json) +- [Example VEX Document Use Case 5](https://github.com/oasis-tcs/csaf/blob/master/csaf_2.0/examples/csaf/csaf_vex/2022-evd-uc-05-001.json) +- [Example VEX Document Use Case 6](https://github.com/oasis-tcs/csaf/blob/master/csaf_2.0/examples/csaf/csaf_vex/2022-evd-uc-06-001.json) +- [Example VEX Document Use Case 7](https://github.com/oasis-tcs/csaf/blob/master/csaf_2.0/examples/csaf/csaf_vex/2022-evd-uc-07-001.json) +- [Example VEX Document Use Case 8](https://github.com/oasis-tcs/csaf/blob/master/csaf_2.0/examples/csaf/csaf_vex/2022-evd-uc-08-001.json) +- [Example VEX Document Use Case 9](https://github.com/oasis-tcs/csaf/blob/master/csaf_2.0/examples/csaf/csaf_vex/2022-evd-uc-09-001.json) +- [Example VEX Document asserting that Secvisogram is not affected by Log4Shell](https://github.com/oasis-tcs/csaf/blob/master/csaf_2.0/examples/csaf/csaf_vex/sec-vex-2022-0001.json) diff --git a/csaf_2.1/examples/csaf/csaf_vex/sec-vex-2022-0001.json b/csaf_2.1/examples/csaf/csaf_vex/sec-vex-2022-0001.json new file mode 100644 index 000000000..d3da67791 --- /dev/null +++ b/csaf_2.1/examples/csaf/csaf_vex/sec-vex-2022-0001.json @@ -0,0 +1,200 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "distribution": { + "tlp": { + "label": "WHITE", + "url": "https://www.first.org/tlp/" + } + }, + "lang": "en-US", + "notes": [ + { + "category": "summary", + "text": "A VEX document stating that Secvisogram is not affected by Log4Shell.", + "title": "Summary" + } + ], + "publisher": { + "category": "vendor", + "name": "Secvisogram", + "namespace": "https://github.com/secvisogram" + }, + "references": [ + { + "category": "external", + "summary": "Apache Log4j Security Vulnerabilities", + "url": "https://logging.apache.org/log4j/2.x/security.html" + } + ], + "title": "Secvisogram not affected by Log4Shell", + "tracking": { + "current_release_date": "2022-05-27T10:00:00.000Z", + "generator": { + "date": "2022-05-27T10:24:35.760Z", + "engine": { + "name": "Secvisogram", + "version": "1.14.0" + } + }, + "id": "SEC-VEX-2022-0001", + "initial_release_date": "2022-05-27T10:00:00.000Z", + "revision_history": [ + { + "date": "2022-05-27T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "branches": [ + { + "category": "product_version_range", + "name": "<=1.14.0", + "product": { + "name": "Secvisogram <=1.14.0", + "product_id": "CSAFPID-0001" + } + } + ], + "category": "product_name", + "name": "Secvisogram" + } + ], + "category": "vendor", + "name": "Secvisogram" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2021-44228", + "flags": [ + { + "date": "2022-05-27T10:00:00.000Z", + "label": "component_not_present", + "product_ids": [ + "CSAFPID-0001" + ] + } + ], + "notes": [ + { + "category": "description", + "text": "Apache Log4j2 2.0-beta9 through 2.15.0 (excluding security releases 2.12.2, 2.12.3, and 2.3.1) JNDI features used in configuration, log messages, and parameters do not protect against attacker controlled LDAP and other JNDI related endpoints. An attacker who can control log messages or log message parameters can execute arbitrary code loaded from LDAP servers when message lookup substitution is enabled. From log4j 2.15.0, this behavior has been disabled by default. From version 2.16.0 (along with 2.12.2, 2.12.3, and 2.3.1), this functionality has been completely removed. Note that this vulnerability is specific to log4j-core and does not affect log4net, log4cxx, or other Apache Logging Services projects.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "references": [ + { + "category": "external", + "summary": "NVD - CVE-2021-44228", + "url": "https://nvd.nist.gov/vuln/detail/CVE-2021-44228" + } + ], + "threats": [ + { + "category": "impact", + "details": "Secvisogram is written in JavaScript. No Java is included.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2021-45046", + "flags": [ + { + "date": "2022-05-27T10:00:00.000Z", + "label": "component_not_present", + "product_ids": [ + "CSAFPID-0001" + ] + } + ], + "notes": [ + { + "category": "description", + "text": "It was found that the fix to address CVE-2021-44228 in Apache Log4j 2.15.0 was incomplete in certain non-default configurations. This could allows attackers with control over Thread Context Map (MDC) input data when the logging configuration uses a non-default Pattern Layout with either a Context Lookup (for example, $${ctx:loginId}) or a Thread Context Map pattern (%X, %mdc, or %MDC) to craft malicious input data using a JNDI Lookup pattern resulting in an information leak and remote code execution in some environments and local code execution in all environments. Log4j 2.16.0 (Java 8) and 2.12.2 (Java 7) fix this issue by removing support for message lookup patterns and disabling JNDI functionality by default.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "references": [ + { + "category": "external", + "summary": "NVD - CVE-2021-45046", + "url": "https://nvd.nist.gov/vuln/detail/CVE-2021-45046" + } + ], + "threats": [ + { + "category": "impact", + "details": "Secvisogram is written in JavaScript. No Java is included.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + }, + { + "cve": "CVE-2021-45105", + "flags": [ + { + "date": "2022-05-27T10:00:00.000Z", + "label": "component_not_present", + "product_ids": [ + "CSAFPID-0001" + ] + } + ], + "notes": [ + { + "category": "description", + "text": "Apache Log4j2 versions 2.0-alpha1 through 2.16.0 (excluding 2.12.3 and 2.3.1) did not protect from uncontrolled recursion from self-referential lookups. This allows an attacker with control over Thread Context Map data to cause a denial of service when a crafted string is interpreted. This issue was fixed in Log4j 2.17.0, 2.12.3, and 2.3.1.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-0001" + ] + }, + "references": [ + { + "category": "external", + "summary": "NVD - CVE-2021-45105", + "url": "https://nvd.nist.gov/vuln/detail/CVE-2021-45105" + } + ], + "threats": [ + { + "category": "impact", + "details": "Secvisogram is written in JavaScript. No Java is included.", + "product_ids": [ + "CSAFPID-0001" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/examples/csaf/rhsa-2019_1862.json b/csaf_2.1/examples/csaf/rhsa-2019_1862.json new file mode 100644 index 000000000..134535abb --- /dev/null +++ b/csaf_2.1/examples/csaf/rhsa-2019_1862.json @@ -0,0 +1,103 @@ +{ + "document": { + "aggregate_severity": { + "namespace": "https://access.redhat.com/security/updates/classification/", + "text": "Low" + }, + "category": "csaf_informational_advisory", + "csaf_version": "2.0", + "distribution": { + "text": "Copyright \u00a9 2022 Red Hat, Inc. All rights reserved.", + "tlp": { + "label": "WHITE", + "url": "https://www.first.org/tlp/" + } + }, + "lang": "en", + "notes": [ + { + "category": "summary", + "text": "This is the one-month notification for the end of the maintenance phase for Red Hat OpenShift Enterprise 3.6 and 3.7. This notification applies only to customers with subscriptions for Red Hat OpenShift Enterprise 3.6 and 3.7.", + "title": "Topic" + }, + { + "category": "general", + "text": "As part of the maintenance phase, qualified security patches of Critical or Important impact, as well as select mission-critical bug-fix patches, were released for Red Hat OpenShift Enterprise 3.6 and 3.7.\n\nAfter July 31st, 2019, customers will not receive those updates.\n\nRed Hat OpenShift Container Platform Life Cycle Policy can be found under:\n\nhttps://access.redhat.com/support/policy/updates/openshift", + "title": "Details" + }, + { + "category": "legal_disclaimer", + "text": "This content is licensed under the Creative Commons Attribution 4.0 International License (https://creativecommons.org/licenses/by/4.0/). If you distribute this content, or a modified version of it, you must provide attribution to Red Hat Inc. and provide a link to the original.", + "title": "Terms of Use" + } + ], + "publisher": { + "category": "vendor", + "contact_details": "https://access.redhat.com/security/team/contact/", + "name": "Red Hat Product Security", + "namespace": "https://www.redhat.com" + }, + "references": [ + { + "category": "self", + "summary": "https://access.redhat.com/errata/RHSA-2019:1862", + "url": "https://access.redhat.com/errata/RHSA-2019:1862" + }, + { + "category": "external", + "summary": "https://access.redhat.com/security/updates/classification/#low", + "url": "https://access.redhat.com/security/updates/classification/#low" + }, + { + "category": "external", + "summary": "https://access.redhat.com/articles/3532971", + "url": "https://access.redhat.com/articles/3532971" + }, + { + "category": "self", + "summary": "Canonical URL", + "url": "https://access.redhat.com/security/data/csaf/beta/2019/rhsa-2019_1862.json" + } + ], + "title": "Red Hat Security Advisory: Red Hat OpenShift Enterprise one-month end-of-life notice", + "tracking": { + "current_release_date": "2019-07-26T06:38:00Z", + "generator": { + "date": "2022-05-17T17:18:00Z", + "engine": { + "name": "Red Hat SDEngine", + "version": "3.5.0" + } + }, + "id": "RHSA-2019:1862", + "initial_release_date": "2019-07-26T06:38:00Z", + "revision_history": [ + { + "date": "2019-07-26T06:38:00Z", + "number": "1", + "summary": "Current version" + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "category": "product_family", + "name": "Red Hat OpenShift Enterprise", + "product": { + "name": "Red Hat OpenShift Enterprise", + "product_id": "Red Hat OpenShift Enterprise" + } + } + ], + "category": "vendor", + "name": "Red Hat" + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/examples/csaf/rhsa-2021_5186.json b/csaf_2.1/examples/csaf/rhsa-2021_5186.json new file mode 100644 index 000000000..236ce78bf --- /dev/null +++ b/csaf_2.1/examples/csaf/rhsa-2021_5186.json @@ -0,0 +1,319 @@ +{ + "document": { + "aggregate_severity": { + "namespace": "https://access.redhat.com/security/updates/classification/", + "text": "Critical" + }, + "category": "csaf_security_advisory", + "csaf_version": "2.0", + "distribution": { + "text": "Copyright \u00a9 2022 Red Hat, Inc. All rights reserved.", + "tlp": { + "label": "WHITE", + "url": "https://www.first.org/tlp/" + } + }, + "lang": "en", + "notes": [ + { + "category": "summary", + "text": "Red Hat OpenShift Container Platform release 4.6.52 is now available with\nupdates to packages and images that fix several bugs and add enhancements.\n\nRed Hat Product Security has rated this update as having a security impact of Critical. A Common Vulnerability Scoring System (CVSS) base score, which gives a detailed severity rating, is available for each vulnerability from the CVE link(s) in the References section.", + "title": "Topic" + }, + { + "category": "general", + "text": "Red Hat OpenShift Container Platform is Red Hat's cloud computing\nKubernetes application platform solution designed for on-premise or private\ncloud deployments.\n\nSecurity Fix(es):\n\n* kube-reporting/hive: Incomplete fix for log4j CVE-2021-44228 and CVE-2021-45046 (CVE-2021-4125)\n\n* log4j: Remote code execution in Log4j 1.x when application is configured to use JMSAppender (CVE-2021-4104)\n\nFor more details about the security issue(s), including the impact, a CVSS score, acknowledgments, and other related information, refer to the CVE page(s) listed in the References section.", + "title": "Details" + }, + { + "category": "legal_disclaimer", + "text": "This content is licensed under the Creative Commons Attribution 4.0 International License (https://creativecommons.org/licenses/by/4.0/). If you distribute this content, or a modified version of it, you must provide attribution to Red Hat Inc. and provide a link to the original.", + "title": "Terms of Use" + } + ], + "publisher": { + "category": "vendor", + "contact_details": "https://access.redhat.com/security/team/contact/", + "name": "Red Hat Product Security", + "namespace": "https://www.redhat.com" + }, + "references": [ + { + "category": "self", + "summary": "https://access.redhat.com/errata/RHSA-2021:5186", + "url": "https://access.redhat.com/errata/RHSA-2021:5186" + }, + { + "category": "external", + "summary": "https://access.redhat.com/security/updates/classification/#critical", + "url": "https://access.redhat.com/security/updates/classification/#critical" + }, + { + "category": "external", + "summary": "https://access.redhat.com/security/vulnerabilities/RHSB-2021-009", + "url": "https://access.redhat.com/security/vulnerabilities/RHSB-2021-009" + }, + { + "category": "self", + "summary": "Canonical URL", + "url": "https://access.redhat.com/security/data/csaf/beta/2021/rhsa-2021_5186.json" + } + ], + "title": "Red Hat Security Advisory: OpenShift Container Platform 4.6.52 security update", + "tracking": { + "current_release_date": "2021-12-16T22:34:00Z", + "generator": { + "date": "2022-03-23T20:31:00Z", + "engine": { + "name": "Red Hat SDEngine", + "version": "3.4.3" + } + }, + "id": "RHSA-2021:5186", + "initial_release_date": "2021-12-16T22:34:00Z", + "revision_history": [ + { + "date": "2021-12-16T22:34:00Z", + "number": "1", + "summary": "Current version" + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "branches": [ + { + "category": "product_name", + "name": "Red Hat OpenShift Container Platform 4.6", + "product": { + "name": "Red Hat OpenShift Container Platform 4.6", + "product_id": "8Base-RHOSE-4.6", + "product_identification_helper": { + "cpe": "cpe:/a:redhat:openshift:4.6::el8" + } + } + } + ], + "category": "product_family", + "name": "Red Hat OpenShift Enterprise" + }, + { + "category": "product_version", + "name": "openshift4/ose-metering-ansible-operator-bundle:v4.6.0.202112161349.p0.gd74112d.assembly.art3595-1", + "product": { + "name": "openshift4/ose-metering-ansible-operator-bundle:v4.6.0.202112161349.p0.gd74112d.assembly.art3595-1", + "product_id": "openshift4/ose-metering-ansible-operator-bundle:v4.6.0.202112161349.p0.gd74112d.assembly.art3595-1" + } + }, + { + "category": "product_version", + "name": "openshift4/ose-metering-ansible-operator:v4.6.0-202112161349.p0.gd74112d.assembly.art3595", + "product": { + "name": "openshift4/ose-metering-ansible-operator:v4.6.0-202112161349.p0.gd74112d.assembly.art3595", + "product_id": "openshift4/ose-metering-ansible-operator:v4.6.0-202112161349.p0.gd74112d.assembly.art3595" + } + }, + { + "category": "product_version", + "name": "openshift4/ose-metering-hive:v4.6.0-202112160147.p0.gf139e12.assembly.stream", + "product": { + "name": "openshift4/ose-metering-hive:v4.6.0-202112160147.p0.gf139e12.assembly.stream", + "product_id": "openshift4/ose-metering-hive:v4.6.0-202112160147.p0.gf139e12.assembly.stream" + } + } + ], + "category": "vendor", + "name": "Red Hat" + } + ], + "relationships": [ + { + "category": "default_component_of", + "full_product_name": { + "name": "openshift4/ose-metering-ansible-operator-bundle:v4.6.0.202112161349.p0.gd74112d.assembly.art3595-1 as a component of Red Hat OpenShift Container Platform 4.6", + "product_id": "8Base-RHOSE-4.6:openshift4/ose-metering-ansible-operator-bundle:v4.6.0.202112161349.p0.gd74112d.assembly.art3595-1" + }, + "product_reference": "openshift4/ose-metering-ansible-operator-bundle:v4.6.0.202112161349.p0.gd74112d.assembly.art3595-1", + "relates_to_product_reference": "8Base-RHOSE-4.6" + }, + { + "category": "default_component_of", + "full_product_name": { + "name": "openshift4/ose-metering-ansible-operator:v4.6.0-202112161349.p0.gd74112d.assembly.art3595 as a component of Red Hat OpenShift Container Platform 4.6", + "product_id": "8Base-RHOSE-4.6:openshift4/ose-metering-ansible-operator:v4.6.0-202112161349.p0.gd74112d.assembly.art3595" + }, + "product_reference": "openshift4/ose-metering-ansible-operator:v4.6.0-202112161349.p0.gd74112d.assembly.art3595", + "relates_to_product_reference": "8Base-RHOSE-4.6" + }, + { + "category": "default_component_of", + "full_product_name": { + "name": "openshift4/ose-metering-hive:v4.6.0-202112160147.p0.gf139e12.assembly.stream as a component of Red Hat OpenShift Container Platform 4.6", + "product_id": "8Base-RHOSE-4.6:openshift4/ose-metering-hive:v4.6.0-202112160147.p0.gf139e12.assembly.stream" + }, + "product_reference": "openshift4/ose-metering-hive:v4.6.0-202112160147.p0.gf139e12.assembly.stream", + "relates_to_product_reference": "8Base-RHOSE-4.6" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2021-4104", + "cwe": { + "id": "CWE-20", + "name": "Improper Input Validation" + }, + "discovery_date": "2021-12-13T00:00:00Z", + "ids": [ + { + "system_name": "Red Hat Bugzilla", + "text": "https://bugzilla.redhat.com/show_bug.cgi?id=2031667" + } + ], + "notes": [ + { + "category": "general", + "text": "log4j: Remote code execution in Log4j 1.x when application is configured to use JMSAppender", + "title": "Vulnerability Description" + } + ], + "product_status": { + "fixed": [ + "8Base-RHOSE-4.6:openshift4/ose-metering-hive:v4.6.0-202112160147.p0.gf139e12.assembly.stream" + ], + "known_not_affected": [ + "8Base-RHOSE-4.6:openshift4/ose-metering-ansible-operator-bundle:v4.6.0.202112161349.p0.gd74112d.assembly.art3595-1", + "8Base-RHOSE-4.6:openshift4/ose-metering-ansible-operator:v4.6.0-202112161349.p0.gd74112d.assembly.art3595" + ] + }, + "references": [ + { + "category": "external", + "summary": "https://github.com/apache/logging-log4j2/pull/608#issuecomment-990494126", + "url": "https://github.com/apache/logging-log4j2/pull/608#issuecomment-990494126" + }, + { + "category": "external", + "summary": "https://github.com/apache/logging-log4j2/pull/608#issuecomment-991723301", + "url": "https://github.com/apache/logging-log4j2/pull/608#issuecomment-991723301" + }, + { + "category": "external", + "summary": "https://lists.apache.org/thread/0x4zvtq92yggdgvwfgsftqrj4xx5w0nx", + "url": "https://lists.apache.org/thread/0x4zvtq92yggdgvwfgsftqrj4xx5w0nx" + }, + { + "category": "external", + "summary": "https://www.openwall.com/lists/oss-security/2021/12/13/1", + "url": "https://www.openwall.com/lists/oss-security/2021/12/13/1" + }, + { + "category": "external", + "summary": "CVE-2021-4104", + "url": "https://access.redhat.com/security/cve/CVE-2021-4104" + }, + { + "category": "external", + "summary": "bz#2031667: CVE-2021-4104 log4j: Remote code execution in Log4j 1.x when application is configured to use JMSAppender", + "url": "https://bugzilla.redhat.com/show_bug.cgi?id=2031667" + } + ], + "release_date": "2021-12-10T00:00:00Z", + "remediations": [ + { + "category": "vendor_fix", + "details": "For OpenShift Container Platform 4.6 see the following documentation, which\nwill be updated shortly for this release, for important instructions on how\nto upgrade your cluster and fully apply this asynchronous errata update:\n\nhttps://docs.openshift.com/container-platform/4.6/release_notes/ocp-4-6-release-notes.html\n\nDetails on how to access this content are available at\nhttps://docs.openshift.com/container-platform/4.6/updating/updating-cluster-cli.html", + "product_ids": [ + "8Base-RHOSE-4.6:openshift4/ose-metering-hive:v4.6.0-202112160147.p0.gf139e12.assembly.stream", + "8Base-RHOSE-4.6:openshift4/ose-metering-ansible-operator-bundle:v4.6.0.202112161349.p0.gd74112d.assembly.art3595-1", + "8Base-RHOSE-4.6:openshift4/ose-metering-ansible-operator:v4.6.0-202112161349.p0.gd74112d.assembly.art3595" + ], + "url": "https://access.redhat.com/errata/RHSA-2021:5186" + } + ], + "threats": [ + { + "category": "impact", + "date": "2021-12-13T00:00:00Z", + "details": "Moderate" + } + ], + "title": "CVE-2021-4104 log4j: Remote code execution in Log4j 1.x when application is configured to use JMSAppender" + }, + { + "cve": "CVE-2021-4125", + "discovery_date": "2021-12-16T00:00:00Z", + "ids": [ + { + "system_name": "Red Hat Bugzilla", + "text": "https://bugzilla.redhat.com/show_bug.cgi?id=2033121" + } + ], + "notes": [ + { + "category": "general", + "text": "kube-reporting/hive: Incomplete fix for log4j CVE-2021-44228 and CVE-2021-45046", + "title": "Vulnerability Description" + } + ], + "product_status": { + "fixed": [ + "8Base-RHOSE-4.6:openshift4/ose-metering-hive:v4.6.0-202112160147.p0.gf139e12.assembly.stream" + ], + "known_not_affected": [ + "8Base-RHOSE-4.6:openshift4/ose-metering-ansible-operator-bundle:v4.6.0.202112161349.p0.gd74112d.assembly.art3595-1", + "8Base-RHOSE-4.6:openshift4/ose-metering-ansible-operator:v4.6.0-202112161349.p0.gd74112d.assembly.art3595" + ] + }, + "references": [ + { + "category": "external", + "summary": "https://access.redhat.com/security/cve/CVE-2021-44228", + "url": "https://access.redhat.com/security/cve/CVE-2021-44228" + }, + { + "category": "external", + "summary": "https://access.redhat.com/security/cve/CVE-2021-45046", + "url": "https://access.redhat.com/security/cve/CVE-2021-45046" + }, + { + "category": "external", + "summary": "CVE-2021-4125", + "url": "https://access.redhat.com/security/cve/CVE-2021-4125" + }, + { + "category": "external", + "summary": "bz#2033121: CVE-2021-4125 kube-reporting/hive: Incomplete fix for log4j CVE-2021-44228 and CVE-2021-45046", + "url": "https://bugzilla.redhat.com/show_bug.cgi?id=2033121" + } + ], + "release_date": "2021-12-16T00:00:00Z", + "remediations": [ + { + "category": "vendor_fix", + "details": "For OpenShift Container Platform 4.6 see the following documentation, which\nwill be updated shortly for this release, for important instructions on how\nto upgrade your cluster and fully apply this asynchronous errata update:\n\nhttps://docs.openshift.com/container-platform/4.6/release_notes/ocp-4-6-release-notes.html\n\nDetails on how to access this content are available at\nhttps://docs.openshift.com/container-platform/4.6/updating/updating-cluster-cli.html", + "product_ids": [ + "8Base-RHOSE-4.6:openshift4/ose-metering-hive:v4.6.0-202112160147.p0.gf139e12.assembly.stream", + "8Base-RHOSE-4.6:openshift4/ose-metering-ansible-operator-bundle:v4.6.0.202112161349.p0.gd74112d.assembly.art3595-1", + "8Base-RHOSE-4.6:openshift4/ose-metering-ansible-operator:v4.6.0-202112161349.p0.gd74112d.assembly.art3595" + ], + "url": "https://access.redhat.com/errata/RHSA-2021:5186" + } + ], + "threats": [ + { + "category": "impact", + "date": "2021-12-16T00:00:00Z", + "details": "Critical" + } + ], + "title": "CVE-2021-4125 kube-reporting/hive: Incomplete fix for log4j CVE-2021-44228 and CVE-2021-45046" + } + ] +} diff --git a/csaf_2.1/examples/csaf/rhsa-2021_5217.json b/csaf_2.1/examples/csaf/rhsa-2021_5217.json new file mode 100644 index 000000000..592fa2981 --- /dev/null +++ b/csaf_2.1/examples/csaf/rhsa-2021_5217.json @@ -0,0 +1,185 @@ +{ + "document": { + "aggregate_severity": { + "namespace": "https://access.redhat.com/security/updates/classification/", + "text": "Important" + }, + "category": "csaf_security_advisory", + "csaf_version": "2.0", + "distribution": { + "text": "Copyright \u00a9 2022 Red Hat, Inc. All rights reserved.", + "tlp": { + "label": "WHITE", + "url": "https://www.first.org/tlp/" + } + }, + "lang": "en", + "notes": [ + { + "category": "summary", + "text": "A security update is now available for Red Hat Single Sign-On 7.5 from the Customer Portal.\n\nRed Hat Product Security has rated this update as having a security impact of Important. A Common Vulnerability Scoring System (CVSS) base score, which gives a detailed severity rating, is available for each vulnerability from the CVE link(s) in the References section.", + "title": "Topic" + }, + { + "category": "general", + "text": "Red Hat Single Sign-On 7.5 is a standalone server, based on the Keycloak project, that provides authentication and standards-based single sign-on capabilities for web and mobile applications.\n\nThis is an asynchronous patch for Red Hat Single Sign-On 7.5, and includes one security fix.\n\nSecurity Fix:\n\n* keycloak: Incorrect authorization allows unpriviledged users to create other users (CVE-2021-4133)\n\nFor more details about the security issue(s), including the impact, a CVSS score, and other related information, refer to the CVE page(s) listed in the References section.", + "title": "Details" + }, + { + "category": "legal_disclaimer", + "text": "This content is licensed under the Creative Commons Attribution 4.0 International License (https://creativecommons.org/licenses/by/4.0/). If you distribute this content, or a modified version of it, you must provide attribution to Red Hat Inc. and provide a link to the original.", + "title": "Terms of Use" + } + ], + "publisher": { + "category": "vendor", + "contact_details": "https://access.redhat.com/security/team/contact/", + "name": "Red Hat Product Security", + "namespace": "https://www.redhat.com" + }, + "references": [ + { + "category": "self", + "summary": "https://access.redhat.com/errata/RHSA-2021:5217", + "url": "https://access.redhat.com/errata/RHSA-2021:5217" + }, + { + "category": "external", + "summary": "https://access.redhat.com/security/updates/classification/#important", + "url": "https://access.redhat.com/security/updates/classification/#important" + }, + { + "category": "external", + "summary": "https://access.redhat.com/jbossnetwork/restricted/listSoftware.html?downloadType=securityPatches&product=core.service.rhsso&version=7.5", + "url": "https://access.redhat.com/jbossnetwork/restricted/listSoftware.html?downloadType=securityPatches&product=core.service.rhsso&version=7.5" + }, + { + "category": "external", + "summary": "https://access.redhat.com/documentation/en-us/red_hat_single_sign-on/7.5/", + "url": "https://access.redhat.com/documentation/en-us/red_hat_single_sign-on/7.5/" + }, + { + "category": "self", + "summary": "Canonical URL", + "url": "https://access.redhat.com/security/data/csaf/beta/2021/rhsa-2021_5217.json" + } + ], + "title": "Red Hat Security Advisory: Red Hat Single Sign-On 7.5.0 security update", + "tracking": { + "current_release_date": "2021-12-20T16:16:00Z", + "generator": { + "date": "2022-03-23T20:31:00Z", + "engine": { + "name": "Red Hat SDEngine", + "version": "3.4.3" + } + }, + "id": "RHSA-2021:5217", + "initial_release_date": "2021-12-20T16:16:00Z", + "revision_history": [ + { + "date": "2021-12-20T16:16:00Z", + "number": "1", + "summary": "Current version" + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "category": "product_family", + "name": "Red Hat Single Sign-On", + "product": { + "name": "Red Hat Single Sign-On", + "product_id": "Red Hat Single Sign-On" + } + } + ], + "category": "vendor", + "name": "Red Hat" + } + ] + }, + "vulnerabilities": [ + { + "acknowledgments": [ + { + "names": [ + "Grzegorz Soba\u0144ski" + ], + "organization": "MLabs" + } + ], + "cve": "CVE-2021-4133", + "cwe": { + "id": "CWE-863", + "name": "Incorrect Authorization" + }, + "discovery_date": "2021-12-17T00:00:00Z", + "ids": [ + { + "system_name": "Red Hat Bugzilla", + "text": "https://bugzilla.redhat.com/show_bug.cgi?id=2033602" + } + ], + "notes": [ + { + "category": "general", + "text": "Keycloak: Incorrect authorization allows unpriviledged users to create other users", + "title": "Vulnerability Description" + } + ], + "product_status": { + "fixed": [ + "Red Hat Single Sign-On" + ] + }, + "references": [ + { + "category": "external", + "summary": "https://github.com/keycloak/keycloak/issues/9247", + "url": "https://github.com/keycloak/keycloak/issues/9247" + }, + { + "category": "external", + "summary": "https://github.com/keycloak/keycloak/security/advisories/GHSA-83x4-9cwr-5487", + "url": "https://github.com/keycloak/keycloak/security/advisories/GHSA-83x4-9cwr-5487" + }, + { + "category": "external", + "summary": "CVE-2021-4133", + "url": "https://access.redhat.com/security/cve/CVE-2021-4133" + }, + { + "category": "external", + "summary": "bz#2033602: CVE-2021-4133 Keycloak: Incorrect authorization allows unpriviledged users to create other users", + "url": "https://bugzilla.redhat.com/show_bug.cgi?id=2033602" + } + ], + "release_date": "2021-12-16T17:05:00Z", + "remediations": [ + { + "category": "vendor_fix", + "details": "Before applying the update, back up your existing installation, including all applications, configuration files, databases and database settings, and so on.\n\nThe References section of this erratum contains a download link (you must log in to download the update).", + "product_ids": [ + "Red Hat Single Sign-On" + ], + "url": "https://access.redhat.com/errata/RHSA-2021:5217" + } + ], + "threats": [ + { + "category": "impact", + "date": "2021-12-17T00:00:00Z", + "details": "Important" + } + ], + "title": "CVE-2021-4133 Keycloak: Incorrect authorization allows unpriviledged users to create other users" + } + ] +} diff --git a/csaf_2.1/examples/csaf/rhsa-2022_0011.json b/csaf_2.1/examples/csaf/rhsa-2022_0011.json new file mode 100644 index 000000000..d5b53fd36 --- /dev/null +++ b/csaf_2.1/examples/csaf/rhsa-2022_0011.json @@ -0,0 +1,427 @@ +{ + "document": { + "aggregate_severity": { + "namespace": "https://access.redhat.com/security/updates/classification/", + "text": "Important" + }, + "category": "csaf_security_advisory", + "csaf_version": "2.0", + "distribution": { + "text": "Copyright \u00a9 2022 Red Hat, Inc. All rights reserved.", + "tlp": { + "label": "WHITE", + "url": "https://www.first.org/tlp/" + } + }, + "lang": "en", + "notes": [ + { + "category": "summary", + "text": "An update for telnet is now available for Red Hat Enterprise Linux 7.6 Advanced Update Support, Red Hat Enterprise Linux 7.6 Telco Extended Update Support, and Red Hat Enterprise Linux 7.6 Update Services for SAP Solutions.\n\nRed Hat Product Security has rated this update as having a security impact of Important. A Common Vulnerability Scoring System (CVSS) base score, which gives a detailed severity rating, is available for each vulnerability from the CVE link(s) in the References section.", + "title": "Topic" + }, + { + "category": "general", + "text": "Telnet is a popular protocol for logging in to remote systems over the Internet. The telnet-server packages include a telnet service that supports remote logins into the host machine. The telnet service is disabled by default.\n\nSecurity Fix(es):\n\n* telnet-server: no bounds checks in nextitem() function allows to remotely execute arbitrary code (CVE-2020-10188)\n\nFor more details about the security issue(s), including the impact, a CVSS score, acknowledgments, and other related information, refer to the CVE page(s) listed in the References section.", + "title": "Details" + }, + { + "category": "legal_disclaimer", + "text": "This content is licensed under the Creative Commons Attribution 4.0 International License (https://creativecommons.org/licenses/by/4.0/). If you distribute this content, or a modified version of it, you must provide attribution to Red Hat Inc. and provide a link to the original.", + "title": "Terms of Use" + } + ], + "publisher": { + "category": "vendor", + "contact_details": "https://access.redhat.com/security/team/contact/", + "name": "Red Hat Product Security", + "namespace": "https://www.redhat.com" + }, + "references": [ + { + "category": "self", + "summary": "https://access.redhat.com/errata/RHSA-2022:0011", + "url": "https://access.redhat.com/errata/RHSA-2022:0011" + }, + { + "category": "external", + "summary": "https://access.redhat.com/security/updates/classification/#important", + "url": "https://access.redhat.com/security/updates/classification/#important" + }, + { + "category": "self", + "summary": "Canonical URL", + "url": "https://access.redhat.com/security/data/csaf/beta/2022/rhsa-2022_0011.json" + } + ], + "title": "Red Hat Security Advisory: telnet security update", + "tracking": { + "current_release_date": "2022-01-04T08:38:00Z", + "generator": { + "date": "2022-03-23T20:31:00Z", + "engine": { + "name": "Red Hat SDEngine", + "version": "3.4.3" + } + }, + "id": "RHSA-2022:0011", + "initial_release_date": "2022-01-04T08:38:00Z", + "revision_history": [ + { + "date": "2022-01-04T08:38:00Z", + "number": "1", + "summary": "Current version" + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "branches": [ + { + "branches": [ + { + "category": "product_name", + "name": "Red Hat Enterprise Linux Server AUS (v. 7.6)", + "product": { + "name": "Red Hat Enterprise Linux Server AUS (v. 7.6)", + "product_id": "7Server-7.6.AUS", + "product_identification_helper": { + "cpe": "cpe:/o:redhat:rhel_aus:7.6::server" + } + } + }, + { + "category": "product_name", + "name": "Red Hat Enterprise Linux Server E4S (v. 7.6)", + "product": { + "name": "Red Hat Enterprise Linux Server E4S (v. 7.6)", + "product_id": "7Server-7.6.E4S", + "product_identification_helper": { + "cpe": "cpe:/o:redhat:rhel_e4s:7.6::server" + } + } + }, + { + "category": "product_name", + "name": "Red Hat Enterprise Linux Server TUS (v. 7.6)", + "product": { + "name": "Red Hat Enterprise Linux Server TUS (v. 7.6)", + "product_id": "7Server-7.6.TUS", + "product_identification_helper": { + "cpe": "cpe:/o:redhat:rhel_tus:7.6::server" + } + } + } + ], + "category": "product_family", + "name": "Red Hat Enterprise Linux" + }, + { + "branches": [ + { + "category": "product_version", + "name": "telnet-1:0.17-65.el7_6.src", + "product": { + "name": "telnet-1:0.17-65.el7_6.src", + "product_id": "telnet-1:0.17-65.el7_6.src" + } + } + ], + "category": "architecture", + "name": "src" + }, + { + "branches": [ + { + "category": "product_version", + "name": "telnet-1:0.17-65.el7_6.x86_64", + "product": { + "name": "telnet-1:0.17-65.el7_6.x86_64", + "product_id": "telnet-1:0.17-65.el7_6.x86_64" + } + }, + { + "category": "product_version", + "name": "telnet-debuginfo-1:0.17-65.el7_6.x86_64", + "product": { + "name": "telnet-debuginfo-1:0.17-65.el7_6.x86_64", + "product_id": "telnet-debuginfo-1:0.17-65.el7_6.x86_64" + } + }, + { + "category": "product_version", + "name": "telnet-server-1:0.17-65.el7_6.x86_64", + "product": { + "name": "telnet-server-1:0.17-65.el7_6.x86_64", + "product_id": "telnet-server-1:0.17-65.el7_6.x86_64" + } + } + ], + "category": "architecture", + "name": "x86_64" + }, + { + "branches": [ + { + "category": "product_version", + "name": "telnet-1:0.17-65.el7_6.ppc64le", + "product": { + "name": "telnet-1:0.17-65.el7_6.ppc64le", + "product_id": "telnet-1:0.17-65.el7_6.ppc64le" + } + }, + { + "category": "product_version", + "name": "telnet-debuginfo-1:0.17-65.el7_6.ppc64le", + "product": { + "name": "telnet-debuginfo-1:0.17-65.el7_6.ppc64le", + "product_id": "telnet-debuginfo-1:0.17-65.el7_6.ppc64le" + } + }, + { + "category": "product_version", + "name": "telnet-server-1:0.17-65.el7_6.ppc64le", + "product": { + "name": "telnet-server-1:0.17-65.el7_6.ppc64le", + "product_id": "telnet-server-1:0.17-65.el7_6.ppc64le" + } + } + ], + "category": "architecture", + "name": "ppc64le" + } + ], + "category": "vendor", + "name": "Red Hat" + } + ], + "relationships": [ + { + "category": "default_component_of", + "full_product_name": { + "name": "telnet-1:0.17-65.el7_6.src as a component of Red Hat Enterprise Linux Server AUS (v. 7.6)", + "product_id": "7Server-7.6.AUS:telnet-1:0.17-65.el7_6.src" + }, + "product_reference": "telnet-1:0.17-65.el7_6.src", + "relates_to_product_reference": "7Server-7.6.AUS" + }, + { + "category": "default_component_of", + "full_product_name": { + "name": "telnet-1:0.17-65.el7_6.x86_64 as a component of Red Hat Enterprise Linux Server AUS (v. 7.6)", + "product_id": "7Server-7.6.AUS:telnet-1:0.17-65.el7_6.x86_64" + }, + "product_reference": "telnet-1:0.17-65.el7_6.x86_64", + "relates_to_product_reference": "7Server-7.6.AUS" + }, + { + "category": "default_component_of", + "full_product_name": { + "name": "telnet-debuginfo-1:0.17-65.el7_6.x86_64 as a component of Red Hat Enterprise Linux Server AUS (v. 7.6)", + "product_id": "7Server-7.6.AUS:telnet-debuginfo-1:0.17-65.el7_6.x86_64" + }, + "product_reference": "telnet-debuginfo-1:0.17-65.el7_6.x86_64", + "relates_to_product_reference": "7Server-7.6.AUS" + }, + { + "category": "default_component_of", + "full_product_name": { + "name": "telnet-server-1:0.17-65.el7_6.x86_64 as a component of Red Hat Enterprise Linux Server AUS (v. 7.6)", + "product_id": "7Server-7.6.AUS:telnet-server-1:0.17-65.el7_6.x86_64" + }, + "product_reference": "telnet-server-1:0.17-65.el7_6.x86_64", + "relates_to_product_reference": "7Server-7.6.AUS" + }, + { + "category": "default_component_of", + "full_product_name": { + "name": "telnet-1:0.17-65.el7_6.ppc64le as a component of Red Hat Enterprise Linux Server E4S (v. 7.6)", + "product_id": "7Server-7.6.E4S:telnet-1:0.17-65.el7_6.ppc64le" + }, + "product_reference": "telnet-1:0.17-65.el7_6.ppc64le", + "relates_to_product_reference": "7Server-7.6.E4S" + }, + { + "category": "default_component_of", + "full_product_name": { + "name": "telnet-1:0.17-65.el7_6.src as a component of Red Hat Enterprise Linux Server E4S (v. 7.6)", + "product_id": "7Server-7.6.E4S:telnet-1:0.17-65.el7_6.src" + }, + "product_reference": "telnet-1:0.17-65.el7_6.src", + "relates_to_product_reference": "7Server-7.6.E4S" + }, + { + "category": "default_component_of", + "full_product_name": { + "name": "telnet-1:0.17-65.el7_6.x86_64 as a component of Red Hat Enterprise Linux Server E4S (v. 7.6)", + "product_id": "7Server-7.6.E4S:telnet-1:0.17-65.el7_6.x86_64" + }, + "product_reference": "telnet-1:0.17-65.el7_6.x86_64", + "relates_to_product_reference": "7Server-7.6.E4S" + }, + { + "category": "default_component_of", + "full_product_name": { + "name": "telnet-debuginfo-1:0.17-65.el7_6.ppc64le as a component of Red Hat Enterprise Linux Server E4S (v. 7.6)", + "product_id": "7Server-7.6.E4S:telnet-debuginfo-1:0.17-65.el7_6.ppc64le" + }, + "product_reference": "telnet-debuginfo-1:0.17-65.el7_6.ppc64le", + "relates_to_product_reference": "7Server-7.6.E4S" + }, + { + "category": "default_component_of", + "full_product_name": { + "name": "telnet-debuginfo-1:0.17-65.el7_6.x86_64 as a component of Red Hat Enterprise Linux Server E4S (v. 7.6)", + "product_id": "7Server-7.6.E4S:telnet-debuginfo-1:0.17-65.el7_6.x86_64" + }, + "product_reference": "telnet-debuginfo-1:0.17-65.el7_6.x86_64", + "relates_to_product_reference": "7Server-7.6.E4S" + }, + { + "category": "default_component_of", + "full_product_name": { + "name": "telnet-server-1:0.17-65.el7_6.ppc64le as a component of Red Hat Enterprise Linux Server E4S (v. 7.6)", + "product_id": "7Server-7.6.E4S:telnet-server-1:0.17-65.el7_6.ppc64le" + }, + "product_reference": "telnet-server-1:0.17-65.el7_6.ppc64le", + "relates_to_product_reference": "7Server-7.6.E4S" + }, + { + "category": "default_component_of", + "full_product_name": { + "name": "telnet-server-1:0.17-65.el7_6.x86_64 as a component of Red Hat Enterprise Linux Server E4S (v. 7.6)", + "product_id": "7Server-7.6.E4S:telnet-server-1:0.17-65.el7_6.x86_64" + }, + "product_reference": "telnet-server-1:0.17-65.el7_6.x86_64", + "relates_to_product_reference": "7Server-7.6.E4S" + }, + { + "category": "default_component_of", + "full_product_name": { + "name": "telnet-1:0.17-65.el7_6.src as a component of Red Hat Enterprise Linux Server TUS (v. 7.6)", + "product_id": "7Server-7.6.TUS:telnet-1:0.17-65.el7_6.src" + }, + "product_reference": "telnet-1:0.17-65.el7_6.src", + "relates_to_product_reference": "7Server-7.6.TUS" + }, + { + "category": "default_component_of", + "full_product_name": { + "name": "telnet-1:0.17-65.el7_6.x86_64 as a component of Red Hat Enterprise Linux Server TUS (v. 7.6)", + "product_id": "7Server-7.6.TUS:telnet-1:0.17-65.el7_6.x86_64" + }, + "product_reference": "telnet-1:0.17-65.el7_6.x86_64", + "relates_to_product_reference": "7Server-7.6.TUS" + }, + { + "category": "default_component_of", + "full_product_name": { + "name": "telnet-debuginfo-1:0.17-65.el7_6.x86_64 as a component of Red Hat Enterprise Linux Server TUS (v. 7.6)", + "product_id": "7Server-7.6.TUS:telnet-debuginfo-1:0.17-65.el7_6.x86_64" + }, + "product_reference": "telnet-debuginfo-1:0.17-65.el7_6.x86_64", + "relates_to_product_reference": "7Server-7.6.TUS" + }, + { + "category": "default_component_of", + "full_product_name": { + "name": "telnet-server-1:0.17-65.el7_6.x86_64 as a component of Red Hat Enterprise Linux Server TUS (v. 7.6)", + "product_id": "7Server-7.6.TUS:telnet-server-1:0.17-65.el7_6.x86_64" + }, + "product_reference": "telnet-server-1:0.17-65.el7_6.x86_64", + "relates_to_product_reference": "7Server-7.6.TUS" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2020-10188", + "cwe": { + "id": "CWE-119", + "name": "Improper Restriction of Operations within the Bounds of a Memory Buffer" + }, + "discovery_date": "2020-03-06T00:00:00Z", + "ids": [ + { + "system_name": "Red Hat Bugzilla", + "text": "https://bugzilla.redhat.com/show_bug.cgi?id=1811673" + } + ], + "notes": [ + { + "category": "general", + "text": "telnet-server: no bounds checks in nextitem() function allows to remotely execute arbitrary code", + "title": "Vulnerability Description" + } + ], + "product_status": { + "fixed": [ + "7Server-7.6.AUS:telnet-1:0.17-65.el7_6.src", + "7Server-7.6.AUS:telnet-1:0.17-65.el7_6.x86_64", + "7Server-7.6.AUS:telnet-debuginfo-1:0.17-65.el7_6.x86_64", + "7Server-7.6.AUS:telnet-server-1:0.17-65.el7_6.x86_64", + "7Server-7.6.E4S:telnet-1:0.17-65.el7_6.ppc64le", + "7Server-7.6.E4S:telnet-1:0.17-65.el7_6.src", + "7Server-7.6.E4S:telnet-1:0.17-65.el7_6.x86_64", + "7Server-7.6.E4S:telnet-debuginfo-1:0.17-65.el7_6.ppc64le", + "7Server-7.6.E4S:telnet-debuginfo-1:0.17-65.el7_6.x86_64", + "7Server-7.6.E4S:telnet-server-1:0.17-65.el7_6.ppc64le", + "7Server-7.6.E4S:telnet-server-1:0.17-65.el7_6.x86_64", + "7Server-7.6.TUS:telnet-1:0.17-65.el7_6.src", + "7Server-7.6.TUS:telnet-1:0.17-65.el7_6.x86_64", + "7Server-7.6.TUS:telnet-debuginfo-1:0.17-65.el7_6.x86_64", + "7Server-7.6.TUS:telnet-server-1:0.17-65.el7_6.x86_64" + ] + }, + "references": [ + { + "category": "external", + "summary": "CVE-2020-10188", + "url": "https://access.redhat.com/security/cve/CVE-2020-10188" + }, + { + "category": "external", + "summary": "bz#1811673: CVE-2020-10188 telnet-server: no bounds checks in nextitem() function allows to remotely execute arbitrary code", + "url": "https://bugzilla.redhat.com/show_bug.cgi?id=1811673" + } + ], + "release_date": "2020-02-28T00:00:00Z", + "remediations": [ + { + "category": "vendor_fix", + "details": "For details on how to apply this update, which includes the changes described in this advisory, refer to:\n\nhttps://access.redhat.com/articles/11258", + "product_ids": [ + "7Server-7.6.AUS:telnet-1:0.17-65.el7_6.src", + "7Server-7.6.AUS:telnet-1:0.17-65.el7_6.x86_64", + "7Server-7.6.AUS:telnet-debuginfo-1:0.17-65.el7_6.x86_64", + "7Server-7.6.AUS:telnet-server-1:0.17-65.el7_6.x86_64", + "7Server-7.6.E4S:telnet-1:0.17-65.el7_6.ppc64le", + "7Server-7.6.E4S:telnet-1:0.17-65.el7_6.src", + "7Server-7.6.E4S:telnet-1:0.17-65.el7_6.x86_64", + "7Server-7.6.E4S:telnet-debuginfo-1:0.17-65.el7_6.ppc64le", + "7Server-7.6.E4S:telnet-debuginfo-1:0.17-65.el7_6.x86_64", + "7Server-7.6.E4S:telnet-server-1:0.17-65.el7_6.ppc64le", + "7Server-7.6.E4S:telnet-server-1:0.17-65.el7_6.x86_64", + "7Server-7.6.TUS:telnet-1:0.17-65.el7_6.src", + "7Server-7.6.TUS:telnet-1:0.17-65.el7_6.x86_64", + "7Server-7.6.TUS:telnet-debuginfo-1:0.17-65.el7_6.x86_64", + "7Server-7.6.TUS:telnet-server-1:0.17-65.el7_6.x86_64" + ], + "url": "https://access.redhat.com/errata/RHSA-2022:0011" + } + ], + "threats": [ + { + "category": "impact", + "date": "2020-03-06T00:00:00Z", + "details": "Important" + } + ], + "title": "CVE-2020-10188 telnet-server: no bounds checks in nextitem() function allows to remotely execute arbitrary code" + } + ] +} diff --git a/csaf_2.1/examples/provider-metadata/example-01-provider-metadata.json b/csaf_2.1/examples/provider-metadata/example-01-provider-metadata.json new file mode 100644 index 000000000..5555a8087 --- /dev/null +++ b/csaf_2.1/examples/provider-metadata/example-01-provider-metadata.json @@ -0,0 +1,32 @@ +{ + "canonical_url": "https://www.example.com/.well-known/csaf/provider-metadata.json", + "distributions": [ + { + "rolie":{ + "feeds": [ + { + "summary":"All TLP:WHITE advisories of Example Company.", + "tlp_label": "WHITE", + "url": "https://www.example.com/.well-known/csaf/feed-tlp-white.json" + } + ] + } + } + ], + "last_updated": "2021-07-12T20:20:56.169Z", + "list_on_CSAF_aggregators": true, + "metadata_version": "2.0", + "mirror_on_CSAF_aggregators": true, + "public_openpgp_keys": [ + { + "fingerprint": "8F5F267907B2C4559DB360DB2294BA7D2B2298B1", + "url": "https://keys.example.net/vks/v1/by-fingerprint/8F5F267907B2C4559DB360DB2294BA7D2B2298B1" + } + ], + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace":"https://psirt.example.com" + }, + "role": "csaf_trusted_provider" +} \ No newline at end of file diff --git a/csaf_2.1/json_schema/NOTES.md b/csaf_2.1/json_schema/NOTES.md new file mode 100644 index 000000000..8c9102c16 --- /dev/null +++ b/csaf_2.1/json_schema/NOTES.md @@ -0,0 +1,107 @@ + +# Done + +- json field names are lowercase and separated by "\_" +- "#text" replaced with just "text" +- "product_tree" really is an array of branches or full products. + +# Design + +- Formatting: Start a new line after every brace or bracket. Indent with each brace or bracket. + +- Naming: Lowercase names with underscores separating words for properties ("snake_eyes"). + +Naming: Shared definitions end with "\_t", as in "non_empty_string_t". + +Naming: Shared definitions of arrays use a plural noun form, such as "notes_t". + + +- Ordering: Properties and definitions are listed alphabetically. Enumerations are listed alphabetically. + +- More than one: Whenever there's the opportunity for more than one value, +the schema specifically does not support having just one. That is, always [{}], not just {}. + +- Extensibility: the "propertyNames" feature of JSON schema prevents future extension, and is only used where +no extensibility is ever intended. + +# Comments + +## Email address? + +Since CVEs require email addresses, shouldn't a contact email be a first-class citizen of the document, rather +than being buried in a contact_details string? + +## Maximums? + +While these documents could be, in the abstract, unbounded, in practice they cannot be. What kinds of upper limits +should we consider? + +## Names? + +Suggested name change: score_set_v3 doesn't identify that it is a CVSS v3 Score. Suggested name "cvss_v3_score". + +Suggested name change: cvss_score_sets presumes CVSS as the only way to score. How aboute "scores"? + +# Of note + +Documents translated from the XML did not have dates of the form valid RFC 3339, Section 5.6. Added "Z" to all of them. + +# Concerns + +## Array vs. Instance + +In a number of places, the sample documents used either an array of items, or a single item. Recommend +that it always be an array, if multiple items are possible. This will make it considerably easier +to parse in languages that are not dynamically typed. + +Examples: +- /document_tracking/revision_tracking/revision vs. /document_tracking/revision_tracking/revision[] +- /product_tree/branch vs. /product_tree/branch[] +- /vulnerability vs. /vulnerability[] + +## Language selection + +In one of the files, we have "document_title" as a string, and the other as an object with "lang" and "text" properties. + +## Revision History Simplification + +Currently have + ` /document_tracking/revision_history/revision[]` +Why not just have + `/document_tracking/revision_history[]` + +## Conversion created "#text" nodes + +I renamed the `"#text` nodes to `text`, but they should be named even better than that. + +# Redesign + +The overall schema includes a number of "document_" fields. "document_notes", "document_tracking", "document_references", +"document_distribution." + +Proposal is that we create a "document" property, and put those other properties of the document under the "document" +property. + +## Status + +In CVRF, the "ProductStatuses" element contains an array of Status elements which contain a type and a list of products. + +Suggestion for JSON format: +``` +product_status : { + "fixed": [], + "first_affected": [], + "known_affected": [], + "known_not_affected": [], + "first_fixed": [], + "recommended": [], + "last_affected": [] +} +``` +# Questions + +## Examples in the schema? + +JSON Schema allows for examples. +Do we want to put examples in? +Or leave that to the specification document? diff --git a/csaf_2.1/json_schema/aggregator_json_schema.json b/csaf_2.1/json_schema/aggregator_json_schema.json new file mode 100644 index 000000000..7929f1ff3 --- /dev/null +++ b/csaf_2.1/json_schema/aggregator_json_schema.json @@ -0,0 +1,215 @@ +{ + "$schema": "https://json-schema.org/draft/2020-12/schema", + "$id": "https://docs.oasis-open.org/csaf/csaf/v2.0/aggregator_json_schema.json", + "title": "CSAF aggregator", + "description": "Representation of information where to find CSAF providers as a JSON document.", + "type": "object", + "$defs": { + "aggregator_url_t": { + "title": "Aggregator URL type", + "description": "Contains a URL.", + "type": "string", + "format": "uri", + "pattern": "/aggregator\\.json$" + }, + "metadata_t": { + "title": "CSAF issuing party metadata.", + "description": "Contains the metadata of a single CSAF issuing party.", + "type": "object", + "required": [ + "last_updated", + "publisher", + "url" + ], + "properties": { + "last_updated": { + "title": "Last updated", + "description": "Holds the date and time when this entry was last updated.", + "type": "string", + "format": "date-time" + }, + "publisher": { + "title": "Publisher", + "description": "Provides information about the issuing party for this entry.", + "$ref": "https://docs.oasis-open.org/csaf/csaf/v2.0/provider_json_schema.json#/properties/publisher" + }, + "role": { + "title": "Role of the issuing party", + "description": "Contains the role of the issuing party according to section 7 in the CSAF standard.", + "$ref": "https://docs.oasis-open.org/csaf/csaf/v2.0/provider_json_schema.json#/properties/role" + }, + "url": { + "title": "URL of the metadata", + "description": "Contains the URL of the provider-metadata.json for that entry.", + "$ref": "https://docs.oasis-open.org/csaf/csaf/v2.0/provider_json_schema.json#/properties/canonical_url" + } + } + }, + "mirrors_t": { + "title": "List of mirrors", + "description": "Contains a list of URLs or mirrors for this issuing party.", + "type": "array", + "minItems": 1, + "uniqueItems": true, + "items": { + "title": "Mirror", + "description": "Contains the base URL of the mirror for this issuing party.", + "$ref": "https://docs.oasis-open.org/csaf/csaf/v2.0/provider_json_schema.json#/$defs/provider_url_t" + } + } + }, + "required": [ + "aggregator", + "aggregator_version", + "canonical_url", + "csaf_providers", + "last_updated" + ], + "properties": { + "aggregator": { + "title": "Aggregator", + "description": "Provides information about the aggregator.", + "type": "object", + "required": [ + "category", + "name", + "namespace" + ], + "properties": { + "category": { + "title": "Category of aggregator", + "description": "Provides information about the category of aggregator.", + "type": "string", + "enum": [ + "aggregator", + "lister" + ] + }, + "contact_details": { + "title": "Contact details", + "description": "Information on how to contact the aggregator, possibly including details such as web sites, email addresses, phone numbers, and postal mail addresses.", + "type": "string", + "minLength": 1, + "examples": [ + "Aggregator can be reached at contact_us@aggregator.example.com, or via our website at https://www.example.com/security/csaf/aggregator/contact." + ] + }, + "issuing_authority": { + "title": "Issuing authority", + "description": "Provides information about the authority of the aggregator to release the list, in particular, the party's constituency and responsibilities or other obligations.", + "type": "string", + "minLength": 1 + }, + "name": { + "title": "Name of aggregator", + "description": "Contains the name of the aggregator.", + "type": "string", + "minLength": 1, + "examples": [ + "BSI", + "CISA", + "CSAF TC" + ] + }, + "namespace": { + "title": "Namespace of aggregator", + "description": "Contains a URL which is under control of the aggregator and can be used as a globally unique identifier for that aggregator.", + "type": "string", + "format": "uri", + "examples": [ + "https://www.example.com", + "https://csaf.io" + ] + } + } + }, + "aggregator_version": { + "title": "CSAF aggregator version", + "description": "Gives the version of the CSAF aggregator specification which the document was generated for.", + "type": "string", + "enum": [ + "2.0" + ] + }, + "canonical_url": { + "title": "Canonical URL", + "description": "Contains the URL for this document.", + "$ref": "#/$defs/aggregator_url_t" + }, + "csaf_providers": { + "title": "List of CSAF providers", + "description": "Contains a list with information from CSAF providers.", + "type": "array", + "minItems": 1, + "uniqueItems": true, + "items": { + "title": "CSAF provider entry", + "description": "Contains information from a CSAF provider.", + "type": "object", + "required": [ + "metadata" + ], + "properties": { + "metadata": { + "title": "CSAF provider metadata.", + "description": "Contains the metadata of a single CSAF provider.", + "$ref": "#/$defs/metadata_t" + }, + "mirrors": { + "title": "List of mirrors", + "description": "Contains a list of URLs or mirrors for this CSAF provider.", + "$ref": "#/$defs/mirrors_t" + } + } + } + }, + "csaf_publishers": { + "title": "List of CSAF publishers", + "description": "Contains a list with information from CSAF publishers.", + "type": "array", + "minItems": 1, + "uniqueItems": true, + "items": { + "title": "CSAF publisher entry", + "description": "Contains information from a CSAF publisher.", + "type": "object", + "required": [ + "metadata", + "mirror", + "update_interval" + ], + "properties": { + "metadata": { + "title": "CSAF publisher metadata.", + "description": "Contains the metadata of a single CSAF publisher extracted from one of its CSAF documents.", + "$ref": "#/$defs/metadata_t" + }, + "mirrors": { + "title": "List of mirrors", + "description": "Contains a list of URLs or mirrors for this CSAF publisher.", + "$ref": "#/$defs/mirrors_t" + }, + "update_interval": { + "title": "Update interval", + "description": "Contains information about how often the CSAF publisher is checked for new CSAF documents.", + "type": "string", + "minLength": 1, + "examples": [ + "daily", + "weekly", + "monthly", + "on best effort", + "on notification by CSAF publisher" + ] + } + } + } + }, + "last_updated": { + "title": "Last updated", + "description": "Holds the date and time when the document was last updated.", + "type": "string", + "format": "date-time" + } + } +} diff --git a/csaf_2.1/json_schema/csaf_json_schema.json b/csaf_2.1/json_schema/csaf_json_schema.json new file mode 100644 index 000000000..93ff152a2 --- /dev/null +++ b/csaf_2.1/json_schema/csaf_json_schema.json @@ -0,0 +1,1414 @@ +{ + "$schema": "https://json-schema.org/draft/2020-12/schema", + "$id": "https://docs.oasis-open.org/csaf/csaf/v2.0/csaf_json_schema.json", + "title": "Common Security Advisory Framework", + "description": "Representation of security advisory information as a JSON document.", + "type": "object", + "$defs": { + "acknowledgments_t": { + "title": "List of acknowledgments", + "description": "Contains a list of acknowledgment elements.", + "type": "array", + "minItems": 1, + "items": { + "title": "Acknowledgment", + "description": "Acknowledges contributions by describing those that contributed.", + "type": "object", + "minProperties": 1, + "properties": { + "names": { + "title": "List of acknowledged names", + "description": "Contains the names of contributors being recognized.", + "type": "array", + "minItems": 1, + "items": { + "title": "Name of the contributor", + "description": "Contains the name of a single contributor being recognized.", + "type": "string", + "minLength": 1, + "examples": [ + "Albert Einstein", + "Johann Sebastian Bach" + ] + } + }, + "organization": { + "title": "Contributing organization", + "description": "Contains the name of a contributing organization being recognized.", + "type": "string", + "minLength": 1, + "examples": [ + "CISA", + "Google Project Zero", + "Talos" + ] + }, + "summary": { + "title": "Summary of the acknowledgment", + "description": "SHOULD represent any contextual details the document producers wish to make known about the acknowledgment or acknowledged parties.", + "type": "string", + "minLength": 1, + "examples": [ + "First analysis of Coordinated Multi-Stream Attack (CMSA)" + ] + }, + "urls": { + "title": "List of URLs", + "description": "Specifies a list of URLs or location of the reference to be acknowledged.", + "type": "array", + "minItems": 1, + "items": { + "title": "URL of acknowledgment", + "description": "Contains the URL or location of the reference to be acknowledged.", + "type": "string", + "format": "uri" + } + } + } + } + }, + "branches_t": { + "title": "List of branches", + "description": "Contains branch elements as children of the current element.", + "type": "array", + "minItems": 1, + "items": { + "title": "Branch", + "description": "Is a part of the hierarchical structure of the product tree.", + "type": "object", + "maxProperties": 3, + "minProperties": 3, + "required": [ + "category", + "name" + ], + "properties": { + "branches": { + "$ref": "#/$defs/branches_t" + }, + "category": { + "title": "Category of the branch", + "description": "Describes the characteristics of the labeled branch.", + "type": "string", + "enum": [ + "architecture", + "host_name", + "language", + "legacy", + "patch_level", + "product_family", + "product_name", + "product_version", + "product_version_range", + "service_pack", + "specification", + "vendor" + ] + }, + "name": { + "title": "Name of the branch", + "description": "Contains the canonical descriptor or 'friendly name' of the branch.", + "type": "string", + "minLength": 1, + "examples": [ + "10", + "365", + "Microsoft", + "Office", + "PCS 7", + "SIMATIC", + "Siemens", + "Windows" + ] + }, + "product": { + "$ref": "#/$defs/full_product_name_t" + } + } + } + }, + "full_product_name_t": { + "title": "Full product name", + "description": "Specifies information about the product and assigns the product_id.", + "type": "object", + "required": [ + "name", + "product_id" + ], + "properties": { + "name": { + "title": "Textual description of the product", + "description": "The value should be the product’s full canonical name, including version number and other attributes, as it would be used in a human-friendly document.", + "type": "string", + "minLength": 1, + "examples": [ + "Cisco AnyConnect Secure Mobility Client 2.3.185", + "Microsoft Host Integration Server 2006 Service Pack 1" + ] + }, + "product_id": { + "$ref": "#/$defs/product_id_t" + }, + "product_identification_helper": { + "title": "Helper to identify the product", + "description": "Provides at least one method which aids in identifying the product in an asset database.", + "type": "object", + "minProperties": 1, + "properties": { + "cpe": { + "title": "Common Platform Enumeration representation", + "description": "The Common Platform Enumeration (CPE) attribute refers to a method for naming platforms external to this specification.", + "type": "string", + "pattern": "^(cpe:2\\.3:[aho\\*\\-](:(((\\?*|\\*?)([a-zA-Z0-9\\-\\._]|(\\\\[\\\\\\*\\?!\"#\\$%&'\\(\\)\\+,/:;<=>@\\[\\]\\^`\\{\\|\\}~]))+(\\?*|\\*?))|[\\*\\-])){5}(:(([a-zA-Z]{2,3}(-([a-zA-Z]{2}|[0-9]{3}))?)|[\\*\\-]))(:(((\\?*|\\*?)([a-zA-Z0-9\\-\\._]|(\\\\[\\\\\\*\\?!\"#\\$%&'\\(\\)\\+,/:;<=>@\\[\\]\\^`\\{\\|\\}~]))+(\\?*|\\*?))|[\\*\\-])){4})|([c][pP][eE]:/[AHOaho]?(:[A-Za-z0-9\\._\\-~%]*){0,6})$", + "minLength": 5 + }, + "hashes": { + "title": "List of hashes", + "description": "Contains a list of cryptographic hashes usable to identify files.", + "type": "array", + "minItems": 1, + "items": { + "title": "Cryptographic hashes", + "description": "Contains all information to identify a file based on its cryptographic hash values.", + "type": "object", + "required": [ + "file_hashes", + "filename" + ], + "properties": { + "file_hashes": { + "title": "List of file hashes", + "description": "Contains a list of cryptographic hashes for this file.", + "type": "array", + "minItems": 1, + "items": { + "title": "File hash", + "description": "Contains one hash value and algorithm of the file to be identified.", + "type": "object", + "required": [ + "algorithm", + "value" + ], + "properties": { + "algorithm": { + "title": "Algorithm of the cryptographic hash", + "description": "Contains the name of the cryptographic hash algorithm used to calculate the value.", + "type": "string", + "default": "sha256", + "minLength": 1, + "examples": [ + "blake2b512", + "sha256", + "sha3-512", + "sha384", + "sha512" + ] + }, + "value": { + "title": "Value of the cryptographic hash", + "description": "Contains the cryptographic hash value in hexadecimal representation.", + "type": "string", + "pattern": "^[0-9a-fA-F]{32,}$", + "minLength": 32, + "examples": [ + "37df33cb7464da5c7f077f4d56a32bc84987ec1d85b234537c1c1a4d4fc8d09dc29e2e762cb5203677bf849a2855a0283710f1f5fe1d6ce8d5ac85c645d0fcb3", + "4775203615d9534a8bfca96a93dc8b461a489f69124a130d786b42204f3341cc", + "9ea4c8200113d49d26505da0e02e2f49055dc078d1ad7a419b32e291c7afebbb84badfbd46dec42883bea0b2a1fa697c" + ] + } + } + } + }, + "filename": { + "title": "Filename", + "description": "Contains the name of the file which is identified by the hash values.", + "type": "string", + "minLength": 1, + "examples": [ + "WINWORD.EXE", + "msotadddin.dll", + "sudoers.so" + ] + } + } + } + }, + "model_numbers": { + "title": "List of models", + "description": "Contains a list of full or abbreviated (partial) model numbers.", + "type": "array", + "minItems": 1, + "uniqueItems": true, + "items": { + "title": "Model number", + "description": "Contains a full or abbreviated (partial) model number of the component to identify.", + "type": "string", + "minLength": 1 + } + }, + "purl": { + "title": "package URL representation", + "description": "The package URL (purl) attribute refers to a method for reliably identifying and locating software packages external to this specification.", + "type": "string", + "format": "uri", + "pattern": "^pkg:[A-Za-z\\.\\-\\+][A-Za-z0-9\\.\\-\\+]*/.+", + "minLength": 7 + }, + "sbom_urls": { + "title": "List of SBOM URLs", + "description": "Contains a list of URLs where SBOMs for this product can be retrieved.", + "type": "array", + "minItems": 1, + "items": { + "title": "SBOM URL", + "description": "Contains a URL of one SBOM for this product.", + "type": "string", + "format": "uri" + } + }, + "serial_numbers": { + "title": "List of serial numbers", + "description": "Contains a list of full or abbreviated (partial) serial numbers.", + "type": "array", + "minItems": 1, + "uniqueItems": true, + "items": { + "title": "Serial number", + "description": "Contains a full or abbreviated (partial) serial number of the component to identify.", + "type": "string", + "minLength": 1 + } + }, + "skus": { + "title": "List of stock keeping units", + "description": "Contains a list of full or abbreviated (partial) stock keeping units.", + "type": "array", + "minItems": 1, + "items": { + "title": "Stock keeping unit", + "description": "Contains a full or abbreviated (partial) stock keeping unit (SKU) which is used in the ordering process to identify the component.", + "type": "string", + "minLength": 1 + } + }, + "x_generic_uris": { + "title": "List of generic URIs", + "description": "Contains a list of identifiers which are either vendor-specific or derived from a standard not yet supported.", + "type": "array", + "minItems": 1, + "items": { + "title": "Generic URI", + "description": "Provides a generic extension point for any identifier which is either vendor-specific or derived from a standard not yet supported.", + "type": "object", + "required": [ + "namespace", + "uri" + ], + "properties": { + "namespace": { + "title": "Namespace of the generic URI", + "description": "Refers to a URL which provides the name and knowledge about the specification used or is the namespace in which these values are valid.", + "type": "string", + "format": "uri" + }, + "uri": { + "title": "URI", + "description": "Contains the identifier itself.", + "type": "string", + "format": "uri" + } + } + } + } + } + } + } + }, + "lang_t": { + "title": "Language type", + "description": "Identifies a language, corresponding to IETF BCP 47 / RFC 5646. See IETF language registry: https://www.iana.org/assignments/language-subtag-registry/language-subtag-registry", + "type": "string", + "pattern": "^(([A-Za-z]{2,3}(-[A-Za-z]{3}(-[A-Za-z]{3}){0,2})?|[A-Za-z]{4,8})(-[A-Za-z]{4})?(-([A-Za-z]{2}|[0-9]{3}))?(-([A-Za-z0-9]{5,8}|[0-9][A-Za-z0-9]{3}))*(-[A-WY-Za-wy-z0-9](-[A-Za-z0-9]{2,8})+)*(-[Xx](-[A-Za-z0-9]{1,8})+)?|[Xx](-[A-Za-z0-9]{1,8})+|[Ii]-[Dd][Ee][Ff][Aa][Uu][Ll][Tt]|[Ii]-[Mm][Ii][Nn][Gg][Oo])$", + "examples": [ + "de", + "en", + "fr", + "frc", + "jp" + ] + }, + "notes_t": { + "title": "List of notes", + "description": "Contains notes which are specific to the current context.", + "type": "array", + "minItems": 1, + "items": { + "title": "Note", + "description": "Is a place to put all manner of text blobs related to the current context.", + "type": "object", + "required": [ + "category", + "text" + ], + "properties": { + "audience": { + "title": "Audience of note", + "description": "Indicates who is intended to read it.", + "type": "string", + "minLength": 1, + "examples": [ + "all", + "executives", + "operational management and system administrators", + "safety engineers" + ] + }, + "category": { + "title": "Note category", + "description": "Contains the information of what kind of note this is.", + "type": "string", + "enum": [ + "description", + "details", + "faq", + "general", + "legal_disclaimer", + "other", + "summary" + ] + }, + "text": { + "title": "Note content", + "description": "Holds the content of the note. Content varies depending on type.", + "type": "string", + "minLength": 1 + }, + "title": { + "title": "Title of note", + "description": "Provides a concise description of what is contained in the text of the note.", + "type": "string", + "minLength": 1, + "examples": [ + "Details", + "Executive summary", + "Technical summary", + "Impact on safety systems" + ] + } + } + } + }, + "product_group_id_t": { + "title": "Reference token for product group instance", + "description": "Token required to identify a group of products so that it can be referred to from other parts in the document. There is no predefined or required format for the product_group_id as long as it uniquely identifies a group in the context of the current document.", + "type": "string", + "minLength": 1, + "examples": [ + "CSAFGID-0001", + "CSAFGID-0002", + "CSAFGID-0020" + ] + }, + "product_groups_t": { + "title": "List of product_group_ids", + "description": "Specifies a list of product_group_ids to give context to the parent item.", + "type": "array", + "minItems": 1, + "uniqueItems": true, + "items": { + "$ref": "#/$defs/product_group_id_t" + } + }, + "product_id_t": { + "title": "Reference token for product instance", + "description": "Token required to identify a full_product_name so that it can be referred to from other parts in the document. There is no predefined or required format for the product_id as long as it uniquely identifies a product in the context of the current document.", + "type": "string", + "minLength": 1, + "examples": [ + "CSAFPID-0004", + "CSAFPID-0008" + ] + }, + "products_t": { + "title": "List of product_ids", + "description": "Specifies a list of product_ids to give context to the parent item.", + "type": "array", + "minItems": 1, + "uniqueItems": true, + "items": { + "$ref": "#/$defs/product_id_t" + } + }, + "references_t": { + "title": "List of references", + "description": "Holds a list of references.", + "type": "array", + "minItems": 1, + "items": { + "title": "Reference", + "description": "Holds any reference to conferences, papers, advisories, and other resources that are related and considered related to either a surrounding part of or the entire document and to be of value to the document consumer.", + "type": "object", + "required": [ + "summary", + "url" + ], + "properties": { + "category": { + "title": "Category of reference", + "description": "Indicates whether the reference points to the same document or vulnerability in focus (depending on scope) or to an external resource.", + "type": "string", + "default": "external", + "enum": [ + "external", + "self" + ] + }, + "summary": { + "title": "Summary of the reference", + "description": "Indicates what this reference refers to.", + "type": "string", + "minLength": 1 + }, + "url": { + "title": "URL of reference", + "description": "Provides the URL for the reference.", + "type": "string", + "format": "uri" + } + } + } + }, + "version_t": { + "title": "Version", + "description": "Specifies a version string to denote clearly the evolution of the content of the document. Format must be either integer or semantic versioning.", + "type": "string", + "pattern": "^(0|[1-9][0-9]*)$|^((0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?)$", + "examples": [ + "1", + "4", + "0.9.0", + "1.4.3", + "2.40.0+21AF26D3" + ] + } + }, + "required": [ + "document" + ], + "properties": { + "document": { + "title": "Document level meta-data", + "description": "Captures the meta-data about this document describing a particular set of security advisories.", + "type": "object", + "required": [ + "category", + "csaf_version", + "publisher", + "title", + "tracking" + ], + "properties": { + "acknowledgments": { + "title": "Document acknowledgments", + "description": "Contains a list of acknowledgment elements associated with the whole document.", + "$ref": "#/$defs/acknowledgments_t" + }, + "aggregate_severity": { + "title": "Aggregate severity", + "description": "Is a vehicle that is provided by the document producer to convey the urgency and criticality with which the one or more vulnerabilities reported should be addressed. It is a document-level metric and applied to the document as a whole — not any specific vulnerability. The range of values in this field is defined according to the document producer's policies and procedures.", + "type": "object", + "required": [ + "text" + ], + "properties": { + "namespace": { + "title": "Namespace of aggregate severity", + "description": "Points to the namespace so referenced.", + "type": "string", + "format": "uri" + }, + "text": { + "title": "Text of aggregate severity", + "description": "Provides a severity which is independent of - and in addition to - any other standard metric for determining the impact or severity of a given vulnerability (such as CVSS).", + "type": "string", + "minLength": 1, + "examples": [ + "Critical", + "Important", + "Moderate" + ] + } + } + }, + "category": { + "title": "Document category", + "description": "Defines a short canonical name, chosen by the document producer, which will inform the end user as to the category of document.", + "type": "string", + "pattern": "^[^\\s\\-_\\.](.*[^\\s\\-_\\.])?$", + "minLength": 1, + "examples": [ + "csaf_base", + "csaf_security_advisory", + "csaf_vex", + "Example Company Security Notice" + ] + }, + "csaf_version": { + "title": "CSAF version", + "description": "Gives the version of the CSAF specification which the document was generated for.", + "type": "string", + "enum": [ + "2.0" + ] + }, + "distribution": { + "title": "Rules for sharing document", + "description": "Describe any constraints on how this document might be shared.", + "type": "object", + "minProperties": 1, + "properties": { + "text": { + "title": "Textual description", + "description": "Provides a textual description of additional constraints.", + "type": "string", + "minLength": 1, + "examples": [ + "Copyright 2021, Example Company, All Rights Reserved.", + "Distribute freely.", + "Share only on a need-to-know-basis only." + ] + }, + "tlp": { + "title": "Traffic Light Protocol (TLP)", + "description": "Provides details about the TLP classification of the document.", + "type": "object", + "required": [ + "label" + ], + "properties": { + "label": { + "title": "Label of TLP", + "description": "Provides the TLP label of the document.", + "type": "string", + "enum": [ + "AMBER", + "GREEN", + "RED", + "WHITE" + ] + }, + "url": { + "title": "URL of TLP version", + "description": "Provides a URL where to find the textual description of the TLP version which is used in this document. Default is the URL to the definition by FIRST.", + "type": "string", + "default": "https://www.first.org/tlp/", + "format": "uri", + "examples": [ + "https://www.us-cert.gov/tlp", + "https://www.bsi.bund.de/SharedDocs/Downloads/DE/BSI/Kritis/Merkblatt_TLP.pdf" + ] + } + } + } + } + }, + "lang": { + "title": "Document language", + "description": "Identifies the language used by this document, corresponding to IETF BCP 47 / RFC 5646.", + "$ref": "#/$defs/lang_t" + }, + "notes": { + "title": "Document notes", + "description": "Holds notes associated with the whole document.", + "$ref": "#/$defs/notes_t" + }, + "publisher": { + "title": "Publisher", + "description": "Provides information about the publisher of the document.", + "type": "object", + "required": [ + "category", + "name", + "namespace" + ], + "properties": { + "category": { + "title": "Category of publisher", + "description": "Provides information about the category of publisher releasing the document.", + "type": "string", + "enum": [ + "coordinator", + "discoverer", + "other", + "translator", + "user", + "vendor" + ] + }, + "contact_details": { + "title": "Contact details", + "description": "Information on how to contact the publisher, possibly including details such as web sites, email addresses, phone numbers, and postal mail addresses.", + "type": "string", + "minLength": 1, + "examples": [ + "Example Company can be reached at contact_us@example.com, or via our website at https://www.example.com/contact." + ] + }, + "issuing_authority": { + "title": "Issuing authority", + "description": "Provides information about the authority of the issuing party to release the document, in particular, the party's constituency and responsibilities or other obligations.", + "type": "string", + "minLength": 1 + }, + "name": { + "title": "Name of publisher", + "description": "Contains the name of the issuing party.", + "type": "string", + "minLength": 1, + "examples": [ + "BSI", + "Cisco PSIRT", + "Siemens ProductCERT" + ] + }, + "namespace": { + "title": "Namespace of publisher", + "description": "Contains a URL which is under control of the issuing party and can be used as a globally unique identifier for that issuing party.", + "type": "string", + "format": "uri", + "examples": [ + "https://csaf.io", + "https://www.example.com" + ] + } + } + }, + "references": { + "title": "Document references", + "description": "Holds a list of references associated with the whole document.", + "$ref": "#/$defs/references_t" + }, + "source_lang": { + "title": "Source language", + "description": "If this copy of the document is a translation then the value of this property describes from which language this document was translated.", + "$ref": "#/$defs/lang_t" + }, + "title": { + "title": "Title of this document", + "description": "This SHOULD be a canonical name for the document, and sufficiently unique to distinguish it from similar documents.", + "type": "string", + "minLength": 1, + "examples": [ + "Cisco IPv6 Crafted Packet Denial of Service Vulnerability", + "Example Company Cross-Site-Scripting Vulnerability in Example Generator" + ] + }, + "tracking": { + "title": "Tracking", + "description": "Is a container designated to hold all management attributes necessary to track a CSAF document as a whole.", + "type": "object", + "required": [ + "current_release_date", + "id", + "initial_release_date", + "revision_history", + "status", + "version" + ], + "properties": { + "aliases": { + "title": "Aliases", + "description": "Contains a list of alternate names for the same document.", + "type": "array", + "minItems": 1, + "uniqueItems": true, + "items": { + "title": "Alternate name", + "description": "Specifies a non-empty string that represents a distinct optional alternative ID used to refer to the document.", + "type": "string", + "minLength": 1, + "examples": [ + "CVE-2019-12345" + ] + } + }, + "current_release_date": { + "title": "Current release date", + "description": "The date when the current revision of this document was released", + "type": "string", + "format": "date-time" + }, + "generator": { + "title": "Document generator", + "description": "Is a container to hold all elements related to the generation of the document. These items will reference when the document was actually created, including the date it was generated and the entity that generated it.", + "type": "object", + "required": [ + "engine" + ], + "properties": { + "date": { + "title": "Date of document generation", + "description": "This SHOULD be the current date that the document was generated. Because documents are often generated internally by a document producer and exist for a nonzero amount of time before being released, this field MAY be different from the Initial Release Date and Current Release Date.", + "type": "string", + "format": "date-time" + }, + "engine": { + "title": "Engine of document generation", + "description": "Contains information about the engine that generated the CSAF document.", + "type": "object", + "required": [ + "name" + ], + "properties": { + "name": { + "title": "Engine name", + "description": "Represents the name of the engine that generated the CSAF document.", + "type": "string", + "minLength": 1, + "examples": [ + "Red Hat rhsa-to-cvrf", + "Secvisogram", + "TVCE" + ] + }, + "version": { + "title": "Engine version", + "description": "Contains the version of the engine that generated the CSAF document.", + "type": "string", + "minLength": 1, + "examples": [ + "0.6.0", + "1.0.0-beta+exp.sha.a1c44f85", + "2" + ] + } + } + } + } + }, + "id": { + "title": "Unique identifier for the document", + "description": "The ID is a simple label that provides for a wide range of numbering values, types, and schemes. Its value SHOULD be assigned and maintained by the original document issuing authority.", + "type": "string", + "pattern": "^[\\S](.*[\\S])?$", + "minLength": 1, + "examples": [ + "Example Company - 2019-YH3234", + "RHBA-2019:0024", + "cisco-sa-20190513-secureboot" + ] + }, + "initial_release_date": { + "title": "Initial release date", + "description": "The date when this document was first published.", + "type": "string", + "format": "date-time" + }, + "revision_history": { + "title": "Revision history", + "description": "Holds one revision item for each version of the CSAF document, including the initial one.", + "type": "array", + "minItems": 1, + "items": { + "title": "Revision", + "description": "Contains all the information elements required to track the evolution of a CSAF document.", + "type": "object", + "required": [ + "date", + "number", + "summary" + ], + "properties": { + "date": { + "title": "Date of the revision", + "description": "The date of the revision entry", + "type": "string", + "format": "date-time" + }, + "legacy_version": { + "title": "Legacy version of the revision", + "description": "Contains the version string used in an existing document with the same content.", + "type": "string", + "minLength": 1 + }, + "number": { + "$ref": "#/$defs/version_t" + }, + "summary": { + "title": "Summary of the revision", + "description": "Holds a single non-empty string representing a short description of the changes.", + "type": "string", + "minLength": 1, + "examples": [ + "Initial version." + ] + } + } + } + }, + "status": { + "title": "Document status", + "description": "Defines the draft status of the document.", + "type": "string", + "enum": [ + "draft", + "final", + "interim" + ] + }, + "version": { + "$ref": "#/$defs/version_t" + } + } + } + } + }, + "product_tree": { + "title": "Product tree", + "description": "Is a container for all fully qualified product names that can be referenced elsewhere in the document.", + "type": "object", + "minProperties": 1, + "properties": { + "branches": { + "$ref": "#/$defs/branches_t" + }, + "full_product_names": { + "title": "List of full product names", + "description": "Contains a list of full product names.", + "type": "array", + "minItems": 1, + "items": { + "$ref": "#/$defs/full_product_name_t" + } + }, + "product_groups": { + "title": "List of product groups", + "description": "Contains a list of product groups.", + "type": "array", + "minItems": 1, + "items": { + "title": "Product group", + "description": "Defines a new logical group of products that can then be referred to in other parts of the document to address a group of products with a single identifier.", + "type": "object", + "required": [ + "group_id", + "product_ids" + ], + "properties": { + "group_id": { + "$ref": "#/$defs/product_group_id_t" + }, + "product_ids": { + "title": "List of Product IDs", + "description": "Lists the product_ids of those products which known as one group in the document.", + "type": "array", + "minItems": 2, + "uniqueItems": true, + "items": { + "$ref": "#/$defs/product_id_t" + } + }, + "summary": { + "title": "Summary of the product group", + "description": "Gives a short, optional description of the group.", + "type": "string", + "minLength": 1, + "examples": [ + "Products supporting Modbus.", + "The x64 versions of the operating system." + ] + } + } + } + }, + "relationships": { + "title": "List of relationships", + "description": "Contains a list of relationships.", + "type": "array", + "minItems": 1, + "items": { + "title": "Relationship", + "description": "Establishes a link between two existing full_product_name_t elements, allowing the document producer to define a combination of two products that form a new full_product_name entry.", + "type": "object", + "required": [ + "category", + "full_product_name", + "product_reference", + "relates_to_product_reference" + ], + "properties": { + "category": { + "title": "Relationship category", + "description": "Defines the category of relationship for the referenced component.", + "type": "string", + "enum": [ + "default_component_of", + "external_component_of", + "installed_on", + "installed_with", + "optional_component_of" + ] + }, + "full_product_name": { + "$ref": "#/$defs/full_product_name_t" + }, + "product_reference": { + "title": "Product reference", + "description": "Holds a Product ID that refers to the Full Product Name element, which is referenced as the first element of the relationship.", + "$ref": "#/$defs/product_id_t" + }, + "relates_to_product_reference": { + "title": "Relates to product reference", + "description": "Holds a Product ID that refers to the Full Product Name element, which is referenced as the second element of the relationship.", + "$ref": "#/$defs/product_id_t" + } + } + } + } + } + }, + "vulnerabilities": { + "title": "Vulnerabilities", + "description": "Represents a list of all relevant vulnerability information items.", + "type": "array", + "minItems": 1, + "items": { + "title": "Vulnerability", + "description": "Is a container for the aggregation of all fields that are related to a single vulnerability in the document.", + "type": "object", + "minProperties": 1, + "properties": { + "acknowledgments": { + "title": "Vulnerability acknowledgments", + "description": "Contains a list of acknowledgment elements associated with this vulnerability item.", + "$ref": "#/$defs/acknowledgments_t" + }, + "cve": { + "title": "CVE", + "description": "Holds the MITRE standard Common Vulnerabilities and Exposures (CVE) tracking number for the vulnerability.", + "type": "string", + "pattern": "^CVE-[0-9]{4}-[0-9]{4,}$" + }, + "cwe": { + "title": "CWE", + "description": "Holds the MITRE standard Common Weakness Enumeration (CWE) for the weakness associated.", + "type": "object", + "required": [ + "id", + "name" + ], + "properties": { + "id": { + "title": "Weakness ID", + "description": "Holds the ID for the weakness associated.", + "type": "string", + "pattern": "^CWE-[1-9]\\d{0,5}$", + "examples": [ + "CWE-22", + "CWE-352", + "CWE-79" + ] + }, + "name": { + "title": "Weakness name", + "description": "Holds the full name of the weakness as given in the CWE specification.", + "type": "string", + "minLength": 1, + "examples": [ + "Cross-Site Request Forgery (CSRF)", + "Improper Limitation of a Pathname to a Restricted Directory ('Path Traversal')", + "Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')" + ] + } + } + }, + "discovery_date": { + "title": "Discovery date", + "description": "Holds the date and time the vulnerability was originally discovered.", + "type": "string", + "format": "date-time" + }, + "flags": { + "title": "List of flags", + "description": "Contains a list of machine readable flags.", + "type": "array", + "minItems": 1, + "uniqueItems": true, + "items": { + "title": "Flag", + "description": "Contains product specific information in regard to this vulnerability as a single machine readable flag.", + "type": "object", + "required": [ + "label" + ], + "properties": { + "date": { + "title": "Date of the flag", + "description": "Contains the date when assessment was done or the flag was assigned.", + "type": "string", + "format": "date-time" + }, + "group_ids": { + "$ref": "#/$defs/product_groups_t" + }, + "label": { + "title": "Label of the flag", + "description": "Specifies the machine readable label.", + "type": "string", + "enum": [ + "component_not_present", + "inline_mitigations_already_exist", + "vulnerable_code_cannot_be_controlled_by_adversary", + "vulnerable_code_not_in_execute_path", + "vulnerable_code_not_present" + ] + }, + "product_ids": { + "$ref": "#/$defs/products_t" + } + } + } + }, + "ids": { + "title": "List of IDs", + "description": "Represents a list of unique labels or tracking IDs for the vulnerability (if such information exists).", + "type": "array", + "minItems": 1, + "uniqueItems": true, + "items": { + "title": "ID", + "description": "Contains a single unique label or tracking ID for the vulnerability.", + "type": "object", + "required": [ + "system_name", + "text" + ], + "properties": { + "system_name": { + "title": "System name", + "description": "Indicates the name of the vulnerability tracking or numbering system.", + "type": "string", + "minLength": 1, + "examples": [ + "Cisco Bug ID", + "GitHub Issue" + ] + }, + "text": { + "title": "Text", + "description": "Is unique label or tracking ID for the vulnerability (if such information exists).", + "type": "string", + "minLength": 1, + "examples": [ + "CSCso66472", + "oasis-tcs/csaf#210" + ] + } + } + } + }, + "involvements": { + "title": "List of involvements", + "description": "Contains a list of involvements.", + "type": "array", + "minItems": 1, + "uniqueItems": true, + "items": { + "title": "Involvement", + "description": "Is a container, that allows the document producers to comment on the level of involvement (or engagement) of themselves or third parties in the vulnerability identification, scoping, and remediation process.", + "type": "object", + "required": [ + "party", + "status" + ], + "properties": { + "date": { + "title": "Date of involvement", + "description": "Holds the date and time of the involvement entry.", + "type": "string", + "format": "date-time" + }, + "party": { + "title": "Party category", + "description": "Defines the category of the involved party.", + "type": "string", + "enum": [ + "coordinator", + "discoverer", + "other", + "user", + "vendor" + ] + }, + "status": { + "title": "Party status", + "description": "Defines contact status of the involved party.", + "type": "string", + "enum": [ + "completed", + "contact_attempted", + "disputed", + "in_progress", + "not_contacted", + "open" + ] + }, + "summary": { + "title": "Summary of the involvement", + "description": "Contains additional context regarding what is going on.", + "type": "string", + "minLength": 1 + } + } + } + }, + "notes": { + "title": "Vulnerability notes", + "description": "Holds notes associated with this vulnerability item.", + "$ref": "#/$defs/notes_t" + }, + "product_status": { + "title": "Product status", + "description": "Contains different lists of product_ids which provide details on the status of the referenced product related to the current vulnerability. ", + "type": "object", + "minProperties": 1, + "properties": { + "first_affected": { + "title": "First affected", + "description": "These are the first versions of the releases known to be affected by the vulnerability.", + "$ref": "#/$defs/products_t" + }, + "first_fixed": { + "title": "First fixed", + "description": "These versions contain the first fix for the vulnerability but may not be the recommended fixed versions.", + "$ref": "#/$defs/products_t" + }, + "fixed": { + "title": "Fixed", + "description": "These versions contain a fix for the vulnerability but may not be the recommended fixed versions.", + "$ref": "#/$defs/products_t" + }, + "known_affected": { + "title": "Known affected", + "description": "These versions are known to be affected by the vulnerability.", + "$ref": "#/$defs/products_t" + }, + "known_not_affected": { + "title": "Known not affected", + "description": "These versions are known not to be affected by the vulnerability.", + "$ref": "#/$defs/products_t" + }, + "last_affected": { + "title": "Last affected", + "description": "These are the last versions in a release train known to be affected by the vulnerability. Subsequently released versions would contain a fix for the vulnerability.", + "$ref": "#/$defs/products_t" + }, + "recommended": { + "title": "Recommended", + "description": "These versions have a fix for the vulnerability and are the vendor-recommended versions for fixing the vulnerability.", + "$ref": "#/$defs/products_t" + }, + "under_investigation": { + "title": "Under investigation", + "description": "It is not known yet whether these versions are or are not affected by the vulnerability. However, it is still under investigation - the result will be provided in a later release of the document.", + "$ref": "#/$defs/products_t" + } + } + }, + "references": { + "title": "Vulnerability references", + "description": "Holds a list of references associated with this vulnerability item.", + "$ref": "#/$defs/references_t" + }, + "release_date": { + "title": "Release date", + "description": "Holds the date and time the vulnerability was originally released into the wild.", + "type": "string", + "format": "date-time" + }, + "remediations": { + "title": "List of remediations", + "description": "Contains a list of remediations.", + "type": "array", + "minItems": 1, + "items": { + "title": "Remediation", + "description": "Specifies details on how to handle (and presumably, fix) a vulnerability.", + "type": "object", + "required": [ + "category", + "details" + ], + "properties": { + "category": { + "title": "Category of the remediation", + "description": "Specifies the category which this remediation belongs to.", + "type": "string", + "enum": [ + "mitigation", + "no_fix_planned", + "none_available", + "vendor_fix", + "workaround" + ] + }, + "date": { + "title": "Date of the remediation", + "description": "Contains the date from which the remediation is available.", + "type": "string", + "format": "date-time" + }, + "details": { + "title": "Details of the remediation", + "description": "Contains a thorough human-readable discussion of the remediation.", + "type": "string", + "minLength": 1 + }, + "entitlements": { + "title": "List of entitlements", + "description": "Contains a list of entitlements.", + "type": "array", + "minItems": 1, + "items": { + "title": "Entitlement of the remediation", + "description": "Contains any possible vendor-defined constraints for obtaining fixed software or hardware that fully resolves the vulnerability.", + "type": "string", + "minLength": 1 + } + }, + "group_ids": { + "$ref": "#/$defs/product_groups_t" + }, + "product_ids": { + "$ref": "#/$defs/products_t" + }, + "restart_required": { + "title": "Restart required by remediation", + "description": "Provides information on category of restart is required by this remediation to become effective.", + "type": "object", + "required": [ + "category" + ], + "properties": { + "category": { + "title": "Category of restart", + "description": "Specifies what category of restart is required by this remediation to become effective.", + "type": "string", + "enum": [ + "connected", + "dependencies", + "machine", + "none", + "parent", + "service", + "system", + "vulnerable_component", + "zone" + ] + }, + "details": { + "title": "Additional restart information", + "description": "Provides additional information for the restart. This can include details on procedures, scope or impact.", + "type": "string", + "minLength": 1 + } + } + }, + "url": { + "title": "URL to the remediation", + "description": "Contains the URL where to obtain the remediation.", + "type": "string", + "format": "uri" + } + } + } + }, + "scores": { + "title": "List of scores", + "description": "Contains score objects for the current vulnerability.", + "type": "array", + "minItems": 1, + "items": { + "title": "Score", + "description": "Specifies information about (at least one) score of the vulnerability and for which products the given value applies.", + "type": "object", + "minProperties": 2, + "required": [ + "products" + ], + "properties": { + "cvss_v2": { + "$ref": "https://www.first.org/cvss/cvss-v2.0.json" + }, + "cvss_v3": { + "oneOf": [ + { + "$ref": "https://www.first.org/cvss/cvss-v3.0.json" + }, + { + "$ref": "https://www.first.org/cvss/cvss-v3.1.json" + } + ] + }, + "products": { + "$ref": "#/$defs/products_t" + } + } + } + }, + "threats": { + "title": "List of threats", + "description": "Contains information about a vulnerability that can change with time.", + "type": "array", + "minItems": 1, + "items": { + "title": "Threat", + "description": "Contains the vulnerability kinetic information. This information can change as the vulnerability ages and new information becomes available.", + "type": "object", + "required": [ + "category", + "details" + ], + "properties": { + "category": { + "title": "Category of the threat", + "description": "Categorizes the threat according to the rules of the specification.", + "type": "string", + "enum": [ + "exploit_status", + "impact", + "target_set" + ] + }, + "date": { + "title": "Date of the threat", + "description": "Contains the date when the assessment was done or the threat appeared.", + "type": "string", + "format": "date-time" + }, + "details": { + "title": "Details of the threat", + "description": "Represents a thorough human-readable discussion of the threat.", + "type": "string", + "minLength": 1 + }, + "group_ids": { + "$ref": "#/$defs/product_groups_t" + }, + "product_ids": { + "$ref": "#/$defs/products_t" + } + } + } + }, + "title": { + "title": "Title", + "description": "Gives the document producer the ability to apply a canonical name or title to the vulnerability.", + "type": "string", + "minLength": 1 + } + } + } + } + } +} diff --git a/csaf_2.1/json_schema/provider_json_schema.json b/csaf_2.1/json_schema/provider_json_schema.json new file mode 100644 index 000000000..5dd5fc9ba --- /dev/null +++ b/csaf_2.1/json_schema/provider_json_schema.json @@ -0,0 +1,211 @@ +{ + "$schema": "https://json-schema.org/draft/2020-12/schema", + "$id": "https://docs.oasis-open.org/csaf/csaf/v2.0/provider_json_schema.json", + "title": "CSAF provider metadata", + "description": "Representation of metadata information of a CSAF provider as a JSON document.", + "type": "object", + "$defs": { + "json_url_t": { + "title": "JSON URL type", + "description": "Contains a URL of a JSON file.", + "type": "string", + "format": "uri", + "pattern": "\\.json$" + }, + "provider_url_t": { + "title": "Provider URL type", + "description": "Contains a URL of a provider-metadata.json.", + "type": "string", + "format": "uri", + "pattern": "/provider-metadata\\.json$" + }, + "url_t": { + "title": "Generic URL type", + "description": "Contains a URL.", + "type": "string", + "format": "uri" + } + }, + "required": [ + "canonical_url", + "last_updated", + "list_on_CSAF_aggregators", + "mirror_on_CSAF_aggregators", + "metadata_version", + "publisher", + "role" + ], + "properties": { + "canonical_url": { + "title": "Canonical URL", + "description": "Contains the URL for this document.", + "$ref": "#/$defs/provider_url_t" + }, + "distributions": { + "title": "List of Distribution", + "description": "Contains a list of used distribution mechanisms.", + "type": "array", + "minItems": 1, + "uniqueItems": true, + "items": { + "title": "Distribution", + "description": "Contains the information of a used distribution mechanism.", + "type": "object", + "minProperties": 1, + "properties": { + "directory_url": { + "title": "Directory URL", + "description": "Contains the base url for the directory distribution.", + "$ref": "#/$defs/url_t" + }, + "rolie": { + "title": "ROLIE", + "description": "Contains all information for ROLIE distribution.", + "type": "object", + "required": [ + "feeds" + ], + "properties": { + "categories": { + "title": "List of ROLIE category document URLs", + "description": "Contains a list of URLs which contain ROLIE category documents.", + "type": "array", + "minItems": 1, + "uniqueItems": true, + "items": { + "title": "ROLIE category document URL", + "description": "Contains a URL of a ROLIE category document.", + "$ref": "#/$defs/json_url_t" + } + }, + "feeds": { + "title": "List of ROLIE feeds", + "description": "Contains a list of information about ROLIE feeds.", + "type": "array", + "minItems": 1, + "uniqueItems": true, + "items": { + "title": "ROLIE feed", + "description": "Contains information about the ROLIE feed.", + "type": "object", + "required": [ + "tlp_label", + "url" + ], + "properties": { + "summary": { + "title": "Summary of the feed", + "description": "Contains a summary of the feed.", + "type": "string", + "examples": [ + "All TLP:WHITE advisories of Example Company." + ] + }, + "tlp_label": { + "title": "TLP label", + "description": "Provides the TLP label for the feed.", + "type": "string", + "enum": [ + "UNLABELED", + "WHITE", + "GREEN", + "AMBER", + "RED" + ] + }, + "url": { + "title": "URL of the feed", + "description": "Contains the URL of the feed.", + "$ref": "#/$defs/json_url_t" + } + } + } + }, + "services": { + "title": "List of ROLIE service document URLs", + "description": "Contains a list of URLs which contain ROLIE service documents.", + "type": "array", + "minItems": 1, + "uniqueItems": true, + "items": { + "title": "ROLIE service document URL", + "description": "Contains a URL of a ROLIE service document.", + "$ref": "#/$defs/json_url_t" + } + } + } + } + } + } + }, + "last_updated": { + "title": "Last updated", + "description": "Holds the date and time when the document was last updated.", + "type": "string", + "format": "date-time" + }, + "list_on_CSAF_aggregators": { + "title": "List on CSAF aggregators", + "description": "Decides whether this file should be linked in the list of a CSAF aggregator.", + "type": "boolean", + "default": true + }, + "metadata_version": { + "title": "CSAF provider metadata version", + "description": "Gives the version of the CSAF provider metadata specification which the document was generated for.", + "type": "string", + "enum": [ + "2.0" + ] + }, + "mirror_on_CSAF_aggregators": { + "title": "Mirror on CSAF aggregators", + "description": "Decides whether the CSAF documents can be mirrored and provided by a CSAF aggregator.", + "type": "boolean", + "default": true + }, + "public_openpgp_keys": { + "title": "List of public OpenPGP keys", + "description": "Contains a list of OpenPGP keys used to sign CSAF documents.", + "type": "array", + "items": { + "title": "PGP keys", + "description": "Contains all information about an OpenPGP key used to sign CSAF documents.", + "type": "object", + "required": [ + "url" + ], + "properties": { + "fingerprint": { + "title": "Fingerprint of the key", + "description": "Contains the fingerprint of the OpenPGP key.", + "type": "string", + "minLength": 40, + "pattern": "^[0-9a-fA-F]{40,}$" + }, + "url": { + "title": "URL of the key", + "description": "Contains the URL where the key can be retrieved.", + "$ref": "#/$defs/url_t" + } + } + } + }, + "publisher": { + "title": "Publisher", + "description": "Provides information about the publisher of the CSAF documents in this repository.", + "$ref": "https://docs.oasis-open.org/csaf/csaf/v2.0/csaf_json_schema.json#/properties/document/properties/publisher" + }, + "role": { + "title": "Role of the issuing party", + "description": "Contains the role of the issuing party according to section 7 in the CSAF standard.", + "type": "string", + "default": "csaf_provider", + "enum": [ + "csaf_publisher", + "csaf_provider", + "csaf_trusted_provider" + ] + } + } +} diff --git a/csaf_2.1/prose/csaf-v2.1-editor-draft.md b/csaf_2.1/prose/csaf-v2.1-editor-draft.md new file mode 100644 index 000000000..3eda7a4f8 --- /dev/null +++ b/csaf_2.1/prose/csaf-v2.1-editor-draft.md @@ -0,0 +1,7146 @@ + +![OASIS Logo](https://docs.oasis-open.org/templates/OASISLogo-v3.0.png) + +------- + +# Common Security Advisory Framework Version 2.0 + +## OASIS Standard + +## 18 November 2022 + +#### This stage: +https://docs.oasis-open.org/csaf/csaf/v2.0/os/csaf-v2.0-os.md (Authoritative) \ +https://docs.oasis-open.org/csaf/csaf/v2.0/os/csaf-v2.0-os.html \ +https://docs.oasis-open.org/csaf/csaf/v2.0/os/csaf-v2.0-os.pdf + +#### Previous stage: +https://docs.oasis-open.org/csaf/csaf/v2.0/cs03/csaf-v2.0-cs03.md (Authoritative) \ +https://docs.oasis-open.org/csaf/csaf/v2.0/cs03/csaf-v2.0-cs03.html \ +https://docs.oasis-open.org/csaf/csaf/v2.0/cs03/csaf-v2.0-cs03.pdf + +#### Latest stage: +https://docs.oasis-open.org/csaf/csaf/v2.0/csaf-v2.0.md (Authoritative) \ +https://docs.oasis-open.org/csaf/csaf/v2.0/csaf-v2.0.html \ +https://docs.oasis-open.org/csaf/csaf/v2.0/csaf-v2.0.pdf + +#### Technical Committee: +[OASIS Common Security Advisory Framework (CSAF) TC](https://www.oasis-open.org/committees/csaf/) + +#### Chair: +Omar Santos (osantos@cisco.com), [Cisco Systems](https://cisco.com/) + +#### Editors: +Langley Rock (lrock@redhat.com), [Red Hat](https://redhat.com/) \ +Stefan Hagen (stefan@hagen.link), [Individual](https://stefan-hagen.website/) \ +Thomas Schmidt (thomas.schmidt@bsi.bund.de), [Federal Office for Information Security (BSI) Germany](https://www.bsi.bund.de/) + +In Memory of Eric Johnson, TIBCO Software Inc. and Mike Gorski, Cisco Systems both active members of the OASIS CSAF Technical Committee. + +#### Additional artifacts: +This prose specification is one component of a Work Product that also includes: + +* Aggregator JSON schema: https://docs.oasis-open.org/csaf/csaf/v2.0/os/schemas/aggregator_json_schema.json. \ +Latest stage: https://docs.oasis-open.org/csaf/csaf/v2.0/aggregator_json_schema.json. +* CSAF JSON schema: https://docs.oasis-open.org/csaf/csaf/v2.0/os/schemas/csaf_json_schema.json. \ +Latest stage: https://docs.oasis-open.org/csaf/csaf/v2.0/csaf_json_schema.json. +* Provider JSON schema: https://docs.oasis-open.org/csaf/csaf/v2.0/os/schemas/provider_json_schema.json. \ +Latest stage: https://docs.oasis-open.org/csaf/csaf/v2.0/provider_json_schema.json. + +#### Related work: +This specification replaces or supersedes: + +* _CSAF Common Vulnerability Reporting Framework (CVRF) Version 1.2_. Edited by Stefan Hagen. Latest stage: https://docs.oasis-open.org/csaf/csaf-cvrf/v1.2/csaf-cvrf-v1.2.html. + +#### Declared JSON namespaces: + +* [https://docs.oasis-open.org/csaf/csaf/v2.0/aggregator_json_schema.json](https://docs.oasis-open.org/csaf/csaf/v2.0/aggregator_json_schema.json) +* [https://docs.oasis-open.org/csaf/csaf/v2.0/csaf_json_schema.json](https://docs.oasis-open.org/csaf/csaf/v2.0/csaf_json_schema.json) +* [https://docs.oasis-open.org/csaf/csaf/v2.0/provider_json_schema.json](https://docs.oasis-open.org/csaf/csaf/v2.0/provider_json_schema.json) + + +#### Abstract: +The Common Security Advisory Framework (CSAF) Version 2.0 is the definitive reference for the language which supports creation, update, and interoperable exchange of security advisories as structured information on products, vulnerabilities and the status of impact and remediation among interested parties. + +#### Status: +This document was last revised or approved by the membership of OASIS on the above date. The level of approval is also listed above. Check the "Latest stage" location noted above for possible later revisions of this document. Any other numbered Versions and other technical work produced by the Technical Committee (TC) are listed at https://www.oasis-open.org/committees/tc_home.php?wg_abbrev=csaf#technical. + +TC members should send comments on this specification to the TC's email list. Others should send comments to the TC's public comment list, after subscribing to it by following the instructions at the "Send A Comment" button on the TC's web page at https://www.oasis-open.org/committees/csaf/. + +This specification is provided under the [Non-Assertion](https://www.oasis-open.org/policies-guidelines/ipr/#Non-Assertion-Mode) Mode of the [OASIS IPR Policy](https://www.oasis-open.org/policies-guidelines/ipr/), the mode chosen when the Technical Committee was established. For information on whether any patents have been disclosed that may be essential to implementing this specification, and any offers of patent licensing terms, please refer to the Intellectual Property Rights section of the TC's web page (https://www.oasis-open.org/committees/csaf/ipr.php). + +Note that any machine-readable content ([Computer Language Definitions](https://www.oasis-open.org/policies-guidelines/tc-process-2017-05-26/#wpComponentsCompLang)) declared Normative for this Work Product is provided in separate plain text files. In the event of a discrepancy between any such plain text file and display content in the Work Product's prose narrative document(s), the content in the separate plain text file prevails. + +#### Citation format: +When referencing this specification the following citation format should be used: + +**[csaf-v2.0]** + +_Common Security Advisory Framework Version 2.0_. Edited by Langley Rock, Stefan Hagen, and Thomas Schmidt. 18 November 2022. OASIS Standard. https://docs.oasis-open.org/csaf/csaf/v2.0/os/csaf-v2.0-os.html. Latest stage: https://docs.oasis-open.org/csaf/csaf/v2.0/csaf-v2.0.html. + + +------- + +## Notices + +Copyright © OASIS Open 2022. All Rights Reserved. + +All capitalized terms in the following text have the meanings assigned to them in the OASIS Intellectual Property Rights Policy (the "OASIS IPR Policy"). The full [Policy](https://www.oasis-open.org/policies-guidelines/ipr/) may be found at the OASIS website. + +This document and translations of it may be copied and furnished to others, and derivative works that comment on or otherwise explain it or assist in its implementation may be prepared, copied, published, and distributed, in whole or in part, without restriction of any kind, provided that the above copyright notice and this section are included on all such copies and derivative works. However, this document itself may not be modified in any way, including by removing the copyright notice or references to OASIS, except as needed for the purpose of developing any document or deliverable produced by an OASIS Technical Committee (in which case the rules applicable to copyrights, as set forth in the OASIS IPR Policy, must be followed) or as required to translate it into languages other than English. + +The limited permissions granted above are perpetual and will not be revoked by OASIS or its successors or assigns. + +This document and the information contained herein is provided on an "AS IS" basis and OASIS DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION HEREIN WILL NOT INFRINGE ANY OWNERSHIP RIGHTS OR ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. + +As stated in the OASIS IPR Policy, the following three paragraphs in brackets apply to OASIS Standards Final Deliverable documents (Committee Specification, Candidate OASIS Standard, OASIS Standard, or Approved Errata). + +\[OASIS requests that any OASIS Party or any other party that believes it has patent claims that would necessarily be infringed by implementations of this OASIS Standards Final Deliverable, to notify OASIS TC Administrator and provide an indication of its willingness to grant patent licenses to such patent claims in a manner consistent with the IPR Mode of the OASIS Technical Committee that produced this deliverable.\] + +\[OASIS invites any party to contact the OASIS TC Administrator if it is aware of a claim of ownership of any patent claims that would necessarily be infringed by implementations of this OASIS Standards Final Deliverable by a patent holder that is not willing to provide a license to such patent claims in a manner consistent with the IPR Mode of the OASIS Technical Committee that produced this OASIS Standards Final Deliverable. OASIS may include such claims on its website, but disclaims any obligation to do so.\] + +\[OASIS takes no position regarding the validity or scope of any intellectual property or other rights that might be claimed to pertain to the implementation or use of the technology described in this OASIS Standards Final Deliverable or the extent to which any license under such rights might or might not be available; neither does it represent that it has made any effort to identify any such rights. Information on OASIS' procedures with respect to rights in any document or deliverable produced by an OASIS Technical Committee can be found on the OASIS website. Copies of claims of rights made available for publication and any assurances of licenses to be made available, or the result of an attempt made to obtain a general license or permission for the use of such proprietary rights by implementers or users of this OASIS Standards Final Deliverable, can be obtained from the OASIS TC Administrator. OASIS makes no representation that any information or list of intellectual property rights will at any time be complete, or that any claims in such list are, in fact, Essential Claims.\] + +The name "OASIS" is a trademark of [OASIS](https://www.oasis-open.org/), the owner and developer of this specification, and should be used only to refer to the organization and its official outputs. OASIS welcomes reference to, and implementation and use of, specifications, while reserving the right to enforce its marks against misleading uses. Please see https://www.oasis-open.org/policies-guidelines/trademark/ for above guidance. + +------- + +# Table of Contents + +[[TOC will be inserted here]] + +------- + +# 1 Introduction + +## 1.1 IPR Policy + +This specification is provided under the [Non-Assertion](https://www.oasis-open.org/policies-guidelines/ipr/#Non-Assertion-Mode) Mode of the [OASIS IPR Policy](https://www.oasis-open.org/policies-guidelines/ipr/), the mode chosen when the Technical Committee was established. For information on whether any patents have been disclosed that may be essential to implementing this specification, and any offers of patent licensing terms, please refer to the Intellectual Property Rights section of the TC's web page ([https://www.oasis-open.org/committees/csaf/ipr.php](https://www.oasis-open.org/committees/csaf/ipr.php)). + +## 1.2 Terminology + +The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 [[RFC2119](#rfc2119)] and [[RFC8174](#rfc8174)] when, and only when, they appear in all capitals, as shown here. + +For purposes of this document, the following terms and definitions apply: + +**advisory**: reporting item that describes a condition present in an artifact and that requires action by the consumers + +**advisory document**: artifact in which an analysis tool reports a result + +**advisory management system**: software system that consumes the documents produced by analysis tools, produces advisories that enable engineering and operating organizations to assess the quality of these software artifacts at a point in time, and performs functions such as filing security advisories and displaying information about individual advisories. **Note**: An advisory management system can interact with a document viewer to display information about individual advisories. + +**advisory matching**: process of determining whether two advisories are targeting the same products and conditions + +**artifact**: sequence of bytes addressable via a URI. _Examples_: A physical file in a file system such as a source file, an object file, a configuration file or a data file; a specific version of a file in a version control system; a database table accessed via an HTTP request; an arbitrary stream of bytes returned from an HTTP request, a product URL, a common product enumeration value. + +**CSAF asset matching system**: program that connects to or is an asset database and is able to manage CSAF documents as required by CSAF management system as well as matching them to assets of the asset database. + +**CSAF basic validator**: A program that reads a document and checks it against the JSON schema and performs mandatory tests. + +**CSAF consumer**: program that reads and interprets a CSAF document + +**CSAF content management system**: program that is able to create, review and manage CSAF documents and is able to preview their details as required by CSAF viewer. + +**CSAF converter**: CSAF producer that transforms the output of an analysis tool from its native output format into the CSAF format + +**CSAF direct producer**: analysis tool which acts as a CSAF producer + +**CSAF document**: security advisory text document in the format defined by this document. + +**CSAF extended validator**: A CSAF basic validator that additionally performs optional tests. + +**CSAF full validator**: A CSAF extended validator that additionally performs informative tests. + +**CSAF management system**: program that is able to manage CSAF documents and is able to display their details as required by CSAF viewer. + +**CSAF modifier**: CSAF post-processor which takes a CSAF document as input and modifies the structure or values of properties. The output is a valid CSAF document. + +**CSAF post-processor**: CSAF producer that transforms an existing CSAF document into a new CSAF document, for example, by removing or redacting elements according to sharing policies. + +**CSAF SBOM matching system**: A program that connects to or is an SBOM database and is able to manage CSAF documents as required by CSAF management system as well as matching them to SBOM components of the SBOM database. + +**CSAF producer**: program that emits output in the CSAF format + +**CSAF translator**: CSAF post-processor which takes a CSAF document as input and translates values of properties into another language. The output is a valid CSAF document. + +**CSAF viewer**: CSAF consumer that reads a CSAF document, displays a list of the results it contains, and allows an end user to view each result in the context of the artifact in which it occurs. + +**CVRF CSAF converter**: CSAF producer which takes a CVRF document as input and converts it into a valid CSAF document. + +**document**: output file produced by an analysis tool, which enumerates the results produced by the tool + +**driver**: tool component containing an analysis tool’s or converter’s primary executable, which controls the tool’s or converter’s execution, and which in the case of an analysis tool typically defines a set of analysis rules + +**embedded link**: syntactic construct which enables a message string to refer to a location mentioned in the document + +**empty array**: array that contains no elements, and so has a length of 0 + +**empty object**: object that contains no properties + +**empty string**: string that contains no characters, and so has a length of 0 + +**(end) user**: person who uses the information in a document to investigate, triage, or resolve results + +**engineering system**: software analysis environment within which analysis tools execute. **Note**: An engineering system might include a build system, a source control system, a result management system, a bug tracking system, a test execution system, and so on. + +**extension**: tool component other than the driver (for example, a plugin, a configuration file, or a taxonomy) + +**external property file**: file containing the values of one or more externalized properties + +**externalizable property**: property that can be contained in an external property file + +**externalized property**: property stored outside of the CSAF document to which it logically belongs + +**false positive**: result which an end user decides does not actually represent a problem + +**fingerprint**: stable value that can be used by a result management system to uniquely identify a result over time, even if a relevant artifact is modified + +**formatted message**: message string which contains formatting information such as Markdown formatting characters + +**fully qualified logical name**: string that fully identifies the programmatic construct specified by a logical location, typically by means of a hierarchical identifier. + +**hierarchical string**: string in the format <component>{/<component>}* + +**line**: contiguous sequence of characters, starting either at the beginning of an artifact or immediately after a newline sequence, and ending at and including the nearest subsequent newline sequence, if one is present, or else extending to the end of the artifact + +**line (number)**: 1-based index of a line within a file. **Note**: Abbreviated to "line" when there is no danger of ambiguity with "line" in the sense of a sequence of characters. + +**localizable**: subject to being translated from one natural language to another + +**message string**: human-readable string that conveys information relevant to an element in a CSAF document + +**nested artifact**: artifact that is contained within another artifact + +**newline sequence**: sequence of one or more characters representing the end of a line of text. **Note**: Some systems represent a newline sequence with a single newline character; others represent it as a carriage return character followed by a newline character. + +**notification**: reporting item that describes a condition encountered by a tool during its execution + +**opaque**: neither human-readable nor machine-parsable into constituent parts + +**parent (artifact)**: artifact which contains one or more nested artifacts + +**plain text message**: message string which does not contain any formatting information + +**plugin**: tool component that defines additional rules + +**policy**: set of rule configurations that specify how results that violate the rules defined by a particular tool component are to be treated + +**problem**: result which indicates a condition that has the potential to detract from the quality of the program. _Examples_: A security vulnerability, a deviation from contractual or legal requirements. + +**product**: is any deliverable (e.g. software, hardware, specification,...) which can be referred to with a name. This applies regardless of the origin, the license model, or the mode of distribution of the deliverable. + +**property**: attribute of an object consisting of a name and a value associated with the name + +**redactable property**: property that potentially contains sensitive information that a CSAF direct producer or a CSAF post-processor might wish to redact + +**reporting item**: unit of output produced by a tool, either a result or a notification + +**reporting configuration**: the subset of reporting metadata that a tool can configure at runtime, before performing its scan. _Examples_: severity level, rank + +**repository** container for a related set of files in a version control system + +**taxonomy**: classification of analysis results into a set of categories + +**tag**: string that conveys additional information about the CSAF document element to which it applies + +**text artifact**: artifact considered as a sequence of characters organized into lines and columns + +**text region**: region representing a contiguous range of zero or more characters in a text artifact + +**tool component**: component of an analysis tool or converter, either its driver or an extension, consisting of one or more files + +**top-level artifact**: artifact which is not contained within any other artifact + +**translation**: rendering of a tool component's localizable strings into another language + +**triage**: decide whether a result indicates a problem that needs to be corrected + +**user**: see end user. + +**VCS**: version control system + +**vendor**: the community, individual, or organization that created or maintains a product (including open source software and hardware providers) + +**VEX**: Vulnerability Exploitability eXchange - enables a supplier or other party to assert whether or not a particular product is affected by a specific vulnerability, especially helpful in efficiently consuming SBOM data. + +**viewer**: see CSAF viewer. + +**vulnerability**: functional behavior of a product or service that violates an implicit or explicit security policy (conforming to ISO/IEC 29147 [ISO29147]) + +**XML**: eXtensible Markup Language - the format used by the predecessors of this standard, namely CVRF 1.1 and CVRF 1.2. + +## 1.3 Normative References + +###### [JSON-Schema-Core] +_JSON Schema: A Media Type for Describing JSON Documents_, draft-bhutton-json-schema-00, December 2020, https://datatracker.ietf.org/doc/html/draft-bhutton-json-schema-00. +###### [JSON-Schema-Validation] +_JSON Schema Validation: A Vocabulary for Structural Validation of JSON_, draft-bhutton-json-schema-validation-00, December 2020, https://datatracker.ietf.org/doc/html/draft-bhutton-json-schema-validation-00. +###### [JSON-Hyper-Schema] +_JSON Hyper-Schema: A Vocabulary for Hypermedia Annotation of JSON_, draft-handrews-json-schema-hyperschema-02, September 2019, https://json-schema.org/draft/2019-09/json-schema-hypermedia.html. +###### [Relative-JSON-Pointers] +_Relative JSON Pointers_, draft-bhutton-relative-json-pointer-00, December 2020, https://datatracker.ietf.org/doc/html/draft-bhutton-relative-json-pointer-00. +###### [RFC2119] +Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, DOI 10.17487/RFC2119, March 1997, https://www.rfc-editor.org/info/rfc2119. +###### [RFC7464] +Williams, N., "JavaScript Object Notation (JSON) Text Sequences", RFC 7464, DOI 10.17487/RFC7464, February 2015, https://www.rfc-editor.org/info/rfc7464. +###### [RFC8174] +Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174, May 2017, https://www.rfc-editor.org/info/rfc8174. +###### [RFC8259] +T. Bray, Ed., "The JavaScript Object Notation (JSON) Data Interchange Format", RFC 8259, DOI 10.17487/RFC8259, December 2017, https://www.rfc-editor.org/info/rfc8259. + +## 1.4 Informative References + +###### [CPE23-A] +_Common Platform Enumeration: Applicability Language Specification Version 2.3 (NISTIR 7698)_, D. Waltermire, P. Cichonski, K. Scarfone, Editors, NIST Interagency Report 7698, August 2011, https://dx.doi.org/10.6028/NIST.IR.7698. +###### [CPE23-D] +_Common Platform Enumeration: Dictionary Specification Version 2.3_, P. Cichonski, D. Waltermire, K. Scarfone, Editors, NIST Interagency Report 7697, August 2011, https://dx.doi.org/10.6028/NIST.IR.7697. +###### [CPE23-M] +_Common Platform Enumeration: Naming Matching Specification Version 2.3_, M. Parmelee, H. Booth, D. Waltermire, K. Scarfone, Editors, NIST Interagency Report 7696, August 2011, https://dx.doi.org/10.6028/NIST.IR.7696. +###### [CPE23-N] +_Common Platform Enumeration: Naming Specification Version 2.3_, B. Cheikes, D. Waltermire, K. Scarfone, Editors, NIST Interagency Report 7695, August 2011, https://dx.doi.org/10.6028/NIST.IR.7695. +###### [CVE] +_Common Vulnerability and Exposures (CVE) – The Standard for Information Security Vulnerability Names_, MITRE, 1999, https://cve.mitre.org/about/. +###### [CVE-NF] +_Common Vulnerability and Exposures (CVE) – The Standard for Information Security Vulnerability Names - CVE ID Syntax Change_, MITRE, January 01, 2014, https://cve.mitre.org/cve/identifiers/syntaxchange.html. +###### [CVRF-1-1] +_The Common Vulnerability Reporting Framework (CVRF) Version 1.1_, M. Schiffman, Editor, May 2012, Internet Consortium for Advancement of Security on the Internet (ICASI), https://www.icasi.org/the-common-vulnerability-reporting-framework-cvrf-v1-1/. +###### [CVRF-v1.2] +_CSAF Common Vulnerability Reporting Framework (CVRF) Version 1.2_. Edited by Stefan Hagen. 13 September 2017. OASIS Committee Specification 01. https://docs.oasis-open.org/csaf/csaf-cvrf/v1.2/cs01/csaf-cvrf-v1.2-cs01.html. Latest version: https://docs.oasis-open.org/csaf/csaf-cvrf/v1.2/csaf-cvrf-v1.2.html. +###### [CVSS2] +_A Complete Guide to the Common Vulnerability Scoring System Version 2.0_, P. Mell, K. Scarfone, S. Romanosky, Editors, First.org, Inc., June 2007, https://www.first.org/cvss/cvss-v2-guide.pdf. +###### [CVSS30] +_Common Vulnerability Scoring System v3.0: Specification Document_, FIRST.Org, Inc., June 2019, https://www.first.org/cvss/v3.0/cvss-v30-specification_v1.9.pdf. +###### [CVSS31] +_Common Vulnerability Scoring System v3.1: Specification Document_, FIRST.Org, Inc., June 2019, https://www.first.org/cvss/v3-1/cvss-v31-specification_r1.pdf. +###### [CWE] +_Common Weakness Enumeration (CWE) – A Community-Developed List of Software Weakness Types_, MITRE, 2005, http://cwe.mitre.org/about/. +###### [CYCLONEDX13] +_CycloneDX Software Bill-of-Material Specification JSON schema version 1.3_, cyclonedx.org, May 2021, https://github.com/CycloneDX/specification/blob/1.3/schema/bom-1.3.schema.json. +###### [GFMCMARK] +_GitHub's fork of cmark, a CommonMark parsing and rendering library and program in C_, https://github.com/github/cmark. +###### [GFMENG] +_GitHub Engineering: A formal spec for GitHub Flavored Markdown_, https://githubengineering.com/a-formal-spec-for-github-markdown/. +###### [ISO8601] +_Data elements and interchange formats — Information interchange — Representation of dates and times_, International Standard, ISO 8601:2004(E), December 1, 2004, https://www.iso.org/standard/40874.html. +###### [ISO19770-2] +_Information technology — IT asset management — Part 2: Software identification tag_, International Standard, ISO 19770-2:2015, September 30, 2015, +https://www.iso.org/standard/65666.html. +###### [ISO29147] +_Information technology — Security techniques — Vulnerability disclosure_, International Standard, ISO/IEC 29147:2018, October, 2018, +https://www.iso.org/standard/72311.html. +###### [OPENSSL] +_GTLS/SSL and crypto library_, OpenSSL Software Foundation, https://www.openssl.org/. +###### [PURL] +_Package URL (PURL)_, GitHub Project, https://github.com/package-url/purl-spec. +###### [RFC3339] +Klyne, G. and C. Newman, "Date and Time on the Internet: Timestamps", RFC 3339, DOI 10.17487/RFC3339, July 2002, https://www.rfc-editor.org/info/rfc3339. +###### [RFC3552] +Rescorla, E. and B. Korver, "Guidelines for Writing RFC Text on Security Considerations", BCP 72, RFC 3552, DOI 10.17487/RFC3552, July 2003, https://www.rfc-editor.org/info/rfc3552. +###### [RFC3986] +Berners-Lee, T., Fielding, R., and L. Masinter, "Uniform Resource Identifier (URI): Generic Syntax", STD 66, RFC 3986, DOI 10.17487/RFC3986, January 2005, https://www.rfc-editor.org/info/rfc3986. +###### [RFC4880] +Callas, J., Donnerhacke, L., Finney, H., Shaw, D., and R. Thayer, "OpenPGP Message Format", RFC 4880, DOI 10.17487/RFC4880, November 2007, https://www.rfc-editor.org/info/rfc4880. +###### [RFC7231] +Fielding, R., Ed., and J. Reschke, Ed., "Hypertext Transfer Protocol (HTTP/1.1): Semantics and Content", RFC 7231, DOI 10.17487/RFC7231, June 2014, https://www.rfc-editor.org/info/rfc7231. +###### [RFC7464] +N. Williams., "JavaScript Object Notation (JSON) Text Sequences", RFC 7464, DOI 10.17487/RFC7464, February 2015, https://www.rfc-editor.org/info/rfc7464. +###### [RFC8615] +Nottingham, M., "Well-Known Uniform Resource Identifiers (URIs)", RFC 8615, DOI 10.17487/RFC8615, May 2019, https://www.rfc-editor.org/info/rfc8615. +###### [RFC9116] +Foudil, E. and Y. Shafranovich, "A File Format to Aid in Security Vulnerability Disclosure", RFC 9116, DOI 10.17487/RFC9116, April 2022, https://www.rfc-editor.org/info/rfc9116. +###### [SCAP12] +_The Technical Specification for the Security Content Automation Protocol (SCAP): SCAP Version 1.2_, D. Waltermire, S. Quinn, K. Scarfone, A. Halbardier, Editors, NIST Spec. Publ. 800‑126 rev. 2, September 2011, https://dx.doi.org/10.6028/NIST.SP.800-126r2. +###### [SECURITY-TXT] +Foudil, E. and Shafranovich, Y., _Security.txt Project_, https://securitytxt.org/. +###### [SemVer] +_Semantic Versioning 2.0.0_, T. Preston-Werner, June 2013, https://semver.org/. +###### [SPDX22] +_The Software Package Data Exchange (SPDX®) Specification Version 2.2_, Linux Foundation and its Contributors, 2020, https://spdx.github.io/spdx-spec/. +###### [VERS] +_vers: a mostly universal version range specifier_, Part of the PURL GitHub Project, https://github.com/package-url/purl-spec/blob/version-range-spec/VERSION-RANGE-SPEC.rst. +###### [VEX] +_Vulnerability-Exploitability eXchange (VEX) - An Overview_, VEX sub-group of the Framing Working Group in the NTIA SBOM initiative, 27 September 2021, +https://ntia.gov/files/ntia/publications/vex_one-page_summary.pdf. +###### [VEX-Justification] +_Vulnerability Exploitability eXchange (VEX) - Status Justifications_, VEX sub-group of the Framing Working Group in the CISA SBOM initiative, XX May 2022, https://www.cisa.gov/sites/default/files/publications/VEX_Status_Justification_Jun22.pdf. +###### [XML] +_Extensible Markup Language (XML) 1.0 (Fifth Edition)_, T. Bray, J. Paoli, M. Sperberg-McQueen, E. Maler, F. Yergeau, Editors, W3C Recommendation, November 26, 2008, https://www.w3.org/TR/2008/REC-xml-20081126/. +Latest version available at https://www.w3.org/TR/xml. +###### [XML-Schema-1] +_W3C XML Schema Definition Language (XSD) 1.1 Part 1: Structures_, S. Gao, M. Sperberg-McQueen, H. Thompson, N. Mendelsohn, D. Beech, M. Maloney, Editors, W3C Recommendation, April 5, 2012, https://www.w3.org/TR/2012/REC-xmlschema11-1-20120405/. +Latest version available at https://www.w3.org/TR/xmlschema11-1/. +###### [XML-Schema-2] +_W3C XML Schema Definition Language (XSD) 1.1 Part 2_: Datatypes W3C XML Schema Definition Language (XSD) 1.1 Part 2: Datatypes, D. Peterson, S. Gao, A. Malhotra, M. Sperberg-McQueen, H. Thompson, Paul V. Biron, Editors, W3C Recommendation, April 5, 2012, https://www.w3.org/TR/2012/REC-xmlschema11-2-20120405/. +Latest version available at https://www.w3.org/TR/xmlschema11-2/. + +## 1.5 Typographical Conventions + +Keywords defined by this specification use this `monospaced` font. + +``` + Normative source code uses this paragraph style. +``` + +Some sections of this specification are illustrated with non-normative examples introduced with "Example" or "Examples" like so: + +*Examples 4321:* + +``` + Informative examples also use this paragraph style but preceded by the text "Example(s)". +``` + +All examples in this document are informative only. + +All other text is normative unless otherwise labeled e.g. like the following informative comment: + +>This is a pure informative comment that may be present, because the information conveyed is deemed useful advice or common pitfalls learned from implementer or operator experience and often given including the rationale. + +------- + +# 2 Design Considerations + +The Common Security Advisory Framework (CSAF) is a language to exchange Security Advisories formulated in JSON. + +The term Security Advisory as used in this document describes any notification of security issues in products of and by providers. Anyone providing a product is considered in this document as a vendor, i.e. developers or maintainers of information system products or services. This includes all authoritative product vendors, Product Security Incident Response Teams (PSIRTs), and product resellers and distributors, including authoritative vendor partners. +A security issue is not necessarily constrained to a problem statement, the focus of the term is on the security aspect impacting (or not impacting) specific product-platform-version combinations. Information on presence or absence of workarounds is also considered part of the security issue. +This document is the definitive reference for the language elements of CSAF version 2.0. The encompassing JSON schema file noted in the Additional Artifacts section of the title page SHALL be taken as normative in the case a gap or an inconsistency in this explanatory document becomes evident. +The following presentation in this section is grouped by topical area, and is not simply derivative documentation from the schema document itself. The information contained aims to be more descriptive and complete. Where applicable, common conventions are stated and known common issues in usage are pointed out informatively to support implementers of document producers and consumers alike. + +This minimal required information set does not provide any useful information on products, vulnerabilities, or security advisories. Thus, any real-world Security Advisory will carry additional information as specified in section 3 Schema elements. + +Care has been taken, to design the containers for product and vulnerability information to support fine-grained mapping of security advisories onto product and vulnerability and minimize data duplication through referencing. +The display of the elements representing Product Tree and Vulnerability information has been placed in the sections named accordingly. + +## 2.1 Construction Principles + +A Security Advisory defined as a CSAF document is the result of complex orchestration of many players and distinct and partially difficult to play schemas. + +The format chosen is [JSONSchema] which allows validation and delegation to sub schema providers. The latter aligns well with separation of concerns and shares the format family of information interchange utilized by the providers of product and vulnerability information which migrated from XML to JSON since the creation of CSAF CVRF version 1.2, the predecessor of this specification. + +The acronym CSAF, “Common Security Advisory Framework”, stands for the target of concerted mitigation and remediation accomplishment. + +Technically, the use of JSON schema allows validation and proof of model conformance (through established schema based validation) of the declared information inside CSAF documents. + +The CSAF schema structures its derived documents into three main classes of the information conveyed: + +1. The frame, aggregation, and reference information of the document +2. Product information considered relevant by the creator +3. Vulnerability information and its relation to the products declared in 2. + +Wherever possible repetition of data has been replaced by linkage through ID elements. Consistency on the content level thus is in the responsibility of the producer of such documents, to link e.g. vulnerability information to the matching product. + +A dictionary like presentation of all defined schema elements is given in the section 3. Any expected relations to other elements (linkage) is described there. This linking relies on setting attribute values accordingly (mostly guided by industry best practice and conventions) and thus implies, that any deep validation on a semantic level (e.g. does the CWE match the described vulnerability) is to be ensured by the producer and consumer of CSAF documents. It is out of scope for this specification. + +Proven and intended usage patterns from practice are given where possible. + +Delegation to industry best practices technologies is used in referencing schemas for: + +* Platform Data: + * Common Platform Enumeration (CPE) Version 2.3 [CPE23-N] +* Vulnerability Scoring: + * Common Vulnerability Scoring System (CVSS) Version 3.1 [CVSS31] + * JSON Schema Reference https://www.first.org/cvss/cvss-v3.1.json + * Common Vulnerability Scoring System (CVSS) Version 3.0 [CVSS30] + * JSON Schema Reference https://www.first.org/cvss/cvss-v3.0.json + * Common Vulnerability Scoring System (CVSS) Version 2.0 [CVSS2] + * JSON Schema Reference https://www.first.org/cvss/cvss-v2.0.json +* Vulnerability Classification + * Common Weakness Enumeration (CWE) [CWE] + * CWE List: http://cwe.mitre.org/data/index.html +* Classification for Document Distribution + * Traffic Light Protocol (TLP) + * Default Definition: https://www.first.org/tlp/ + +Even though the JSON schema does not prohibit specifically additional properties and custom keywords, it is strongly recommended not to use them. Suggestions for new fields SHOULD be made through issues in the TC's GitHub. + +> The standardized fields allow for scalability across different issuing parties and dramatically reduce the human effort and need for dedicated parsers as well as other tools on the side of the consuming parties. + +Section 4 defined profiles that are used to ensure a common understanding of which fields are required in a given use case. Additional conventions are stated in section 5. The tests given in section 6 support CSAF producers and consumers to verify rules from the specification which can not be tested by the schema. Section 7 states how to distribute and where to find CSAF documents. Safety, Security and Data Protection are considered in section 8. Finally, a set of conformance targets describes tools in the ecosystem. + +------- + +# 3 Schema Elements + +The CSAF schema describes how to represent security advisory information as a JSON document. + +The CSAF schema Version 2.0 builds on the JSON Schema draft 2020-12 rules. + +``` + "$schema": "https://json-schema.org/draft/2020-12/schema" +``` + +The schema identifier is: + +``` + "$id": "https://docs.oasis-open.org/csaf/csaf/v2.0/csaf_json_schema.json" +``` + +The further documentation of the schema is organized via Definitions and Properties. + +* Definitions provide types that extend the JSON schema model +* Properties use these types to support assembling security advisories + +Types and properties together provide the vocabulary for the domain specific language supporting security advisories. + +The single mandatory property is `document`. +The optional two additional properties are `product_tree` and `vulnerabilities`. + +## 3.1 Definitions + +The definitions (`$defs`) introduce the following domain specific types into the CSAF language: +Acknowledgments (`acknowledgments_t`), Branches (`branches_t`), Full Product Name (`full_product_name_t`), Language (`lang_t`), Notes (`notes_t`), +Product Group ID (`product_group_id_t`), Product Groups (`product_groups_t`), Product ID (`product_id_t`), Products (`products_t`), References (`references_t`), +and Version (`version_t`). + +``` + "$defs": { + "acknowledgments_t": { + // ... + }, + "branches_t": { + // ... + }, + "full_product_name_t": { + // ... + }, + "lang_t": { + // ... + }, + "notes_t": { + // ... + }, + "product_group_id_t": { + // ... + }, + "product_groups_t": { + // ... + }, + "product_id_t": { + // ... + }, + "products_t": { + // ... + }, + "references_t": { + // ... + }, + "version_t": { + // ... + } + }, +``` + +### 3.1.1 Acknowledgments Type + +List of Acknowledgments (`acknowledgments_t`) type instances of value type `array` with 1 or more elements contain a list of `Acknowledgment` elements. + +``` + "acknowledgments_t": { + // ... + "items": { + // ... + } + }, +``` + +The value type of Acknowledgment is `object` with at least 1 and at most 4 properties. Every such element acknowledges contributions by describing those that contributed. +The properties are: `names`, `organization`, `summary`, and `urls`. + +``` + "properties": { + "names": { + // ... + }, + "organization": { + // ... + }, + "summary": { + // ... + }, + "urls": { + // ... + } + } +``` + +#### 3.1.1.1 Acknowledgments Type - Names + +List of acknowledged names (`names`) has value type `array` with 1 or more items holds the names of contributors being recognized. +Every such item of value type `string` with 1 or more characters represents the name of the contributor and contains the name of a single contributor being recognized. + +*Examples 1:* + +``` + Albert Einstein + Johann Sebastian Bach +``` + +#### 3.1.1.2 Acknowledgments Type - Organization + +The contributing organization (`organization`) has value type `string` with 1 or more characters and holds the name of the contributing organization being recognized. + +*Examples 2:* + +``` + CISA + Google Project Zero + Talos +``` + +#### 3.1.1.3 Acknowledgments Type - Summary + +Summary of the acknowledgment (`summary`) of value type `string` with 1 or more characters SHOULD represent any contextual details the document producers wish to make known about the acknowledgment or acknowledged parties. + +*Example 3:* + +``` + First analysis of Coordinated Multi-Stream Attack (CMSA) +``` + +#### 3.1.1.4 Acknowledgments Type - URLs + +List of URLs (`urls`) of acknowledgment is a container (value type `array`) for 1 or more `string` of type URL that specifies a list of URLs or location of the reference to be acknowledged. +Any URL of acknowledgment contains the URL or location of the reference to be acknowledged. +Value type is string with format URI (`uri`). + +#### 3.1.1.5 Acknowledgments Type - Example + +*Example 4:* + +``` + "acknowledgments": [ + { + "names": [ + "Johann Sebastian Bach", + "Georg Philipp Telemann", + "Georg Friedrich Händel" + ], + "organization": "Baroque composers", + "summary": "wonderful music" + }, + { + "organization": "CISA", + "summary": "coordination efforts", + "urls": [ + "https://cisa.gov" + ] + }, + { + "organization": "BSI", + "summary": "assistance in coordination" + }, + { + "names": [ + "Antonio Vivaldi" + ], + "summary": "influencing other composers" + } + ], +``` + +The example 4 above SHOULD lead to the following outcome in a human-readable advisory: + +> We thank the following parties for their efforts: +> +> * Johann Sebastian Bach, Georg Philipp Telemann, Georg Friedrich Händel from Baroque composers for wonderful music +> * CISA for coordination efforts (see: https://cisa.gov) +> * BSI for assistance in coordination +> * Antonio Vivaldi for influencing other composers + +### 3.1.2 Branches Type + +List of branches (`branches_t`) with value type `array` contains 1 or more branch elements as children of the current element. + +``` + "branches_t": { + //... + "items": { + // ... + } + }, +``` + +Every Branch holds exactly 3 properties and is a part of the hierarchical structure of the product tree. +The properties `name` and `category` are mandatory. In addition, the object contains either a `branches` or a `product` property. + +``` + "properties": { + "branches": { + // ... + }, + "category": { + // ... + }, + "name": { + // ... + }, + "product": { + // ... + } + } +``` + +> `branches_t` supports building a hierarchical structure of products that allows to indicate the relationship of products to each other and enables grouping for simpler referencing. As an example, the structure MAY use the following levels: `vendor` -> `product_family` -> `product_name` -> `product_version`. +> It is recommended to use the hierarchical structure of `vendor` -> `product_name` -> `product_version` whenever possible to support the identification and matching of products on the consumer side. + +#### 3.1.2.1 Branches Type - Branches + +List of branches (`branches`) has the value type `branches_t`. + +#### 3.1.2.2 Branches Type - Category + +Category of the branch (`category`) of value type `string` and `enum` describes the characteristics of the labeled branch. +Valid `enum` values are: + +``` + architecture + host_name + language + legacy + patch_level + product_family + product_name + product_version + product_version_range + service_pack + specification + vendor +``` + +The value `architecture` indicates the architecture for which the product is intended. + +The value `host_name` indicates the host name of a system/service. + +The value `language` indicates the language of the product. + +The value `legacy` indicates an entry that has reached its end of life. + +The value `patch_level` indicates the patch level of the product. + +The value `product_family` indicates the product family that the product falls into. + +The value `product_name` indicates the name of the product. + +The value `product_version` indicates exactly a single version of the product. The value of the adjacent `name` property can be numeric or some other descriptor. However, it MUST NOT contain version ranges of any kind. + +> It is recommended to enumerate versions wherever possible. Nevertheless, the TC understands that this is sometimes impossible. To reflect that in the specification and aid in automatic processing of CSAF documents the value `product_version_range` was introduced. See next section for details. + +The value `product_version_range` indicates a range of versions for the product. The value of the adjacent `name` property SHOULD NOT be used to convey a single version. + +The value `service_pack` indicates the service pack of the product. + +The value `specification` indicates the specification such as a standard, best common practice, etc. + +The value `vendor` indicates the name of the vendor or manufacturer that makes the product. + +#### 3.1.2.3 Branches Type - Name + +Name of the branch (`name`) of value type `string` with 1 or more characters contains the canonical descriptor or 'friendly name' of the branch. + +*Examples 5:* + +``` + 10 + 365 + Microsoft + Office + PCS 7 + SIMATIC + Siemens + Windows +``` + +A leading `v` or `V` in the value of `name` SHOULD only exist for the categories `product_version` or `product_version_range` if it is part of the product version as given by the vendor. + +##### 3.1.2.3.1 Branches Type - Name under Product Version + +If adjacent property `category` has the value `product_version`, the value of `name` MUST NOT contain version ranges of any kind. + +*Examples 6 for `name` when using `product_version`:* + +``` + 10 + 17.4 + v3 +``` + +> The `product_version` is the easiest way for users to determine whether their version is meant (provided that the given ancestors in the product tree matched): If both version strings are the same, it is a match - otherwise not. Therefore, it is always recommended to enumerate product versions instead of providing version ranges. + +*Examples 7 for `name` when using `product_version` which are invalid:* + +``` + 8.0.0 - 8.0.1 + 8.1.5 and later + <= 2 + prior to 4.2 + All versions < V3.0.29 + V3.0, V4.0, V4.1, V4.2 +``` + +> All the examples above contain some kind of a version range and are therefore invalid under the category `product_version`. + +##### 3.1.2.3.2 Branches Type - Name under Product Version Range + +If adjacent property `category` has the value `product_version_range`, the value of `name` MUST contain version ranges. The value of MUST obey to exactly one of the following options: + +1. Version Range Specifier (vers) + + > vers is an ongoing community effort to address the problem of version ranges. Its draft specification is available at [VERS]. + + vers MUST be used in its canonical form. To convey the term "all versions" the special string `vers:all/*` MUST be used. + + *Examples 8 for `name` when using `product_version_range` with vers:* + + ``` + vers:gem/>=2.2.0|!= 2.2.1|<2.3.0 + vers:npm/1.2.3|>=2.0.0|<5.0.0 + vers:pypi/0.0.0|0.0.1|0.0.2|0.0.3|1.0|2.0pre1 + vers:tomee/>=8.0.0-M1|<=8.0.1 + ``` + + > Through the definitions of the vers specification a user can compute whether a given version is in a given range. + +2. Vers-like Specifier (vls) + + This option uses only the `` part from the vers specification. It MUST NOT have an URI nor the `` part. It is a fallback option and SHOULD NOT be used unless really necessary. + > The reason for that is, that it is nearly impossible for tools to reliable determine whether a given version is in the range or not. + + Tools MAY support this on best effort basis. + + *Examples 9 for `name` when using `product_version_range` with vls:* + + ``` + <=2 + <4.2 + =8.1.5 + ``` + +#### 3.1.2.4 Branches Type - Product + +Product (`product`) has the value type Full Product Name (`full_product_name_t`). + +### 3.1.3 Full Product Name Type + +Full Product Name (`full_product_name_t`) with value type `object` specifies information about the product and assigns the product ID. +The properties `name` and `product_id` are required. The property `product_identification_helper` is optional. + +``` + "full_product_name_t": { + // ... + "properties": { + "name": { + // ... + }, + "product_id": { + // ... + }, + "product_identification_helper": { + // ... + } + } + }, +``` + +#### 3.1.3.1 Full Product Name Type - Name + +Textual description of the product (`name`) has value type `string` with 1 or more characters. +The value SHOULD be the product's full canonical name, including version number and other attributes, as it would be used in a human-friendly document. + +*Examples 10:* + +``` + Cisco AnyConnect Secure Mobility Client 2.3.185 + Microsoft Host Integration Server 2006 Service Pack 1 +``` + +#### 3.1.3.2 Full Product Name Type - Product ID + +Product ID (`product_id`) holds a value of type Product ID (`product_id_t`). + +#### 3.1.3.3 Full Product Name Type - Product Identification Helper + +Helper to identify the product (`product_identification_helper`) of value type `object` provides in its properties at least one method which aids in identifying the product in an asset database. +Of the given eight properties `cpe`, `hashes`, `model_numbers`, `purl`, `sbom_urls`, `serial_numbers`, `skus`, and `x_generic_uris`, one is mandatory. + +``` + "product_identification_helper": { + // ... + "properties": { + "cpe": { + // ... + }, + "hashes": { + // ... + }, + "model_numbers": { + // ... + }, + "purl": { + // ... + }, + "sbom_urls": { + // ... + }, + "serial_numbers": { + // ... + }, + "skus": { + // ... + }, + "x_generic_uris": { + // ... + } + } +``` + +##### 3.1.3.3.1 Full Product Name Type - Product Identification Helper - CPE + +Common Platform Enumeration representation (`cpe`) of value type `string` of 5 or more characters with `pattern` (regular expression): + +``` + ^(cpe:2\\.3:[aho\\*\\-](:(((\\?*|\\*?)([a-zA-Z0-9\\-\\._]|(\\\\[\\\\\\*\\?!\"#\\$%&'\\(\\)\\+,/:;<=>@\\[\\]\\^`\\{\\|\\}~]))+(\\?*|\\*?))|[\\*\\-])){5}(:(([a-zA-Z]{2,3}(-([a-zA-Z]{2}|[0-9]{3}))?)|[\\*\\-]))(:(((\\?*|\\*?)([a-zA-Z0-9\\-\\._]|(\\\\[\\\\\\*\\?!\"#\\$%&'\\(\\)\\+,/:;<=>@\\[\\]\\^`\\{\\|\\}~]))+(\\?*|\\*?))|[\\*\\-])){4})|([c][pP][eE]:/[AHOaho]?(:[A-Za-z0-9\\._\\-~%]*){0,6})$ +``` + +The Common Platform Enumeration (CPE) attribute refers to a method for naming platforms external to this specification. See [CPE23-N] for details. + +##### 3.1.3.3.2 Full Product Name Type - Product Identification Helper - Hashes + +List of hashes (`hashes`) of value type `array` holding at least one item contains a list of cryptographic hashes usable to identify files. + +``` + "hashes": { + // ... + "items": { + // ... + } + }, +``` + +Cryptographic hashes of value type `object` contains all information to identify a file based on its cryptographic hash values. +Any cryptographic hashes object has the 2 mandatory properties `file_hashes` and `filename`. + +``` + "properties": { + "file_hashes": { + // ... + }, + "filename": { + // ... + } + } +``` + +List of file hashes (`file_hashes`) of value type `array` holding at least one item contains a list of cryptographic hashes for this file. + +``` + "file_hashes": { + // ... + "items": { + // ... + } + }, +``` + +Each File hash of value type `object` contains one hash value and algorithm of the file to be identified. Any File hash object has the 2 mandatory properties `algorithm` and `value`. + +``` + "properties": { + "algorithm": { + // ... + }, + "value": { + // ... + } + } +``` + +The algorithm of the cryptographic hash representation (`algorithm`) of value type `string` with one or more characters contains the name of the cryptographic hash algorithm used to calculate the value. +The default value for `algorithm` is `sha256`. + +*Examples 11:* + +``` + blake2b512 + sha256 + sha3-512 + sha384 + sha512 +``` + +These values are derived from the currently supported digests OpenSSL [OPENSSL]. Leading dashes were removed. + +> The command `openssl dgst -list` (Version 1.1.1f from 2020-03-31) outputs the following: +> +>``` +> Supported digests: +> -blake2b512 -blake2s256 -md4 +> -md5 -md5-sha1 -ripemd +> -ripemd160 -rmd160 -sha1 +> -sha224 -sha256 -sha3-224 +> -sha3-256 -sha3-384 -sha3-512 +> -sha384 -sha512 -sha512-224 +> -sha512-256 -shake128 -shake256 +> -sm3 -ssl3-md5 -ssl3-sha1 +> -whirlpool +>``` + +The Value of the cryptographic hash representation (`value`) of value type `string` of 32 or more characters with `pattern` (regular expression): + +``` + ^[0-9a-fA-F]{32,}$ +``` + +The Value of the cryptographic hash attribute contains the cryptographic hash value in hexadecimal representation. + +*Examples 12:* + +``` + 37df33cb7464da5c7f077f4d56a32bc84987ec1d85b234537c1c1a4d4fc8d09dc29e2e762cb5203677bf849a2855a0283710f1f5fe1d6ce8d5ac85c645d0fcb3 + 4775203615d9534a8bfca96a93dc8b461a489f69124a130d786b42204f3341cc + 9ea4c8200113d49d26505da0e02e2f49055dc078d1ad7a419b32e291c7afebbb84badfbd46dec42883bea0b2a1fa697c +``` + +The filename representation (`filename`) of value type `string` with one or more characters contains the name of the file which is identified by the hash values. + +*Examples 13:* + +``` + WINWORD.EXE + msotadddin.dll + sudoers.so +``` + +If the value of the hash matches and the filename does not, a user SHOULD prefer the hash value. In such cases, the filename SHOULD be used as informational property. + +##### 3.1.3.3.3 Full Product Name Type - Product Identification Helper - Model Numbers + +The list of models (`model_numbers`) of value type `array` with 1 or more unique items contains a list of full or abbreviated (partial) model numbers. + +A list of models SHOULD only be used if a certain range of model numbers with its corresponding software version is affected, or the model numbers change during update. + +This can also be used to identify hardware. If necessary, the software, or any other related part, SHALL be bind to that via a product relationship. + +``` + "model_numbers": { + //... + "items": { + //... + } + }, +``` + +Any given model number of value type `string` with at least 1 character represents a full or abbreviated (partial) model number of the component to identify. + +> The terms "model", "model number" and "model variant" are mostly used synonymously. Often it is abbreviated as "MN", M/N" or "model no.". + +If a part of a model number of the component to identify is given, it SHOULD begin with the first character of the model number and stop at any point. +Characters which SHOULD NOT be matched MUST be replaced by either `?` (for a single character) or `*` (for zero or more characters). +Two `*` MUST NOT follow each other. + +*Examples 14:* + +``` + 6RA8096-4MV62-0AA0 + 6RA801?-??V62-0AA0 + IC25T060ATCS05-0 +``` + +##### 3.1.3.3.4 Full Product Name Type - Product Identification Helper - PURL + +The package URL (PURL) representation (`purl`) is a `string` of 7 or more characters with `pattern` (regular expression): + +``` + ^pkg:[A-Za-z\\.\\-\\+][A-Za-z0-9\\.\\-\\+]*/.+ +``` + +> The given pattern does not completely evaluate whether a PURL is valid according to the [PURL] specification. It provides a more generic approach and general guidance to enable forward compatibility. +> CSAF uses only the canonical form of PURL to conform with section 3.3 of [RFC3986]. Therefore, URLs starting with `pkg://` are considered invalid. + +This package URL (PURL) attribute refers to a method for reliably identifying and locating software packages external to this specification. See [PURL] for details. + +##### 3.1.3.3.5 Full Product Name Type - Product Identification Helper - SBOM URLs + +The list of SBOM URLs (`sbom_urls`) of value type `array` with 1 or more items contains a list of URLs where SBOMs for this product can be retrieved. + +> The SBOMs might differ in format or depth of detail. Currently supported formats are SPDX, CycloneDX, and SWID. + +``` + "sbom_urls": { + //... + "items": { + //... + } + }, +``` + +Any given SBOM URL of value type `string` with format `uri` contains a URL of one SBOM for this product. + +*Examples 15:* + +``` + https://raw.githubusercontent.com/CycloneDX/bom-examples/master/SBOM/keycloak-10.0.2/bom.json + https://swinslow.net/spdx-examples/example4/main-bin-v2 +``` + +##### 3.1.3.3.6 Full Product Name Type - Product Identification Helper - Serial Numbers + +The list of serial numbers (`serial_numbers`) of value type `array` with 1 or more unique items contains a list of full or abbreviated (partial) serial numbers. + +A list of serial numbers SHOULD only be used if a certain range of serial numbers with its corresponding software version is affected, or the serial numbers change during update. + +``` + "serial_numbers": { + //... + "items": { + //... + } + }, +``` + +Any given serial number of value type `string` with at least 1 character represents a full or abbreviated (partial) serial number of the component to identify. + +If a part of a serial number of the component to identify is given, it SHOULD begin with the first character of the serial number and stop at any point. +Characters which SHOULD NOT be matched MUST be replaced by either `?` (for a single character) or `*` (for zero or more characters). +Two `*` MUST NOT follow each other. + +##### 3.1.3.3.7 Full Product Name Type - Product Identification Helper - SKUs + +The list of stock keeping units (`skus`) of value type `array` with 1 or more items contains a list of full or abbreviated (partial) stock keeping units. + +A list of stock keeping units SHOULD only be used if the list of relationships is used to decouple e.g. hardware from the software, or the stock keeping units change during update. In the latter case the remediations SHALL include the new stock keeping units is or a description how it can be obtained. + +> The use of the list of relationships in the first case is important. Otherwise, the end user is unable to identify which version (the affected or the not affected / fixed one) is used. + +``` + "skus": { + //... + "items": { + //... + } + }, +``` + +Any given stock keeping unit of value type `string` with at least 1 character represents a full or abbreviated (partial) stock keeping unit (SKU) of the component to identify. + +> Sometimes this is also called "item number", "article number" or "product number". + +If a part of a stock keeping unit of the component to identify is given, it SHOULD begin with the first character of the stock keeping unit and stop at any point. +Characters which SHOULD NOT be matched MUST be replaced by either `?` (for a single character) or `*` (for zero or more characters). +Two `*` MUST NOT follow each other. + +##### 3.1.3.3.8 Full Product Name Type - Product Identification Helper - Generic URIs + +List of generic URIs (`x_generic_uris`) of value type `array` with at least 1 item contains a list of identifiers which are either vendor-specific or derived from a standard not yet supported. + +``` + "x_generic_uris": { + // ... + "items": { + // ... + } + } +``` + +Any such Generic URI item of value type `object` provides the two mandatory properties Namespace (`namespace`) and URI (`uri`). + +``` + "properties": { + "namespace": { + // ... + }, + "uri": { + // ... + } + } +``` + +The namespace of the generic URI (`namespace`) of value type `string` with format `uri` refers to a URL which provides the name and knowledge about the specification used or is the namespace in which these values are valid. + +The URI (`uri`) of value type `string` with format `uri` contains the identifier itself. + +> These elements can be used to reference a specific component from an SBOM: + +*Example 16 linking a component from a CycloneDX SBOM using the bomlink mechanism:* + +``` + "x_generic_uris": [ + { + "namespace": "https://cyclonedx.org/capabilities/bomlink/", + "uri": "urn:cdx:411dafd2-c29f-491a-97d7-e97de5bc2289/1#pkg:maven/org.jboss.logging/jboss-logging@3.4.1.Final?type=jar" + } + ] +``` + +*Example 17 linking a component from an SPDX SBOM:* + +``` + "x_generic_uris": [ + { + "namespace": "https://spdx.github.io/spdx-spec/document-creation-information/#65-spdx-document-namespace-field", + "uri": "https://swinslow.net/spdx-examples/example4/main-bin-v2#SPDXRef-libc" + } + ] +``` + +### 3.1.4 Language Type + +Language type (`lang_t`) has value type `string` with `pattern` (regular expression): + +``` + ^(([A-Za-z]{2,3}(-[A-Za-z]{3}(-[A-Za-z]{3}){0,2})?|[A-Za-z]{4,8})(-[A-Za-z]{4})?(-([A-Za-z]{2}|[0-9]{3}))?(-([A-Za-z0-9]{5,8}|[0-9][A-Za-z0-9]{3}))*(-[A-WY-Za-wy-z0-9](-[A-Za-z0-9]{2,8})+)*(-[Xx](-[A-Za-z0-9]{1,8})+)?|[Xx](-[A-Za-z0-9]{1,8})+|[Ii]-[Dd][Ee][Ff][Aa][Uu][Ll][Tt]|[Ii]-[Mm][Ii][Nn][Gg][Oo])$ +``` + +The value identifies a language, corresponding to IETF BCP 47 / RFC 5646. +See IETF language registry: [https://www.iana.org/assignments/language-subtag-registry/language-subtag-registry](https://www.iana.org/assignments/language-subtag-registry/language-subtag-registry) + +> CSAF skips those grandfathered language tags that are deprecated at the time of writing the specification. Even though the private use language tags are supported they should not be used to ensure readability across the ecosystem. +> It is recommended to follow the conventions for the capitalization of the subtags even though it is not mandatory as most users are used to that. + +*Examples 18:* + +``` + de + en + fr + frc + jp +``` + +### 3.1.5 Notes Type + +List of notes (`notes_t`) of value type `array` with 1 or more items of type `Note` contains notes which are specific to the current context. + +``` + "notes_t": { + // ... + "items": { + // ... + } + }, +``` + +Value type of every such Note item is `object` with the mandatory properties `category` and `text` providing a place to put all manner of text blobs related to the current context. +A Note `object` MAY provide the optional properties `audience` and `title`. + +``` + "properties": { + "audience": { + // ... + }, + "category": { + // ... + }, + "text": { + // ... + }, + "title": { + // ... + } + } +``` + +Audience of note (`audience`) of value type `string` with 1 or more characters indicates who is intended to read it. + +*Examples 19:* + +``` + all + executives + operational management and system administrators + safety engineers +``` + +Note category (`category`) of value type `string` and `enum` contains the information of what kind of note this is. +Valid `enum` values are: + +``` + description + details + faq + general + legal_disclaimer + other + summary +``` + +The value `description` indicates the note is a description of something. The optional sibling property `title` MAY have more information in this case. + +The value `details` indicates the note is a low-level detailed discussion. The optional sibling property `title` MAY have more information in this case. + +The value `faq` indicates the note is a list of frequently asked questions. + +The value `general` indicates the note is a general, high-level note. The optional sibling property `title` MAY have more information in this case. + +The value `legal_disclaimer` indicates the note represents any possible legal discussion, including constraints, surrounding the document. + +The value `other` indicates the note is something that doesn’t fit the other categories. The optional sibling attribute `title` SHOULD have more information to indicate clearly what kind of note to expect in this case. + +The value `summary` indicates the note is a summary of something. The optional sibling property `title` MAY have more information in this case. + +Note content (`text`) of value type `string` with 1 or more characters holds the content of the note. Content varies depending on type. + +Title of note (`title`) of value type `string` with 1 or more characters provides a concise description of what is contained in the text of the note. + +*Examples 20:* + +``` + Details + Executive summary + Technical summary + Impact on safety systems +``` + +### 3.1.6 Product Group ID Type + +The Product Group ID Type (`product_group_id_t`) of value type `string` with 1 or more characters is a reference token for product group instances. +The value is a token required to identify a group of products so that it can be referred to from other parts in the document. +There is no predefined or required format for the Product Group ID (`product_group_id`) as long as it uniquely identifies a product group in the context of the current document. + +``` + "product_group_id_t": { + // ... + }, +``` + +*Examples 21:* + +``` + CSAFGID-0001 + CSAFGID-0002 + CSAFGID-0020 +``` + +> Even though the standard does not require a specific format it is recommended to use different prefixes for the Product ID and the Product Group ID to support reading and parsing the document. + +### 3.1.7 Product Groups Type + +List of Product Group ID (`product_groups_t`) of value type `array` with 1 or more unique items (a `set`) of type Product Group ID (`product_group_id_t`) specifies a list of `product_group_ids` to give context to the parent item. + +``` + "product_groups_t": { + // ... + "items": { + // ... + } + }, +``` + +### 3.1.8 Product ID Type + +The Product ID Type (`product_id_t`) of value type `string` with 1 or more characters is a reference token for product instances. +The value is a token required to identify a `full_product_name` so that it can be referred to from other parts in the document. There is no predefined or required format for the Product ID (`product_id`) as long as it uniquely identifies a product in the context of the current document. + +``` + "product_id_t": { + // ... + }, +``` + +*Examples 22:* + +``` + CSAFPID-0004 + CSAFPID-0008 +``` + +> Even though the standard does not require a specific format it is recommended to use different prefixes for the Product ID and the Product Group ID to support reading and parsing the document. + +### 3.1.9 Products Type + +List of Product IDs (`products_t`) of value type `array` with 1 or more unique items (a `set`) of type Product ID (`product_id_t`) specifies a list of `product_ids` to give context to the parent item. + +``` + "products_t": { + // ... + "items": { + // ... + } + }, +``` + +### 3.1.10 References Type + +List of references (`references_t`) of value type `array` with 1 or more items of type Reference holds a list of Reference objects. + +``` + "references_t": { + // ... + "items": { + // ... + } + }, +``` + +Value type of every such Reference item is `object` with the mandatory properties `url` and `summary` holding any reference to conferences, papers, advisories, and other resources that are related and considered related to either a surrounding part of or the entire document and to be of value to the document consumer. +A reference `object` MAY provide the optional property `category`. + +``` + "properties": { + "category": { + // ... + }, + "summary": { + // ... + }, + "url": { + // ... + } + } +``` + +Category of reference (`category`) of value type `string` and `enum` indicates whether the reference points to the same document or vulnerability in focus (depending on scope) or to an external resource. +Valid `enum` values are: + +``` + external + self +``` + +The default value for `category` is `external`. + +The value `external` indicates, that this document is an external reference to a document or vulnerability in focus (depending on scope). + +The value `self` indicates, that this document is a reference to this same document or vulnerability (also depending on scope). + +> This includes links to documents with the same content but different file format (e.g. advisories as PDF or HTML). + +Summary of the reference (`summary`) of value type `string` with 1 or more characters indicates what this reference refers to. + +URL of reference (`url`) of value type `string` with format `uri` provides the URL for the reference. + +### 3.1.11 Version Type + +The Version (`version_t`) type has value type `string` with `pattern` (regular expression): + +``` + ^(0|[1-9][0-9]*)$|^((0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?)$ +``` + +The version specifies a version string to denote clearly the evolution of the content of the document. There are two options how it can be used: + +* semantic versioning (preferred; according to the rules below) +* integer versioning + +A CSAF document MUST use only one versioning system. + +*Examples 23:* + +``` + 1 + 4 + 0.9.0 + 1.4.3 + 2.40.0+21AF26D3 +``` + +#### 3.1.11.1 Version Type - Integer versioning + +Integer versioning increments for each version where the `/document/tracking/status` is `final` the version number by one. The regular expression for this type is: + +``` +^(0|[1-9][0-9]*)$ +``` + +The following rules apply: + +1. Once a versioned document has been released, the contents of that version MUST NOT be modified. Any modifications MUST be released as a new version. +2. Version zero (0) is for initial development before the `initial_release_date`. The document status MUST be `draft`. Anything MAY change at any time. The document SHOULD NOT be considered stable. +3. Version 1 defines the initial public release. Each new version where `/document/tracking/status` is `final` has a version number incremented by one. +4. Pre-release versions (document status `draft`) MUST carry the new version number. Sole exception is before the initial release (see rule 2). The combination of document status `draft` and version 1 MAY be used to indicate that the content is unlikely to change. +5. Build metadata is never included in the version. +6. Precedence MUST be calculate by integer comparison. + +#### 3.1.11.2 Version Type - Semantic versioning + +Semantic versioning derived the rules from [SemVer]. The regular expression for this type is: + +``` +^((0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?)$ +``` + +The goal of this structure is to provide additional information to the end user whether a new comparison with the asset database is needed. The "public API" in regards to CSAF is the CSAF document with its structure and content. This results in the following rules: + +1. A normal version number MUST take the form X.Y.Z where X, Y, and Z are non-negative integers, and MUST NOT contain leading zeroes. X is the major version, Y is the minor version, and Z is the patch version. Each element MUST increase numerically. For instance: 1.9.0 -> 1.10.0 -> 1.11.0. +2. Once a versioned document has been released, the contents of that version MUST NOT be modified. Any modifications MUST be released as a new version. +3. Major version zero (0.y.z) is for initial development before the `initial_release_date`. The document status MUST be `draft`. Anything MAY change at any time. The document SHOULD NOT be considered stable. Changes which would increment the major version according to rule 7 are tracked in this stage with (0.y.z) by incrementing the minor version y instead. Changes that would increment the minor or patch version according to rule 6 or 5 are both tracked in this stage with (0.y.z) by incrementing the patch version z instead. +4. Version 1.0.0 defines the initial public release. The way in which the version number is incremented after this release is dependent on the content and structure of the document and how it changes. +5. Patch version Z (x.y.Z | x > 0) MUST be incremented if only backwards compatible bug fixes are introduced. A bug fix is defined as an internal change that fixes incorrect behavior. + + > In the context of the document this is the case e.g. for spelling mistakes. + +6. Minor version Y (x.Y.z | x > 0) MUST be incremented if the content of an existing element changes except for those which are covert through rule 7. It MUST be incremented if substantial new information are introduced or new elements are provided. It MAY include patch level changes. Patch version MUST be reset to 0 when minor version is incremented. +7. Major version X (X.y.z | X > 0) MUST be incremented if a new comparison with the end user's asset database is required. This includes: + + * changes (adding, removing elements or modifying content) in `/product_tree` or elements which contain `/product_tree` in their path + * adding or removing items of `/vulnerabilities` + * adding or removing elements in: + * `/vulnerabilities[]/product_status/first_affected` + * `/vulnerabilities[]/product_status/known_affected` + * `/vulnerabilities[]/product_status/last_affected` + * removing elements from: + * `/vulnerabilities[]/product_status/first_fixed` + * `/vulnerabilities[]/product_status/fixed` + * `/vulnerabilities[]/product_status/known_not_affected` + + It MAY also include minor and patch level changes. Patch and minor version MUST be reset to 0 when major version is incremented. +8. A pre-release version (document status `draft`) MAY be denoted by appending a hyphen and a series of dot separated identifiers immediately following the patch version. Identifiers MUST comprise only ASCII alphanumerics and hyphens [0-9A-Za-z-]. Identifiers MUST NOT be empty. Numeric identifiers MUST NOT include leading zeroes. Pre-release versions have a lower precedence than the associated normal version. A pre-release version indicates that the version is unstable and might not satisfy the intended compatibility requirements as denoted by its associated normal version. + + *Examples 24:* + + ``` + 1.0.0-0.3.7 + 1.0.0-alpha + 1.0.0-alpha.1 + 1.0.0-x-y-z.– + 1.0.0-x.7.z.92 + ``` + +9. Pre-release MUST NOT be included if `/document/tracking/status` is `final`. +10. Build metadata MAY be denoted by appending a plus sign and a series of dot separated identifiers immediately following the patch or pre-release version. Identifiers MUST comprise only ASCII alphanumerics and hyphens [0-9A-Za-z-]. Identifiers MUST NOT be empty. Build metadata MUST be ignored when determining version precedence. Thus two versions that differ only in the build metadata, have the same precedence. + + *Examples 25:* + + ``` + 1.0.0+20130313144700 + 1.0.0+21AF26D3—-117B344092BD + 1.0.0-alpha+001 + 1.0.0-beta+exp.sha.5114f85 + ``` + +11. Precedence refers to how versions are compared to each other when ordered. + + 1. Precedence MUST be calculated by separating the version into major, minor, patch and pre-release identifiers in that order (Build metadata does not figure into precedence). + 2. Precedence is determined by the first difference when comparing each of these identifiers from left to right as follows: Major, minor, and patch versions are always compared numerically. + + *Example 26:* + + ``` + 1.0.0 < 2.0.0 < 2.1.0 < 2.1.1 + ``` + + 3. When major, minor, and patch are equal, a pre-release version has lower precedence than a normal version: + + *Example 27:* + + ``` + 1.0.0-alpha < 1.0.0 + ``` + + 4. Precedence for two pre-release versions with the same major, minor, and patch version MUST be determined by comparing each dot separated identifier from left to right until a difference is found as follows: + + 1. Identifiers consisting of only digits are compared numerically. + 2. Identifiers with letters or hyphens are compared lexically in ASCII sort order. + 3. Numeric identifiers always have lower precedence than non-numeric identifiers. + 4. A larger set of pre-release fields has a higher precedence than a smaller set, if all of the preceding identifiers are equal. + + *Example 28:* + + ``` + 1.0.0-alpha < 1.0.0-alpha.1 < 1.0.0-alpha.beta < 1.0.0-beta < 1.0.0-beta.2 < 1.0.0-beta.11 < 1.0.0-rc.1 < 1.0.0 + ``` + +## 3.2 Properties + +These final three subsections document the three properties of a CSAF document. The single mandatory property `document`, as well as the optional properties `product_tree` and `vulnerabilities` in that order. + +### 3.2.1 Document Property + +Document level meta-data (`document`) of value type `object` with the 5 mandatory properties Category (`category`), CSAF Version (`csaf_version`), Publisher (`publisher`), Title (`title`), and Tracking (`tracking`) captures the meta-data about this document describing a particular set of security advisories. +In addition, the `document` object MAY provide the 7 optional properties Acknowledgments (`acknowledgments`), Aggregate Severity (`aggregate_severity`), Distribution (`distribution`), Language (`lang`), Notes (`notes`), References (`references`), and Source Language (`source_lang`). + +``` + "document": { + // ... + "properties": { + "acknowledgments": { + // ... + }, + "aggregate_severity" : { + // ... + }, + "category": { + // ... + }, + "csaf_version": { + // ... + }, + "distribution": { + // ... + }, + "lang": { + // ... + }, + "notes": { + // ... + }, + "publisher": { + // ... + }, + "references": { + // ... + }, + "source_lang": { + // ... + }, + "title": { + // ... + }, + "tracking": { + // ... + } + } + }, +``` + +#### 3.2.1.1 Document Property - Acknowledgments + +Document acknowledgments (`acknowledgments`) of value type Acknowledgments Type (`acknowledgments_t`) contains a list of acknowledgment elements associated with the whole document. + +``` + "acknowledgments": { + // ... + }, +``` + +#### 3.2.1.2 Document Property - Aggregate Severity + +Aggregate severity (`aggregate_severity`) of value type `object` with the mandatory property `text` and the optional property `namespace` is a vehicle that is provided by the document producer to convey the urgency and criticality with which the one or more vulnerabilities reported should be addressed. It is a document-level metric and applied to the document as a whole — not any specific vulnerability. The range of values in this field is defined according to the document producer's policies and procedures. + +``` + "aggregate_severity": { + // ... + "properties": { + "namespace": { + // ... + }, + "text": { + // ... + } + } + }, +``` + +The Namespace of aggregate severity (`namespace`) of value type `string` with format `uri` points to the namespace so referenced. + +The Text of aggregate severity (`text`) of value type `string` with 1 or more characters provides a severity which is independent of - and in addition to - any other standard metric for determining the impact or severity of a given vulnerability (such as CVSS). + +*Examples 29:* + +``` + Critical + Important + Moderate +``` + +#### 3.2.1.3 Document Property - Category + +Document category (`category`) with value type `string` of 1 or more characters with `pattern` (regular expression): + +``` + ^[^\\s\\-_\\.](.*[^\\s\\-_\\.])?$ +``` + +Document category defines a short canonical name, chosen by the document producer, which will inform the end user as to the category of document. + +> It is directly related to the profiles defined in section 4. + +``` + "category": { + // ... + } +``` + +*Examples 30*: + +``` + csaf_base + csaf_security_advisory + csaf_vex + Example Company Security Notice +``` + +#### 3.2.1.4 Document Property - CSAF Version + +CSAF version (`csaf_version`) of value type `string` and `enum` gives the version of the CSAF specification which the document was generated for. +The single valid value for this `enum` is: + +``` + 2.0 +``` + +#### 3.2.1.5 Document Property - Distribution + +Rules for sharing document (`distribution`) of value type `object` with at least 1 of the 2 properties Text (`text`) and Traffic Light Protocol (TLP) (`tlp`) describes any constraints on how this document might be shared. + +``` + "distribution": { + // ... + "properties": { + "text": { + // ... + }, + "tlp": { + // ... + } + } + }, +``` + +If both values are present, the TLP information SHOULD be preferred as this aids in automation. + +##### 3.2.1.5.1 Document Property - Distribution - Text + +The Textual description (`text`) of value type `string` with 1 or more characters provides a textual description of additional constraints. + +*Examples 31:* + +``` + Copyright 2021, Example Company, All Rights Reserved. + Distribute freely. + Share only on a need-to-know-basis only. +``` + +##### 3.2.1.5.2 Document Property - Distribution - TLP + +Traffic Light Protocol (TLP) (`tlp`) of value type `object` with the mandatory property Label (`label`) and the optional property URL (`url`) provides details about the TLP classification of the document. + +``` + "tlp": { + // ... + "properties": { + "label": { + // ... + }, + "url": { + // ... + } + } + } +``` + +The Label of TLP (`label`) with value type `string` and `enum` provides the TLP label of the document. +Valid values of the `enum` are: + +``` + AMBER + GREEN + RED + WHITE +``` + +The URL of TLP version (`url`) with value type `string` with format `uri` provides a URL where to find the textual description of the TLP version which is used in this document. The default value is the URL to the definition by FIRST: + +``` + https://www.first.org/tlp/ +``` + +*Examples 32:* + +``` + https://www.us-cert.gov/tlp + https://www.bsi.bund.de/SharedDocs/Downloads/DE/BSI/Kritis/Merkblatt_TLP.pdf +``` + +#### 3.2.1.6 Document Property - Language + +Document language (`lang`) of value type Language Type (`lang_t`) identifies the language used by this document, corresponding to IETF BCP 47 / RFC 5646. + +#### 3.2.1.7 Document Property - Notes + +Document notes (`notes`) of value type Notes Type (`notes_t`) holds notes associated with the whole document. + +``` + "notes": { + // ... + }, +``` + +#### 3.2.1.8 Document Property - Publisher + +Publisher (`publisher`) has value type `object` with the mandatory properties Category (`category`), Name (`name`) and Namespace (`namespace`) and provides information on the publishing entity. +The 2 other optional properties are: `contact_details` and `issuing_authority`. + +``` + "publisher": { + // ... + "properties": { + "category": { + // ... + }, + "contact_details": { + // ... + }, + "issuing_authority": { + // ... + }, + "name": { + // ... + } + "namespace": { + // ... + } + } + }, +``` + +##### 3.2.1.8.1 Document Property - Publisher - Category + +The Category of publisher (`category`) of value type `string` and `enum` provides information about the category of publisher releasing the document. +The valid values are: + +``` + coordinator + discoverer + other + translator + user + vendor +``` + +The value `coordinator` indicates individuals or organizations that manage a single vendor’s response or multiple vendors’ responses to a vulnerability, a security flaw, or an incident. This includes all Computer Emergency/Incident Response Teams (CERTs/CIRTs) or agents acting on the behalf of a researcher. + +The value `discoverer` indicates individuals or organizations that find vulnerabilities or security weaknesses. This includes all manner of researchers. + +The value `translator` indicates individuals or organizations that translate CSAF documents. This includes all manner of language translators, also those who work for the party issuing the original advisory. + +The value `other` indicates a catchall for everyone else. Currently this includes editors, reviewers, forwarders, republishers, and miscellaneous contributors. + +The value `user` indicates anyone using a vendor’s product. + +The value `vendor` indicates developers or maintainers of information system products or services. This includes all authoritative product vendors, Product Security Incident Response Teams (PSIRTs), and product resellers and distributors, including authoritative vendor partners. + +##### 3.2.1.8.2 Document Property - Publisher - Contact Details + +Contact details (`contact_details`) of value type `string` with 1 or more characters provides information on how to contact the publisher, possibly including details such as web sites, email addresses, phone numbers, and postal mail addresses. + +*Example 33:* + +``` + Example Company can be reached at contact_us@example.com, or via our website at https://www.example.com/contact. +``` + +##### 3.2.1.8.3 Document Property - Publisher - Issuing Authority + +Issuing authority (`issuing_authority`) of value type `string` with 1 or more characters Provides information about the authority of the issuing party to release the document, in particular, the party's constituency and responsibilities or other obligations. + +##### 3.2.1.8.4 Document Property - Publisher - Name + +The Name of publisher (`name`) of value type `string` with 1 or more characters contains the name of the issuing party. + +*Example 34:* + +``` + BSI + Cisco PSIRT + Siemens ProductCERT +``` + +##### 3.2.1.8.5 Document Property - Publisher - Namespace + +The Namespace of publisher (`namespace`) of value type `string` with format `uri` contains a URL which is under control of the issuing party and can be used as a globally unique identifier for that issuing party. The URL SHALL be normalized. + +An issuing party can choose any URL which fulfills the requirements state above. The URL MAY be dereferenceable. If an issuing party has chosen a URL, it SHOULD NOT change. Tools can make use of the combination of `/document/publisher/namespace` and `/document/tracking/id` as it identifies a CSAF document globally unique. + +If an issuing party decides to change its Namespace it SHOULD reissue all CSAF documents with an incremented (patch) version which has no other changes than: + +* the new publisher information +* the updated revision history +* the updated item in `/document/references[]` which points to the new version of the CSAF document +* an added item in `/document/references[]` which points to the previous version of the CSAF document (if the URL changed) + +*Example 35:* + +``` + https://csaf.io + https://www.example.com +``` + +#### 3.2.1.9 Document Property - References + +Document references (`references`) of value type References Type (`references_t`) holds a list of references associated with the whole document. + +``` + "references": { + // ... + }, +``` + +#### 3.2.1.10 Document Property - Source Language + +Source language (`source_lang`) of value type Language Type (`lang_t`) identifies if this copy of the document is a translation then the value of this property describes from which language this document was translated. + +The property MUST be present and set for any CSAF document with the value `translator` in `/document/publisher/category`. The property SHALL NOT be present if the document was not translated. + +> If an issuing party publishes a CSAF document with the same content in more than one language, one of these documents SHOULD be deemed the "original", the other ones SHOULD be considered translations from the "original". The issuing party can retain its original publisher information including the `category`. However, other rules defined in the conformance clause "CSAF translator" SHOULD be applied. + +#### 3.2.1.11 Document Property - Title + +Title of this document (`title`) of value type `string` with 1 or more characters SHOULD be a canonical name for the document, and sufficiently unique to distinguish it from similar documents. + +*Examples 36:* + +``` + Cisco IPv6 Crafted Packet Denial of Service Vulnerability + Example Company Cross-Site-Scripting Vulnerability in Example Generator +``` + +#### 3.2.1.12 Document Property - Tracking + +Tracking (`tracking`) of value type `object` with the six mandatory properties: Current Release Date (`current_release_date`), Identifier (`id`), Initial Release Date (`initial_release_date`), Revision History (`revision_history`), Status (`status`), and Version (`version`) is a container designated to hold all management attributes necessary to track a CSAF document as a whole. +The two optional additional properties are Aliases (`aliases`) and Generator (`generator`). + +``` + "tracking": { + // ... + "properties": { + "aliases": { + // ... + }, + "current_release_date": { + // ... + }, + "generator": { + // ... + }, + "id": { + // ... + }, + "initial_release_date": { + // ... + }, + "revision_history": { + // ... + }, + "status": { + // ... + }, + "version": { + // ... + } + } + }, +``` + +##### 3.2.1.12.1 Document Property - Tracking - Aliases + +Aliases (`aliases`) of value type `array` with 1 or more unique items (a `set`) representing Alternate Names contains a list of alternate names for the same document. + +``` + "aliases": { + // ... + "items": { + // ... + } + }, +``` + +Every such Alternate Name of value type `string` with 1 or more characters specifies a non-empty string that represents a distinct optional alternative ID used to refer to the document. + +*Example 37:* + +``` + CVE-2019-12345 +``` + +##### 3.2.1.12.2 Document Property - Tracking - Current Release Date + +Current release date (`current_release_date`) with value type `string` with format `date-time` holds the date when the current revision of this document was released. + +##### 3.2.1.12.3 Document Property - Tracking - Generator + +Document Generator (`generator`) of value type `object` with mandatory property Engine (`engine`) and optional property Date (`date`) is a container to hold all elements related to the generation of the document. These items will reference when the document was actually created, including the date it was generated and the entity that generated it. + +``` + "generator": { + // ... + "properties": { + "date": { + // ... + }, + "engine": { + // ... + } + } + }, +``` + +Date of document generation (`date`) of value type `string` with format `date-time` SHOULD be the current date that the document was generated. +Because documents are often generated internally by a document producer and exist for a nonzero amount of time before being released, this field MAY be different from the Initial Release Date and Current Release Date. + +Engine of document generation (`engine`) of value type `object` with mandatory property Engine name (`name`) and optional property Engine version (`version`) contains information about the engine that generated the CSAF document. + +``` + "engine": { + // ... + "properties": { + "name": { + // ... + }, + "version": { + // ... + } + } + }, +``` + +Engine name (`name`) of value type `string` with 1 or more characters represents the name of the engine that generated the CSAF document. + +*Examples 38:* + +``` + Red Hat rhsa-to-cvrf + Secvisogram + TVCE +``` + +Engine version (`version`) of value type `string` with 1 or more characters contains the version of the engine that generated the CSAF document. + +> Although it is not formally required, the TC suggests to use a versioning which compatible wth Semantic Versioning as described in the external specification [SemVer]. This could help the end user to identify when CSAF consumers have to be updated. + +*Examples 39:* + +``` + 0.6.0 + 1.0.0-beta+exp.sha.a1c44f85 + 2 +``` + +##### 3.2.1.12.4 Document Property - Tracking - ID + +Unique identifier for the document (`id`) of value type `string` with 1 or more characters with `pattern` (regular expression): + +``` + ^[\\S](.*[\\S])?$ +``` + +Unique identifier for the document holds the Identifier. + +> It SHALL NOT start or end with a white space and SHALL NOT contain a line break. + +The ID is a simple label that provides for a wide range of numbering values, types, and schemes. +Its value SHOULD be assigned and maintained by the original document issuing authority. It MUST be unique for that organization. + +*Examples 40:* + +``` + Example Company - 2019-YH3234 + RHBA-2019:0024 + cisco-sa-20190513-secureboot +``` + +> The combination of `/document/publisher/namespace` and `/document/tracking/id` identifies a CSAF document globally unique. + +This value is also used to determine the filename for the CSAF document (cf. section 5.1). + +##### 3.2.1.12.5 Document Property - Tracking - Initial Release Date + +Initial release date (`initial_release_date`) with value type `string` with format `date-time` holds the date when this document was first published. + +##### 3.2.1.12.6 Document Property - Tracking - Revision History + +The Revision History (`revision_history`) with value type `array` of 1 or more Revision History Entries holds one revision item for each version of the CSAF document, including the initial one. + +``` + "revision_history": { + // ... + "items": { + // ... + } + }, +``` + +Each Revision contains all the information elements required to track the evolution of a CSAF document. Revision History Entry items are of value type `object` with the three mandatory properties: Date (`date`), Number (`number`), and Summary (`summary`). In addition, a Revision MAY expose the optional property `legacy_version`. + +``` + "properties": { + "date": { + // ... + }, + "legacy_version": { + // ... + }, + "number": { + // ... + }, + "summary": { + // ... + } + } +``` + +The Date of the revision (`date`) of value type `string` with format `date-time` states the date of the revision entry. + +Legacy version of the revision (`legacy_version`) of value type `string` with 1 or more characters contains the version string used in an existing document with the same content. + +> This SHOULD be used to aid in the mapping between existing (human-readable) documents which might use a different version scheme and CSAF documents with the same content. It is recommended, to use the CSAF revision number to describe the revision history for any new human-readable equivalent. + +The Number (`number`) has value type Version (`version_t`). + +The Summary of the revision (`summary`) of value type `string` with 1 or more characters holds a single non-empty string representing a short description of the changes. + +Each Revision item which has a `number` of `0` or `0.y.z` MUST be removed from the document if the document status is `final`. Versions of the document which are pre-release SHALL NOT have its own revision item. All changes MUST be tracked in the item for the next release version. Build metadata SHOULD NOT be included in the `number` of any revision item. + +##### 3.2.1.12.7 Document Property - Tracking - Status + +Document status (`status`) of value type `string` and `enum` defines the draft status of the document. +The value MUST be one of the following: + +``` + draft + final + interim +``` + +The value `draft` indicates, that this is a pre-release, intended for issuing party's internal use only, or possibly used externally when the party is seeking feedback or indicating its intentions regarding a specific issue. + +The value `final` indicates, that the issuing party asserts the content is unlikely to change. “Final” status is an indication only, and does not preclude updates. This SHOULD be used if the issuing party expects no, slow or few changes. + +The value `interim` indicates, that the issuing party expects rapid updates. This SHOULD be used if the expected rate of release for this document is significant higher than for other documents. Once the rate slows down it MUST be changed to `final`. This MAY be done in a patch version. + +> This is extremely useful for downstream vendors to constantly inform the end users about ongoing investigation. It can be used as an indication to pull the CSAF document more frequently. + +##### 3.2.1.12.8 Document Property - Tracking - Version + +Version has the value type Version (`version_t`). + +### 3.2.2 Product Tree Property + +Product Tree (`product_tree`) has value type `object` with 1 or more properties is a container for all fully qualified product names that can be referenced elsewhere in the document. +The properties are Branches (`branches`), Full Product Names (`full_product_names`), Product Groups (`product_groups`), and Relationships (`relationships`). + +``` + "product_tree": { + // ... + "properties": { + "branches": { + // ... + }, + "full_product_names": { + // ... + }, + "product_groups": { + // ... + }, + "relationships": { + // ... + } + } + }, +``` + +#### 3.2.2.1 Product Tree Property - Branches + +List of branches (`branches`) has the value type `branches_t`. + +#### 3.2.2.2 Product Tree Property - Full Product Names + +List of full product names (`full_product_names`) of value type `array` with 1 or more items of type `full_product_name_t` contains a list of full product names. + +#### 3.2.2.3 Product Tree Property - Product Groups + +List of product groups (`product_groups`) of value type `array` with 1 or more items of value type `object` contains a list of product groups. + +``` + "product_groups": { + // ... + "items": { + // ... + } + }, +``` + +The product group items are of value type `object` with the 2 mandatory properties Group ID (`group_id`) and Product IDs (`product_ids`) and the optional Summary (`summary`) property. + +``` + "properties": { + "group_id": { + // ... + }, + "product_ids": { + // ... + }, + "summary": { + // ... + } + } +``` + +The summary of the product group (`summary`) of value type `string` with 1 or more characters gives a short, optional description of the group. + +*Examples 41:* + +``` + Products supporting Modbus. + The x64 versions of the operating system. +``` + +Group ID (`group_id`) has value type Product Group ID (`product_group_id_t`). + +List of Product IDs (`product_ids`) of value type `array` with 2 or more unique items of value type Product ID (`product_id_t`) lists the product_ids of those products which known as one group in the document. + +#### 3.2.2.4 Product Tree Property - Relationships + +List of relationships (`relationships`) of value type `array` with 1 or more items contains a list of relationships. + +``` + "relationships": { + // ... + "items": { + // ... + } + } +``` + +The Relationship item is of value type `object` and has four mandatory properties: Relationship category (`category`), Full Product Name (`full_product_name`), Product Reference (`product_reference`), and Relates to Product Reference (`relates_to_product_reference`). The Relationship item establishes a link between two existing `full_product_name_t` elements, allowing the document producer to define a combination of two products that form a new `full_product_name` entry. + +``` + "properties": { + "category": { + // ... + }, + "full_product_name": { + // ... + }, + "product_reference": { + // ... + }, + "relates_to_product_reference": { + // ... + } + } +``` + +> The situation where a need for declaring a Relationship arises, is given when a product is e.g. vulnerable only when installed together with another, or to describe operating system components. + +Relationship category (`category`) of value type `string` and `enum` defines the category of relationship for the referenced component. +The valid values are: + +``` + default_component_of + external_component_of + installed_on + installed_with + optional_component_of +``` + +The value `default_component_of` indicates that the entity labeled with one Product ID (e.g. CSAFPID-0001) is a default component of an entity with another Product ID (e.g. CSAFPID-0002). These Product IDs SHOULD NOT be identical to provide minimal redundancy. + +The value `external_component_of` indicates that the entity labeled with one Product ID (e.g. CSAFPID-0001) is an external component of an entity with another Product ID (e.g. CSAFPID-0002). These Product IDs SHOULD NOT be identical to provide minimal redundancy. + +The value `installed_on` indicates that the entity labeled with one Product ID (e.g. CSAFPID-0001) is installed on a platform entity with another Product ID (e.g. CSAFPID-0002). These Product IDs SHOULD NOT be identical to provide minimal redundancy. + +The value `installed_with` indicates that the entity labeled with one Product ID (e.g. CSAFPID-0001) is installed alongside an entity with another Product ID (e.g. CSAFPID-0002). These Product IDs SHOULD NOT be identical to provide minimal redundancy. + +The value `optional_component_of` indicates that the entity labeled with one Product ID (e.g. CSAFPID-0001) is an optional component of an entity with another Product ID (e.g. CSAFPID-0002). These Product IDs SHOULD NOT be identical to provide minimal redundancy. + +Full Product Name (`full_product_name`) of value type Full Product Name Type (`full_product_name_t`). + +Product Reference (`product_reference`) of value type Product ID (`product_id_t`) holds a Product ID that refers to the Full Product Name element, which is referenced as the first element of the relationship. + +Relates to Product Reference (`relates_to_product_reference`) of value type Product ID (`product_id_t`) holds a Product ID that refers to the Full Product Name element, which is referenced as the second element of the relationship. + +*Example 42:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-908070601", + "name": "Cisco AnyConnect Secure Mobility Client 4.9.04053" + }, + { + "product_id": "CSAFPID-908070602", + "name": "Microsoft Windows" + } + ], + "relationships": [ + { + "product_reference": "CSAFPID-908070601", + "category": "installed_on", + "relates_to_product_reference": "CSAFPID-908070602", + "full_product_name": { + "product_id": "CSAFPID-908070603", + "name": "Cisco AnyConnect Secure Mobility Client 2.3.185 installed on Microsoft Windows" + } + } + ] + } +``` + +> The product `Cisco AnyConnect Secure Mobility Client 4.9.04053"` (Product ID: `CSAFPID-908070601`) and the product `Microsoft Windows` (Product ID: `CSAFPID-908070602`) form together a new product with the separate Product ID `CSAFPID-908070603`. The latter one can be used to refer to that combination in other parts of the CSAF document. In example 34, it might be the case that `Cisco AnyConnect Secure Mobility Client 4.9.04053"` is only vulnerable when installed on `Microsoft Windows`. + +### 3.2.3 Vulnerabilities Property + +Vulnerabilities (`vulnerabilities`) of value type `array` with 1 or more objects representing vulnerabilities and providing 1 or more properties represents a list of all relevant vulnerability information items. + +``` + "vulnerabilities": { + // ... + "items": { + // ... + } + } +``` + +The Vulnerability item of value type `object` with 1 or more properties is a container for the aggregation of all fields that are related to a single vulnerability in the document. +Any vulnerability MAY provide the optional properties Acknowledgments (`acknowledgments`), Common Vulnerabilities and Exposures (CVE) (`cve`), Common Weakness Enumeration (CWE) (`cwe`), Discovery Date (`discovery_date`), Flags (`flags`), IDs (`ids`), Involvements (`involvements`), Notes (`notes`), Product Status (`product_status`), References (`references`), Release Date (`release_date`), Remediations (`remediations`), Scores (`scores`), Threats (`threats`), and Title (`title`). + +``` + "properties": { + "acknowledgments": { + // ... + }, + "cve": { + // ... + }, + "cwe": { + // ... + }, + "discovery_date": { + // ... + }, + "flags": { + // ... + }, + "ids": { + // ... + }, + "involvements": { + // ... + }, + "notes": { + // ... + }, + "product_status": { + // ... + }, + "references": { + // ... + }, + "release_date": { + // ... + }, + "remediations": { + // ... + }, + "scores": { + // ... + }, + "threats": { + // ... + }, + "title": { + // ... + } + } +``` + +#### 3.2.3.1 Vulnerabilities Property - Acknowledgments + +Vulnerability acknowledgments (`acknowledgments`) of value type Acknowledgments Type (`acknowledgments_t`) contains a list of acknowledgment elements associated with this vulnerability item. + +``` + "acknowledgments": { + // ... + }, +``` + +#### 3.2.3.2 Vulnerabilities Property - CVE + +CVE (`cve`) of value type `string` with `pattern` (regular expression): + +``` + ^CVE-[0-9]{4}-[0-9]{4,}$ +``` + +holds the MITRE standard Common Vulnerabilities and Exposures (CVE) tracking number for the vulnerability. + +#### 3.2.3.3 Vulnerabilities Property - CWE + +CWE (`cwe`) of value type `object` with the 2 mandatory properties Weakness ID (`id`) and Weakness Name (`name`) holds the MITRE standard Common Weakness Enumeration (CWE) for the weakness associated. For more information cf. [CWE]. + +``` + "cwe": { + // ... + "properties": { + "id": { + // ... + }, + "name": { + // ... + } + } + }, +``` + +The Weakness ID (`id`) has value type `string` with `pattern` (regular expression): + +``` + ^CWE-[1-9]\\d{0,5}$ +``` + +and holds the ID for the weakness associated. + +*Examples 43:* + +``` + CWE-22 + CWE-352 + CWE-79 +``` + +The Weakness name (`name`) has value type `string` with 1 or more characters and holds the full name of the weakness as given in the CWE specification. + +*Examples 44:* + +``` + Cross-Site Request Forgery (CSRF) + Improper Limitation of a Pathname to a Restricted Directory ('Path Traversal') + Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting') +``` + +#### 3.2.3.4 Vulnerabilities Property - Discovery Date + +Discovery date (`discovery_date`) of value type `string` with format `date-time` holds the date and time the vulnerability was originally discovered. + +#### 3.2.3.5 Vulnerabilities Property - Flags + +List of flags (`flags`) of value type `array` with 1 or more unique items (a set) of value type `object` contains a list of machine readable flags. + +``` + "flags": { + // ... + "items": { + // ... + } + }, +``` + +Every Flag item of value type `object` with the mandatory property Label (`label`) contains product specific information in regard to this vulnerability as a single machine readable flag. +For example, this could be a machine readable justification code why a product is not affected. +At least one of the optional elements Group IDs (`group_ids`) and Product IDs (`product_ids`) MUST be present to state for which products or product groups this flag is applicable. + +> These flags enable the receiving party to automate the selection of actions to take. + +In addition, any Flag item MAY provide the three optional properties Date (`date`), Group IDs (`group_ids`) and Product IDs (`product_ids`). + +``` + "properties": { + "date": { + // ... + }, + "group_ids": { + // ... + }, + "label": { + // ... + }, + "product_ids": { + // ... + } + } +``` + +Date of the flag (`date`) of value type `string` with format `date-time` contains the date when assessment was done or the flag was assigned. + +Group IDs (`group_ids`) are of value type Product Groups (`product_groups_t`) and contain a list of Product Groups the current flag item applies to. + +Label of the flag (`label`) of value type `string` and `enum` specifies the machine readable label. Valid `enum` values are: + +``` + component_not_present + inline_mitigations_already_exist + vulnerable_code_cannot_be_controlled_by_adversary + vulnerable_code_not_in_execute_path + vulnerable_code_not_present +``` + +The given values reflect the VEX not affected justifications. See [VEX-Justification] for more details. The values MUST be used as follows: + +* `component_not_present`: The software is not affected because the vulnerable component is not in the product. +* `vulnerable_code_not_present`: The product is not affected because the code underlying the vulnerability is not present in the product. + > Unlike `component_not_present`, the component in question is present, but for whatever reason (e.g. compiler options) the specific code causing the vulnerability is not present in the component. +* `vulnerable_code_cannot_be_controlled_by_adversary`: The vulnerable component is present, and the component contains the vulnerable code. However, vulnerable code is used in such a way that an attacker cannot mount any anticipated attack. +* `vulnerable_code_not_in_execute_path`: The affected code is not reachable through the execution of the code, including non-anticipated states of the product. + > Components that are neither used nor executed by the product. +* `inline_mitigations_already_exist`: Built-in inline controls or mitigations prevent an adversary from leveraging the vulnerability. + +Product IDs (`product_ids`) are of value type Products (`products_t`) and contain a list of Products the current flag item applies to. + +#### 3.2.3.6 Vulnerabilities Property - IDs + +List of IDs (`ids`) of value type `array` with one or more unique ID items of value type `object` represents a list of unique labels or tracking IDs for the vulnerability (if such information exists). + +``` + "ids": { + // ... + "items": { + // ... + } + }, +``` + +Every ID item of value type `object` with the two mandatory properties System Name (`system_name`) and Text (`text`) contains a single unique label or tracking ID for the vulnerability. + +``` + "properties": { + "system_name": { + // ... + }, + "text": { + // ... + } + } +``` + +System name (`system_name`) of value type `string` with 1 or more characters indicates the name of the vulnerability tracking or numbering system. + +*Example 45:* + +``` + Cisco Bug ID + GitHub Issue +``` + +Text (`text`) of value type `string` with 1 or more characters is unique label or tracking ID for the vulnerability (if such information exists). + +*Example 46:* + +``` + CSCso66472 + oasis-tcs/csaf#210 +``` + +> General examples may include an identifier from a vulnerability tracking system that is available to customers, such as: +> +> * a Cisco bug ID, +> * a GitHub Issue number, +> * an ID from a Bugzilla system, or +> * an ID from a public vulnerability database such as the X-Force Database. +> +> The ID MAY be a vendor-specific value but is not to be used to publish the CVE tracking numbers (MITRE standard Common Vulnerabilities and Exposures), as these are specified inside the dedicated CVE element. + +#### 3.2.3.7 Vulnerabilities Property - Involvements + +List of involvements (`involvements`) of value type `array` with 1 or more items of value type `object` contains a list of involvements. + +``` + "involvements": { + // ... + "items": { + // ... + } + }, +``` + +Every Involvement item of value type `object` with the 2 mandatory properties Party (`party`), Status (`status`) and the 2 optional properties Date of involvement (`date`) and Summary (`summary`) is a container that allows the document producers to comment on the level of involvement (or engagement) of themselves (or third parties) in the vulnerability identification, scoping, and remediation process. It can also be used to convey the disclosure timeline. The ordered tuple of the values of `party` and `date` (if present) SHALL be unique within `involvements`. + +``` + "properties": { + "date": { + // ... + }, + "party": { + // ... + }, + "status": { + // ... + }, + "summary": { + // ... + }, + } +``` + +Date of involvement (`date`) of value type `string` with format `date-time` holds the date and time of the involvement entry. + +Party category (`party`) of value type `string` and `enum` defines the category of the involved party. +Valid values are: + +``` + coordinator + discoverer + other + user + vendor +``` + +These values follow the same definitions as given for the publisher category (cf. section 3.2.1.8.1). + +Party status (`status`) of value type `string` and `enum` defines contact status of the involved party. +Valid values are: + +``` + completed + contact_attempted + disputed + in_progress + not_contacted + open +``` + +Each status is mutually exclusive - only one status is valid for a particular vulnerability at a particular time. As the vulnerability ages, a party's involvement could move from state to state. However, in many cases, a document producer may choose not to issue CSAF documents at each state, or simply omit this element altogether. It is recommended, however, that vendors that issue CSAF documents indicating an open or in-progress involvement SHOULD eventually expect to issue a document containing one of the statuses `disputed` or `completed` as the latest one. + +> The two vulnerability involvement status states, `contact_attempted` and `not_contacted` are intended for use by document producers other than vendors (such as research or coordinating entities). + +The value `completed` indicates that the party asserts that investigation of the vulnerability is complete. No additional information, fixes, or documentation from the party about the vulnerability should be expected to be released. + +The value `contact_attempted` indicates that the document producer attempted to contact the party. + +The value `disputed` indicates that the party disputes the vulnerability report in its entirety. This status SHOULD be used when the party believes that a vulnerability report regarding a product is completely inaccurate (that there is no real underlying security vulnerability) or that the technical issue being reported has no security implications. + +The value `in_progress` indicates that some hotfixes, permanent fixes, mitigations, workarounds, or patches may have been made available by the party, but more information or fixes may be released in the future. The use of this status by a vendor indicates that future information from the vendor about the vulnerability is to be expected. + +The value `not_contacted` indicates that the document producer has not attempted to make contact with the party. + +The value `open` is the default status. It doesn’t indicate anything about the vulnerability remediation effort other than the fact that the party has acknowledged awareness of the vulnerability report. The use of this status by a vendor indicates that future updates from the vendor about the vulnerability are to be expected. + +Summary of involvement (`summary`) of value type `string` with 1 or more characters contains additional context regarding what is going on. + +#### 3.2.3.8 Vulnerabilities Property - Notes + +Vulnerability notes (`notes`) of value type Notes Type (`notes_t`) holds notes associated with this vulnerability item. + +``` + "notes": { + // ... + }, +``` + +#### 3.2.3.9 Vulnerabilities Property - Product Status + +Product status (`product_status`) of value type `object` with 1 or more properties contains different lists of product_ids which provide details on the status of the referenced product related to the current vulnerability. +The eight defined properties are First affected (`first_affected`), First fixed (`first_fixed`), Fixed (`fixed`), Known affected (`known_affected`), Known not affected (`known_not_affected`), Last affected (`last_affected`), Recommended (`recommended`), and Under investigation (`under_investigation`) are all of value type Products (`products_t`). + +``` + "product_status": { + // ... + "properties": { + "first_affected": { + // ... + }, + "first_fixed": { + // ... + }, + "fixed": { + // ... + }, + "known_affected": { + // ... + }, + "known_not_affected": { + // ... + }, + "last_affected": { + // ... + }, + "recommended": { + // ... + }, + "under_investigation": { + // .. + } + } + }, +``` + +First affected (`first_affected`) of value type Products (`products_t`) represents that these are the first versions of the releases known to be affected by the vulnerability. + +First fixed (`first_fixed`) of value type Products (`products_t`) represents that these versions contain the first fix for the vulnerability but may not be the recommended fixed versions. + +Fixed (`fixed`) of value type Products (`products_t`) represents that these versions contain a fix for the vulnerability but may not be the recommended fixed versions. + +Known affected (`known_affected`) of value type Products (`products_t`) represents that these versions are known to be affected by the vulnerability. Actions are recommended to remediate or address this vulnerability. + +> This could include for instance learning more about the vulnerability and context, and/or making a risk-based decision to patch or apply defense-in-depth measures. See `/vulnerabilities[]/remediations`, `/vulnerabilities[]/notes` and `/vulnerabilities[]/threats` for more details. + +Known not affected (`known_not_affected`) of value type Products (`products_t`) represents that these versions are known not to be affected by the vulnerability. No remediation is required regarding this vulnerability. + +> This could for instance be because the code referenced in the vulnerability is not present, not exposed, compensating controls exist, or other factors. +See `/vulnerabilities[]/threats` in category `impact` for more details. + +Last affected (`last_affected`) of value type Products (`products_t`) represents that these are the last versions in a release train known to be affected by the vulnerability. Subsequently released versions would contain a fix for the vulnerability. + +Recommended (`recommended`) of value type Products (`products_t`) represents that these versions have a fix for the vulnerability and are the vendor-recommended versions for fixing the vulnerability. + +Under investigation (`under_investigation`) of value type Products (`products_t`) represents that it is not known yet whether these versions are or are not affected by the vulnerability. However, it is still under investigation - the result will be provided in a later release of the document. + +#### 3.2.3.10 Vulnerabilities Property - References + +Vulnerability references (`references`) of value type References Type (`references_t`) holds a list of references associated with this vulnerability item. + +``` + "references": { + // ... + }, +``` + +#### 3.2.3.11 Vulnerabilities Property - Release Date + +Release date (`release_date`) with value type `string` of format `date-time` holds the date and time the vulnerability was originally released into the wild. + +#### 3.2.3.12 Vulnerabilities Property - Remediations + +List of remediations (`remediations`) of value type `array` with 1 or more Remediation items of value type `object` contains a list of remediations. + +``` + "remediations": { + // ... + "items": { + // ... + } + }, +``` + +Every Remediation item of value type `object` with the 2 mandatory properties Category (`category`) and Details (`details`) specifies details on how to handle (and presumably, fix) a vulnerability. At least one of the optional elements Group IDs (`group_ids`) and Product IDs (`product_ids`) MUST be present to state for which products or product groups this remediation is applicable. + +In addition, any Remediation MAY expose the six optional properties Date (`date`), Entitlements (`entitlements`), Group IDs (`group_ids`), Product IDs (`product_ids`), Restart required (`restart_required`), and URL (`url`). + +``` + "properties": { + "category": { + // ... + }, + "date": { + // ... + }, + "details": { + // ... + }, + "entitlements": { + // ... + }, + "group_ids": { + // ... + }, + "product_ids": { + // ... + }, + "restart_required": { + // ... + }, + "url": { + // ... + } + } +``` + +##### 3.2.3.12.1 Vulnerabilities Property - Remediations - Category + +Category of the remediation (`category`) of value type `string` and `enum` specifies the category which this remediation belongs to. +Valid values are: + +``` + mitigation + no_fix_planned + none_available + vendor_fix + workaround +``` + +The value `workaround` indicates that the remediation contains information about a configuration or specific deployment scenario that can be used to avoid exposure to the vulnerability. There MAY be none, one, or more workarounds available. This is typically the “first line of defense” against a new vulnerability before a mitigation or vendor fix has been issued or even discovered. + +The value `mitigation` indicates that the remediation contains information about a configuration or deployment scenario that helps to reduce the risk of the vulnerability but that does not resolve the vulnerability on the affected product. Mitigations MAY include using devices or access controls external to the affected product. Mitigations MAY or MAY NOT be issued by the original author of the affected product, and they MAY or MAY NOT be officially sanctioned by the document producer. + +The value `vendor_fix` indicates that the remediation contains information about an official fix that is issued by the original author of the affected product. Unless otherwise noted, it is assumed that this fix fully resolves the vulnerability. +This value contradicts with the categories `none_available` and `no_fix_planned` for the same product. Therefore, such a combination can't be used in the list of remediations. + +The value `none_available` indicates that there is currently no fix or other remediation available. The text in field `details` SHOULD contain details about why there is no fix or other remediation. +The values `none_available` and `vendor_fix` are mutually exclusive per product. + +> An issuing party might choose to use this category to announce that a fix is currently developed. It is recommended that this also includes a date when a customer can expect the fix to be ready and distributed. + +The value `no_fix_planned` indicates that there is no fix for the vulnerability and it is not planned to provide one at any time. This is often the case when a product has been orphaned, declared end-of-life, or otherwise deprecated. The text in field `details` SHOULD contain details about why there will be no fix issued. +The values `no_fix_planned` and `vendor_fix` are mutually exclusive per product. + +##### 3.2.3.12.2 Vulnerabilities Property - Remediations - Date + +Date of the remediation (`date`) of value type `string` with format `date-time` contains the date from which the remediation is available. + +##### 3.2.3.12.3 Vulnerabilities Property - Remediations - Details + +Details of the remediation (`details`) of value type `string` with 1 or more characters contains a thorough human-readable discussion of the remediation. + +##### 3.2.3.12.4 Vulnerabilities Property - Remediations - Entitlements + +List of entitlements (`entitlements`) of value type `array` with 1 or more items of type Entitlement of the remediation as `string` with 1 or more characters contains a list of entitlements. + +``` + "entitlements": { + // .... + "items": { + // ... + } + }, +``` + +Every Entitlement of the remediation contains any possible vendor-defined constraints for obtaining fixed software or hardware that fully resolves the vulnerability. + +##### 3.2.3.12.5 Vulnerabilities Property - Remediations - Group IDs + +Group IDs (`group_ids`) are of value type Product Groups (`product_groups_t`) and contain a list of Product Groups the current remediation item applies to. + +##### 3.2.3.12.6 Vulnerabilities Property - Remediations - Product IDs + +Product IDs (`product_ids`) are of value type Products (`products_t`) and contain a list of Products the current remediation item applies to. + +##### 3.2.3.12.7 Vulnerabilities Property - Remediations - Restart Required + +Restart required by remediation (`restart_required`) of value type `object` with the 1 mandatory property Category (`category`) and the optional property Details (`details`) provides information on category of restart is required by this remediation to become effective. + +``` + "restart_required": { + // ... + "properties": { + "category": { + // ... + } + "details": { + // ... + } + } + }, +``` + +Category of restart (`category`) of value type `string` and `enum` specifies what category of restart is required by this remediation to become effective. +Valid values are: + +``` + connected + dependencies + machine + none + parent + service + system + vulnerable_component + zone +``` + +The values MUST be used as follows: + +* `none`: No restart required. +* `vulnerable_component`: Only the vulnerable component (as given by the elements of `product_ids` or `group_ids` in the current remediation item) needs to be restarted. +* `service`: The vulnerable component and the background service used by the vulnerable component need to be restarted. +* `parent`: The vulnerable component and its parent process need to be restarted. This could be the case if the parent process has no build-in way to restart the vulnerable component or process values / context is only given at the start of the parent process. +* `dependencies`: The vulnerable component and all components which require the vulnerable component to work need to be restarted. This could be the case e.g. for a core service of a software. +* `connected`: The vulnerable component and all components connected (via network or any type of inter-process communication) to the vulnerable component need to be restarted. +* `machine`: The machine on which the vulnerable component is installed on needs to be restarted. This is the value which SHOULD be used if an OS needs to be restarted. It is typically the case for OS upgrades. +* `zone`: The security zone in which the machine resides on which the vulnerable component is installed needs to be restarted. This value might be useful for a remediation if no patch is available. If the malware can be wiped out by restarting the infected machines but the infection spreads fast the controlled shutdown of all machines at the same time and restart afterwards can leave one with a clean system. +* `system`: The whole system which the machine resides on which the vulnerable component is installed needs to be restarted. This MAY include multiple security zones. This could be the case for a major system upgrade in an ICS system or a protocol change. + +Additional restart information (`details`) of value type `string` with 1 or more characters provides additional information for the restart. This can include details on procedures, scope or impact. + +##### 3.2.3.12.8 Vulnerabilities Property - Remediations - URL + +URL (`url`) of value type `string` with format `uri` contains the URL where to obtain the remediation. + +#### 3.2.3.13 Vulnerabilities Property - Scores + +List of scores (`scores`) of value type `array` with 1 or more items of type score holds a list of score objects for the current vulnerability. + +``` + "scores": { + // ... + "items": { + // ... + } + }, +``` + +Value type of every such Score item is `object` with the mandatory property `products` and the optional properties `cvss_v2` and `cvss_v3` specifies information about (at least one) score of the vulnerability and for which products the given value applies. Each Score item has at least 2 properties. + +``` + "properties": { + "cvss_v2": { + // ... + }, + "cvss_v3": { + "oneOf": [ + // ... + ] + } + "products": { + // ... + } + } +``` + +The property CVSS v2 (`cvss_v2`) holding a CVSS v2.0 value abiding by the schema at [https://www.first.org/cvss/cvss-v2.0.json](https://www.first.org/cvss/cvss-v2.0.json). + +The property CVSS v3 (`cvss_v3`) holding a CVSS v3.x value abiding by one of the schemas at [https://www.first.org/cvss/cvss-v3.0.json](https://www.first.org/cvss/cvss-v3.0.json) or [https://www.first.org/cvss/cvss-v3.1.json](https://www.first.org/cvss/cvss-v3.1.json). + +Product IDs (`products`) of value type `products_t` with 1 or more items indicates for which products the given scores apply. A score object SHOULD reflect the associated product's status (for example, a fixed product no longer contains a vulnerability and should have a CVSS score of 0, or simply no score listed; the known affected versions of that product can list the vulnerability score as it applies to them). + +#### 3.2.3.14 Vulnerabilities Property - Threats + +List of threats (`threats`) of value type `array` with 1 or more items of value type `object` contains information about a vulnerability that can change with time. + +``` + "threats": { + // ... + "items": { + // ... + } + }, +``` + +Every Threat item of value type `object` with the two mandatory properties Category (`category`) and Details (`details`) contains the vulnerability kinetic information. +This information can change as the vulnerability ages and new information becomes available. +In addition, any Threat item MAY expose the three optional properties Date (`date`), Group IDs (`group_ids`), and Product IDs (`product_ids`). + +``` + "properties": { + "category": { + // ... + } + "date": { + // ... + }, + "details": { + // ... + }, + "group_ids": { + // ... + }, + "product_ids": { + // ... + } + } +``` + +Category of the threat (`category`) of value type `string` and `enum` categorizes the threat according to the rules of the specification. +Valid values are: + +``` + exploit_status + impact + target_set +``` + +The value `exploit_status` indicates that the `details` field contains a description of the degree to which an exploit for the vulnerability is known. This knowledge can range from information privately held among a very small group to an issue that has been described to the public at a major conference or is being widely exploited globally. For consistency and simplicity, this section can be a mirror image of the CVSS "Exploitability" metric. However, it can also contain a more contextual status, such as "Weaponized" or "Functioning Code". + +The value `impact` indicates that the `details` field contains an assessment of the impact on the user or the target set if the vulnerability is successfully exploited or a description why it cannot be exploited. If applicable, for consistency and simplicity, this section can be a textual summary of the three CVSS impact metrics. These metrics measure how a vulnerability detracts from the three core security properties of an information system: Confidentiality, Integrity, and Availability. + +The value `target_set` indicates that the `details` field contains a description of the currently known victim population in whatever terms are appropriate. Such terms MAY include: operating system platform, types of products, user segments, and geographic distribution. + +Date of the threat (`date`) of value type `string` with format `date-time` contains the date when the assessment was done or the threat appeared. + +Details of the threat (`details`) of value type `string` with 1 or more characters represents a thorough human-readable discussion of the threat. + +Group IDs (`group_ids`) are of value type Product Groups (`product_groups_t`) and contain a list of Product Groups the current threat item applies to. + +Product IDs (`product_ids`) are of value type Products (`products_t`) and contain a list of Products the current threat item applies to. + +#### 3.2.3.15 Vulnerabilities Property - Title + +Title (`title`) has value type `string` with 1 or more characters and gives the document producer the ability to apply a canonical name or title to the vulnerability. + +------- + +# 4 Profiles + +CSAF documents do not have many required fields as they can be used for different purposes. To ensure a common understanding of which fields are required in a given use case the standard defines profiles. Each subsection describes such a profile by describing necessary content for that specific use case and providing insights into its purpose. The value of `/document/category` is used to identify a CSAF document's profile. The following rules apply: + +1. Each CSAF document MUST conform the **CSAF Base** profile. +2. Each profile extends the base profile "CSAF Base" - directly or indirect through another profile from the standard - by making additional fields from the standard mandatory. A profile can always add, but never subtract nor overwrite requirements defined in the profile it extends. +3. Any optional field from the standard can also be added to a CSAF document which conforms with a profile without breaking conformance with the profile. One and only exempt is when the profile requires not to have a certain set of fields. +4. Values of `/document/category` starting with `csaf_` are reserved for existing, upcoming and future profiles defined in the CSAF standard. +5. Values of `/document/category` that do not match any of the values defined in section 4 of this standard SHALL be validated against the "CSAF Base" profile. +6. Local or private profiles MAY exist and tools MAY choose to support them. +7. If an official profile and a private profile exists, tools MUST validate against the official one from the standard. + +## 4.1 Profile 1: CSAF Base + +This profile defines the default required fields for any CSAF document. Therefore, it is a "catch all" for CSAF documents that do not satisfy any other profile. Furthermore, it is the foundation all other profiles are build on. + +A CSAF document SHALL fulfill the following requirements to satisfy the profile "CSAF Base": + +* The following elements MUST exist and be valid: + * `/document/category` + * `/document/csaf_version` + * `/document/publisher/category` + * `/document/publisher/name` + * `/document/publisher/namespace` + * `/document/title` + * `/document/tracking/current_release_date` + * `/document/tracking/id` + * `/document/tracking/initial_release_date` + * `/document/tracking/revision_history[]/date` + * `/document/tracking/revision_history[]/number` + * `/document/tracking/revision_history[]/summary` + * `/document/tracking/status` + * `/document/tracking/version` +* The value of `/document/category` SHALL NOT be equal to any value that is intended to only be used by another profile nor to the (case insensitive) name of any other profile from the standard. This does not differentiate between underscore, dash or whitespace. To explicitly select the use of this profile the value `csaf_base` SHOULD be used. + +> Neither `CSAF Security Advisory` nor `csaf security advisory` are valid values for `/document/category`. + +An issuing party might choose to set `/document/publisher/name` in front of a value that is intended to only be used by another profile to state that the CSAF document does not use the profile associated with this value. In this case, the (case insensitive) string "CSAF" MUST be removed from the value. This SHOULD be done if the issuing party is unable or unwilling to use the value `csaf_base`, e.g. due to legal or cooperate identity reasons. + +> Both values `Example Company Security Advisory` and `Example Company security_advisory` in `/document/category` use the profile "CSAF Base". This is important to prepare forward compatibility as later versions of CSAF might add new profiles. Therefore, the values which can be used for the profile "CSAF Base" might change. + +## 4.2 Profile 2: Security incident response + +This profile SHOULD be used to provide a response to a security breach or incident. This MAY also be used to convey information about an incident that is unrelated to the issuing party's own products or infrastructure. + +> Example Company might use a CSAF document satisfying this profile to respond to a security incident at ACME Inc. and the implications on its own products and infrastructure. + +A CSAF document SHALL fulfill the following requirements to satisfy the profile "Security incident response": + +* The following elements MUST exist and be valid: + * all elements required by the profile "CSAF Base". + * `/document/notes` with at least one item which has a `category` of `description`, `details`, `general` or `summary` + > Reasoning: Without at least one note item which contains information about response to the event referred to this doesn't provide any useful information. + * `/document/references` with at least one item which has a `category` of `external` + > The intended use for this field is to refer to one or more documents or websites which provides more details about the incident. +* The value of `/document/category` SHALL be `csaf_security_incident_response`. + +## 4.3 Profile 3: Informational Advisory + +This profile SHOULD be used to provide information which are **not related to a vulnerability** but e.g. a misconfiguration. + +A CSAF document SHALL fulfill the following requirements to satisfy the profile "Informational Advisory": + +* The following elements MUST exist and be valid: + * all elements required by the profile "CSAF Base". + * `/document/notes` with at least one item which has a `category` of `description`, `details`, `general` or `summary` + > Reasoning: Without at least one note item which contains information about the "issue" which is the topic of the advisory it is useless. + * `/document/references` with at least one item which has a `category` of `external` + > The intended use for this field is to refer to one or more documents or websites which provide more details about the issue or its remediation (if possible). This could be a hardening guide, a manual, best practices or any other helpful information. +* The value of `/document/category` SHALL be `csaf_informational_advisory`. +* The element `/vulnerabilities` SHALL NOT exist. If there is any information that would reside in the element `/vulnerabilities` the CSAF document SHOULD use another profile, e.g. "Security Advisory". + +If the element `/product_tree` exists, a user MUST assume that all products mentioned are affected. + +## 4.4 Profile 4: Security Advisory + +This profile SHOULD be used to provide information which is related to vulnerabilities and corresponding remediations. + +A CSAF document SHALL fulfill the following requirements to satisfy the profile "Security Advisory": + +* The following elements MUST exist and be valid: + * all elements required by the profile "CSAF Base". + * `/product_tree` which lists all products referenced later on in the CSAF document regardless of their state. + * `/vulnerabilities` which lists all vulnerabilities. + * `/vulnerabilities[]/notes` + > Provides details about the vulnerability. + * `/vulnerabilities[]/product_status` + > Lists each product's status in regard to the vulnerability. +* The value of `/document/category` SHALL be `csaf_security_advisory`. + +## 4.5 Profile 5: VEX + +This profile SHOULD be used to provide information of the "Vulnerability Exploitability eXchange". The main purpose of the VEX format is to state that and why a certain product is, or is not, affected by a vulnerability. See [VEX] for details. + +A CSAF document SHALL fulfill the following requirements to satisfy the profile "VEX": + +* The following elements MUST exist and be valid: + * all elements required by the profile "CSAF Base". + * `/product_tree` which lists all products referenced later on in the CSAF document regardless of their state. + * `/vulnerabilities` which lists all vulnerabilities. + * at least one of + * `/vulnerabilities[]/product_status/fixed` + * `/vulnerabilities[]/product_status/known_affected` + * `/vulnerabilities[]/product_status/known_not_affected` + * `/vulnerabilities[]/product_status/under_investigation` + * at least one of + * `/vulnerabilities[]/cve` + * `/vulnerabilities[]/ids` + * `/vulnerabilities[]/notes` + > Provides details about the vulnerability. +* For each item in + * `/vulnerabilities[]/product_status/known_not_affected` an impact statement SHALL exist as machine readable flag in `/vulnerabilities[]/flags` or as human readable justification in `/vulnerabilities[]/threats`. For the latter one, the `category` value for such a statement MUST be `impact` and the `details` field SHALL contain a a description why the vulnerability cannot be exploited. + * `/vulnerabilities[]/product_status/known_affected` additional product specific information SHALL be provided in `/vulnerabilities[]/remediations` as an action statement. Optional, additional information MAY also be provide through `/vulnerabilities[]/notes` and `/vulnerabilities[]/threats`. + > The use of the categories `no_fix_planned` and `none_available` for an action statement is permitted. + > Even though Product status lists Product IDs, Product Group IDs can be used in the `remediations` and `threats` object. However, it MUST be ensured that for each Product ID the required information according to its product status as stated in the two points above is available. This implies that all products with the status `known_not_affected` MUST have an impact statement and all products with the status `known_affected` MUST have additional product specific information regardless of whether that is referenced through the Product ID or a Product Group ID. +* The value of `/document/category` SHALL be `csaf_vex`. + +------- + +# 5 Additional Conventions + +This section provides additional rules for handling CSAF documents. + +## 5.1 Filename + +The following rules MUST be applied to determine the filename for the CSAF document: + +1. The value `/document/tracking/id` is converted into lower case. +2. Any character sequence which is not part of one of the following groups MUST be replaced by a single underscore (`_`): + * Lower case ASCII letters (0x61 - 0x7A) + * digits (0x30 - 0x39) + * special characters: `+` (0x2B), `-` (0x2D) + > The regex `[^+\-a-z0-9]+` can be used to find a character sequence which has to be replaced by an underscore. However, it SHALL NOT be applied before completing the first step. + > + > Even though the underscore `_` (0x5F) is a valid character in the filename it is replaced to avoid situations where the conversion rule might lead to multiple consecutive underscores. As a result, a `/document/tracking/id` with the value `2022_#01-A` is converted into `2022_01-a` instead of `2022__01-a`. +3. The file extension `.json` MUST be appended. + +*Examples 47:* + +``` + cisco-sa-20190513-secureboot.json + example_company_-_2019-yh3234.json + rhba-2019_0024.json +``` + +> It is currently considered best practice to indicate that a CSAF document is invalid by inserting `_invalid` into the filename in front of the file extension. + +*Examples 48:* + +``` + cisco-sa-20190513-secureboot_invalid.json + example_company_-_2019-yh3234_invalid.json + rhba-2019_0024_invalid.json +``` + +## 5.2 Separation in Data Stream + +If multiple CSAF documents are transported via a data stream in a sequence without requests inbetween, they MUST be separated by the Record Separator in accordance with [RFC7464]. + +## 5.3 Sorting + +The keys within a CSAF document SHOULD be sorted alphabetically. + +------- + +# 6 Tests + +The following three subsections list a number of tests which all will have a short description and an excerpt of an example which fails the test. + +## 6.1 Mandatory Tests + +Mandatory tests MUST NOT fail at a valid CSAF document. A program MUST handle a test failure as an error. + +### 6.1.1 Missing Definition of Product ID + +For each element of type `/$defs/product_id_t` which is not inside a Full Product Name (type: `full_product_name_t`) and therefore reference an element within the `product_tree` it MUST be tested that the Full Product Name element with the matching `product_id` exists. The same applies for all items of elements of type `/$defs/products_t`. + +The relevant paths for this test are: + +``` + /product_tree/product_groups[]/product_ids[] + /product_tree/relationships[]/product_reference + /product_tree/relationships[]/relates_to_product_reference + /vulnerabilities[]/product_status/first_affected[] + /vulnerabilities[]/product_status/first_fixed[] + /vulnerabilities[]/product_status/fixed[] + /vulnerabilities[]/product_status/known_affected[] + /vulnerabilities[]/product_status/known_not_affected[] + /vulnerabilities[]/product_status/last_affected[] + /vulnerabilities[]/product_status/recommended[] + /vulnerabilities[]/product_status/under_investigation[] + /vulnerabilities[]/remediations[]/product_ids[] + /vulnerabilities[]/scores[]/products[] + /vulnerabilities[]/threats[]/product_ids[] +``` + +*Example 49 which fails the test:* + +``` + "product_tree": { + "product_groups": [ + { + "group_id": "CSAFGID-1020300", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ] + } +``` + +> Neither `CSAFPID-9080700` nor `CSAFPID-9080701` were defined in the `product_tree`. + +### 6.1.2 Multiple Definition of Product ID + +For each Product ID (type `/$defs/product_id_t`) in Full Product Name elements (type: `/$defs/full_product_name_t`) it MUST be tested that the `product_id` was not already defined within the same document. + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/product/product_id + /product_tree/full_product_names[]/product_id + /product_tree/relationships[]/full_product_name/product_id +``` + +*Example 50 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080700", + "name": "Product B" + } + ] + } +``` + +> `CSAFPID-9080700` was defined twice. + +### 6.1.3 Circular Definition of Product ID + +For each new defined Product ID (type `/$defs/product_id_t`) in items of relationships (`/product_tree/relationships`) it MUST be tested that the `product_id` does not end up in a circle. + +The relevant path for this test is: + +``` + /product_tree/relationships[]/full_product_name/product_id +``` + +> As this can be quite complex a program for large CSAF documents, a program could check first whether a Product ID defined in a relationship item is used as `product_reference` or `relates_to_product_reference`. Only for those which fulfill this condition it is necessary to run the full check following the references. + +*Example 51 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ], + "relationships": [ + { + "category": "installed_on", + "full_product_name": { + "name": "Product B", + "product_id": "CSAFPID-9080701" + }, + "product_reference": "CSAFPID-9080700", + "relates_to_product_reference": "CSAFPID-9080701" + } + ] + } +``` + +> `CSAFPID-9080701` refers to itself - this is a circular definition. + +### 6.1.4 Missing Definition of Product Group ID + +For each element of type `/$defs/product_group_id_t` which is not inside a Product Group (`/product_tree/product_groups[]`) and therefore reference an element within the `product_tree` it MUST be tested that the Product Group element with the matching `group_id` exists. The same applies for all items of elements of type `/$defs/product_groups_t`. + +The relevant paths for this test are: + +``` + /vulnerabilities[]/remediations[]/group_ids + /vulnerabilities[]/threats[]/group_ids +``` + +*Example 52 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "threats": [ + { + "category": "exploit_status", + "details": "Reliable exploits integrated in Metasploit.", + "group_ids": [ + "CSAFGID-1020301" + ] + } + ] + } + ] +``` + +> `CSAFGID-1020301` was not defined in the Product Tree. + +### 6.1.5 Multiple Definition of Product Group ID + +For each Product Group ID (type `/$defs/product_group_id_t`) Product Group elements (`/product_tree/product_groups[]`) it MUST be tested that the `group_id` was not already defined within the same document. + +The relevant path for this test is: + +``` + /product_tree/product_groups[]/group_id +``` + +*Example 53 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ], + "product_groups": [ + { + "group_id": "CSAFGID-1020300", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + }, + { + "group_id": "CSAFGID-1020300", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080702" + ] + } + ] + } +``` + +> `CSAFGID-1020300` was defined twice. + +### 6.1.6 Contradicting Product Status + +For each item in `/vulnerabilities` it MUST be tested that the same Product ID is not member of contradicting product status groups. The sets formed by the contradicting groups within one vulnerability item MUST be pairwise disjoint. + +Contradiction groups are: + +* Affected: + + ``` + /vulnerabilities[]/product_status/first_affected[] + /vulnerabilities[]/product_status/known_affected[] + /vulnerabilities[]/product_status/last_affected[] + ``` + +* Not affected: + + ``` + /vulnerabilities[]/product_status/known_not_affected[] + ``` + +* Fixed: + + ``` + /vulnerabilities[]/product_status/first_fixed[] + /vulnerabilities[]/product_status/fixed[] + ``` + +* Under investigation: + + ``` + /vulnerabilities[]/product_status/under_investigation[] + ``` + +> Note: An issuer might recommend (`/vulnerabilities[]/product_status/recommended`) a product version from any group - also from the affected group, i.e. if it was discovered that fixed versions introduce a more severe vulnerability. + +*Example 54 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "known_affected": [ + "CSAFPID-9080700" + ], + "known_not_affected": [ + "CSAFPID-9080700" + ] + } + } + ] +``` + +> `CSAFPID-9080700` is a member of the two contradicting groups "Affected" and "Not affected". + +### 6.1.7 Multiple Scores with same Version per Product + +For each item in `/vulnerabilities` it MUST be tested that the same Product ID is not member of more than one CVSS-Vectors with the same version. + +The relevant path for this test is: + +``` + /vulnerabilities[]/scores[] +``` + +*Example 55 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H", + "baseScore": 10, + "baseSeverity": "CRITICAL" + } + }, + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 6.5, + "baseSeverity": "MEDIUM" + } + } + ] + } + ] +``` + +> Two CVSS v3.1 scores are given for `CSAFPID-9080700`. + +### 6.1.8 Invalid CVSS + +It MUST be tested that the given CVSS object is valid according to the referenced schema. + +The relevant paths for this test are: + +``` + /vulnerabilities[]/scores[]/cvss_v2 + /vulnerabilities[]/scores[]/cvss_v3 +``` + +*Example 56 which fails the test:* + +``` + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 6.5 + } +``` + +> The required element `baseSeverity` is missing. + +> A tool MAY add one or more of the missing properties `version`, `baseScore` and `baseSeverity` based on the values given in `vectorString` as quick fix. + +### 6.1.9 Invalid CVSS computation + +It MUST be tested that the given CVSS object has the values computed correctly according to the definition. + +> The `vectorString` SHOULD take precedence. + +The relevant paths for this test are: + +``` + /vulnerabilities[]/scores[]/cvss_v2/baseScore + /vulnerabilities[]/scores[]/cvss_v2/temporalScore + /vulnerabilities[]/scores[]/cvss_v2/environmentalScore + /vulnerabilities[]/scores[]/cvss_v3/baseScore + /vulnerabilities[]/scores[]/cvss_v3/baseSeverity + /vulnerabilities[]/scores[]/cvss_v3/temporalScore + /vulnerabilities[]/scores[]/cvss_v3/temporalSeverity + /vulnerabilities[]/scores[]/cvss_v3/environmentalScore + /vulnerabilities[]/scores[]/cvss_v3/environmentalSeverity +``` + +*Example 57 which fails the test:* + +``` + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 10.0, + "baseSeverity": "LOW" + } +``` + +> Neither `baseScore` nor `baseSeverity` has the correct value according to the specification. + +> A tool MAY set the correct values as computed according to the specification as quick fix. + +### 6.1.10 Inconsistent CVSS + +It MUST be tested that the given CVSS properties do not contradict the CVSS vector. + +The relevant paths for this test are: + +``` + /vulnerabilities[]/scores[]/cvss_v2 + /vulnerabilities[]/scores[]/cvss_v3 +``` + +*Example 58 which fails the test:* + +``` + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H", + "baseScore": 9.8, + "baseSeverity": "CRITICAL", + "attackVector": "LOCAL", + "attackComplexity": "LOW", + "privilegesRequired": "NONE", + "userInteraction": "NONE", + "scope": "CHANGED", + "confidentialityImpact": "HIGH", + "integrityImpact": "HIGH", + "availabilityImpact": "LOW" + } +``` + +> The values in CVSS vector differs from values of the properties `attackVector`, `scope` and `availabilityImpact`. + +> A tool MAY overwrite contradicting values according to the `vectorString` as quick fix. + +### 6.1.11 CWE + +It MUST be tested that given CWE exists and is valid. + +The relevant path for this test is: + +``` + /vulnerabilities[]/cwe +``` + +*Example 59 which fails the test:* + +``` + "cwe": { + "id": "CWE-79", + "name": "Improper Input Validation" + } +``` + +> The `CWE-79` exists. However, its name is `Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')`. + +### 6.1.12 Language + +For each element of type `/$defs/language_t` it MUST be tested that the language code is valid and exists. + +The relevant paths for this test are: + +``` + /document/lang + /document/source_lang +``` + +*Example 60 which fails the test:* + +``` + "lang": "EZ" +``` + +> `EZ` is not a valid language. It is the subtag for the region "Eurozone". + +> For any deprecated subtag, a tool MAY replace it with its preferred value as a quick fix. + +### 6.1.13 PURL + +It MUST be tested that given PURL is valid. + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/product/product_identification_helper/purl + /product_tree/full_product_names[]/product_identification_helper/purl + /product_tree/relationships[]/full_product_name/product_identification_helper/purl +``` + +*Example 61 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "purl": "pkg:maven/@1.3.4" + } + } + ] + } +``` + +> Any valid purl has a name component. + +### 6.1.14 Sorted Revision History + +It MUST be tested that the value of `number` of items of the revision history are sorted ascending when the items are sorted ascending by `date`. + +The relevant path for this test is: + +``` + /document/tracking/revision_history +``` + +*Example 62 which fails the test:* + +``` + "revision_history": [ + { + "date": "2021-07-22T10:00:00.000Z", + "number": "2", + "summary": "Second version." + }, + { + "date": "2021-07-23T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ] +``` + +> The first item has a higher version number than the second. + +### 6.1.15 Translator + +It MUST be tested that `/document/source_lang` is present and set if the value `translator` is used for `/document/publisher/category`. + +The relevant path for this test is: + +``` + /document/source_lang +``` + +*Example 63 which fails the test:* + +``` + "document": { + // ... + "publisher": { + "category": "translator", + "name": "CSAF TC Translator", + "namespace": "https://csaf.io/translator" + }, + "title": "Mandatory test: Translator (failing example 1)", + // ... + } +``` + +> The required element `source_lang` is missing. + +### 6.1.16 Latest Document Version + +It MUST be tested that document version has the same value as the the `number` in the last item of Revision History when it is sorted ascending by `date`. Build metadata is ignored in the comparison. Any pre-release part is also ignored if the document status is `draft`. + +The relevant path for this test is: + +``` + /document/tracking/version +``` + +*Example 64 which fails the test:* + +``` + "tracking": { + // ... + "revision_history": [ + { + "date": "2021-07-21T09:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + // ... + "version": "1" + } +``` + +> The value of `number` of the last item after sorting is `2`. However, the document version is `1`. + +### 6.1.17 Document Status Draft + +It MUST be tested that document status is `draft` if the document version is `0` or `0.y.z` or contains the pre-release part. + +The relevant path for this test is: + +``` + /document/tracking/status +``` + +*Example 65 which fails the test:* + +``` + "tracking": { + // ... + "status": "final", + "version": "0.9.5" + } +``` + +> The `/document/tracking/version` is `0.9.5` but the document status is `final`. + +### 6.1.18 Released Revision History + +It MUST be tested that no item of the revision history has a `number` of `0` or `0.y.z` when the document status is `final` or `interim`. + +The relevant path for this test is: + +``` + /document/tracking/revision_history[]/number +``` + +*Example 66 which fails the test:* + +``` + "tracking": { + // ... + "revision_history": [ + { + "date": "2021-05-17T10:00:00.000Z", + "number": "0", + "summary": "First draft" + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } +``` + +> The document status is `final` but the revision history includes an item which has `0` as value for `number`. + +### 6.1.19 Revision History Entries for Pre-release Versions + +It MUST be tested that no item of the revision history has a `number` which includes pre-release information. + +The relevant path for this test is: + +``` + /document/tracking/revision_history[]/number +``` + +*Example 67 which fails the test:* + +``` + "revision_history": [ + { + "date": "2021-04-22T10:00:00.000Z", + "number": "1.0.0-rc", + "summary": "Release Candidate for initial version." + }, + { + "date": "2021-04-23T10:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + } + ] +``` + +> The revision history contains an item which has a `number` that indicates that this is pre-release. + +### 6.1.20 Non-draft Document Version + +It MUST be tested that document version does not contain a pre-release part if the document status is `final` or `interim`. + +The relevant path for this test is: + +``` + /document/tracking/version +``` + +*Example 68 which fails the test:* + +``` + "tracking": { + // ... + "status": "interim", + "version": "1.0.0-alpha" + } +``` + +> The document status is `interim` but the document version contains the pre-release part `-alpha`. + +### 6.1.21 Missing Item in Revision History + +It MUST be tested that items of the revision history do not omit a version number when the items are sorted ascending by `date`. In the case of semantic versioning, this applies only to the Major version. It MUST also be tested that the first item in such a sorted list has either the version number 0 or 1 in the case of integer versioning or a Major version of 0 or 1 in the case of semantic versioning. + +The relevant path for this test is: + +``` + /document/tracking/revision_history +``` + +*Example 69 which fails the test:* + +``` + "revision_history": [ + { + "date": "2021-04-22T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "3", + "summary": "Some other changes." + } + ] +``` + +> The item for version `2` is missing. + +### 6.1.22 Multiple Definition in Revision History + +It MUST be tested that items of the revision history do not contain the same version number. + +The relevant path for this test is: + +``` + /document/tracking/revision_history +``` + +*Example 70 which fails the test:* + +``` + "revision_history": [ + { + "date": "2021-07-20T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Some other changes." + } + ] +``` + +> The revision history contains two items with the version number `1`. + +### 6.1.23 Multiple Use of Same CVE + +It MUST be tested that a CVE is not used in multiple vulnerability items. + +The relevant path for this test is: + +``` + /vulnerabilities[]/cve +``` + +*Example 71 which fails the test:* + +``` + "vulnerabilities": [ + { + "cve": "CVE-2017-0145" + }, + { + "cve": "CVE-2017-0145" + } + ] +``` + +> The vulnerabilities array contains two items with the same CVE identifier `CVE-2017-0145`. + +### 6.1.24 Multiple Definition in Involvements + +It MUST be tested that items of the list of involvements do not contain the same `party` regardless of its `status` more than once at any `date`. + +The relevant path for this test is: + +``` + /vulnerabilities[]/involvements +``` + +*Example 72 which fails the test:* + +``` + "vulnerabilities": [ + { + "involvements": [ + { + "date": "2021-04-23T10:00:00.000Z", + "party": "vendor", + "status": "completed" + }, + { + "date": "2021-04-23T10:00:00.000Z", + "party": "vendor", + "status": "in_progress", + "summary": "The vendor has released a mitigation and is working to fully resolve the issue." + } + ] + } + ] +``` + +> The list of involvements contains two items with the same tuple `party` and `date`. + +### 6.1.25 Multiple Use of Same Hash Algorithm + +It MUST be tested that the same hash algorithm is not used multiple times in one item of hashes. + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/product/product_identification_helper/hashes[]/file_hashes + /product_tree/full_product_names[]/product_identification_helper/hashes[]/file_hashes + /product_tree/relationships[]/full_product_name/product_identification_helper/hashes[]/file_hashes +``` + +*Example 73 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "hashes": [ + { + "file_hashes": [ + { + "algorithm": "sha256", + "value": "026a37919b182ef7c63791e82c9645e2f897a3f0b73c7a6028c7febf62e93838" + }, + { + "algorithm": "sha256", + "value": "0a853ce2337f0608489ac596a308dc5b7b19d35a52b10bf31261586ac368b175" + } + ], + "filename": "product_a.so" + } + ] + } + } + ] + } +``` + +> The hash algorithm `sha256` is used two times in one item of hashes. + +### 6.1.26 Prohibited Document Category Name + +It MUST be tested that the document category is not equal to the (case insensitive) name (without the prefix `csaf_`) or value of any other profile than "CSAF Base". Any occurrences of dash, whitespace, and underscore characters are removed from the values on both sides before the match. Also the value MUST NOT start with the reserved prefix `csaf_` except if the value is `csaf_base`. + +This test does only apply for CSAF documents with the profile "CSAF Base". Therefore, it MUST be skipped if the document category matches one of the values defined for the profile other than "CSAF Base". + +> For CSAF 2.0, the test must be skipped for the following values in `/document/category`: +> +> ``` +> csaf_base +> csaf_security_incident_response +> csaf_informational_advisory +> csaf_security_advisory +> csaf_vex +> ``` + +This is the only mandatory test related to the profile "CSAF Base" as the required fields SHALL be checked by validating the JSON schema. + +The relevant path for this test is: + +``` + /document/category +``` + +*Examples 74 for currently prohibited values:* + +``` + Csaf_a + Informational Advisory + security-incident-response + Security Advisory + veX + V_eX +``` + +*Example 75 which fails the test:* + +``` + "category": "Security_Incident_Response" +``` + +> The value `Security_Incident_Response` is the name of a profile where the space was replaced with underscores. + +### 6.1.27 Profile Tests + +This subsubsection structures the tests for the profiles. Not all tests apply for all profiles. Tests SHOULD be skipped if the document category does not match the one given in the test. Each of the following tests SHOULD be treated as they where listed similar to the other tests. + +> An application MAY group these tests by profiles when providing the additional function to only run one or more selected tests. This results in one virtual test per profile. + +#### 6.1.27.1 Document Notes + +It MUST be tested that at least one item in `/document/notes` exists which has a `category` of `description`, `details`, `general` or `summary`. + +The relevant values for `/document/category` are: + +``` + csaf_informational_advisory + csaf_security_incident_response +``` + +The relevant path for this test is: + +``` + /document/notes +``` + +*Example 76 which fails the test:* + +``` + "notes": [ + { + "category": "legal_disclaimer", + "text": "The CSAF document is provided to You \"AS IS\" and \"AS AVAILABLE\" and with all faults and defects without warranty of any kind.", + "title": "Terms of Use" + } + ] +``` + +> The document notes do not contain an item which has a `category` of `description`, `details`, `general` or `summary`. + +#### 6.1.27.2 Document References + +It MUST be tested that at least one item in `/document/references` exists that has links to an `external` source. + +The relevant values for `/document/category` are: + +``` + csaf_informational_advisory + csaf_security_incident_response +``` + +The relevant path for this test is: + +``` + /document/references +``` + +*Example 77 which fails the test:* + +``` + "references": [ + { + "category": "self", + "summary": "The canonical URL.", + "url": "https://example.com/security/data/csaf/2021/OASIS_CSAF_TC-CSAF_2_0-2021-6-1-27-02-01.json" + } + ] +``` + +> The document references do not contain any item which has the category `external`. + +#### 6.1.27.3 Vulnerabilities + +It MUST be tested that the element `/vulnerabilities` does not exist. + +The relevant value for `/document/category` is: + +``` + csaf_informational_advisory +``` + +The relevant path for this test is: + +``` + /vulnerabilities +``` + +*Example 78 which fails the test:* + +``` + "vulnerabilities": [ + { + "title": "A vulnerability item that SHALL NOT exist" + } + ] +``` + +> The element `/vulnerabilities` exists. + +> A tool MAY change the `/document/category` to `csaf_base` as a quick fix. + +#### 6.1.27.4 Product Tree + +It MUST be tested that the element `/product_tree` exists. + +The relevant values for `/document/category` are: + +``` + csaf_security_advisory + csaf_vex +``` + +The relevant path for this test is: + +``` + /product_tree +``` + +*Example 79 which fails the test:* + +``` + { + "document": { + // ... + }, + "vulnerabilities": [ + // ... + ] + } +``` + +> The element `/product_tree` does not exist. + +#### 6.1.27.5 Vulnerability Notes + +For each item in `/vulnerabilities` it MUST be tested that the element `notes` exists. + +The relevant values for `/document/category` are: + +``` + csaf_security_advisory + csaf_vex +``` + +The relevant path for this test is: + +``` + /vulnerabilities[]/notes +``` + +*Example 80 which fails the test:* + +``` + "vulnerabilities": [ + { + "title": "A vulnerability item without a note" + } + ] +``` + +> The vulnerability item has no `notes` element. + +#### 6.1.27.6 Product Status + +For each item in `/vulnerabilities` it MUST be tested that the element `product_status` exists. + +The relevant value for `/document/category` is: + +``` + csaf_security_advisory +``` + +The relevant path for this test is: + +``` + /vulnerabilities[]/product_status +``` + +*Example 81 which fails the test:* + +``` + "vulnerabilities": [ + { + "title": "A vulnerability item without a product status" + } + ] +``` + +> The vulnerability item has no `product_status` element. + +#### 6.1.27.7 VEX Product Status + +For each item in `/vulnerabilities` it MUST be tested that at least one of the elements `fixed`, `known_affected`, `known_not_affected`, or `under_investigation` is present in `product_status`. + +The relevant value for `/document/category` is: + +``` + csaf_vex +``` + +The relevant paths for this test are: + +``` + /vulnerabilities[]/product_status/fixed + /vulnerabilities[]/product_status/known_affected + /vulnerabilities[]/product_status/known_not_affected + /vulnerabilities[]/product_status/under_investigation +``` + +*Example 82 which fails the test:* + +``` + "product_status": { + "first_fixed": [ + // ... + ], + "recommended": [ + // ... + ] + } +``` + +> None of the elements `fixed`, `known_affected`, `known_not_affected`, or `under_investigation` is present in `product_status`. + +#### 6.1.27.8 Vulnerability ID + +For each item in `/vulnerabilities` it MUST be tested that at least one of the elements `cve` or `ids` is present. + +The relevant value for `/document/category` is: + +``` + csaf_vex +``` + +The relevant paths for this test are: + +``` + /vulnerabilities[]/cve + /vulnerabilities[]/ids +``` + +*Example 83 which fails the test:* + +``` + "vulnerabilities": [ + { + "title": "A vulnerability item without a CVE or ID" + } + ] +``` + +> None of the elements `cve` or `ids` is present. + +#### 6.1.27.9 Impact Statement + +For each item in `/vulnerabilities[]/product_status/known_not_affected` it MUST be tested that a corresponding impact statement exist in `/vulnerabilities[]/flags` or `/vulnerabilities[]/threats`. For the latter one, the `category` value for such a statement MUST be `impact`. + +The relevant value for `/document/category` is: + +``` + csaf_vex +``` + +The relevant path for this test is: + +``` + /vulnerabilities[]/flags + /vulnerabilities[]/threats +``` + +*Example 84 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ], + "product_groups": [ + { + "group_id": "CSAFGID-0001", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ] + }, + "vulnerabilities": [ + { + // ... + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "threats": [ + { + "category": "impact", + "details": "The vulnerable code is not present in these products.", + "group_ids": [ + "CSAFGID-0001" + ] + } + ] + } + ] +``` + +> There is no impact statement for `CSAFPID-9080702`. +> +> Note: The impact statement for `CSAFPID-9080700` and `CSAFPID-9080701` is given through `CSAFGID-0001`. + +#### 6.1.27.10 Action Statement + +For each item in `/vulnerabilities[]/product_status/known_affected` it MUST be tested that a corresponding action statement exist in `/vulnerabilities[]/remediations`. + +The relevant value for `/document/category` is: + +``` + csaf_vex +``` + +The relevant path for this test is: + +``` + /vulnerabilities[]/remediations +``` + +*Example 85 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ], + "product_groups": [ + { + "group_id": "CSAFGID-0001", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ], + "summary": "EOL products" + } + ] + }, + "vulnerabilities": [ + { + // ... + "product_status": { + "known_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "remediations": [ + { + "category": "no_fix_planned", + "details": "These products are end-of-life. Therefore, no fix will be provided.", + "group_ids": [ + "CSAFGID-0001" + ] + } + ] + } + ] +``` + +> There is no action statement for `CSAFPID-9080702`. +> +> Note: The action statement for `CSAFPID-9080700` and `CSAFPID-9080701` is given through `CSAFGID-0001`. + +#### 6.1.27.11 Vulnerabilities + +It MUST be tested that the element `/vulnerabilities` exists. + +The relevant values for `/document/category` are: + +``` + csaf_security_advisory + csaf_vex +``` + +The relevant path for this test is: + +``` + /vulnerabilities +``` + +*Example 86 which fails the test:* + +``` + { + "document": { + // ... + }, + "product_tree": [ + // ... + ] + } +``` + +> The element `/vulnerabilities` does not exist. + +### 6.1.28 Translation + +It MUST be tested that the given source language and document language are not the same. + +The relevant path for this test is: + +``` + /document/lang + /document/source_lang +``` + +*Example 87 which fails the test:* + +``` + "document": { + // ... + "lang": "en-US", + // ... + "source_lang": "en-US", + // ... + } +``` + +> The document language and the source language have the same value `en-US`. +> +> Note: A translation from `en-US` to `en-GB` would pass the test. + +> A tool MAY remove the source language as quick fix. + +### 6.1.29 Remediation without Product Reference + +For each item in `/vulnerabilities[]/remediations` it MUST be tested that it includes at least one of the elements `group_ids` or `product_ids`. + +The relevant path for this test is: + +``` + /vulnerabilities[]/remediations[] +``` + +*Example 88 which fails the test:* + +``` + "remediations": [ + { + "category": "no_fix_planned", + "details": "These products are end-of-life. Therefore, no fix will be provided." + } + ] +``` + +> The given remediation does not specify to which products it should be applied. + +> A tool MAY add all products of the affected group of this vulnerability to the remediation as quick fix. + +### 6.1.30 Mixed Integer and Semantic Versioning + +It MUST be tested that all elements of type `/$defs/version_t` follow either integer versioning or semantic versioning homogeneously within the same document. + +The relevant paths for this test are: + +``` + /document/tracking/revision_history[]/number + /document/tracking/version +``` + +*Example 89 which fails the test:* + +``` + "tracking": { + // ... + "revision_history": [ + { + "date": "2021-07-21T09:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + // ... + "version": "2" + } +``` + +> The document started with semantic versioning (`1.0.0`) and switched to integer versioning (`2`). + +> A tool MAY assign all items their corresponding value according to integer versioning as a quick fix. In such case, the old `number` SHOULD be stored in `legacy_version`. + +### 6.1.31 Version Range in Product Version + +For each element of type `/$defs/branches_t` with `category` of `product_version` it MUST be tested that the value of `name` does not contain a version range. + +> To implement this test it is deemed sufficient that, when converted to lower case, the value of `name` does not contain any of the following strings: +> +> ``` +> < +> <= +> > +> >= +> after +> all +> before +> earlier +> later +> prior +> versions +> ``` + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/name +``` + +*Example 90 which fails the test:* + +``` + "branches": [ + { + "category": "product_version", + "name": "prior to 4.2", + // ... + } + ] +``` + +> The version range `prior to 4.2` is given for the branch category `product_version`. + +### 6.1.32 Flag without Product Reference + +For each item in `/vulnerabilities[]/flags` it MUST be tested that it includes at least one of the elements `group_ids` or `product_ids`. + +The relevant path for this test is: + +``` + /vulnerabilities[]/flags[] +``` + +*Example 91 which fails the test:* + +``` + "flags": [ + { + "label": "component_not_present" + } + ] +``` + +> The given flag does not specify to which products it should be applied. + +### 6.1.33 Multiple Flags with VEX Justification Codes per Product + +For each item in `/vulnerabilities[]` it MUST be tested that a Product is not member of more than one Flag item with a VEX justification code (see section 3.2.3.5). This takes indirect relations through Product Groups into account. + +> Additional flags with a different purpose might be provided in later versions of CSAF. Through the explicit reference of VEX justification codes the test is specified to be forward-compatible. + +The relevant path for this test is: + +``` + /vulnerabilities[]/flags +``` + +*Example 92 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + } + ], + "product_groups": [ + { + "group_id": "CSAFGID-0001", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ] + }, + "vulnerabilities": [ + { + // ... + "flags": [ + { + "label": "component_not_present", + "group_ids": [ + "CSAFGID-0001" + ] + }, + { + "label": "vulnerable_code_cannot_be_controlled_by_adversary", + "product_ids": [ + "CSAFPID-9080700" + ] + } + ], + // ... + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + } + ] +``` + +> There are two flags given for for `CSAFPID-9080700` - one indirect through `CSAFGID-0001` and one direct. + +## 6.2 Optional Tests + +Optional tests SHOULD NOT fail at a valid CSAF document without a good reason. Failing such a test does not make the CSAF document invalid. These tests may include information about features which are still supported but expected to be deprecated in a future version of CSAF. A program MUST handle a test failure as a warning. + +### 6.2.1 Unused Definition of Product ID + +For each Product ID (type `/$defs/product_id_t`) in Full Product Name elements (type: `/$defs/full_product_name_t`) it MUST be tested that the `product_id` is referenced somewhere within the same document. + +This test SHALL be skipped for CSAF documents conforming the profile "Informational Advisory". + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/product/product_id + /product_tree/full_product_names[]/product_id + /product_tree/relationships[]/full_product_name/product_id +``` + +*Example 93 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + } +``` + +> `CSAFPID-9080700` was defined but never used. + +> A tool MAY remove the unused definition as quick fix. However, such quick fix shall not be applied if the test was skipped. + +### 6.2.2 Missing Remediation + +For each Product ID (type `/$defs/product_id_t`) in the Product Status groups Affected and Under investigation it MUST be tested that a remediation exists. + +> The remediation might be of the category `none_available` or `no_fix_planned`. + +The relevant paths for this test are: + +``` + /vulnerabilities[]/product_status/first_affected[] + /vulnerabilities[]/product_status/known_affected[] + /vulnerabilities[]/product_status/last_affected[] + /vulnerabilities[]/product_status/under_investigation[] +``` + +*Example 94 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "last_affected": [ + "CSAFPID-9080700" + ] + } + } + ] +``` + +> `CSAFPID-9080700` has in Product Status `last_affected` but there is no remediation object for this Product ID. + +### 6.2.3 Missing Score + +For each Product ID (type `/$defs/product_id_t`) in the Product Status groups Affected it MUST be tested that a score object exists which covers this product. + +The relevant paths for this test are: + +``` + /vulnerabilities[]/product_status/first_affected[] + /vulnerabilities[]/product_status/known_affected[] + /vulnerabilities[]/product_status/last_affected[] +``` + +*Example 95 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "first_affected": [ + "CSAFPID-9080700" + ] + } + } + ] +``` + +> `CSAFPID-9080700` has in Product Status `first_affected` but there is no score object which covers this Product ID. + +### 6.2.4 Build Metadata in Revision History + +For each item in revision history it MUST be tested that `number` does not include build metadata. + +The relevant path for this test is: + +``` + /document/tracking/revision_history[]/number +``` + +*Example 96 which fails the test:* + +``` + "revision_history": [ + { + "date": "2021-04-23T10:00:00.000Z", + "number": "1.0.0+exp.sha.ac00785", + "summary": "Initial version." + } + ] +``` + +> The revision history contains an item which has a `number` that includes the build metadata `+exp.sha.ac00785`. + +### 6.2.5 Older Initial Release Date than Revision History + +It MUST be tested that the Initial Release Date is not older than the `date` of the oldest item in Revision History. + +The relevant path for this test is: + +``` + /document/tracking/initial_release_date +``` + +*Example 97 which fails the test:* + +``` + "tracking": { + // ... + "initial_release_date": "2021-04-22T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-05-06T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T11:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + // ... + } +``` + +> The initial release date `2021-04-22T10:00:00.000Z` is older than `2021-05-06T10:00:00.000Z` which is the `date` of the oldest item in Revision History. + +### 6.2.6 Older Current Release Date than Revision History + +It MUST be tested that the Current Release Date is not older than the `date` of the newest item in Revision History. + +The relevant path for this test is: + +``` + /document/tracking/current_release_date +``` + +*Example 98 which fails the test:* + +``` + "tracking": { + "current_release_date": "2021-05-06T10:00:00.000Z", + // ... + "revision_history": [ + { + "date": "2021-05-06T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T11:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + // ... + } +``` + +> The current release date `2021-05-06T10:00:00.000Z` is older than `2021-05-23T1100:00.000Z` which is the `date` of the newest item in Revision History. + +### 6.2.7 Missing Date in Involvements + +For each item in the list of involvements it MUST be tested that it includes the property `date`. + +The relevant path for this test is: + +``` + /vulnerabilities[]/involvements +``` + +*Example 99 which fails the test:* + +``` + "vulnerabilities": [ + { + "involvements": [ + { + "party": "vendor", + "status": "in_progress" + } + ] + } + ] +``` + +> The list of involvements contains an item which does not contain the property `date`. + +### 6.2.8 Use of MD5 as the only Hash Algorithm + +It MUST be tested that the hash algorithm `md5` is not the only one present. + +> Since collision attacks exist for MD5 such value should be accompanied by a second cryptographically stronger hash. This will allow users to double check the results. + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/product/product_identification_helper/hashes[]/file_hashes + /product_tree/full_product_names[]/product_identification_helper/hashes[]/file_hashes + /product_tree/relationships[]/full_product_name/product_identification_helper/hashes[]/file_hashes +``` + +*Example 100 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "hashes": [ + { + "file_hashes": [ + { + "algorithm": "md5", + "value": "6ae24620ea9656230f49234efd078935" + } + ], + "filename": "product_a.so" + } + ] + } + } + ] + } +``` + +> The hash algorithm `md5` is used in one item of hashes without being accompanied by a second hash algorithm. + +### 6.2.9 Use of SHA-1 as the only Hash Algorithm + +It MUST be tested that the hash algorithm `sha1` is not the only one present. + +> Since collision attacks exist for SHA-1 such value should be accompanied by a second cryptographically stronger hash. This will allow users to double check the results. + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/product/product_identification_helper/hashes[]/file_hashes + /product_tree/full_product_names[]/product_identification_helper/hashes[]/file_hashes + /product_tree/relationships[]/full_product_name/product_identification_helper/hashes[]/file_hashes +``` + +*Example 101 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "hashes": [ + { + "file_hashes": [ + { + "algorithm": "sha1", + "value": "e067035314dd8673fe1c9fc6b01414fe0950fdc4" + } + ], + "filename": "product_a.so" + } + ] + } + } + ] + } +``` + +> The hash algorithm `sha1` is used in one item of hashes without being accompanied by a second hash algorithm. + +### 6.2.10 Missing TLP label + +It MUST be tested that `/document/distribution/tlp/label` is present and valid. + +> TLP labels support the machine-readability and automated distribution. + +The relevant path for this test is: + +``` + /document/distribution/tlp/label +``` + +*Example 102 which fails the test:* + +``` + "distribution": { + "text": "Distribute freely." + } +``` + +> The CSAF document has no TLP label. + +### 6.2.11 Missing Canonical URL + +It MUST be tested that the CSAF document has a canonical URL. + +> To implement this test it is deemed sufficient that one item in `/document/references` fulfills all of the following: +> +> * It has the category `self`. +> * The `url` starts with `https://`. +> * The `url` ends with the valid filename for the CSAF document according to the rules in section 5.1. + +The relevant path for this test is: + +``` + /document/references +``` + +*Example 103 which fails the test:* + +``` + "document": { + // ... + "references": [ + { + "category": "self", + "summary": "A non-canonical URL.", + "url": "https://example.com/security/data/csaf/2021/OASIS_CSAF_TC-CSAF_2.0-2021-6-2-11-01_1.json" + } + ], + // ... + "tracking": { + // ... + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-11-01", + // ... + "version": "1" + }, + // ... + } +``` + +> The only element where the `category` is `self` has a URL that does not fulfill the requirement of a valid filename for a CSAF document. + +### 6.2.12 Missing Document Language + +It MUST be tested that the document language is present and set. + +The relevant path for this test is: + +``` + /document/lang +``` + +*Example 104 which fails the test:* + +``` + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + // ... + }, + // ... + } +``` + +> The document language is not defined. + +### 6.2.13 Sorting + +It MUST be tested that all keys in a CSAF document are sorted alphabetically. + +The relevant path for this test is: + +``` + / +``` + +*Example 105 which fails the test:* + +``` + "document": { + "csaf_version": "2.0", + "category": "csaf_base", + // ... + } +``` + +> The key `csaf_version` is not at the right place. + +> A tool MAY sort the keys as a quick fix. + +### 6.2.14 Use of Private Language + +For each element of type `/$defs/language_t` it MUST be tested that the language code does not contain subtags reserved for private use. + +The relevant paths for this test are: + +``` + /document/lang + /document/source_lang +``` + +*Example 106 which fails the test:* + +``` + "lang": "qtx" +``` + +> The language code `qtx` is reserved for private use. + +> A tool MAY remove such subtag as a quick fix. + +### 6.2.15 Use of Default Language + +For each element of type `/$defs/language_t` it MUST be tested that the language code is not `i-default`. + +The relevant paths for this test are: + +``` + /document/lang + /document/source_lang +``` + +*Example 107 which fails the test:* + +``` + "lang": "i-default" +``` + +> The language code `i-default` is used. + +> A tool MAY remove such element as a quick fix. + +### 6.2.16 Missing Product Identification Helper + +For each element of type `/$defs/full_product_name_t` it MUST be tested that it includes the property `product_identification_helper`. + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/product + /product_tree/full_product_names[] + /product_tree/relationships[]/full_product_name +``` + +*Example 108 which fails the test:* + +``` + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] +``` + +> The product `CSAFPID-9080700` does not provide any Product Identification Helper at all. + +### 6.2.17 CVE in field IDs + +For each item in `/vulnerabilities[]/ids` it MUST be tested that it is not a CVE ID. + +> It is sufficient to check, whether the property `text` matches the regex `^CVE-[0-9]{4}-[0-9]{4,}$`. + +The relevant paths for this test are: + +``` + /vulnerabilities[]/ids[] +``` + +*Example 109 which fails the test:* + +``` + "ids": [ + { + "system_name": "CVE Project", + "text": "CVE-2021-44228" + } + ] +``` + +> The `CVE-2021-44228` is listed in an item of the `ids` array instead under `cve`. + +> A tool MAY set such element as value for the `cve` property as a quick fix, if that didn't exist before. Alternatively, it MAY remove such element as a quick fix. + +### 6.2.18 Product Version Range without vers + +For each element of type `/$defs/branches_t` with `category` of `product_version_range` it MUST be tested that the value of `name` conforms the vers specification. + +> To implement this test it is deemed sufficient that the value of `name` matches the following regex: +> +> ``` +> ^vers:[a-z\\.\\-\\+][a-z0-9\\.\\-\\+]*/.+ +> ``` + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/name +``` + +*Example 110 which fails the test:* + +``` + "branches": [ + { + "category": "product_version_range", + "name": ">4.2", + // ... + } + ] +``` + +> The version range `>4.2` is a valid vsl but not valid according to the vers specification. + +### 6.2.19 CVSS for Fixed Products + +For each item the fixed products group (`first_fixed` and `fixed`) it MUST be tested that a CVSS applying to this product has an environmental score of `0`. The test SHALL pass if none of the Product IDs listed within product status `fixed` or `first_fixed` is found in `products` of any item of the `scores` element. + +The relevant path for this test is: + +``` + /vulnerabilities[]/product_status/first_fixed[] + /vulnerabilities[]/product_status/fixed[] +``` + +*Example 111 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "fixed": [ + "CSAFPID-9080700" + ] + }, + "scores": [ + { + "cvss_v3": { + "baseScore": 6.5, + "baseSeverity": "MEDIUM", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "version": "3.1" + }, + "products": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +``` + +> Neither the `environmentalScore` nor the properties `modifiedIntegrityImpact`, `modifiedAvailabilityImpact`, `modifiedConfidentialityImpact` nor the corresponding attributes in the `vectorString` have been set. + +> A tool MAY set the properties `modifiedIntegrityImpact`, `modifiedAvailabilityImpact`, `modifiedConfidentialityImpact` accordingly and compute the `environmentalScore` as quick fix. + +### 6.2.20 Additional Properties + +It MUST be tested that there is no additional property in the CSAF document that was not defined in the CSAF JSON schema. + +The relevant path for this test is: + +``` + / +``` + +> To implement this test it is deemed sufficient to validate the CSAF document against a "strict" version schema that sets `additionalProperties` to `false` for every key of type `object`. + +*Example 112 which fails the test:* + +``` + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "custom_property": "any", + // ... + } +``` + +> The key `custom_property` is not defined in the JSON schema. + +> A tool MAY remove such keys as a quick fix. + +## 6.3 Informative Test + +Informative tests provide insights in common mistakes and bad practices. They MAY fail at a valid CSAF document. It is up to the issuing party to decide whether this was an intended behavior and can be ignore or should be treated. These tests MAY include information about recommended usage. A program MUST handle a test failure as a information. + +### 6.3.1 Use of CVSS v2 as the only Scoring System + +For each item in the list of scores which contains the `cvss_v2` object it MUST be tested that is not the only scoring item present. The test SHALL pass if a second scoring object is available. + +The relevant path for this test is: + +``` + /vulnerabilities[]/scores +``` + +*Example 113 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v2": { + "version": "2.0", + "vectorString": "AV:N/AC:L/Au:N/C:C/I:C/A:C", + "baseScore": 10 + } + } + ] + } + ] +``` + +> There is only a CVSS v2 score given for `CSAFPID-9080700`. + +Recommendation: + +It is recommended to (also) use the CVSS v3.1. + +### 6.3.2 Use of CVSS v3.0 + +For each item in the list of scores which contains the `cvss_v3` object it MUST be tested that CVSS v3.0 is not used. + +The relevant paths for this test are: + +``` + /vulnerabilities[]/scores[]/cvss_v3/version + /vulnerabilities[]/scores[]/cvss_v3/vectorString +``` + +*Example 114 which fails the test:* + +``` + "cvss_v3": { + "version": "3.0", + "vectorString": "CVSS:3.0/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 6.5, + "baseSeverity": "MEDIUM" + } +``` + +> The CVSS v3.0 is used. + +Recommendation: + +It is recommended to upgrade to CVSS v3.1. + +> A tool MAY upgrade to CVSS v3.1 as quick fix. However, if such quick fix is supported the tool SHALL also recompute the `baseScore` and `baseSeverity`. The same applies for `temporalScore` and `temporalSeverity` respectively `environmentalScore` and `environmentalSeverity` if the necessary fields for computing their value are present and set. + +### 6.3.3 Missing CVE + +It MUST be tested that the CVE number is given. + +The relevant path for this test is: + +``` + /vulnerabilities[]/cve +``` + +*Example 115 which fails the test:* + +``` + "vulnerabilities": [ + { + "title": "BlueKeep" + } + ] +``` + +> The CVE number is not given. + +Recommendation: + +It is recommended to provide a CVE number to support the users efforts to find more details about a vulnerability and potentially track it through multiple advisories. If no CVE exists for that vulnerability, it is recommended to get one assigned. + +### 6.3.4 Missing CWE + +It MUST be tested that the CWE is given. + +The relevant path for this test is: + +``` + /vulnerabilities[]/cwe +``` + +*Example 116 which fails the test:* + +``` + "vulnerabilities": [ + { + "cve": "CVE-2019-0708", + "title": "BlueKeep" + } + ] +``` + +> The CWE number is not given. + +### 6.3.5 Use of Short Hash + +It MUST be tested that the length of the hash value is not shorter than 64 characters. + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/product/product_identification_helper/hashes[]/file_hashes[]/value + /product_tree/full_product_names[]/product_identification_helper/hashes[]/file_hashes[]/value + /product_tree/relationships[]/full_product_name/product_identification_helper/hashes[]/file_hashes[]/value +``` + +*Example 117 which fails the test*: + +``` + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "hashes": [ + { + "file_hashes": [ + { + "algorithm": "md4", + "value": "3202b50e2e5b2fcd75e284c3d9d5f8d6" + } + ], + "filename": "product_a.so" + } + ] + } + } + ] + } +``` + +> The length of the hash value is only 32 characters long. + +### 6.3.6 Use of non-self referencing URLs Failing to Resolve + +For each URL which is not in the category `self` it MUST be tested that it resolves with a HTTP status code from the 2xx (Successful) or 3xx (Redirection) class. + +> This test does not apply for any item in an array of type `references_t` with the category `self`. For details about the HTTP status code classes see [RFC7231]. + +The relevant paths for this test are: + +``` + /document/acknowledgments[]/urls[] + /document/aggregate_severity/namespace + /document/distribution/tlp/url + /document/references[]/url + /document/publisher/namespace + /product_tree/branches[]/product/product_identification_helper/sbom_urls[] + /product_tree/branches[]/product/product_identification_helper/x_generic_uris[]/namespace + /product_tree/branches[]/product/product_identification_helper/x_generic_uris[]/uri + /product_tree/branches[](/branches[])*/product/product_identification_helper/sbom_urls[] + /product_tree/branches[](/branches[])*/product/product_identification_helper/x_generic_uris[]/namespace + /product_tree/branches[](/branches[])*/product/product_identification_helper/x_generic_uris[]/uri + /product_tree/full_product_names[]/product_identification_helper/sbom_urls[] + /product_tree/full_product_names[]/product_identification_helper/x_generic_uris[]/namespace + /product_tree/full_product_names[]/product_identification_helper/x_generic_uris[]/uri + /product_tree/relationships[]/full_product_name/product_identification_helper/sbom_urls[] + /product_tree/relationships[]/full_product_name/product_identification_helper/x_generic_uris[]/namespace + /product_tree/relationships[]/full_product_name/product_identification_helper/x_generic_uris[]/uri + /vulnerabilities[]/acknowledgments[]/urls[] + /vulnerabilities[]/references[]/url + /vulnerabilities[]/remediations[]/url +``` + +*Example 118 which fails the test:* + +``` + "references": [ + { + "summary": "A URL that does not resolve with HTTP status code in the interval between (including) 200 and (excluding) 400.", + "url": "https://example.invalid" + } + ] +``` + +> The `category` is not set and therefore treated as its default value `external`. A request to that URL does not resolve with a status code from the 2xx (Successful) or 3xx (Redirection) class. + +### 6.3.7 Use of self referencing URLs Failing to Resolve + +For each item in an array of type `references_t` with the category `self` it MUST be tested that the URL referenced resolves with a HTTP status code less than 400. + +> This test will most likely fail if the CSAF document is in a status before the initial release. For details about the HTTP status code classes see [RFC7231]. + +The relevant paths for this test are: + +``` + /document/references[]/url + /vulnerabilities[]/references[]/url +``` + +*Example 119 which fails the test:* + +``` + "references": [ + { + "category": "self", + "summary": "A URL that does not resolve with HTTP status code in the interval between (including) 200 and (excluding) 400.", + "url": "https://example.invalid" + } + ] +``` + +> The `category` is `self` and a request to that URL does not resolve with a status code from the 2xx (Successful) or 3xx (Redirection) class. + +### 6.3.8 Spell check + +If the document language is given it MUST be tested that a spell check for the given language does not find any mistakes. The test SHALL be skipped if not document language is set. It SHALL fail it the given language is not supported. The value of `/document/category` SHOULD NOT be tested if the CSAF document does not use the profile "CSAF Base". + +The relevant paths for this test are: + +``` + /document/acknowledgments[]/names[] + /document/acknowledgments[]/organization + /document/acknowledgments[]/summary + /document/aggregate_severity/text + /document/category + /document/distribution/text + /document/notes[]/audience + /document/notes[]/text + /document/notes[]/title + /document/publisher/issuing_authority + /document/publisher/name + /document/references[]/summary + /document/title + /document/tracking/aliases[] + /document/tracking/generator/engine/name + /document/tracking/revision_history[]/summary + /product_tree/branches[](/branches[])*/name + /product_tree/branches[](/branches[])*/product/name + /product_tree/branches[]/name + /product_tree/branches[]/product/name + /product_tree/full_product_names[]/name + /product_tree/product_groups[]/summary + /product_tree/relationships[]/full_product_name/name + /vulnerabilities[]/acknowledgments[]/names[] + /vulnerabilities[]/acknowledgments[]/organization + /vulnerabilities[]/acknowledgments[]/summary + /vulnerabilities[]/involvements[]/summary + /vulnerabilities[]/notes[]/audience + /vulnerabilities[]/notes[]/text + /vulnerabilities[]/notes[]/title + /vulnerabilities[]/references[]/summary + /vulnerabilities[]/remediations[]/details + /vulnerabilities[]/remediations[]/entitlements[] + /vulnerabilities[]/remediations[]/restart_required/details + /vulnerabilities[]/threats[]/details + /vulnerabilities[]/title +``` + +*Example 120 which fails the test:* + +``` + "document": { + // ... + "lang": "en", + "notes": [ + { + "category": "summary", + "text": "Secruity researchers found multiple vulnerabilities in XYZ." + } + ], + // ... + } +``` + +> There is a spelling mistake in `Secruity`. + +### 6.3.9 Branch Categories + +For each element of type `/$defs/full_product_name_t` in `/product_tree/branches` it MUST be tested that ancestor nodes along the path exist which use the following branch categories `vendor` -> `product_name` -> `product_version` in that order starting with the Product tree node. + +> Other branch categories can be used before, after or between the aforementioned branch categories without making the test invalid. + +The relevant paths for this test are: + +``` + /product_tree/branches +``` + +*Example 121 which fails the test:* + +``` + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "patch_level", + "name": "91", + "product": { + "product_id": "CSAFPID-0002", + "name": "Example Company Product A Update 91" + } + } + ] + } + ] + } + ] +``` + +> The product `CSAFPID-9080700` does not have any ancestor with the branch category `product_version`. + +### 6.3.10 Usage of Product Version Range + +For each element of type `/$defs/branches_t` it MUST be tested that the `category` is not `product_version_range`. + +> It is usually hard decide for machines whether a product version matches a product version ranges. Therefore, it is recommended to avoid version ranges and enumerate versions wherever possible. + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/category +``` + +*Example 122 which fails the test:* + +``` + "category": "product_version_range", +``` + +> The category `product_version_range` was used. + +### 6.3.11 Usage of V as Version Indicator + +For each element of type `/$defs/branches_t` with `category` of `product_version` it MUST be tested that the value of `name` does not start with `v` or `V` before the version. + +> To implement this test it is deemed sufficient that the value of `name` does not match the following regex: +> +> ``` +> ^[vV][0-9].*$ +> ``` + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/name +``` + +*Example 123 which fails the test:* + +``` + "branches": [ + { + "category": "product_version", + "name": "v4.2", + // ... + } + ] +``` + +> The product version starts with a `v`. + +------- + +# 7 Distributing CSAF documents + +This section lists requirements and roles defined for distributing CSAF documents. The first subsection provides all requirements - the second one the roles. It is mandatory to fulfill the basic role "CSAF publisher". The last section provides specific rules for the process of retrieving CSAF documents. + +## 7.1 Requirements + +The requirements in this subsection are consecutively numbered to be able to refer to them directly. The order does not give any hint about the importance. Not all requirements have to be fulfilled to conform to this specification - the sets of requirements per conformance clause are defined in section 7.2. + +### 7.1.1 Requirement 1: Valid CSAF document + +The document is a valid CSAF document (cf. Conformance clause 1). + +### 7.1.2 Requirement 2: Filename + +The CSAF document has a filename according to the rules in section 5.1. + +### 7.1.3 Requirement 3: TLS + +The CSAF document is per default retrievable from a website which uses TLS for encryption and server authenticity. The CSAF document MUST NOT be downloadable from a location which does not encrypt the transport when crossing organizational boundaries to maintain the chain of custody. + +### 7.1.4 Requirement 4: TLP:WHITE + +If the CSAF document is labeled TLP:WHITE, it MUST be freely accessible. + +This does not exclude that such a document is also available in an access protected customer portal. However, there MUST be one copy of the document available for people without access to the portal. + +> Reasoning: If an advisory is already in the media, an end user should not be forced to collect the pieces of information from a press release but be able to retrieve the CSAF document. + +### 7.1.5 Requirement 5: TLP:AMBER and TLP:RED + +CSAF documents labeled TLP:AMBER or TLP:RED MUST be access protected. If they are provided via a web server this SHALL be done under a different path than for TLP:WHITE, TLP:GREEN and unlabeled CSAF documents. TLS client authentication, access tokens or any other automatable authentication method SHALL be used. + +An issuing party MAY agree with the recipients to use any kind of secured drop at the recipients' side to avoid putting them on their own website. However, it MUST be ensured that the documents are still access protected. + +### 7.1.6 Requirement 6: No Redirects + +Redirects SHOULD NOT be used. If they are inevitable only HTTP Header redirects are allowed. + +> Reasoning: Clients should not parse the payload for navigation and some, as e.g. `curl`, do not follow any other kind of redirects. + +### 7.1.7 Requirement 7: provider-metadata.json + +The party MUST provide a valid `provider-metadata.json` according to the schema [CSAF provider metadata](https://docs.oasis-open.org/csaf/csaf/v2.0/provider_json_schema.json) for its own metadata. The `publisher` object SHOULD match the one used in the CSAF documents of the issuing party but can be set to whatever value a CSAF aggregator SHOULD display over any individual `publisher` values in the CSAF documents themselves. + +> This information is used to collect the data for CSAF aggregators, listers and end users. The CSAF provider metadata schema ensures the consistency of the metadata for a CSAF provider across the ecosystem. Other approaches, like extracting the `publisher` object from CSAF documents, are likely to fail if the object differs between CSAF documents. +> +> It is suggested to put the file `provider-metadata.json` adjacent to the ROLIE feed documents (requirement 15) or in the main directory adjacent to the year folders (requirement 14), `changes.csv` (requirement 13) and the `index.txt` (requirement 12). +> Suggested locations to store the `provider-metadata.json` are: +> +> * https://www.example.com/.well-known/csaf/provider-metadata.json +> * https://domain.tld/security/data/csaf/provider-metadata.json +> * https://psirt.domain.tld/advisories/csaf/provider-metadata.json +> * https://domain.tld/security/csaf/provider-metadata.json + +*Example 124 Minimal with ROLIE document:* + +``` + { + "canonical_url": "https://www.example.com/.well-known/csaf/provider-metadata.json", + "distributions": [ + { + "rolie":{ + "feeds": [ + { + "summary":"All TLP:WHITE advisories of Example Company.", + "tlp_label": "WHITE", + "url": "https://www.example.com/.well-known/csaf/feed-tlp-white.json" + } + ] + } + } + ], + "last_updated": "2021-07-12T20:20:56.169Z", + "list_on_CSAF_aggregators": true, + "metadata_version": "2.0", + "mirror_on_CSAF_aggregators": true, + "public_openpgp_keys": [ + { + "fingerprint": "8F5F267907B2C4559DB360DB2294BA7D2B2298B1", + "url": "https://keys.example.net/vks/v1/by-fingerprint/8F5F267907B2C4559DB360DB2294BA7D2B2298B1" + } + ], + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace":"https://psirt.example.com" + }, + "role": "csaf_trusted_provider" + } +``` + +If a CSAF publisher (cf. section 7.2.1) does not provide the `provider-metadata.json`, an aggregator SHOULD contact the CSAF publisher in question to determine the values for `list_on_CSAF_aggregators` and `mirror_on_CSAF_aggregators`. If that is impossible or if the CSAF publisher is unresponsive the following values MUST be used: + +``` + "list_on_CSAF_aggregators": true, + "mirror_on_CSAF_aggregators": false +``` + +> This prevents that CSAF documents of a CSAF publisher which have been collected by one CSAF aggregator A are mirrored again on a second CSAF aggregator B. Such cascades are prone to outdated information. +> If the first aggregator A collects the CSAF documents on best effort and B copies the files from A and announces that this is done weekly, one might assume that B's CSAF documents are more recent. However, that is not the case as B's information depends on A. + +### 7.1.8 Requirement 8: security.txt + +In the security.txt there MUST be at least one field `CSAF` which points to the `provider-metadata.json` (requirement 7). If this field indicates a web URI, then it MUST begin with "https://" (as per section 2.7.2 of [RFC7230]). See [SECURITY-TXT] for more details. + +> The security.txt was published as [RFC9116] in April 2022. At the time of this writing, the `CSAF` field is in the process of being officially added. + +*Examples 125:* + +``` +CSAF: https://domain.tld/security/data/csaf/provider-metadata.json +CSAF: https://psirt.domain.tld/advisories/csaf/provider-metadata.json +CSAF: https://domain.tld/security/csaf/provider-metadata.json +CSAF: https://www.example.com/.well-known/csaf/provider-metadata.json +``` + +It is possible to advertise more than one `provider-metadata.json` by adding multiple `CSAF` fields, e.g. in case of changes to the organizational structure through merges or acquisitions. However, this SHOULD NOT be done and removed as soon as possible. If one of the URLs fulfills requirement 9, this MUST be used as the first CSAF entry in the security.txt. + +### 7.1.9 Requirement 9: Well-known URL for provider-metadata.json + +The URL path `/.well-known/csaf/provider-metadata.json` under the main domain of the issuing authority serves directly the `provider-metadata.json` according to requirement 7. The use of the scheme "HTTPS" is required. See [RFC8615] for more details. + +*Example 126:* + +``` + https://www.example.com/.well-known/csaf/provider-metadata.json +``` + +### 7.1.10 Requirement 10: DNS path + +The DNS record `csaf.data.security.domain.tld` SHALL resolve as a web server which serves directly the `provider-metadata.json` according to requirement 7. The use of the scheme "HTTPS" is required. + +### 7.1.11 Requirement 11: One folder per year + +The CSAF documents MUST be located within folders named `` where `` is the year given in the value of `/document/tracking/initial_release_date`. + +*Examples 127:* + +``` +2021 +2020 +``` + +### 7.1.12 Requirement 12: index.txt + +The index.txt file within MUST provide a list of all filenames of CSAF documents which are located in the sub-directories with their filenames. + +*Example 128:* + +``` +2020/example_company_-_2020-yh4711.json +2019/example_company_-_2019-yh3234.json +2018/example_company_-_2018-yh2312.json +``` + +> This can be used to download all CSAF documents. + +### 7.1.13 Requirement 13: changes.csv + +The file changes.csv MUST contain the filename as well as the value of `/document/tracking/current_release_date` for each CSAF document in the sub-directories without a heading; lines MUST be sorted by the `current_release_date` timestamp with the latest one first. + +*Example 129:* + +``` +"2020/example_company_-_2020-yh4711.json","2020-07-01T10:09:07Z" +"2018/example_company_-_2018-yh2312.json","2020-07-01T10:09:01Z" +"2019/example_company_-_2019-yh3234.json","2019-04-17T15:08:41Z" +"2018/example_company_-_2018-yh2312.json","2019-03-01T06:01:00Z" +``` + +### 7.1.14 Requirement 14: Directory listings + +Directory listing SHALL be enabled to support manual navigation. + +### 7.1.15 Requirement 15: ROLIE feed + +Resource-Oriented Lightweight Information Exchange (ROLIE) is a standard to ease discovery of security content. ROLIE is built on top of the Atom Publishing Format and Protocol, with specific requirements that support publishing security content. All CSAF documents with the same TLP level MUST be listed in a single ROLIE feed. At least one of the feeds + +* TLP:WHITE +* TLP:GREEN +* unlabeled + +MUST exist. Each ROLIE feed document MUST be a JSON file that conforms with [RFC8322]. + +*Example 130:* + +``` + { + "feed": { + "id": "example-csaf-feed-tlp-white", + "title": "Example CSAF feed (TLP:WHITE)", + "link": [ + { + "rel": "self", + "href": "https://psirt.domain.tld/advisories/csaf/feed-tlp-white.json" + } + ], + "category": [ + { + "scheme": "urn:ietf:params:rolie:category:information-type", + "term": "csaf" + } + ], + "updated": "2021-01-01T12:00:00.000Z", + "entry": [ + { + "id": "2020-ESA-001", + "title": "Example Security Advisory 001", + "link": [ + { + "rel": "self", + "href": "https://psirt.domain.tld/advisories/csaf/2020/2020-ESA-001.json" + }, + { + "rel": "hash", + "href": "https://psirt.domain.tld/advisories/csaf/2020/2020-ESA-001.json.sha512" + }, + { + "rel": "signature", + "href": "https://psirt.domain.tld/advisories/csaf/2020/2020-ESA-001.json.asc" + } + ], + "published": "2021-01-01T11:00:00.000Z", + "updated": "2021-01-01T12:00:00.000Z", + "summary": { + "content": "Vulnerabilities fixed in ABC 0.0.1" + }, + "content": { + "type": "application/json", + "src": "https://psirt.domain.tld/advisories/csaf/2020/2020-ESA-001.json" + }, + "format": { + "schema": "https://docs.oasis-open.org/csaf/csaf/v2.0/csaf_json_schema.json", + "version": "2.0" + } + } + ] + } + } +``` + +Any existing hash file (requirement 18) MUST be listed in the corresponding entry of the ROLIE feed as an item of the array `link` having the `rel` value of `hash`. +Any existing signature file (requirement 19) MUST be listed in the corresponding entry of the ROLIE feed as an item of the array `link` having the `rel` value of `signature`. + +### 7.1.16 Requirement 16: ROLIE service document + +The use and therefore the existence of ROLIE service document is optional. If it is used, each ROLIE service document MUST be a JSON file that conforms with [RFC8322] and lists the ROLIE feed documents. + +*Example 131:* + +``` + { + "service": { + "workspace": [ + { + "title": "Public CSAF feed", + "collection": [ + { + "title": "Example CSAF feed (TLP:WHITE)", + "href": "https://psirt.domain.tld/advisories/csaf/feed-tlp-white.json", + "categories": { + "category": [ + { + "scheme": "urn:ietf:params:rolie:category:information-type", + "term": "csaf" + } + ] + } + } + ] + } + ] + } + } +``` + +### 7.1.17 Requirement 17: ROLIE category document + +The use and therefore the existence of ROLIE category document is optional. If it is used, each ROLIE category document MUST be a JSON file that conforms with [RFC8322]. ROLIE categories SHOULD be used for to further dissect CSAF documents by one or more of the following criteria: + +* document category +* document language +* values of the branch category within the Product Tree including but not limited to + * `vendor` + * `product_family` + * `product_name` + * `product_version` +* type of product + + *Example 132:* + + ``` + CPU + Firewall + Monitor + PLC + Printer + Router + Sensor + Server + ``` + +* areas or sectors, the products are used in + + *Example 133:* + + ``` + Chemical + Commercial + Communication + Critical Manufacturing + Dams + Energy + Healthcare + Water + ``` + +* any other categorization useful to the consumers + +*Example 134:* + +``` + { + "categories": { + "category": [ + { + "term": "Example Company Product A" + }, + { + "term": "Example Company Product B" + } + ] + } + } +``` + +### 7.1.18 Requirement 18: Integrity + +All CSAF documents SHALL have at least one hash file computed with a secure cryptographic hash algorithm (e.g. SHA-512 or SHA-3) to ensure their integrity. The filename is constructed by appending the file extension which is given by the algorithm. + +MD5 and SHA1 SHOULD NOT be used. + +*Example 135:* + +``` +File name of CSAF document: example_company_-_2019-yh3234.json +File name of SHA-256 hash file: example_company_-_2019-yh3234.json.sha256 +File name of SHA-512 hash file: example_company_-_2019-yh3234.json.sha512 +``` + +The file content SHALL start with the first byte of the hexadecimal hash value. Any subsequent data (like a filename) which is optional SHALL be separated by at least one space. + +*Example 136:* + +``` +ea6a209dba30a958a78d82309d6cdcc6929fcb81673b3dc4d6b16fac18b6ff38 example_company_-_2019-yh3234.json +``` + +If a ROLIE feed exists, each hash file MUST be listed in it as described in requirement 15. + +### 7.1.19 Requirement 19: Signatures + +All CSAF documents SHALL have at least one OpenPGP signature file which is provided under the same filename which is extended by the appropriate extension. See [RFC4880] for more details. + +*Example 137:* + +``` +File name of CSAF document: example_company_-_2019-yh3234.json +File name of signature file: example_company_-_2019-yh3234.json.asc +``` + +If a ROLIE feed exists, each signature file MUST be listed in it as described in requirement 15. + +### 7.1.20 Requirement 20: Public OpenPGP Key + +The public part of the OpenPGP key used to sign the CSAF documents MUST be available. It SHOULD also be available at a public key server. + +> For example, the public part of the OpenPGP key could be placed in a directory `openpgp` adjacent to the `provider-metadata.json`. + +The OpenPGP key SHOULD have a strength that is considered secure. + +> Guidance on OpenPGP key strength can be retrieved from technical guidelines of competent authorities. + +### 7.1.21 Requirement 21: List of CSAF providers + +The file `aggregator.json` MUST be present and valid according to the JSON schema [CSAF aggregator](https://docs.oasis-open.org/csaf/csaf/v2.0/aggregator_json_schema.json). It MUST NOT be stored adjacent to a `provider-metadata.json`. + +> Suggested locations to store the `aggregator.json` are: +> +> * https://www.example.com/.well-known/csaf-aggregator/aggregator.json +> * https://domain.tld/security/data/aggregator/csaf/aggregator.json +> * https://psirt.domain.tld/advisories/aggregator/csaf/aggregator.json +> * https://domain.tld/security/aggregator/csaf/aggregator.json + +The file `aggregator.json` SHOULD only list the latest version of the metadata of a CSAF provider. + +*Example 138:* + +``` + { + "aggregator": { + "category": "lister", + "contact_details": "Example CSAF Lister can be reached at contact_us@lister.example, or via our website at https://lister.example/security/csaf/aggregator/contact.", + "issuing_authority": "This service is provided as it is. It is free for everybody.", + "name": "Example CSAF Lister", + "namespace": "https://lister.example" + }, + "aggregator_version": "2.0", + "canonical_url": "https://aggregator.example/.well-known/csaf-aggregator/aggregator.json", + "csaf_providers": [ + { + "metadata": { + "last_updated": "2021-07-12T20:20:56.169Z", + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "url": "https://www.example.com/.well-known/csaf/provider-metadata.json" + } + }, + { + "metadata": { + "last_updated": "2021-07-12T21:35:38.000Z", + "publisher": { + "category": "coordinator", + "name": "Example Coordinator CERT", + "namespace": "https://cert.example" + }, + "url": "https://cert.example/advisories/csaf/provider-metadata.json" + } + } + ], + "last_updated":"2021-07-12T22:35:38.978Z" + } +``` + +### 7.1.22 Requirement 22: Two disjoint issuing parties + +The file `aggregator.json` (requirement 21) lists at least two disjoint CSAF providers (including CSAF trusted providers) or one CSAF publisher and one CSAF provider (including CSAF trusted provider). + +### 7.1.23 Requirement 23: Mirror + +The CSAF documents for each issuing party that is mirrored MUST be in a different folder. The folder name SHOULD be retrieved from the name of the issuing authority. This folders MUST be adjacent to the `aggregator.json` (requirement 21). Each such folder MUST at least: + +* provide a `provider-metadata.json` for the current issuing party. +* provide the ROLIE feed document according to requirement 15 which links to the local copy of the CSAF document. + +*Example 139:* + +``` + { + "aggregator": { + "category": "aggregator", + "contact_details": "Example Aggregator can be reached at contact_us@aggregator.example, or via our website at https://aggregator.example/security/csaf/aggregator/contact.", + "issuing_authority": "This service is provided as it is. It is free for everybody.", + "name": "Example Aggregator", + "namespace": "https://aggregator.example" + }, + "aggregator_version": "2.0", + "canonical_url": "https://aggregator.example/.well-known/csaf-aggregator/aggregator.json", + "csaf_providers": [ + { + "metadata": { + "last_updated": "2021-07-12T20:20:56.169Z", + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "url": "https://www.example.com/.well-known/csaf/provider-metadata.json" + }, + "mirrors": [ + "https://aggregator.example/.well-known/csaf-aggregator/Example_Company_ProductCERT/provider-metadata.json" + ] + }, + { + "metadata": { + "last_updated": "2021-07-12T21:35:38.000Z", + "publisher": { + "category": "coordinator", + "name": "Example Coordinator CERT", + "namespace": "https://cert.example" + }, + "url": "https://cert.example/advisories/csaf/provider-metadata.json" + }, + "mirrors": [ + "https://aggregator.example/.well-known/csaf-aggregator/Example_Coordinator_CERT/provider-metadata.json" + ] + } + ], + "last_updated":"2021-07-12T22:35:38.978Z" + } +``` + +## 7.2 Roles + +This subsection groups the requirements from the previous subsection into named sets which target the roles with the same name. This allows end users to request their suppliers to fulfill a certain set of requirements. A supplier can use roles for advertising and marketing. + +The roles "CSAF publisher", "CSAF provider", and "CSAF trusted provider" are intended directly for issuing parties and form the first group. The second group consists of the roles "CSAF lister" and "CSAF aggregator". They collect data from the aforementioned issuing parties of the first group and provide them in a single place to aid in automation. Parties of the second group can also issue their own advisories. However, they MUST follow the rules for the first group for that. + +Both, a CSAF lister and a CSAF aggregator, decide based on their own rules which issuing parties to list respectively to mirror. However, an issuing party MAY apply to be listed or mirrored. + +Issuing parties MUST indicate through the value `false` in `list_on_CSAF_aggregators` if they do not want to be listed. +Issuing parties MUST indicate through the value `false` in `mirror_on_CSAF_aggregators` if they do not want to be mirrored. + +The values are independent. The combination of the value `false` in `list_on_CSAF_aggregators` and `true` in `mirror_on_CSAF_aggregators` implies that the issuing party does not want to be listed without having the CSAF documents mirrored. Therefore, a CSAF aggregator can list that issuing party if it mirrors the files. + +### 7.2.1 Role: CSAF publisher + +A distributing party satisfies the "CSAF publisher" role if the party: + +* satisfies the requirements 1 to 4 in section 7.1. +* distributes only CSAF documents on behalf of its own. + +### 7.2.2 Role: CSAF provider + +A CSAF publisher satisfies the "CSAF provider" role if the party fulfills the following three groups of requirements: + +Firstly, the party: + +* satisfies the "CSAF publisher" role profile. +* additionally satisfies the requirements 5 to 7 in section 7.1. + +Secondly, the party: + +* satisfies at least one of the requirements 8 to 10 in section 7.1. + +Thirdly, the party: + +* satisfies the requirements 11 to 14 in section 7.1 or requirements 15 to 17 in section 7.1. + +> If the party uses the ROLIE-based distribution, it MUST also satisfy requirements 15 to 17. If it uses the directory-based distribution, it MUST also satisfy requirements 11 to 14. + +### 7.2.3 Role: CSAF trusted provider + +A CSAF provider satisfies the "CSAF trusted provider" role if the party: + +* satisfies the "CSAF provider" role profile. +* additionally satisfies the requirements 18 to 20 in section 7.1. + +### 7.2.4 Role: CSAF lister + +A distributing party satisfies the "CSAF lister" role if the party: + +* satisfies the requirements 6, 21 and 22 in section 7.1. +* uses the value `lister` for `/aggregator/category`. +* does not list any mirror pointing to a domain under its own control. + +> The purpose of this role is to provide a list of URLs where to find CSAF documents. It is not assumed that the list will be complete. + +### 7.2.5 Role: CSAF aggregator + +A distributing party satisfies the "CSAF aggregator" role if the party: + +* satisfies the requirements 1 to 6 and 21 to 23 in section 7.1. +* uses the value `aggregator` for `/aggregator/category`. +* lists a mirror for at least two disjoint issuing parties pointing to a domain under its own control. +* links the public part of the OpenPGP key used to sign CSAF documents for each mirrored issuing party in the corresponding `provider-metadata.json`. +* provides for each CSAF document that is mirrored a signature (requirement 19) and a hash (requirement 18). Both SHALL be listed in the ROLIE feed. If the issuing party provides those files for a CSAF document, they SHOULD be copied as well. If the issuing party does not provide those files, they SHALL be created by the CSAF aggregator. Such a signature does not imply any liability of CSAF aggregator for the content of the corresponding CSAF document. It just confirms that the CSAF document provided has not been modified after being downloaded from the issuing party. A CSAF aggregator MAY add additional signatures and hashes for a CSAF document. + +Additionally, a CSAF aggregator MAY list one or more issuing parties that it does not mirror. + +> The purpose of this role is to provide a single point where CSAF documents can be retrieved. Multiple CSAF aggregators are expected to exist around the world. None of them is required to mirror all CSAF documents of all issuing parties. +> CSAF aggregators can be provided for free or as a paid service. +> +> To aid in automation, CSAF aggregators MAY mirror CSAF documents from CSAF publishers. Regarding the terms of use they SHOULD consult with the issuing party. +> The purpose of this option is that a consumer can retrieve CSAF documents from a CSAF publisher as if this issuing party would be a CSAF trusted provider. To reach that goal, a CSAF aggregator collects the CSAF documents from the CSAF publisher and mirrors it. The collection process MAY be automated or manual. CSAF aggregators announce the collection interval through the field `update_interval` in the corresponding item of the CSAF publishers list (`csaf_publishers`) in their `aggregator.json`. +> To minimize the implementation efforts and process overhead, a CSAF aggregator MAY upload the CSAF documents of a CSAF publisher into an internal instance of a CSAF provider software. Such construct is called "CSAF proxy provider" as it can be mirrored by the CSAF aggregator software. However, such a CSAF proxy provider MUST NOT be accessible from anyone else than the CSAF aggregator itself. Otherwise, that would violate the second rule of section 7.2.1. Therefore, it is recommended to expose the CSAF proxy provider only on localhost and allow the access only from the CSAF aggregator software. + +## 7.3 Retrieving rules + +The retrieving process executes in two phases: Finding the `provider-metadata.json` (requirement 7 in section 7.1) and retrieving CSAF documents. + +> A retrieving party SHOULD do the first phase every time. Based on the setup and use case of the retrieving party it MAY choose to do it less often, e.g. only when adding new or updating distributing parties. In that case, it SHOULD to check regularly whether new information is available. + +### 7.3.1 Finding provider-metadata.json + +**Direct locating**: The following process SHOULD be used to determine the location of a `provider-metadata.json` (requirement 7 in section 7.1) based on the main domain of the issuing party: + +1. Checking the Well-known URL (requirement 9 in section 7.1) +2. Checking the security.txt (requirement 8 in section 7.1) +3. Checking the DNS path (requirement 10 in section 7.1) +4. Select one or more `provider-metadata.json` to use. + +> The term "checking" used in the listing above SHOULD be understood as follows: Try to access the resource and test whether the response provides an expected result as defined in the requirement in section 7.1. If that is the case, the step was successful - otherwise not. + +The first two steps SHOULD be performed in all cases as the security.txt MAY advertise additional `provider-metadata.json`. The third step SHOULD only be performed if the first two did not result in the location of at least one `provider-metadata.json`. + +**Indirect locating**: A retrieving party MAY choose to determine the location of a `provider-metadata.json` by retrieving its location from an `aggregator.json` (requirement 21 in section 7.1) of a CSAF lister or CSAF aggregator. + +### 7.3.2 Retrieving CSAF documents + +Given a `provider-metadata.json`, the following process SHOULD be used to retrieve CSAF documents: + +1. Parse the `provider-metadata.json` to determine whether the directory-based (requirements 11 to 14 in section 7.1) or ROLIE-based distribution (requirements 15 to 17 in section 7.1) is used. If both are present, the ROLIE information SHOULD be preferred. +2. For any CSAF trusted provider, the hash and signature files (requirements 18 to 19 in section 7.1) SHOULD be retrieved together with the CSAF document. They MUST be checked before further processing the CSAF document. +3. Test the CSAF document against the schema. +4. Execute mandatory tests on the CSAF document. + +------- + +# 8 Safety, Security, and Data Protection Considerations + +CSAF documents are based on JSON, thus the security considerations of [RFC8259] apply and are repeated here as service for the reader: +>Generally, there are security issues with scripting languages. JSON is a subset of JavaScript but excludes assignment and invocation. +> +>Since JSON's syntax is borrowed from JavaScript, it is possible to use that language's `eval()` function to parse most JSON texts (but not all; certain characters such as `U+2028 LINE SEPARATOR` and `U+2029 PARAGRAPH SEPARATOR` are legal in JSON but not JavaScript). This generally constitutes an unacceptable security risk, since the text could contain executable code along with data declarations. The same consideration applies to the use of eval()-like functions in any other programming language in which JSON texts conform to that language's syntax. + +In addition, CSAF documents may be rendered by consumers in various human-readable formats like HTML or PDF. +Thus, for security reasons, CSAF producers and consumers SHALL adhere to the following: + +* CSAF producers SHOULD NOT emit messages that contain HTML, even though all variants of Markdown permit it. To include HTML, source code, or any other content that may be interpreted or executed by a CSAF consumer, e.g. to provide a proof-of-concept, the issuing party SHALL use Markdown's fenced code blocks or inline code option. +* Deeply nested markup can cause a stack overflow in the Markdown processor [GFMENG]. To reduce this risk, CSAF consumers SHALL use a Markdown processor that is hardened against such attacks. + **Note**: One example is the GitHub fork of the `cmark` Markdown processor [GFMCMARK]. +* To reduce the risk posed by possibly malicious CSAF files that do contain arbitrary HTML (including, for example, javascript: links), CSAF consumers SHALL either disable HTML processing (for example, by using an option such as the --safe option in the cmark Markdown processor) or run the resulting HTML through an HTML sanitizer. +CSAF consumers that are not prepared to deal with the security implications of formatted messages SHALL NOT attempt to render them and SHALL instead fall back to the corresponding plain text messages. As also any other programming code can be contained within a CSAF document, CSAF consumers SHALL ensure that none of the values of a CSAF document is run as code. Moreover, it SHALL be treated as unsafe (user) input. + > Additional, supporting mitigation measures like retrieving only CSAF documents from trusted sources and check their integrity and signature before parsing the document SHOULD be in place to reduce the risk further. + +------- + +# 9 Conformance + +In the only subsection of this section, the conformance targets and clauses are listed. +The clauses, matching the targets one to one, are listed in separate sub-subsections of the targets listing subsection. + +Informative Comments: + +> The order in which targets, and their corresponding clauses appear is somewhat arbitrary as there is no natural order on such diverse roles participating in the document exchanging ecosystem. +> +> Except for the target **CSAF document**, all other 16 targets span a taxonomy of the complex CSAF ecosystems existing in and between diverse security advisory generating, sharing, and consuming communities. +> +> In any case, there are no capabilities organized in increasing quality levels for targets because the security advisory sharing communities follow the chain link model. +> Instead, a single minimum capability level for every target is given to maintain important goals of providing a common framework for security advisories: +> +> * Fast production, sharing, and actionable consumption of security advisories +> * Consistent end to end automation through collaborating actors +> * Clear baseline across the communities per this specification +> * Additional per-community cooperative extensions which may flow back into future updates of this specification + +## 9.1 Conformance Targets + +This document defines requirements for the CSAF file format and for certain software components that interact with it. +The entities ("conformance targets") for which this document defines requirements are: + +* **CSAF document**: A security advisory text document in the format defined by this document. +* **CSAF producer**: A program which emits output in the CSAF format. +* **CSAF direct producer**: An analysis tool which acts as a CSAF producer. +* **CSAF converter**: A CSAF producer that transforms the output of an analysis tool from its native output format into the CSAF format. +* **CVRF CSAF converter**: A CSAF producer which takes a CVRF document as input and converts it into a valid CSAF document. +* **CSAF content management system**: A program that is able to create, review and manage CSAF documents and is able to preview their details as required by CSAF viewer. +* **CSAF post-processor**: A CSAF producer that transforms an existing CSAF document into a new CSAF document, for example, by removing or redacting elements according to sharing policies. +* **CSAF modifier**: A CSAF post-processor which takes a CSAF document as input and modifies the structure or values of properties. The output is a valid CSAF document. +* **CSAF translator**: A CSAF post-processor which takes a CSAF document as input and translates values of properties into another language. The output is a valid CSAF document. +* **CSAF consumer**: A program that reads and interprets a CSAF document. +* **CSAF viewer**: A CSAF consumer that reads a CSAF document, displays a list of the results it contains, and allows an end user to view each result in the context of the artifact in which it occurs. +* **CSAF management system**: A program that is able to manage CSAF documents and is able to display their details as required by CSAF viewer. +* **CSAF asset matching system**: A program that connects to or is an asset database and is able to manage CSAF documents as required by CSAF management system as well as matching them to assets of the asset database. +* **CSAF basic validator**: A program that reads a document and checks it against the JSON schema and performs mandatory tests. +* **CSAF extended validator**: A CSAF basic validator that additionally performs optional tests. +* **CSAF full validator**: A CSAF extended validator that additionally performs informative tests. +* **CSAF SBOM matching system**: A program that connects to or is an SBOM database and is able to manage CSAF documents as required by CSAF management system as well as matching them to SBOM components of the SBOM database. + +### 9.1.1 Conformance Clause 1: CSAF document + +A text file or data stream satisfies the "CSAF document" conformance profile if it: + +* conforms to the syntax and semantics defined in section 3. +* satisfies at least one profile defined in section 4. +* does not fail any mandatory test defined in section 6.1. + +### 9.1.2 Conformance Clause 2: CSAF producer + +A program satisfies the "CSAF producer" conformance profile if the program: + +* produces output in the CSAF format, according to the conformance profile "CSAF document" . +* satisfies those normative requirements in section 3 and 8 that are designated as applying to CSAF producers. + +### 9.1.3 Conformance Clause 3: CSAF direct producer + +An analysis tool satisfies the "CSAF direct producer" conformance profile if the analysis tool: + +* satisfies the "CSAF producer" conformance profile. +* additionally satisfies those normative requirements in section 3 that are designated as applying to "direct producers" or to "analysis tools". +* does not emit any objects, properties, or values which, according to section 3, are intended to be produced only by converters. + +### 9.1.4 Conformance Clause 4: CSAF converter + +A converter satisfies the “CSAF converter” conformance profile if the converter: + +* satisfies the "CSAF producer" conformance profile. +* additionally satisfies those normative requirements in section 3 that are designated as applying to converters. +* does not emit any objects, properties, or values which, according to section 3, are intended to be produced only by direct producers. + +### 9.1.5 Conformance Clause 5: CVRF CSAF converter + +A program satisfies the "CVRF CSAF converter" conformance profile if the program fulfills the following two groups of requirements: + +Firstly, the program: + +* satisfies the "CSAF producer" conformance profile. +* takes only CVRF documents as input. +* additionally satisfies the normative requirements given below. + +Secondly, the program fulfills the following for all items of: + +* type `/$defs/branches_t`: If any `prod:Branch` instance has the type `Realm` or `Resource`, the CVRF CSAF converter replaces those with the category `product_name`. In addition, the converter outputs a warning that that those types do not exist in CSAF and have been replaced with the category `product_name`. +* type `/$defs/version_t`: If any element doesn't match the semantic versioning, replace the all elements of type `/$defs/version_t` with the corresponding integer version. For that, CVRF CSAF converter sorts the items of `/document/tracking/revision_history` by `number` ascending according to the rules of CVRF. Then, it replaces the value of `number` with the index number in the array (starting with 1). The value of `/document/tracking/version` is replaced by value of `number` of the corresponding revision item. The match MUST be calculated by the original values used in the CVRF document. If this conversion was applied, for each Revision the original value of `cvrf:Number` MUST be set as `legacy_version` in the converted document. +* `/document/acknowledgments[]/organization` and `/vulnerabilities[]/acknowledgments[]/organization`: If more than one `cvrf:Organization` instance is given, the CVRF CSAF converter converts the first one into the `organization`. In addition, the converter outputs a warning that information might be lost during conversion of document or vulnerability acknowledgment. +* `/document/lang`: If one or more CVRF element containing an `xml:lang` attribute exist and contain the exact same value, the CVRF CSAF converter converts this value into `lang`. If the values of `xml:lang` attributes are not equal, the CVRF CSAF converter outputs a warning that the language could not be determined and possibly a document with multiple languages was produced. In addition, it SHOULD also present all values of `xml:lang` attributes as a set in the warning. +* `/document/publisher/name` and `/document/publisher/namespace`: Sets the value as given in the configuration of the program or the corresponding argument the program was invoked with. If values from both sources are present, the program SHOULD prefer the latter one. The program SHALL NOT use hard-coded values. +* `/document/tracking/id`: If the element `cvrf:ID` contains any line breaks or leading or trailing white space, the CVRF CSAF converter removes those characters. In addition, the converter outputs a warning that the ID was changed. +* `/product_tree/relationships[]`: If more than one `prod:FullProductName` instance is given, the CVRF CSAF converter converts the first one into the `full_product_name`. In addition, the converter outputs a warning that information might be lost during conversion of product relationships. +* `/vulnerabilities[]/cwe`: If more than one `vuln:CWE` instance is given, the CVRF CSAF converter converts the first one into `cwe`. In addition, the converter outputs a warning that information might be lost during conversion of the CWE. +* `/vulnerabilities[]/ids`: If a `vuln:ID` element is given, the CVRF CSAF converter converts it into the first item of the `ids` array. +* `/vulnerabilities[]/remediation[]`: If no `product_ids` or `group_ids` is given, the CVRF CSAF converter appends all Product IDs which are listed under `../product_status` in the arrays `known_affected`, `first_affected` and `last_affected` into `product_ids`. If none of these arrays exist, the CVRF CSAF converter outputs an error that no matching Product ID was found for this remediation element. +* `/vulnerabilities[]/scores[]`: + * For any CVSS v3 element, the CVRF CSAF converter MUST compute the `baseSeverity` from the `baseScore` according to the rules of the applicable CVSS standard. + * If no `product_id` is given, the CVRF CSAF converter appends all Product IDs which are listed under `../product_status` in the arrays `known_affected`, `first_affected` and `last_affected`. If none of these arrays exist, the CVRF CSAF converter outputs an error that no matching Product ID was found for this score element. + * If a `vectorString` is missing, the CVRF CSAF converter outputs an error that the CVSS element could not be converted as the CVSS vector was missing. A CVRF CSAF converter MAY offer a configuration option to delete such elements. + * If there are CVSS v3.0 and CVSS v3.1 Vectors available for the same product, the CVRF CSAF converter discards the CVSS v3.0 information and provide in CSAF only the CVSS v3.1 information. + * To determine, which minor version of CVSS v3 is used, the CVRF CSAF converter uses the following steps: + 1. Retrieve the CVSS version from the CVSS vector, if present. + + *Example 140:* + + ``` + CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H => 3.1 + ``` + + 2. Retrieve the CVSS version from the CVSS element's namespace, if present. The CVRF CSAF converter outputs a warning that this value was guessed from the element's namespace. + + *Example 141:* + + ``` + xmlns:cvssv31="https://www.first.org/cvss/cvss-v3.1.xsd" + + + ``` + + is handled the same as + + *Example 142:* + + ``` + + ``` + + 3. Retrieve the CVSS version from the CVSS namespace given in the root element, if present. The CVRF CSAF converter outputs a warning that this value was guessed from the global namespace. If more than one CVSS namespace is present and the element is not clearly defined via the namespace, this step MUST be skipped without a decision. + + *Example 143:* + + ``` + xmlns:cvssv3="https://www.first.org/cvss/cvss-v3.0.xsd" => 3.0 + ``` + + 4. Retrieve the CVSS version from a config value, which defaults to `3.0`. (As CSAF CVRF v1.2 predates CVSS v3.1.) The CVRF CSAF converter outputs a warning that this value was taken from the config. + +### 9.1.6 Conformance Clause 6: CSAF content management system + +A CSAF content management system satisfies the "CSAF content management system" conformance profile if the content management system: + +* satisfies the "CSAF producer" conformance profile. +* satisfies the "CSAF viewer" conformance profile. +* provides at least the following management functions: + + * create new CSAF documents + * prefill CSAF documents based on values given in the configuration (see below) + * create a new version of an existing CSAF document + * checkout old versions of a CSAF document + * show all differences between versions of a CSAF document + * list all CSAF documents within the system + * delete CSAF documents from the system + * review CSAF documents in the system + * approve CSAF documents + * search for CSAF documents by values of required fields at `document`-level or their children within the system + * search for CSAF documents by values of `cve` within the system + * search for CSAF documents based on properties of `product_tree` + * filter on all properties which it is required to search for + * export of CSAF documents + * show an audit log for each CSAF document + * identify the latest version of CSAF documents with the same `/document/tracking/id` + * suggest a `/document/tracking/id` based on the given configuration. + * track of the version of CSAF documents automatically and increment according to the versioning scheme (see also subsections of 3.1.11) selected in the configuration. + * check that the document version is set correctly based on the changes in comparison to the previous version (see also subsections of 3.1.11). + * suggest to use the document status `interim` if a CSAF document is updated more frequent than the given threshold in the configuration (default: 3 weeks) + * suggest to publish a new version of the CSAF document with the document status `final` if the document status was `interim` and no new release has be done during the the given threshold in the configuration (default: 6 weeks) + * support the following workflows: + + * "New Advisory": create a new advisory, request a review, provide review comments or approve it, resolve review comments; if the review approved it, the approval for publication can be requested; if granted the document status changes to `final` (or `ìnterim` based on the selection in approval or configuration) and the advisory is provided for publication (manual or time-based) + * "Update Advisory": open an existing advisory, create new revision & change content, request a review, provide review comments or approve it, resolve review comments; if the review approved it, the approval for publication can be requested; if granted the document status changes to `final` (or `ìnterim` based on the selection in approval or configuration) and the advisory is provided for publication (manual or time-based) + +* offers both: publication immediately or at a given date/time. +* automates handling of date/time and version. +* provides an API to retrieve all CSAF documents which are currently in the status published. +* optionally provides an API to import or create new advisories from outside systems (e.g. bug tracker, CVD platform,...). +* provides a user management and support at least the following roles: + + * _Registered_: Able to see all published CSAF documents (but only in the published version). + * _Author_: inherits _Registered_ permissions and also can Create and Edit Own (mostly used for automated creation, see above) + * _Editor_: inherits _Author_ permissions and can Edit (mostly used in PSIRT) + * _Publisher_: inherits _Editor_ permissions and can Change state and Review any (mostly used as HEAD of PSIRT or team lead) + * _Reviewer_: inherits _Registered_ permissions and can Review advisories assigned to him (might be a subject matter expert or management) + * _Manager_: inherits _Publisher_ permissions and can Delete; User management up to _Publisher_ + * _Administrator_: inherits _Manager_ permissions and can Change the configuration + +* may use groups to support client separation (multitenancy) and therefore restrict the roles to actions within their group. In this case, there MUST be a _Group configurator_ which is able to change the values which are used to prefill fields in new advisories for that group. He might also do the user management for the group up to a configured level. +* prefills the following fields in new CSAF documents with the values given below or based on the templates from configuration: + + * `/document/csaf_version` with the value `2.0` + * `/document/language` + * `/document/notes` + * `legal_disclaimer` (Terms of use from the configuration) + * `general` (General Security recommendations from the configuration) + * `/document/tracking/current_release_date` with the current date + * `/document/tracking/generator` and children + * `/document/tracking/initial_release_date` with the current date + * `/document/tracking/revision_history` + * `date` with the current date + * `number` (based on the templates according to the versioning scheme configured) + * `summary` (based on the templates from configuration; default: "Initial version.") + * `/document/tracking/status` with `draft` + * `/document/tracking/version` with the value of `number` the latest `/document/tracking/revision_history[]` element + * `/document/publisher` and children + * `/document/category` (based on the templates from configuration) + +* When updating an existing CSAF document: + + * prefills all fields which have be present in the existing CSAF document + * adds a new item in `/document/tracking/revision_history[]` + * updates the following fields with the values given below or based on the templates from configuration: + * `/document/csaf_version` with the value `2.0` + * `/document/language` + * `/document/notes` + * `legal_disclaimer` (Terms of use from the configuration) + * `general` (General Security recommendations from the configuration) + * `/document/tracking/current_release_date` with the current date + * `/document/tracking/generator` and children + * the new item in `/document/tracking/revision_history[]` + * `date` with the current date + * `number` (based on the templates according to the versioning scheme configured) + * `/document/tracking/status` with `draft` + * `/document/tracking/version` with the value of `number` the latest `/document/tracking/revision_history[]` element + * `/document/publisher` and children + +### 9.1.7 Conformance Clause 7: CSAF post-processor + +A CSAF post-processor satisfies the "CSAF post-processor" conformance profile if the post-processor: + +* satisfies the "CSAF consumer" conformance profile. +* satisfies the "CSAF producer" conformance profile. +* additionally satisfies those normative requirements in section 3 that are designated as applying to post-processors. + +### 9.1.8 Conformance Clause 8: CSAF modifier + +A program satisfies the "CSAF modifier" conformance profile if the program fulfills the two following groups of requirements: + +The program: + +* satisfies the "CSAF post-processor" conformance profile. +* adds, deletes or modifies at least one property, array, object or value of a property or item of an array. +* does not emit any objects, properties, or values which, according to section 9, are intended to be produced only by CSAF translators. +* satisfies the normative requirements given below. + +The resulting modified document: + +* does not have the same `/document/tracking/id` as the original document. The modified document can use a completely new `/document/tracking/id` or compute one by appending the original `/document/tracking/id` as a suffix after an ID from the naming scheme of the issuer of the modified version. It SHOULD NOT use the original `/document/tracking/id` as a prefix. +* includes a reference to the original advisory as first element of the array `/document/references[]`. + +### 9.1.9 Conformance Clause 9: CSAF translator + +A program satisfies the "CSAF translator" conformance profile if the program fulfills the two following groups of requirements: + +The program: + +* satisfies the "CSAF post-processor" conformance profile. +* translates at least one value. +* preserves the same semantics and form across translations. +* satisfies the normative requirements given below and does not add or remove other elements than required below. + +The resulting translated document: + +* does not use the same `/document/tracking/id` as the original document. The translated document can use a completely new `/document/tracking/id` or compute one by using the original `/document/tracking/id` as a prefix and adding an ID from the naming scheme of the issuer of the translated version. It SHOULD NOT use the original `/document/tracking/id` as a suffix. If an issuer uses a CSAF translator to publish his advisories in multiple languages they MAY use the combination of the original `/document/tracking/id` and translated `/document/lang` as a `/document/tracking/id` for the translated document. +* provides the `/document/lang` property with a value matching the language of the translation. +* provides the `/document/source_lang` to contain the language of the original document (and SHOULD only be set by CSAF translators). +* has the value `translator` set in `/document/publisher/category` +* includes a reference to the original advisory as first element of the array `/document/references[]`. +* MAY contain translations for elements in arrays of `references_t` after the first element. However, it MUST keep the original URLs as references at the end. + +### 9.1.10 Conformance Clause 10: CSAF consumer + +A processor satisfies the "CSAF consumer" conformance profile if the processor: + +* reads CSAF documents and interprets them according to the semantics defined in section 3. +* satisfies those normative requirements in section 3 and 8 that are designated as applying to CSAF consumers. + +### 9.1.11 Conformance Clause 11: CSAF viewer + +A viewer satisfies the "CSAF viewer" conformance profile if the viewer fulfills the two following groups of requirements: + +The viewer: + +* satisfies the "CSAF consumer" conformance profile. +* satisfies the normative requirements given below. + +For each CVSS-Score in `/vulnerabilities[]/scores[]` the viewer: + +* preferably shows the `vector` if there is an inconsistency between the `vector` and any other sibling attribute. +* SHOULD prefer the item of `scores[]` for each `product_id` which has the highest CVSS Base Score and newest CVSS version (in that order) if a `product_id` is listed in more than one item of `scores[]`. + +### 9.1.12 Conformance Clause 12: CSAF management system + +A CSAF management system satisfies the "CSAF management system" conformance profile if the management system: + +* satisfies the "CSAF viewer" conformance profile. +* provides at least the following management functions: + * add new CSAF documents (e.g. from file system or URL) to the system + * list all CSAF documents within the system + * delete CSAF documents from the system + * comment on CSAF documents in the system + * mark CSAF documents as read in the system + * search for CSAF documents by values of required fields at `document`-level or their children within the system + * search for CSAF documents by values of `cve` within the system + * search for CSAF documents based on properties of `/product_tree` + * filter on all properties which it is required to search for + * sort on all properties which it is required to search for + * sort on CVSS scores and `/document/aggregate_severity/text` +* identifies the latest version of CSAF documents with the same `/document/tracking/id`. +* is able to show the difference between 2 versions of a CSAF document with the same `/document/tracking/id`. + +### 9.1.13 Conformance Clause 13: CSAF asset matching system + +A CSAF asset matching system satisfies the "CSAF asset matching system" conformance profile if the asset matching system: + +* satisfies the "CSAF management system" conformance profile. +* is an asset database or connects to one. +* matches the CSAF documents within the system to the respective assets. This might be done with a probability which gives the end user the chance to broaden or narrow the results. The process of matching is also referred to as "run of the asset matching module". +* provides for each product of the asset database a list of matched advisories. +* provides for each asset of the asset database a list of matched advisories. +* provides for each CSAF document a list of matched product of the asset database. +* provides for each CSAF document a list of matched asset of the asset database. +* provides for each vulnerability within a CSAF document the option to mark a matched asset in the asset database as "not remediated", "remediation in progress", or "remediation done". A switch to mark all assets at once MAY be implemented. +* does not bring up a newer revision of a CSAF document as a new match if the remediation for the matched product or asset has not changed. +* detects the usage semantic version (as described in section 3.1.11.2). +* is able to trigger a run of the asset matching module: + * manually: + * per CSAF document + * per list of CSAF documents + * per asset + * per list of assets + * automatically: + * when a new CSAF document is inserted (for this CSAF document) + * when a new asset is inserted (for this asset) + * when the Major version in a CSAF document with semantic versioning changes (for this CSAF document) + > These also apply if more than one CSAF document or asset was added. To reduce the computational efforts the runs can be pooled into one run which fulfills all the tasks at once (batch mode). + * Manually and automatically triggered runs SHOULD NOT be pooled. +* provides at least the following statistics for the count of assets: + * matching that CSAF document at all + * marked with a given status + +### 9.1.14 Conformance Clause 14: CSAF basic validator + +A program satisfies the "CSAF basic validator" conformance profile if the program: + +* reads documents and performs a check against the JSON schema. +* performs all mandatory tests as given in section 6.1. +* does not change the CSAF documents. + +A CSAF basic validator MAY provide one or more additional functions: + +* Only run one or more selected mandatory tests. +* Apply quick fixes as specified in the standard. +* Apply additional quick fixes as implemented by the vendor. + +### 9.1.15 Conformance Clause 15: CSAF extended validator + +A CSAF basic validator satisfies the "CSAF extended validator" conformance profile if the CSAF basic validator: + +* satisfies the "CSAF basic validator" conformance profile. +* additionally performs all optional tests as given in section 6.2. + +A CSAF extended validator MAY provide an additional function to only run one or more selected optional tests. + +### 9.1.16 Conformance Clause 16: CSAF full validator + +A CSAF extended validator satisfies the "CSAF full validator" conformance profile if the CSAF extended validator: + +* satisfies the "CSAF extended validator" conformance profile. +* additionally performs all informative tests as given in section 6.3. + +A CSAF full validator MAY provide an additional function to only run one or more selected informative tests. + +### 9.1.17 Conformance Clause 17: CSAF SBOM matching system + +A CSAF SBOM matching system satisfies the "CSAF SBOM matching system" conformance profile if the SBOM matching system: + +* satisfies the "CSAF management system" conformance profile. +* is an SBOM database or connects to one. + > A repository or any other location that can be queried for SBOMs and their content is also considered an SBOM database. +* matches the CSAF documents within the system to the respective SBOM components. This might be done with a probability which gives the user the chance to broaden or narrow the results. The process of matching is also referred to as "run of the SBOM matching module". +* provides for each SBOM of the SBOM database a list of matched advisories. +* provides for each SBOM component of the SBOM database a list of matched advisories. +* provides for each CSAF document a list of matched SBOMs of the SBOM database. +* provides for each CSAF document a list of matched SBOM components of the SBOM database. +* provides for each vulnerability within a CSAF document the option to mark a matched SBOM component in the SBOM database as "not remediated", "remediation in progress", or "remediation done". A switch to mark all SBOM component at once MAY be implemented. +* does not bring up a newer revision of a CSAF document as a new match if the remediation for the matched SBOM or SBOM component has not changed. +* detects the usage semantic version (as described in section 3.1.11.2). +* is able to trigger a run of the asset matching module: + * manually: + * per CSAF document + * per list of CSAF documents + * per SBOM component + * per list of SBOM components + * automatically: + * when a new CSAF document is inserted (for this CSAF document) + * when a new SBOM component is inserted (for this SBOM component) + * when the Major version in a CSAF document with semantic versioning changes (for this CSAF document) + > These also apply if more than one CSAF document or SBOM component was added. To reduce the computational efforts the runs can be pooled into one run which fulfills all the tasks at once (batch mode). + > Manually and automatically triggered runs should not be pooled. +* provides at least the following statistics for the count of SBOM component: + * matching that CSAF document at all + * marked with a given status + +------- + +# Appendix A. Acknowledgments + +The following individuals were members of the OASIS CSAF Technical Committee during the creation of this specification and their contributions are gratefully acknowledged: + +**CSAF TC Members:** + +| First Name | Last Name | Company | +| :--- | :--- | :--- | +|Alexandre | Dulaunoy | CIRCL| +|Anthony | Berglas | Cryptsoft Pty Ltd.| +|Art | Manion | Carnegie Mellon University| +|Aukjan | van Belkum | EclecticIQ| +|Ben | Sooter | Electric Power Research Institute (EPRI)| +|Bernd | Grobauer | Siemens AG| +|Bruce | Rich | Cryptsoft Pty Ltd.| +|Chok | Poh | Oracle| +|Dan | West | Microsoft| +|David | Waltermire | NIST| +|Denny | Page | TIBCO Software Inc.| +|Duncan | Sparrell | sFractal Consulting LLC| +|Eric | Johnson | TIBCO Software Inc.| +|Ethan | Rahn | Arista Networks| +|Feng | Cao | Oracle| +|Greg | Scott | Cryptsoft Pty Ltd.| +|Harold | Booth | NIST| +|Jason | Masters | TELUS| +|Jennifer | Victor | Dell| +|Jessica | Fitzgerald-McKay | National Security Agency| +|Jonathan | Bitle | Kaiser Permanente| +|Justin | Corlett | Cryptsoft Pty Ltd.| +|Kazuo | Noguchi | Hitachi, Ltd.| +|Kent | Landfield | McAfee| +|Langley | Rock | Red Hat| +|Martin | Prpic | Red Hat| +|Masato | Terada | Hitachi, Ltd.| +|Mike | Gorski | Cisco Systems| +|Nicole | Parrish | Mitre Corporation| +|Omar | Santos | Cisco Systems| +|Patrick | Maroney | AT&T| +|Rhonda | Levy | Cisco Systems| +|Richard | Struse | Mitre Corporation| +|Ritwik | Ghoshal | Oracle| +|Robert | Coderre | Accenture| +|Robert | Keith | Accenture| +|Stefan | Hagen | Individual| +|Tania | Ward | Dell| +|Ted | Bedwell | Cisco Systems| +|Thomas | Proell | Siemens AG| +|Thomas | Schmidt | Federal Office for Information Security (BSI) Germany| +|Tim | Hudson | Cryptsoft Pty Ltd.| +|Tobias | Limmer | Siemens AG| +|Tony | Cox | Cryptsoft Pty Ltd.| +|Vincent | Danen | Red Hat| +|Will | Rideout | Arista Networks| +|Xiaoyu | Ge | Huawei Technologies Co., Ltd.| + +The following individuals were members of the OASIS CSAF Technical Committee during the creation of the previous version (CVRF v1.2) of this specification and their contributions are gratefully acknowledged: + +**CSAF TC Members:** + +| First Name | Last Name | Company | +| :--- | :--- | :--- | +|Adam | Montville | CIS| +|Allan | Thomson | LookingGlass| +|Anthony | Berglas | Cryptsoft Pty Ltd.| +|Art | Manion | Carnegie Mellon University| +|Aukjan | van Belkum | EclecticIQ| +|Ben | Sooter | Electric Power Research Institute| +|Bernd | Grobauer | Siemens AG| +|Beth | Pumo | Kaiser Permanente| +|Bret | Jordan | Symantec Corp.| +|Bruce | Rich | Cryptsoft Pty Ltd.| +|Chet | Ensign | OASIS| +|Chok | Poh | Oracle| +|Chris | Rouland | Individual| +|David | Waltermire | NIST| +|Denny | Page | TIBCO Software Inc.| +|Doron | Shiloach | IBM| +|Duncan | Sparrell | sFractal Consulting LLC| +|Eric | Johnson | TIBCO Software Inc.| +|Feng | Cao | Oracle| +|Greg | Reaume | TELUS| +|Greg | Scott | Cryptsoft Pty Ltd.| +|Harold | Booth | NIST| +|Jamison | Day | LookingGlass| +|Jared | Semrau | "FireEye, Inc."| +|Jason | Masters | TELUS| +|Jerome | Athias | Individual| +|Jessica | Fitzgerald-McKay | National Security Agency| +|Jonathan | Bitle | Kaiser Permanente| +|Justin | Corlett | Cryptsoft Pty Ltd.| +|Karen | Scarfone | Individual| +|Kazuo | Noguchi | "Hitachi, Ltd."| +|Kent | Landfield | McAfee| +|Lothar | Braun | Siemens AG| +|Louis | Ronnau | Cisco Systems| +|Mark | Davidson | NC4| +|Mark-David | McLaughlin | Cisco Systems| +|Masato | Terada | "Hitachi, Ltd."| +|Masood | Nasir | TELUS| +|Nicole | Gong | Mitre Corporation| +|Omar | Santos | Cisco Systems| +|Patrick | Maroney | Wapack Labs LLC| +|Paul | Patrick | "FireEye, Inc."| +|Peter | Allor | IBM| +|Phillip | Boles | "FireEye, Inc."| +|Ravi | Balupari | Netskope| +|Rich | Reybok | ServiceNow| +|Richard | Struse | DHS Office of Cybersecurity and Communications (CS&C)| +|Ritwik | Ghoshal | Oracle| +|Robert | Coderre | VeriSign| +|Robin | Cover | OASIS| +|Rupert | Wimmer | Siemens AG| +|Sanjiv | Kalkar | Individual| +|Sean | Barnum | Mitre Corporation| +|Stefan | Hagen | Individual| +|Ted | Bedwell | Cisco Systems| +|Thomas | Schreck | Siemens AG| +|Tim | Hudson | Cryptsoft Pty Ltd.| +|Tony | Cox | Cryptsoft Pty Ltd.| +|Trey | Darley | "Kingfisher Operations, sprl"| +|Vincent | Danen | Red Hat| +|Zach | Turk | Microsoft| + +------- + +# Appendix B. Revision History + +| Revision | Date | Editor | Changes Made | +|:-------------------------|:-----------|:--------------------------------|:--------------------------------------------------------------------------------------| +| csaf-v2.0-wd20210927-dev | 2021-09-27 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS for public review | +| csaf-v2.0-wd20220329-dev | 2022-03-29 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CSD02 for public review | +| csaf-v2.0-wd20220514-dev | 2022-05-14 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | +| csaf-v2.0-wd20220715-dev | 2022-07-15 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | +| csaf-v2.0-wd20220720-dev | 2022-07-20 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | + +------- + +# Appendix C. Guidance on the Size of CSAF Documents + +This appendix provides informative guidance on the size of CSAF documents. + +The TC carefully considered all known aspects to provide size limits for CSAF documents for this version of the specification with the result that hard limits SHOULD NOT be enforced. However, since there is the need for guidance to ensure interoperability in the ecosystem, the TC provides a set of soft limits. A CSAF document which exceeds those, can still be valid but it might not be processable for some parties. + +All _CSAF consumers_ SHOULD be able to process CSAF documents which comply with the limits below. All _CSAF producers_ SHOULD NOT produce CSAF documents which exceed those limits. + +> If you come across a case where these limits are exceeded, please provide feedback to the TC. + +## C.1 File size + +A CSAF document in the specified JSON format encoded in UTF-8 SHOULD conform to known size limits of current technologies parsing JSON content, e.g.: 15 MB. + +> At least one database technology in wide use for storing CSAF documents rejects insert attempts when the transformed BSON size exceeds 16 megabytes. The BSON format optimizes for accessibility and not size. So, small integers and small strings may incur more overhead in the BSON format than in JSON. In addition, the BSON format adds length information for the entries inside the document, which adds to the size when storing CSAF document content in a BSON format. + +## C.2 Array length + +An array SHOULD NOT have more than: + +* 10 000 items for + * `/document/acknowledgments` + * `/document/acknowledgments[]/names` + * `/document/acknowledgments[]/urls` + * `/document/tracking/aliases` + * `/product_tree/branches[]/product/product_identification_helper/hashes` + * `/product_tree/branches[]/product/product_identification_helper/hashes[]/file_hashes` + * `/product_tree/branches[]/product/product_identification_helper/sbom_urls` + * `/product_tree/branches[]/product/product_identification_helper/x_generic_uris` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/hashes` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/hashes[]/file_hashes` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/sbom_urls` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/x_generic_uris` + * `/product_tree/full_product_names[]/product_identification_helper/hashes` + * `/product_tree/full_product_names[]/product_identification_helper/hashes[]/file_hashes` + * `/product_tree/full_product_names[]/product_identification_helper/sbom_urls` + * `/product_tree/full_product_names[]/product_identification_helper/x_generic_uris` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/hashes` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/hashes[]/file_hashes` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/sbom_urls` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/x_generic_uris` + * `/vulnerabilities[]/acknowledgments` + * `/vulnerabilities[]/acknowledgments[]/names` + * `/vulnerabilities[]/acknowledgments[]/urls` + * `/vulnerabilities[]/ids` + * `/vulnerabilities[]/remediations[]/entitlements` + +* 40 000 items for + * `/document/notes` + * `/document/references` + * `/vulnerabilities[]/involvements` + * `/vulnerabilities[]/notes` + * `/vulnerabilities[]/references` + +* 100 000 for + * `/document/tracking/revision_history` + * `/product_tree/branches` + * `/product_tree(/branches[])*/branches` + * `/product_tree/branches[]/product/product_identification_helper/model_numbers` + * `/product_tree/branches[]/product/product_identification_helper/serial_numbers` + * `/product_tree/branches[]/product/product_identification_helper/skus` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/model_numbers` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/serial_numbers` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/skus` + * `/product_tree/full_product_names` + * `/product_tree/full_product_names[]/product_identification_helper/model_numbers` + * `/product_tree/full_product_names[]/product_identification_helper/serial_numbers` + * `/product_tree/full_product_names[]/product_identification_helper/skus` + * `/product_tree/product_groups[]/product_ids` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/model_numbers` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/serial_numbers` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/skus` + * `/vulnerabilities` + +* 10 000 000 for + * `/product_tree/relationships` + * `/product_tree/product_groups` + * `/vulnerabilities[]/remediations[]/group_ids` + +* 100 000 000 for + * `/vulnerabilities[]/flags` + * `/vulnerabilities[]/flags[]/group_ids` + * `/vulnerabilities[]/flags[]/product_ids` + * `/vulnerabilities[]/product_status/first_affected` + * `/vulnerabilities[]/product_status/first_fixed` + * `/vulnerabilities[]/product_status/fixed` + * `/vulnerabilities[]/product_status/known_affected` + * `/vulnerabilities[]/product_status/known_not_affected` + * `/vulnerabilities[]/product_status/last_affected` + * `/vulnerabilities[]/product_status/recommended` + * `/vulnerabilities[]/product_status/under_investigation` + * `/vulnerabilities[]/remediations` + * `/vulnerabilities[]/remediations[]/product_ids` + * `/vulnerabilities[]/scores` + * `/vulnerabilities[]/scores[]/products` + * `/vulnerabilities[]/threats` + * `/vulnerabilities[]/threats[]/group_ids` + * `/vulnerabilities[]/threats[]/product_ids` + +## C.3 String length + +A string SHOULD NOT have a length greater than: + +* 1000 for + * `/document/acknowledgments[]/names[]` + * `/document/acknowledgments[]/organization` + * `/document/aggregate_severity/text` + * `/document/category` + * `/document/lang` + * `/document/notes[]/audience` + * `/document/notes[]/title` + * `/document/publisher/name` + * `/document/source_lang` + * `/document/title` + * `/document/tracking/aliases[]` + * `/document/tracking/generator/engine/name` + * `/document/tracking/generator/engine/version` + * `/document/tracking/id` + * `/document/tracking/revision_history[]/legacy_version` + * `/document/tracking/revision_history[]/number` + * `/document/tracking/version` + * `/product_tree/branches[]/name` + * `/product_tree/branches[]/product/name` + * `/product_tree/branches[]/product/product_id` + * `/product_tree/branches[]/product/product_identification_helper/hashes[]/file_hashes[]/algorithm` + * `/product_tree/branches[]/product/product_identification_helper/hashes[]/file_hashes[]/value` + * `/product_tree/branches[]/product/product_identification_helper/hashes[]/filename` + * `/product_tree/branches[]/product/product_identification_helper/model_numbers[]` + * `/product_tree/branches[]/product/product_identification_helper/serial_numbers[]` + * `/product_tree/branches[]/product/product_identification_helper/skus[]` + * `/product_tree/branches[](/branches[])*/name` + * `/product_tree/branches[](/branches[])*/product/name` + * `/product_tree/branches[](/branches[])*/product/product_id` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/hashes[]/file_hashes[]/algorithm` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/hashes[]/file_hashes[]/value` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/hashes[]/filename` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/model_numbers[]` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/serial_numbers[]` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/skus[]` + * `/product_tree/full_product_names[]/name` + * `/product_tree/full_product_names[]/product_id` + * `/product_tree/full_product_names[]/product_identification_helper/hashes[]/file_hashes[]/algorithm` + * `/product_tree/full_product_names[]/product_identification_helper/hashes[]/file_hashes[]/value` + * `/product_tree/full_product_names[]/product_identification_helper/hashes[]/filename` + * `/product_tree/full_product_names[]/product_identification_helper/model_numbers[]` + * `/product_tree/full_product_names[]/product_identification_helper/serial_numbers[]` + * `/product_tree/full_product_names[]/product_identification_helper/skus[]` + * `/product_tree/product_groups[]/group_id` + * `/product_tree/product_groups[]/product_ids[]` + * `/product_tree/relationships[]/full_product_name/name` + * `/product_tree/relationships[]/full_product_name/product_id` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/hashes[]/file_hashes[]/algorithm` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/hashes[]/file_hashes[]/value` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/hashes[]/filename` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/model_numbers[]` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/serial_numbers[]` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/skus[]` + * `/product_tree/relationships[]/product_reference` + * `/product_tree/relationships[]/relates_to_product_reference` + * `/vulnerabilities[]/acknowledgments[]/names[]` + * `/vulnerabilities[]/acknowledgments[]/organization` + * `/vulnerabilities[]/cve` + * `/vulnerabilities[]/cwe/id` + * `/vulnerabilities[]/cwe/name` + * `/vulnerabilities[]/flags[]/group_ids[]` + * `/vulnerabilities[]/flags[]/product_ids[]` + * `/vulnerabilities[]/ids[]/system_name` + * `/vulnerabilities[]/ids[]/text` + * `/vulnerabilities[]/notes[]/audience` + * `/vulnerabilities[]/notes[]/title` + * `/vulnerabilities[]/product_status/first_affected[]` + * `/vulnerabilities[]/product_status/first_fixed[]` + * `/vulnerabilities[]/product_status/fixed[]` + * `/vulnerabilities[]/product_status/known_affected[]` + * `/vulnerabilities[]/product_status/known_not_affected[]` + * `/vulnerabilities[]/product_status/last_affected[]` + * `/vulnerabilities[]/product_status/recommended[]` + * `/vulnerabilities[]/product_status/under_investigation[]` + * `/vulnerabilities[]/remediations[]/group_ids[]` + * `/vulnerabilities[]/remediations[]/product_ids[]` + * `/vulnerabilities[]/scores[]/cvss_v2/vectorString` + * `/vulnerabilities[]/scores[]/cvss_v3/vectorString` + * `/vulnerabilities[]/scores[]/products[]` + * `/vulnerabilities[]/threats[]/group_ids[]` + * `/vulnerabilities[]/threats[]/product_ids[]` + * `/vulnerabilities[]/title` + +* 10 000 for + * `/document/acknowledgments[]/summary` + * `/document/distribution/text` + * `/document/publisher/contact_details` + * `/document/publisher/issuing_authority` + * `/document/references[]/summary` + * `/document/tracking/revision_history[]/summary` + * `/product_tree/branches[]/product/product_identification_helper/cpe` + * `/product_tree/branches[]/product/product_identification_helper/purl` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/cpe` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/purl` + * `/product_tree/full_product_names[]/product_identification_helper/cpe` + * `/product_tree/full_product_names[]/product_identification_helper/purl` + * `/product_tree/product_groups[]/summary` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/cpe` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/purl` + * `/vulnerabilities[]/acknowledgments[]/summary` + * `/vulnerabilities[]/involvements[]/summary` + * `/vulnerabilities[]/references[]/summary` + * `/vulnerabilities[]/remediations[]/entitlements[]` + +* 30 000 for + * `/document/notes[]/text` + * `/vulnerabilities[]/notes[]/text` + +* 250 000 for + * `/vulnerabilities[]/remediations[]/details` + * `/vulnerabilities[]/remediations[]/restart_required/details` + * `/vulnerabilities[]/threats[]/details` + +## C.4 URI length + +A string with format `uri` SHOULD NOT have a length greater than 20000. This applies to: + +* `/document/acknowledgments[]/urls[]` +* `/document/aggregate_severity/namespace` +* `/document/distribution/tlp/url` +* `/document/references[]/url` +* `/document/publisher/namespace` +* `/product_tree/branches[]/product/product_identification_helper/sbom_urls[]` +* `/product_tree/branches[]/product/product_identification_helper/x_generic_uris[]/namespace` +* `/product_tree/branches[]/product/product_identification_helper/x_generic_uris[]/uri` +* `/product_tree/branches[](/branches[])*/product/product_identification_helper/sbom_urls[]` +* `/product_tree/branches[](/branches[])*/product/product_identification_helper/x_generic_uris[]/namespace` +* `/product_tree/branches[](/branches[])*/product/product_identification_helper/x_generic_uris[]/uri` +* `/product_tree/full_product_names[]/product_identification_helper/sbom_urls[]` +* `/product_tree/full_product_names[]/product_identification_helper/x_generic_uris[]/namespace` +* `/product_tree/full_product_names[]/product_identification_helper/x_generic_uris[]/uri` +* `/product_tree/relationships[]/full_product_name/product_identification_helper/sbom_urls[]` +* `/product_tree/relationships[]/full_product_name/product_identification_helper/x_generic_uris[]/namespace` +* `/product_tree/relationships[]/full_product_name/product_identification_helper/x_generic_uris[]/uri` +* `/vulnerabilities[]/acknowledgments[]/urls[]` +* `/vulnerabilities[]/references[]/url` +* `/vulnerabilities[]/remediations[]/url` + +## C.5 Enum + +A string which is an enum has a fixed maximum length given by its longest value. + +> Later versions of CSAF might add, modify or delete possible value which could change the longest value. Therefore, this sizes should not be implemented as fixed limits if forward compatibility is desired. + +It seems to be safe to assume that the length of each value is not greater than 50. This applies to: + +* `/document/csaf_version` (3) +* `/document/distribution/tlp/label` (5) +* `/document/notes[]/category` (16) +* `/document/publisher/category` (11) +* `/document/references[]/category` (8) +* `/document/tracking/status` (7) +* `/product_tree/branches[]/category` (15) +* `/product_tree/branches[](/branches[])*/category` (15) +* `/product_tree/relationships[]/category` (21) +* `/vulnerabilities[]/flags[]/label` (49) +* `/vulnerabilities[]/involvements[]/party` (11) +* `/vulnerabilities[]/involvements[]/status` (17) +* `/vulnerabilities[]/notes[]/category` (16) +* `/vulnerabilities[]/references[]/category` (8) +* `/vulnerabilities[]/remediations[]/category` (14) +* `/vulnerabilities[]/remediations[]/restart_required/category` (20) +* `/vulnerabilities[]/scores[]/cvss_v2/version` (3) +* `/vulnerabilities[]/scores[]/cvss_v2/accessVector` (16) +* `/vulnerabilities[]/scores[]/cvss_v2/accessComplexity` (6) +* `/vulnerabilities[]/scores[]/cvss_v2/authentication` (8) +* `/vulnerabilities[]/scores[]/cvss_v2/confidentialityImpact` (8) +* `/vulnerabilities[]/scores[]/cvss_v2/integrityImpact` (8) +* `/vulnerabilities[]/scores[]/cvss_v2/availabilityImpact` (8) +* `/vulnerabilities[]/scores[]/cvss_v2/exploitability` (16) +* `/vulnerabilities[]/scores[]/cvss_v2/remediationLevel` (13) +* `/vulnerabilities[]/scores[]/cvss_v2/reportConfidence` (14) +* `/vulnerabilities[]/scores[]/cvss_v2/collateralDamagePotential` (11) +* `/vulnerabilities[]/scores[]/cvss_v2/targetDistribution` (11) +* `/vulnerabilities[]/scores[]/cvss_v2/confidentialityRequirement` (11) +* `/vulnerabilities[]/scores[]/cvss_v2/integrityRequirement` (11) +* `/vulnerabilities[]/scores[]/cvss_v2/availabilityRequirement` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/version` (3) +* `/vulnerabilities[]/scores[]/cvss_v3/attackVector` (16) +* `/vulnerabilities[]/scores[]/cvss_v3/attackComplexity` (4) +* `/vulnerabilities[]/scores[]/cvss_v3/privilegesRequired` (4) +* `/vulnerabilities[]/scores[]/cvss_v3/userInteraction` (8) +* `/vulnerabilities[]/scores[]/cvss_v3/scope` (9) +* `/vulnerabilities[]/scores[]/cvss_v3/confidentialityImpact` (4) +* `/vulnerabilities[]/scores[]/cvss_v3/integrityImpact` (4) +* `/vulnerabilities[]/scores[]/cvss_v3/availabilityImpact` (4) +* `/vulnerabilities[]/scores[]/cvss_v3/baseSeverity` (8) +* `/vulnerabilities[]/scores[]/cvss_v3/exploitCodeMaturity` (16) +* `/vulnerabilities[]/scores[]/cvss_v3/remediationLevel` (13) +* `/vulnerabilities[]/scores[]/cvss_v3/reportConfidence` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/temporalSeverity` (8) +* `/vulnerabilities[]/scores[]/cvss_v3/confidentialityRequirement` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/integrityRequirement` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/availabilityRequirement` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/modifiedAttackVector` (16) +* `/vulnerabilities[]/scores[]/cvss_v3/modifiedAttackComplexity` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/modifiedPrivilegesRequired` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/modifiedUserInteraction` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/modifiedScope` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/modifiedConfidentialityImpact` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/modifiedIntegrityImpact` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/modifiedAvailabilityImpact` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/environmentalSeverity` (8) +* `/vulnerabilities[]/threats[]/category` (14) + +## C.6 Date + +The maximum length of strings representing a temporal value is given by the format specifier. This applies to: + +* `/document/tracking/current_release_date` +* `/document/tracking/generator/date` +* `/document/tracking/initial_release_date` +* `/document/tracking/revision_history[]/date` +* `/vulnerabilities[]/discovery_date` +* `/vulnerabilities[]/flags[]/date` +* `/vulnerabilities[]/release_date` +* `/vulnerabilities[]/involvements[]/date` +* `/vulnerabilities[]/remediations[]/date` +* `/vulnerabilities[]/threats[]/date` diff --git a/csaf_2.1/submit/README.md b/csaf_2.1/submit/README.md new file mode 100644 index 000000000..8bcd74eae --- /dev/null +++ b/csaf_2.1/submit/README.md @@ -0,0 +1,3 @@ +# Submission request to advance CSAF v2.1 to an International Standard + +TBD diff --git a/csaf_2.1/test/aggregator_schema/run_tests.sh b/csaf_2.1/test/aggregator_schema/run_tests.sh new file mode 100755 index 000000000..01581a98c --- /dev/null +++ b/csaf_2.1/test/aggregator_schema/run_tests.sh @@ -0,0 +1,45 @@ +#!/bin/bash + +ORIG_SCHEMA=csaf_2.0/json_schema/aggregator_json_schema.json +AGGREGATOR_STRICT_SCHEMA=aggregator_strict_schema.json +CSAF_STRICT_SCHEMA=csaf_strict_schema.json +PROVIDER_STRICT_SCHEMA=provider_strict_schema.json +VALIDATOR=csaf_2.0/test/validator.py +STRICT_GENERATOR=csaf_2.0/test/generate_strict_schema.py +TESTPATH=csaf_2.0/examples/aggregator/*.json + +FAIL=0 + +# go to root of git repository +cd `dirname $0`/../../.. + +validate() { + printf "%s" "Testing file $1 against schema ${SCHEMA} ... " + if python3 ${VALIDATOR} ${SCHEMA} $1 ${CSAF_STRICT_SCHEMA} ${PROVIDER_STRICT_SCHEMA}; then + printf "%s\n" SUCCESS + else + printf "%s\n" FAILED + FAIL=1 + fi + +} + + +test_all() { + for i in ${TESTPATH} + do + validate $i + done +} + +SCHEMA=${ORIG_SCHEMA} +test_all + +printf "%s" "Generating strict schema ... " +python3 "${STRICT_GENERATOR}" "${ORIG_SCHEMA}" > "${AGGREGATOR_STRICT_SCHEMA}" +printf "%s\n" "done" + +SCHEMA=${AGGREGATOR_STRICT_SCHEMA} +test_all + +exit ${FAIL} diff --git a/csaf_2.1/test/cpe/run_tests.sh b/csaf_2.1/test/cpe/run_tests.sh new file mode 100755 index 000000000..83233ec12 --- /dev/null +++ b/csaf_2.1/test/cpe/run_tests.sh @@ -0,0 +1,61 @@ +#!/bin/bash + +SCHEMA=csaf_2.0/json_schema/csaf_json_schema.json +VALIDATOR=csaf_2.0/test/cpe/test-regex.js +CPE_BASE_URL=https://nvd.nist.gov/feeds/xml/cpe/dictionary/ +CPE_2_3=official-cpe-dictionary_v2.3 +CPE_2_2=official-cpe-dictionary_v2.2 + +FAIL=0 + +# go to root of git repository +cd "$(dirname "$0")"/../../.. || exit + +get_dictionary() { + rm "${2}"* + wget "$1$2" + gunzip -f "$2" +} + +prepare_23_dictionary() { + # Get CPE 2.3 fields + # Correctly decode special characters + grep '$//' \ + | sed -e 's/\\&/\\\&/g' \ + | sed -e 's/\\"/\\"/g' \ + > "$CPE".txt +} + +prepare_22_dictionary() { + # Get CPE 2.2 fields + # Correctly decode special characters + grep '$//' > "$CPE".txt +} + +validate() { + printf "Testing file %s against cpe regex from %s ... \n" "$1" "$SCHEMA" + if node "$VALIDATOR" "$SCHEMA" "$1"; then + printf "SUCCESS\n" + else + printf "FAILED\n" + FAIL=1 + fi + +} + +echo -n "Test CPE 2.3 ... " +CPE=$CPE_2_3 +get_dictionary $CPE_BASE_URL ${CPE}.xml.gz +prepare_23_dictionary $CPE +validate $CPE.txt +printf "done\n" + +echo -n "Test CPE 2.2 ... " +CPE=$CPE_2_2 +get_dictionary $CPE_BASE_URL ${CPE}.xml.gz +prepare_22_dictionary $CPE +validate $CPE.txt +printf "done\n" + + +exit $FAIL diff --git a/csaf_2.1/test/cpe/test-regex.js b/csaf_2.1/test/cpe/test-regex.js new file mode 100644 index 000000000..567ba08e4 --- /dev/null +++ b/csaf_2.1/test/cpe/test-regex.js @@ -0,0 +1,26 @@ +const { exit } = require('process') +const fs = require('fs') + +const args = process.argv.slice(2); +const obj = JSON.parse(fs.readFileSync(args[0], 'utf8')) + +const pattern = obj.$defs.full_product_name_t.properties.product_identification_helper.properties.cpe.pattern +const r = new RegExp(pattern) + +console.log('Current regex to test:', '\n', pattern) + +const cpeStr = fs.readFileSync(args[1], 'utf8').split('\n') + +let failed = false + +cpeStr.forEach(element => { + if (element.length > 0) { + const result = (r.exec(element) != null) + failed = failed | !result + if (!result) { + console.log(result, '\t', element) + } + } +}); + +exit(failed) diff --git a/csaf_2.1/test/csaf_schema/run_tests.sh b/csaf_2.1/test/csaf_schema/run_tests.sh new file mode 100755 index 000000000..a1501cc29 --- /dev/null +++ b/csaf_2.1/test/csaf_schema/run_tests.sh @@ -0,0 +1,43 @@ +#!/bin/bash + +ORIG_SCHEMA=csaf_2.0/json_schema/csaf_json_schema.json +STRICT_SCHEMA=csaf_strict_schema.json +VALIDATOR=csaf_2.0/test/validator.py +STRICT_GENERATOR=csaf_2.0/test/generate_strict_schema.py +TESTPATH=csaf_2.0/examples/csaf/$1/*.json + +FAIL=0 + +# go to root of git repository +cd `dirname $0`/../../.. + +validate() { + printf "%s" "Testing file $1 against schema ${SCHEMA} ... " + if python3 ${VALIDATOR} ${SCHEMA} $1; then + printf "%s\n" SUCCESS + else + printf "%s\n" FAILED + FAIL=1 + fi + +} + +test_all() { + for i in ${TESTPATH} + do + validate $i + done +} + +SCHEMA=${ORIG_SCHEMA} +test_all + + +printf "%s" "Generating strict schema ... " +python3 "${STRICT_GENERATOR}" "${ORIG_SCHEMA}" > "${STRICT_SCHEMA}" +printf "%s\n" "done" + +SCHEMA=${STRICT_SCHEMA} +test_all + +exit ${FAIL} diff --git a/csaf_2.1/test/filenames/data/invalid/OASIS_CSAF_TC-CSAF_2.0-2021-5-1-01.json b/csaf_2.1/test/filenames/data/invalid/OASIS_CSAF_TC-CSAF_2.0-2021-5-1-01.json new file mode 100644 index 000000000..3ef602cb2 --- /dev/null +++ b/csaf_2.1/test/filenames/data/invalid/OASIS_CSAF_TC-CSAF_2.0-2021-5-1-01.json @@ -0,0 +1,26 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Filename (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-5-1-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} diff --git a/csaf_2.1/test/filenames/data/invalid/oasis-open_csaf_tc-csaf_20-2021-5-1-02.json b/csaf_2.1/test/filenames/data/invalid/oasis-open_csaf_tc-csaf_20-2021-5-1-02.json new file mode 100644 index 000000000..0663bb26c --- /dev/null +++ b/csaf_2.1/test/filenames/data/invalid/oasis-open_csaf_tc-csaf_20-2021-5-1-02.json @@ -0,0 +1,26 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Filename (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-5-1-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} diff --git a/csaf_2.1/test/filenames/data/invalid/oasis____csaf_tc-csaf_2_0-2021-5-1-03.json b/csaf_2.1/test/filenames/data/invalid/oasis____csaf_tc-csaf_2_0-2021-5-1-03.json new file mode 100644 index 000000000..02b1ebb07 --- /dev/null +++ b/csaf_2.1/test/filenames/data/invalid/oasis____csaf_tc-csaf_2_0-2021-5-1-03.json @@ -0,0 +1,26 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Filename (failing example 3)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS: #/CSAF_TC-CSAF_2.0-2021-5-1-03", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} diff --git a/csaf_2.1/test/filenames/data/valid/oasis_csaf_tc-csaf_2_0-2021-5-1-11.json b/csaf_2.1/test/filenames/data/valid/oasis_csaf_tc-csaf_2_0-2021-5-1-11.json new file mode 100644 index 000000000..1bf912f2e --- /dev/null +++ b/csaf_2.1/test/filenames/data/valid/oasis_csaf_tc-csaf_2_0-2021-5-1-11.json @@ -0,0 +1,26 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Filename (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-5-1-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/filenames/data/valid/oasis_csaf_tc-csaf_2_0-2021-5-1-12.json b/csaf_2.1/test/filenames/data/valid/oasis_csaf_tc-csaf_2_0-2021-5-1-12.json new file mode 100644 index 000000000..d24bf04b6 --- /dev/null +++ b/csaf_2.1/test/filenames/data/valid/oasis_csaf_tc-csaf_2_0-2021-5-1-12.json @@ -0,0 +1,26 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Filename (valid example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-5-1-12", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/filenames/data/valid/oasis_csaf_tc-csaf_2_0-2021-5-1-13.json b/csaf_2.1/test/filenames/data/valid/oasis_csaf_tc-csaf_2_0-2021-5-1-13.json new file mode 100644 index 000000000..632fa3f96 --- /dev/null +++ b/csaf_2.1/test/filenames/data/valid/oasis_csaf_tc-csaf_2_0-2021-5-1-13.json @@ -0,0 +1,26 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Filename (valid example 3)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS: #/CSAF_TC-CSAF_2.0-2021-5-1-13", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/filenames/run_invalid_tests.sh b/csaf_2.1/test/filenames/run_invalid_tests.sh new file mode 100755 index 000000000..4954c1004 --- /dev/null +++ b/csaf_2.1/test/filenames/run_invalid_tests.sh @@ -0,0 +1,24 @@ +#!/bin/bash + +TESTPATH=$* + +FAIL=0 + +# go to root of git repository +cd `dirname $0`/../../.. + +check() { + printf "%s" "Testing that filename of $1 is invalid ... " + paikalta --labels FAILED,SUCCESS $1 && FAIL=1 +} + +test_all() { + for i in ${TESTPATH} + do + check $i + done +} + +test_all + +exit ${FAIL} diff --git a/csaf_2.1/test/filenames/run_tests.sh b/csaf_2.1/test/filenames/run_tests.sh new file mode 100755 index 000000000..a6f089d71 --- /dev/null +++ b/csaf_2.1/test/filenames/run_tests.sh @@ -0,0 +1,24 @@ +#!/bin/bash + +TESTPATH=$* + +FAIL=0 + +# go to root of git repository +cd `dirname $0`/../../.. + +check() { + printf "%s" "Testing filename of $1 ... " + paikalta --labels SUCCESS,FAILED $1 || FAIL=1 +} + +test_all() { + for i in ${TESTPATH} + do + check $i + done +} + +test_all + +exit ${FAIL} diff --git a/csaf_2.1/test/generate_strict_schema.py b/csaf_2.1/test/generate_strict_schema.py new file mode 100644 index 000000000..8b07da9fe --- /dev/null +++ b/csaf_2.1/test/generate_strict_schema.py @@ -0,0 +1,23 @@ +import jsonschema +import simplejson as json +import sys +import jsonpath_rw +from pprint import pprint + +if len(sys.argv)!=2: + print("%s " % (sys.argv[0])) + sys.exit(1) + + +json_schema = sys.argv[1] +with open(json_schema, 'r') as f: + schema_data = f.read() + schema = json.loads(schema_data) + +for i in jsonpath_rw.parse("$..* where properties").find(schema): + i.value['additionalProperties'] = False + +# Don't forget to add it at the root level +schema['additionalProperties'] = False + +print(json.dumps(schema, sort_keys=True, indent=2)) diff --git a/csaf_2.1/test/provider_schema/run_tests.sh b/csaf_2.1/test/provider_schema/run_tests.sh new file mode 100755 index 000000000..82bdf5ee5 --- /dev/null +++ b/csaf_2.1/test/provider_schema/run_tests.sh @@ -0,0 +1,44 @@ +#!/bin/bash + +ORIG_SCHEMA=csaf_2.0/json_schema/provider_json_schema.json +CSAF_STRICT_SCHEMA=csaf_strict_schema.json +PROVIDER_STRICT_SCHEMA=provider_strict_schema.json +VALIDATOR=csaf_2.0/test/validator.py +STRICT_GENERATOR=csaf_2.0/test/generate_strict_schema.py +TESTPATH=csaf_2.0/examples/provider-metadata/*.json + +FAIL=0 + +# go to root of git repository +cd `dirname $0`/../../.. + +validate() { + printf "%s" "Testing file $1 against schema ${SCHEMA} ... " + if python3 ${VALIDATOR} ${SCHEMA} $1 ${CSAF_STRICT_SCHEMA}; then + printf "%s\n" SUCCESS + else + printf "%s\n" FAILED + FAIL=1 + fi + +} + + +test_all() { + for i in ${TESTPATH} + do + validate $i + done +} + +SCHEMA=${ORIG_SCHEMA} +test_all + +printf "%s" "Generating strict schema ... " +python3 "${STRICT_GENERATOR}" "${ORIG_SCHEMA}" > "${PROVIDER_STRICT_SCHEMA}" +printf "%s\n" "done" + +SCHEMA=${PROVIDER_STRICT_SCHEMA} +test_all + +exit ${FAIL} diff --git a/csaf_2.1/test/validator.py b/csaf_2.1/test/validator.py new file mode 100644 index 000000000..1001d9220 --- /dev/null +++ b/csaf_2.1/test/validator.py @@ -0,0 +1,34 @@ +import jsonschema +from jsonschema.validators import Draft202012Validator, RefResolver +import simplejson as json +import sys + +if len(sys.argv) < 3: + print(" [ [.. ]]") + sys.exit(1) + + +json_schema = sys.argv[1] +json_input = sys.argv[2] +json_referenced_schemas = sys.argv[3:] + +with open(json_schema, 'r') as f: + schema_data = f.read() + schema = json.loads(schema_data) + +schema_store = {schema['$id']: schema} + +with open(json_input, 'r') as f: + input_data = f.read() + input_obj = json.loads(input_data) + +if len(json_referenced_schemas) > 0: + for i in json_referenced_schemas: + with open(i, 'r') as f: + current_ref_schema_data = f.read() + current_ref_schema = json.loads(current_ref_schema_data) + schema_store[current_ref_schema['$id']] = current_ref_schema + +resolver = RefResolver.from_schema(schema_store[list(schema_store)[0]], store=schema_store) +validator = Draft202012Validator(schema, resolver, Draft202012Validator.FORMAT_CHECKER) +validator.validate(input_obj) diff --git a/csaf_2.1/test/validator/check_testcases.sh b/csaf_2.1/test/validator/check_testcases.sh new file mode 100755 index 000000000..68a5b909e --- /dev/null +++ b/csaf_2.1/test/validator/check_testcases.sh @@ -0,0 +1,55 @@ +#!/bin/bash + +SCHEMA=csaf_2.0/test/validator/testcases_json_schema.json +VALIDATOR=csaf_2.0/test/validator.py +TESTPATH=csaf_2.0/test/validator/data/ +TESTFILE=testcases.json + +FAIL=0 +DIRFILES="" +TESTFILES="" + +# go to root of git repository +cd `dirname $0`/../../.. + +validate() { + printf "%s" "Testing file $1 against schema ${SCHEMA} ... " + if python3 $VALIDATOR $SCHEMA $1; then + printf "%s\n" SUCCESS + else + printf "%s\n" FAILED + FAIL=1 + fi + +} + +collect_dir_files() { + printf "%s\n" "Collect list of files in $1 ... " + cd $1 + DIRFILES=$(ls -1 */*.json | sort) +} + +collect_test_files() { + printf "%s\n" "Collect list of files in $1 ..." + NEGATIVE=$(jq '.tests[].failures[].name' $1 -r) + POSITIVE=$(jq '.tests[].valid[]?.name' $1 -r) + TESTFILES=$(echo -e "${NEGATIVE}\n${POSITIVE}" | sort) +} + +check_files_exist() { + printf "%s" "Testing files in ${TESTPATH} and ${TESTFILE} are the same... " + if diff -b <(echo "$1") <(echo "$2"); then + printf "%s\n" SUCCESS + else + printf "%s\n" FAILED + FAIL=1 + fi +} + +validate "${TESTPATH}${TESTFILE}" +collect_dir_files ${TESTPATH} +collect_test_files "${TESTFILE}" +check_files_exist "${DIRFILES}" "${TESTFILES}" + + +exit ${FAIL} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-01.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-01.json new file mode 100644 index 000000000..2a4e4a2a8 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-01.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Use of CVSS v2 as the only Scoring System (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-01-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v2": { + "version": "2.0", + "vectorString": "AV:N/AC:L/Au:N/C:C/I:C/A:C", + "baseScore": 10 + } + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-02.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-02.json new file mode 100644 index 000000000..eb6d45517 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-02.json @@ -0,0 +1,84 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Use of CVSS v2 as the only Scoring System (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-01-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v2": { + "version": "2.0", + "vectorString": "AV:N/AC:L/Au:S/C:P/I:P/A:N", + "baseScore": 5.5 + } + } + ] + }, + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v2": { + "version": "2.0", + "vectorString": "AV:N/AC:L/Au:N/C:C/I:C/A:C", + "baseScore": 10 + }, + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H", + "baseScore": 10, + "baseSeverity": "CRITICAL" + } + } + ] + }, + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v2": { + "version": "2.0", + "vectorString": "AV:N/AC:M/Au:N/C:P/I:N/A:N", + "baseScore": 4.3 + } + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-11.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-11.json new file mode 100644 index 000000000..e82269126 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-11.json @@ -0,0 +1,56 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Use of CVSS v2 as the only Scoring System (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-01-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v2": { + "version": "2.0", + "vectorString": "AV:N/AC:L/Au:N/C:C/I:C/A:C", + "baseScore": 10 + }, + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H", + "baseScore": 10, + "baseSeverity": "CRITICAL" + } + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-12.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-12.json new file mode 100644 index 000000000..70b9603bd --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-12.json @@ -0,0 +1,96 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Use of CVSS v2 as the only Scoring System (valid example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-01-12", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v2": { + "version": "2.0", + "vectorString": "AV:N/AC:L/Au:S/C:P/I:P/A:N", + "baseScore": 5.5 + }, + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:C/C:L/I:L/A:N", + "baseScore": 6.4, + "baseSeverity": "MEDIUM" + } + } + ] + }, + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v2": { + "version": "2.0", + "vectorString": "AV:N/AC:L/Au:N/C:C/I:C/A:C", + "baseScore": 10 + }, + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H", + "baseScore": 10, + "baseSeverity": "CRITICAL" + } + } + ] + }, + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v2": { + "version": "2.0", + "vectorString": "AV:N/AC:M/Au:N/C:P/I:N/A:N", + "baseScore": 4.3 + }, + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:H/PR:N/UI:R/S:U/C:L/I:N/A:N", + "baseScore": 3.1, + "baseSeverity": "LOW" + } + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-01.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-01.json new file mode 100644 index 000000000..e1ad84c31 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-01.json @@ -0,0 +1,51 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Use of CVSS v3.0 (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-02-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.0", + "vectorString": "CVSS:3.0/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 6.5, + "baseSeverity": "MEDIUM" + } + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-02.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-02.json new file mode 100644 index 000000000..56ca1a261 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-02.json @@ -0,0 +1,81 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Use of CVSS v3.0 (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-02-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.0", + "vectorString": "CVSS:3.0/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 6.5, + "baseSeverity": "MEDIUM" + } + } + ] + }, + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:N/UI:R/S:U/C:N/I:H/A:H", + "baseScore": 7.1, + "baseSeverity": "HIGH" + } + } + ] + }, + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.0", + "vectorString": "CVSS:3.0/AV:P/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 6.1, + "baseSeverity": "MEDIUM" + } + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-11.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-11.json new file mode 100644 index 000000000..a63bc0d8a --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-11.json @@ -0,0 +1,51 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Use of CVSS v3.0 (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-02-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 6.5, + "baseSeverity": "MEDIUM" + } + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-12.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-12.json new file mode 100644 index 000000000..a4cec8122 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-12.json @@ -0,0 +1,81 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Use of CVSS v3.0 (valid example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-02-12", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 6.5, + "baseSeverity": "MEDIUM" + } + } + ] + }, + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:N/UI:R/S:U/C:N/I:H/A:H", + "baseScore": 7.1, + "baseSeverity": "HIGH" + } + } + ] + }, + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:P/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 6.1, + "baseSeverity": "MEDIUM" + } + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-01.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-01.json new file mode 100644 index 000000000..04053ff75 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-01.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Missing CVE (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-03-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "title": "BlueKeep" + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-02.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-02.json new file mode 100644 index 000000000..98d2f2c14 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-02.json @@ -0,0 +1,38 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Missing CVE (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-03-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "title": "BlueKeep" + }, + { + "cve": "CVE-2014-0160", + "title": "Heartbleed" + }, + { + "title": "EternalBlue" + } + ] +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-11.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-11.json new file mode 100644 index 000000000..24c6a7dc6 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-11.json @@ -0,0 +1,32 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Missing CVE (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-03-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "cve": "CVE-2019-0708", + "title": "BlueKeep" + } + ] +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-12.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-12.json new file mode 100644 index 000000000..788829640 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-12.json @@ -0,0 +1,40 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Missing CVE (valid example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-03-12", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "cve": "CVE-2019-0708", + "title": "BlueKeep" + }, + { + "cve": "CVE-2014-0160", + "title": "Heartbleed" + }, + { + "cve": "CVE-2017-0144", + "title": "EternalBlue" + } + ] +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-01.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-01.json new file mode 100644 index 000000000..f2b87fe39 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-01.json @@ -0,0 +1,32 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Missing CWE (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-04-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "cve": "CVE-2019-0708", + "title": "BlueKeep" + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-02.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-02.json new file mode 100644 index 000000000..b9d381cb3 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-02.json @@ -0,0 +1,44 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Missing CWE (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-04-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "cve": "CVE-2019-0708", + "title": "BlueKeep" + }, + { + "cve": "CVE-2014-0160", + "cwe": { + "id": "CWE-119", + "name": "Improper Restriction of Operations within the Bounds of a Memory Buffer" + }, + "title": "Heartbleed" + }, + { + "cve": "CVE-2017-0144", + "title": "EternalBlue" + } + ] +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-11.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-11.json new file mode 100644 index 000000000..47f683c34 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-11.json @@ -0,0 +1,36 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Missing CWE (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-04-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "cve": "CVE-2019-0708", + "cwe": { + "id": "CWE-416", + "name": "Use After Free" + }, + "title": "BlueKeep" + } + ] +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-12.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-12.json new file mode 100644 index 000000000..2e771f3a3 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-12.json @@ -0,0 +1,52 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Missing CWE (valid example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-04-12", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "cve": "CVE-2019-0708", + "cwe": { + "id": "CWE-416", + "name": "Use After Free" + }, + "title": "BlueKeep" + }, + { + "cve": "CVE-2014-0160", + "cwe": { + "id": "CWE-119", + "name": "Improper Restriction of Operations within the Bounds of a Memory Buffer" + }, + "title": "Heartbleed" + }, + { + "cve": "CVE-2017-0144", + "cwe": { + "id": "CWE-20", + "name": "Improper Input Validation" + }, + "title": "EternalBlue" + } + ] +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-05-01.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-05-01.json new file mode 100644 index 000000000..a72af3ee6 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-05-01.json @@ -0,0 +1,47 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Use of Short Hash (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-05-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "hashes": [ + { + "file_hashes": [ + { + "algorithm": "md4", + "value": "3202b50e2e5b2fcd75e284c3d9d5f8d6" + } + ], + "filename": "product_a.so" + } + ] + } + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-06-01.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-06-01.json new file mode 100644 index 000000000..c2f6765ba --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-06-01.json @@ -0,0 +1,32 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "references": [ + { + "summary": "A URL that does not resolve with HTTP status code in the interval between (including) 200 and (excluding) 400.", + "url": "https://example.invalid" + } + ], + "title": "Informative test: Use of non-self referencing URLs Failing to Resolve (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-06-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-06-02.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-06-02.json new file mode 100644 index 000000000..4fc958233 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-06-02.json @@ -0,0 +1,34 @@ +{ + "document": { + "acknowledgments": [ + { + "summary": "A URL that does resolve with HTTP status code 400.", + "urls": [ + "https://github.com/oasis-tcs/csaf/not-available" + ] + } + ], + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Use of non-self referencing URLs Failing to Resolve (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-06-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-06-11.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-06-11.json new file mode 100644 index 000000000..1ae07110d --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-06-11.json @@ -0,0 +1,32 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "references": [ + { + "summary": "A URL that does resolve with HTTP status code in the interval between (including) 200 and (excluding) 400.", + "url": "https://example.net" + } + ], + "title": "Informative test: Use of non-self referencing URLs Failing to Resolve (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-06-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-07-01.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-07-01.json new file mode 100644 index 000000000..725de7cc8 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-07-01.json @@ -0,0 +1,33 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "references": [ + { + "category": "self", + "summary": "A URL that does not resolve with HTTP status code in the interval between (including) 200 and (excluding) 400.", + "url": "https://example.invalid" + } + ], + "title": "Informative test: Use of self referencing URLs Failing to Resolve (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-07-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-07-11.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-07-11.json new file mode 100644 index 000000000..9f4e79cd5 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-07-11.json @@ -0,0 +1,33 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "references": [ + { + "category": "self", + "summary": "A URL that does resolve with HTTP status code in the interval between (including) 200 and (excluding) 400.", + "url": "https://example.net" + } + ], + "title": "Informative test: Use of self referencing URLs Failing to Resolve (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-07-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-08-01.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-08-01.json new file mode 100644 index 000000000..8531f0bcd --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-08-01.json @@ -0,0 +1,33 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "en", + "notes": [ + { + "category": "summary", + "text": "Secruity researchers found multiple vulnerabilities in XYZ." + } + ], + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Spell check (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-08-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-08-11.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-08-11.json new file mode 100644 index 000000000..7b4df5136 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-08-11.json @@ -0,0 +1,33 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "en", + "notes": [ + { + "category": "summary", + "text": "Security researchers found multiple vulnerabilities in XYZ." + } + ], + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Spell check (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-08-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-01.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-01.json new file mode 100644 index 000000000..b1f1dd0ca --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-01.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Branch Categories (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-09-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "patch_level", + "name": "91", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A Update 91" + } + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-02.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-02.json new file mode 100644 index 000000000..5f3b0c8cc --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-02.json @@ -0,0 +1,58 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Branch Categories (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-09-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "product_family", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "91", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A 91" + } + }, + { + "category": "product_version", + "name": "92", + "product": { + "product_id": "CSAFPID-9080701", + "name": "Example Company Product A 92" + } + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-03.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-03.json new file mode 100644 index 000000000..340b41c31 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-03.json @@ -0,0 +1,58 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Branch Categories (failing example 3)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-09-03", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "product_family", + "name": "Example Company", + "branches": [ + { + "category": "product_version", + "name": "91", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A 91" + } + }, + { + "category": "product_name", + "name": "Product B", + "product": { + "product_id": "CSAFPID-9080701", + "name": "Example Company Product B 91" + } + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-04.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-04.json new file mode 100644 index 000000000..0c4a6a6da --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-04.json @@ -0,0 +1,58 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Branch Categories (failing example 4)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-09-04", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_version", + "name": "91", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A 91" + } + }, + { + "category": "product_name", + "name": "Product B", + "product": { + "product_id": "CSAFPID-9080701", + "name": "Example Company Product B 91" + } + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-05.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-05.json new file mode 100644 index 000000000..40115ef49 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-05.json @@ -0,0 +1,100 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Branch Categories (failing example 5)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-09-05", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "host_name", + "name": "unknown-host", + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_version", + "name": "91", + "branches": [ + { + "category": "language", + "name": "XYZ", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "architecture", + "name": "x86", + "branches": [ + { + "category": "service_pack", + "name": "1", + "branches": [ + { + "category": "patch_level", + "name": "104", + "product": { + "product_id": "CSAFPID-9080700", + "name": "unknown-host Example Company XYZ Product A x86 Version 91 SP1 Update 104" + } + } + ] + } + ] + }, + { + "category": "architecture", + "name": "amd64", + "branches": [ + { + "category": "service_pack", + "name": "1", + "branches": [ + { + "category": "patch_level", + "name": "104", + "product": { + "product_id": "CSAFPID-9080701", + "name": "unknown-host Example Company XYZ Product A amd64 Version 91 SP1 Update 104" + } + } + ] + } + ] + } + ] + } + ] + } + ] + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-06.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-06.json new file mode 100644 index 000000000..d8d3e626c --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-06.json @@ -0,0 +1,70 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Branch Categories (failing example 6)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-09-06", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "host_name", + "name": "unknown-hostname", + "branches": [ + { + "category": "architecture", + "name": "x86", + "branches": [ + { + "category": "language", + "name": "XYZ", + "product": { + "product_id": "CSAFPID-9080700", + "name": "unknown-hostname x86 XYZ" + } + } + ] + }, + { + "category": "architecture", + "name": "amd64", + "branches": [ + { + "category": "service_pack", + "name": "1", + "branches": [ + { + "category": "patch_level", + "name": "104", + "product": { + "product_id": "CSAFPID-9080701", + "name": "unknown-hostname amd64 SP1 Update 104" + } + } + ] + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-11.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-11.json new file mode 100644 index 000000000..b7d21c4cc --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-11.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Branch Categories (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-09-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "91", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A 91" + } + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-12.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-12.json new file mode 100644 index 000000000..a7f310fa7 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-12.json @@ -0,0 +1,64 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Branch Categories (valid example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-09-12", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_family", + "name": "ABC Products", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "91", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company ABC Products Product A 91" + } + }, + { + "category": "product_version", + "name": "92", + "product": { + "product_id": "CSAFPID-9080701", + "name": "Example Company ABC Products Product A 92" + } + } + ] + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-13.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-13.json new file mode 100644 index 000000000..4426ee406 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-13.json @@ -0,0 +1,70 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Branch Categories (valid example 3)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-09-13", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_family", + "name": "ABC Products", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "91", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company ABC Products Product A 91" + } + } + ] + }, + { + "category": "product_name", + "name": "Product B", + "branches": [ + { + "category": "product_version", + "name": "91", + "product": { + "product_id": "CSAFPID-9080701", + "name": "Example Company ABC Products Product B 91" + } + } + ] + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-14.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-14.json new file mode 100644 index 000000000..c9c818d49 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-14.json @@ -0,0 +1,64 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Branch Categories (valid example 4)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-09-14", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "91", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A 91" + } + } + ] + }, + { + "category": "product_name", + "name": "Product B", + "branches": [ + { + "category": "product_version", + "name": "91", + "product": { + "product_id": "CSAFPID-9080701", + "name": "Example Company Product B 91" + } + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-15.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-15.json new file mode 100644 index 000000000..dab25e844 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-15.json @@ -0,0 +1,112 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Branch Categories (valid example 5)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-09-15", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "host_name", + "name": "unknown-host", + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_family", + "name": "ABC Products", + "branches": [ + { + "category": "language", + "name": "XYZ", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "architecture", + "name": "x86", + "branches": [ + { + "category": "product_version", + "name": "91", + "branches": [ + { + "category": "service_pack", + "name": "1", + "branches": [ + { + "category": "patch_level", + "name": "104", + "product": { + "product_id": "CSAFPID-9080700", + "name": "unknown-host Example Company ABC Products XYZ Product A x86 Version 91 SP1 Update 104" + } + } + ] + } + ] + } + ] + }, + { + "category": "architecture", + "name": "amd64", + "branches": [ + { + "category": "product_version", + "name": "91", + "branches": [ + { + "category": "service_pack", + "name": "1", + "branches": [ + { + "category": "patch_level", + "name": "104", + "product": { + "product_id": "CSAFPID-9080701", + "name": "unknown-host Example Company ABC Products XYZ Product A amd64 Version 91 SP1 Update 104" + } + } + ] + } + ] + } + ] + } + ] + } + ] + } + ] + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-10-01.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-10-01.json new file mode 100644 index 000000000..27bafa1e1 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-10-01.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Usage of Product Version Range (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-10-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version_range", + "name": "vers:npm/>=2.2.0|<2.3.0", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A between 2.2.0 and 2.3.0" + } + } + ] + } + ] + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-10-11.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-10-11.json new file mode 100644 index 000000000..f8112db80 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-10-11.json @@ -0,0 +1,66 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Usage of Product Version Range (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-10-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "2.2.0", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A 2.2.0" + } + }, + { + "category": "product_version", + "name": "2.2.1", + "product": { + "product_id": "CSAFPID-9080701", + "name": "Example Company Product A 2.2.1" + } + }, + { + "category": "product_version", + "name": "2.2.2", + "product": { + "product_id": "CSAFPID-9080702", + "name": "Example Company Product A 2.2.2" + } + } + ] + } + ] + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-11-01.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-11-01.json new file mode 100644 index 000000000..2627334f4 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-11-01.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Usage of V as Version Indicator (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-11-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "v4.2", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A 4.2" + } + } + ] + } + ] + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-11-11.json b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-11-11.json new file mode 100644 index 000000000..860700a54 --- /dev/null +++ b/csaf_2.1/test/validator/data/informative/oasis_csaf_tc-csaf_2_0-2021-6-3-11-11.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Informative test: Usage of V as Version Indicator (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-3-11-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "4.2", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A 4.2" + } + } + ] + } + ] + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-01-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-01-01.json new file mode 100644 index 000000000..7ffd5b841 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-01-01.json @@ -0,0 +1,37 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Missing Definition of Product ID (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-01-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "product_groups": [ + { + "group_id": "CSAFGID-1020300", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-02-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-02-01.json new file mode 100644 index 000000000..1ba7124cc --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-02-01.json @@ -0,0 +1,38 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Multiple Definition of Product ID (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-02-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080700", + "name": "Product B" + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-03-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-03-01.json new file mode 100644 index 000000000..a66be0822 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-03-01.json @@ -0,0 +1,45 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Circular Definition of Product ID (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-03-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ], + "relationships": [ + { + "category": "installed_on", + "full_product_name": { + "name": "Product B", + "product_id": "CSAFPID-9080701" + }, + "product_reference": "CSAFPID-9080700", + "relates_to_product_reference": "CSAFPID-9080701" + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-04-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-04-01.json new file mode 100644 index 000000000..4537a8bd2 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-04-01.json @@ -0,0 +1,47 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Missing Definition of Product Group ID (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-04-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "threats": [ + { + "category": "exploit_status", + "details": "Reliable exploits integrated in Metasploit.", + "group_ids": [ + "CSAFGID-1020301" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-05-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-05-01.json new file mode 100644 index 000000000..e8ed7c57c --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-05-01.json @@ -0,0 +1,58 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Multiple Definition of Product Group ID (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-05-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ], + "product_groups": [ + { + "group_id": "CSAFGID-1020300", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + }, + { + "group_id": "CSAFGID-1020300", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080702" + ] + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-01.json new file mode 100644 index 000000000..8dcf01e54 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-01.json @@ -0,0 +1,46 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Contradicting Product Status (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-06-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "known_affected": [ + "CSAFPID-9080700" + ], + "known_not_affected": [ + "CSAFPID-9080700" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-02.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-02.json new file mode 100644 index 000000000..8fe7d9f63 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-02.json @@ -0,0 +1,46 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Contradicting Product Status (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-06-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "first_affected": [ + "CSAFPID-9080700" + ], + "known_not_affected": [ + "CSAFPID-9080700" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-03.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-03.json new file mode 100644 index 000000000..fc37213c8 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-03.json @@ -0,0 +1,46 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Contradicting Product Status (failing example 3)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-06-03", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700" + ], + "last_affected": [ + "CSAFPID-9080700" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-04.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-04.json new file mode 100644 index 000000000..d09515e63 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-04.json @@ -0,0 +1,56 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Contradicting Product Status (failing example 4)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-06-04", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "fixed": [ + "CSAFPID-9080701" + ], + "known_not_affected": [ + "CSAFPID-9080701" + ], + "last_affected": [ + "CSAFPID-9080700" + ], + "under_investigation": [ + "CSAFPID-9080700" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-05.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-05.json new file mode 100644 index 000000000..9f25ac3f8 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-05.json @@ -0,0 +1,67 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Contradicting Product Status (failing example 5)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-06-05", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "first_affected": [ + "CSAFPID-9080700" + ], + "first_fixed": [ + "CSAFPID-9080702" + ], + "known_affected": [ + "CSAFPID-9080700" + ], + "known_not_affected": [ + "CSAFPID-9080701" + ], + "last_affected": [ + "CSAFPID-9080702" + ], + "under_investigation": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-11.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-11.json new file mode 100644 index 000000000..ec3d75ce6 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-11.json @@ -0,0 +1,46 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Contradicting Product Status (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-06-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "known_affected": [ + "CSAFPID-9080700" + ], + "recommended": [ + "CSAFPID-9080700" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-12.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-12.json new file mode 100644 index 000000000..b84eb6334 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-12.json @@ -0,0 +1,46 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Contradicting Product Status (valid example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-06-12", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "first_affected": [ + "CSAFPID-9080700" + ], + "known_affected": [ + "CSAFPID-9080700" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-13.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-13.json new file mode 100644 index 000000000..68048d8de --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-13.json @@ -0,0 +1,46 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Contradicting Product Status (valid example 3)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-06-13", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "known_affected": [ + "CSAFPID-9080700" + ], + "last_affected": [ + "CSAFPID-9080700" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-14.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-14.json new file mode 100644 index 000000000..9ee711531 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-14.json @@ -0,0 +1,56 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Contradicting Product Status (valid example 4)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-06-14", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "first_fixed": [ + "CSAFPID-9080701" + ], + "fixed": [ + "CSAFPID-9080701" + ], + "recommended": [ + "CSAFPID-9080700" + ], + "under_investigation": [ + "CSAFPID-9080700" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-15.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-15.json new file mode 100644 index 000000000..818f15374 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-15.json @@ -0,0 +1,67 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Contradicting Product Status (valid example 5)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-06-15", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "first_affected": [ + "CSAFPID-9080700" + ], + "first_fixed": [ + "CSAFPID-9080702" + ], + "fixed": [ + "CSAFPID-9080702" + ], + "known_affected": [ + "CSAFPID-9080700" + ], + "known_not_affected": [ + "CSAFPID-9080701" + ], + "recommended": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-07-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-07-01.json new file mode 100644 index 000000000..25880f024 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-07-01.json @@ -0,0 +1,62 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Multiple Scores with same Version per Product (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-07-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H", + "baseScore": 10, + "baseSeverity": "CRITICAL" + } + }, + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 6.5, + "baseSeverity": "MEDIUM" + } + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-07-11.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-07-11.json new file mode 100644 index 000000000..ee92137f6 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-07-11.json @@ -0,0 +1,66 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Multiple Scores with same Version per Product (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-07-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H", + "baseScore": 10, + "baseSeverity": "CRITICAL" + } + } + ] + }, + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 6.5, + "baseSeverity": "MEDIUM" + } + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-07-12.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-07-12.json new file mode 100644 index 000000000..6a8fe632b --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-07-12.json @@ -0,0 +1,56 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Multiple Scores with same Version per Product (valid example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-07-12", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v2": { + "version": "2.0", + "vectorString": "AV:N/AC:L/Au:S/C:P/I:P/A:N", + "baseScore": 5.5 + }, + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:C/C:L/I:L/A:N", + "baseScore": 6.4, + "baseSeverity": "MEDIUM" + } + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-08-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-08-01.json new file mode 100644 index 000000000..b52addd80 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-08-01.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Invalid CVSS (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-08-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 6.5 + } + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-09-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-09-01.json new file mode 100644 index 000000000..8cea252e8 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-09-01.json @@ -0,0 +1,51 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Invalid CVSS computation (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-09-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 10, + "baseSeverity": "LOW" + } + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-10-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-10-01.json new file mode 100644 index 000000000..1bf603707 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-10-01.json @@ -0,0 +1,59 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Inconsistent CVSS (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-10-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H", + "baseScore": 9.8, + "baseSeverity": "CRITICAL", + "attackVector": "LOCAL", + "attackComplexity": "LOW", + "privilegesRequired": "NONE", + "userInteraction": "NONE", + "scope": "CHANGED", + "confidentialityImpact": "HIGH", + "integrityImpact": "HIGH", + "availabilityImpact": "LOW" + } + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-11-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-11-01.json new file mode 100644 index 000000000..2737361c8 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-11-01.json @@ -0,0 +1,34 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: CWE (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-11-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "cwe": { + "id": "CWE-79", + "name": "Improper Input Validation" + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-12-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-12-01.json new file mode 100644 index 000000000..b38e9cfdb --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-12-01.json @@ -0,0 +1,27 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "EZ", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Language (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-12-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-13-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-13-01.json new file mode 100644 index 000000000..9c8f275fd --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-13-01.json @@ -0,0 +1,37 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: PURL (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-13-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "purl": "pkg:maven/@1.3.4" + } + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-14-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-14-01.json new file mode 100644 index 000000000..904e6d607 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-14-01.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Sorted Revision History (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-14-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-22T10:00:00.000Z", + "number": "2", + "summary": "Second version." + }, + { + "date": "2021-07-23T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-15-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-15-01.json new file mode 100644 index 000000000..760235cc2 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-15-01.json @@ -0,0 +1,26 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "translator", + "name": "OASIS CSAF TC Translator", + "namespace": "https://csaf.io/translator" + }, + "title": "Mandatory test: Translator (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-15-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-01.json new file mode 100644 index 000000000..16309f09a --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-01.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-01", + "initial_release_date": "2021-07-21T09:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T09:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-02.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-02.json new file mode 100644 index 000000000..f0b444c98 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-02.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-03.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-03.json new file mode 100644 index 000000000..f0726c542 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-03.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (failing example 3)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-03", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2", + "summary": "Second version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-04.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-04.json new file mode 100644 index 000000000..1c78eb7d4 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-04.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (failing example 4)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-04", + "initial_release_date": "2021-07-21T09:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T09:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2.0.0", + "summary": "Second version." + } + ], + "status": "final", + "version": "1.0.0" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-05.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-05.json new file mode 100644 index 000000000..d9551a8be --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-05.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (failing example 5)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-05", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2.0.0", + "summary": "Second version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1.0.0" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-06.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-06.json new file mode 100644 index 000000000..2b6906627 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-06.json @@ -0,0 +1,71 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (failing example 6)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-06", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2", + "summary": "Second version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "3", + "summary": "Third version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "4", + "summary": "Fourth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "5", + "summary": "Fifth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "6", + "summary": "Sixth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "7", + "summary": "Seventh version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "8", + "summary": "Eighth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "9", + "summary": "Ninth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "10", + "summary": "Tenth version." + } + ], + "status": "final", + "version": "9" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-07.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-07.json new file mode 100644 index 000000000..b354b71b1 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-07.json @@ -0,0 +1,76 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (failing example 7)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-07", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.1.0", + "summary": "Second version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.2.0", + "summary": "Third version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.3.0", + "summary": "Fourth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.4.0", + "summary": "Fifth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.5.0", + "summary": "Sixth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.6.0", + "summary": "Seventh version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.7.0", + "summary": "Eighth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.8.0", + "summary": "Ninth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.9.0", + "summary": "Tenth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.10.0", + "summary": "Eleventh version." + } + ], + "status": "final", + "version": "1.9.0" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-08.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-08.json new file mode 100644 index 000000000..d02f1ccc5 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-08.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (failing example 8)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-08", + "initial_release_date": "2021-07-21T10:00:00.00000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.00000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-11.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-11.json new file mode 100644 index 000000000..74cb6b21f --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-11.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-11", + "initial_release_date": "2021-07-21T09:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T09:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2.0.0", + "summary": "Second version." + } + ], + "status": "final", + "version": "2.0.0" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-12.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-12.json new file mode 100644 index 000000000..57947f515 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-12.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (valid example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-12", + "initial_release_date": "2021-07-21T09:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T09:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2.0.0", + "summary": "Second version." + } + ], + "status": "final", + "version": "2.0.0+21AF26D3" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-13.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-13.json new file mode 100644 index 000000000..de74091c8 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-13.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (valid example 3)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-13", + "initial_release_date": "2021-07-21T09:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T09:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2.0.0+143D5", + "summary": "Second version." + } + ], + "status": "final", + "version": "2.0.0+21AF26D3" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-14.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-14.json new file mode 100644 index 000000000..648e01df8 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-14.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (valid example 4)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-14", + "initial_release_date": "2021-07-21T09:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T09:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + "status": "final", + "version": "2" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-15.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-15.json new file mode 100644 index 000000000..1d66570f0 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-15.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (valid example 5)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-15", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + "status": "final", + "version": "2" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-16.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-16.json new file mode 100644 index 000000000..f0b0d73f5 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-16.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (valid example 6)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-16", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2", + "summary": "Second version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "2" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-17.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-17.json new file mode 100644 index 000000000..a1d01af4e --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-17.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (valid example 7)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-17", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2.0.0", + "summary": "Second version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + } + ], + "status": "final", + "version": "2.0.0" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-18.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-18.json new file mode 100644 index 000000000..769b380db --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-18.json @@ -0,0 +1,71 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (valid example 8)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-18", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2", + "summary": "Second version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "3", + "summary": "Third version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "4", + "summary": "Fourth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "5", + "summary": "Fifth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "6", + "summary": "Sixth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "7", + "summary": "Seventh version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "8", + "summary": "Eighth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "9", + "summary": "Ninth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "10", + "summary": "Tenth version." + } + ], + "status": "final", + "version": "10" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-19.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-19.json new file mode 100644 index 000000000..25c49e4d9 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-19.json @@ -0,0 +1,76 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (valid example 9)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-19", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.1.0", + "summary": "Second version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.2.0", + "summary": "Third version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.3.0", + "summary": "Fourth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.4.0", + "summary": "Fifth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.5.0", + "summary": "Sixth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.6.0", + "summary": "Seventh version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.7.0", + "summary": "Eighth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.8.0", + "summary": "Ninth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.9.0", + "summary": "Tenth version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.10.0", + "summary": "Eleventh version." + } + ], + "status": "final", + "version": "1.10.0" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-31.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-31.json new file mode 100644 index 000000000..a9e5a39ac --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-31.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Latest Document Version (valid example 10)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-16-31", + "initial_release_date": "2021-07-21T10:00:00.00000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.00000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + "status": "final", + "version": "2" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-17-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-17-01.json new file mode 100644 index 000000000..b33034477 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-17-01.json @@ -0,0 +1,26 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Document Status Draft (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-17-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "0.9.5", + "summary": "Initial draft version." + } + ], + "status": "final", + "version": "0.9.5" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-18-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-18-01.json new file mode 100644 index 000000000..ceec17780 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-18-01.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Released Revision History (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-18-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-04-17T10:00:00.000Z", + "number": "0", + "summary": "First draft" + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-19-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-19-01.json new file mode 100644 index 000000000..cc9b3ae8d --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-19-01.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Revision History Entries for Pre-release Versions (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-19-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-04-22T10:00:00.000Z", + "number": "1.0.0-rc", + "summary": "Release Candidate for initial version." + }, + { + "date": "2021-04-23T10:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1.0.0" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-19-02.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-19-02.json new file mode 100644 index 000000000..7764c674d --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-19-02.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Revision History Entries for Pre-release Versions (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-19-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-04-23T10:00:00.000Z", + "number": "1.0.0-rc", + "summary": "Release Candidate for initial version." + }, + { + "date": "2021-04-23T10:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1.0.0" + } + } +} diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-20-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-20-01.json new file mode 100644 index 000000000..e4390cd41 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-20-01.json @@ -0,0 +1,26 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Non-draft Document Version (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-20-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + } + ], + "status": "interim", + "version": "1.0.0-alpha" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-01.json new file mode 100644 index 000000000..1ddf0e30f --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-01.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Missing Item in Revision History (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-21-01", + "initial_release_date": "2021-04-22T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-04-22T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "3", + "summary": "Some other changes." + } + ], + "status": "final", + "version": "3" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-02.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-02.json new file mode 100644 index 000000000..ae2ed6118 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-02.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Missing Item in Revision History (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-21-02", + "initial_release_date": "2021-04-22T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-04-22T10:00:00.000Z", + "number": "2", + "summary": "Second version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "3", + "summary": "Some other changes." + } + ], + "status": "final", + "version": "3" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-11.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-11.json new file mode 100644 index 000000000..8719a997a --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-11.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Missing Item in Revision History (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-21-11", + "initial_release_date": "2021-04-22T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-04-22T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2", + "summary": "Some other changes." + } + ], + "status": "final", + "version": "2" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-12.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-12.json new file mode 100644 index 000000000..1cad8d429 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-12.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Missing Item in Revision History (valid example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-21-12", + "initial_release_date": "2021-04-22T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-03-22T10:00:00.000Z", + "number": "0", + "summary": "Draft version." + }, + { + "date": "2021-04-22T10:00:00.000Z", + "number": "1", + "summary": "Initial public release." + } + ], + "status": "draft", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-13.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-13.json new file mode 100644 index 000000000..6bf2905be --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-13.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Missing Item in Revision History (valid example 3)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-21-13", + "initial_release_date": "2021-04-22T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-04-22T10:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1.1.0", + "summary": "Some other changes." + } + ], + "status": "final", + "version": "1.1.0" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-22-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-22-01.json new file mode 100644 index 000000000..846b8248e --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-22-01.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Multiple Definition in Revision History (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-22-01", + "initial_release_date": "2021-07-20T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-20T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Some other changes." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-23-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-23-01.json new file mode 100644 index 000000000..37bc7c67f --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-23-01.json @@ -0,0 +1,34 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Multiple Use of Same CVE (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-23-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145" + }, + { + "cve": "CVE-2017-0145" + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-01.json new file mode 100644 index 000000000..b492a5915 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-01.json @@ -0,0 +1,43 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Multiple Definition in Involvements (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-24-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "involvements": [ + { + "date": "2021-04-23T10:00:00.000Z", + "party": "vendor", + "status": "completed" + }, + { + "date": "2021-04-23T10:00:00.000Z", + "party": "vendor", + "status": "in_progress", + "summary": "The vendor has released a mitigation and is working to fully resolve the issue." + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-02.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-02.json new file mode 100644 index 000000000..5136245fb --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-02.json @@ -0,0 +1,43 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Multiple Definition in Involvements (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-24-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "involvements": [ + { + "date": "2021-04-23T10:00:00.000Z", + "party": "vendor", + "status": "in_progress" + }, + { + "date": "2021-04-23T10:00:00.000Z", + "party": "vendor", + "status": "in_progress", + "summary": "The vendor has released a mitigation and is working to fully resolve the issue." + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-11.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-11.json new file mode 100644 index 000000000..2140c983c --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-11.json @@ -0,0 +1,47 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Multiple Definition in Involvements (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-24-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "involvements": [ + { + "date": "2021-04-23T10:00:00.000Z", + "party": "vendor", + "status": "completed" + } + ] + }, + { + "involvements": [ + { + "date": "2021-04-23T10:00:00.000Z", + "party": "vendor", + "status": "in_progress", + "summary": "The vendor has released a mitigation and is working to fully resolve the issue." + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-12.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-12.json new file mode 100644 index 000000000..950e41050 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-12.json @@ -0,0 +1,47 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Multiple Definition in Involvements (valid example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-24-12", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "involvements": [ + { + "date": "2021-04-23T10:00:00.000Z", + "party": "vendor", + "status": "in_progress" + } + ] + }, + { + "involvements": [ + { + "date": "2021-04-23T10:00:00.000Z", + "party": "vendor", + "status": "in_progress", + "summary": "The vendor has released a mitigation and is working to fully resolve the issue." + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-25-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-25-01.json new file mode 100644 index 000000000..44adfbabc --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-25-01.json @@ -0,0 +1,51 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Multiple Use of Same Hash Algorithm (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-25-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "hashes": [ + { + "file_hashes": [ + { + "algorithm": "sha256", + "value": "026a37919b182ef7c63791e82c9645e2f897a3f0b73c7a6028c7febf62e93838" + }, + { + "algorithm": "sha256", + "value": "0a853ce2337f0608489ac596a308dc5b7b19d35a52b10bf31261586ac368b175" + } + ], + "filename": "product_a.so" + } + ] + } + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-26-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-26-01.json new file mode 100644 index 000000000..bf9fc0c59 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-26-01.json @@ -0,0 +1,26 @@ +{ + "document": { + "category": "Security_Incident_Response", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Prohibited Document Category Name (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-26-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-01-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-01-01.json new file mode 100644 index 000000000..2559108c2 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-01-01.json @@ -0,0 +1,33 @@ +{ + "document": { + "category": "csaf_security_incident_response", + "csaf_version": "2.0", + "notes": [ + { + "category": "legal_disclaimer", + "text": "The CSAF document is provided to You \"AS IS\" and \"AS AVAILABLE\" and with all faults and defects without warranty of any kind.", + "title": "Terms of Use" + } + ], + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Document Notes (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-01-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-02-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-02-01.json new file mode 100644 index 000000000..768cbc5fb --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-02-01.json @@ -0,0 +1,33 @@ +{ + "document": { + "category": "csaf_informational_advisory", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "references": [ + { + "category": "self", + "summary": "The canonical URL.", + "url": "https://example.com/security/data/csaf/2021/OASIS_CSAF_TC-CSAF_2_0-2021-6-1-27-02-01.json" + } + ], + "title": "Mandatory test: Document References (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-02-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-03-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-03-01.json new file mode 100644 index 000000000..e33def47c --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-03-01.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_informational_advisory", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Vulnerabilities (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-03-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "title": "A vulnerability item that SHALL NOT exist" + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-04-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-04-01.json new file mode 100644 index 000000000..0c2fdea88 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-04-01.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_security_advisory", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Product Tree (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-04-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "title": "A vulnerability item that can't reference any product as the product_tree does not exist." + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-05-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-05-01.json new file mode 100644 index 000000000..c1512e093 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-05-01.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_security_advisory", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Vulnerability Notes (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-05-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "title": "A vulnerability item without a note" + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-06-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-06-01.json new file mode 100644 index 000000000..858dbb587 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-06-01.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_security_advisory", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Product Status (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-06-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "title": "A vulnerability item without a product status" + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-07-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-07-01.json new file mode 100644 index 000000000..fbff40ba3 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-07-01.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: VEX Product Status (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-07-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "first_fixed": [ + "CSAFPID-9080700" + ], + "recommended": [ + "CSAFPID-9080701" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-08-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-08-01.json new file mode 100644 index 000000000..ff1a2db7f --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-08-01.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Vulnerability ID (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-08-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "title": "A vulnerability item without a CVE or ID" + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-01.json new file mode 100644 index 000000000..3e214d975 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-01.json @@ -0,0 +1,79 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Impact Statement (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-09-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ], + "product_groups": [ + { + "group_id": "CSAFGID-0001", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "notes": [ + { + "category": "description", + "text": "The SMBv1 server in Microsoft Windows Vista SP2; Windows Server 2008 SP2 and R2 SP1; Windows 7 SP1; Windows 8.1; Windows Server 2012 Gold and R2; Windows RT 8.1; and Windows 10 Gold, 1511, and 1607; and Windows Server 2016 allows remote attackers to execute arbitrary code via crafted packets, aka \"Windows SMB Remote Code Execution Vulnerability.\" This vulnerability is different from those described in CVE-2017-0143, CVE-2017-0144, CVE-2017-0146, and CVE-2017-0148. ", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "threats": [ + { + "category": "impact", + "details": "The vulnerable code is not present in these products.", + "group_ids": [ + "CSAFGID-0001" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-02.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-02.json new file mode 100644 index 000000000..f6329227d --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-02.json @@ -0,0 +1,78 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Impact Statement (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-09-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ], + "product_groups": [ + { + "group_id": "CSAFGID-0001", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "flags": [ + { + "label": "vulnerable_code_not_present", + "group_ids": [ + "CSAFGID-0001" + ] + } + ], + "notes": [ + { + "category": "description", + "text": "The SMBv1 server in Microsoft Windows Vista SP2; Windows Server 2008 SP2 and R2 SP1; Windows 7 SP1; Windows 8.1; Windows Server 2012 Gold and R2; Windows RT 8.1; and Windows 10 Gold, 1511, and 1607; and Windows Server 2016 allows remote attackers to execute arbitrary code via crafted packets, aka \"Windows SMB Remote Code Execution Vulnerability.\" This vulnerability is different from those described in CVE-2017-0143, CVE-2017-0144, CVE-2017-0146, and CVE-2017-0148. ", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-03.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-03.json new file mode 100644 index 000000000..6f090d0ef --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-03.json @@ -0,0 +1,71 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Impact Statement (failing example 3)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-09-03", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "notes": [ + { + "category": "description", + "text": "The SMBv1 server in Microsoft Windows Vista SP2; Windows Server 2008 SP2 and R2 SP1; Windows 7 SP1; Windows 8.1; Windows Server 2012 Gold and R2; Windows RT 8.1; and Windows 10 Gold, 1511, and 1607; and Windows Server 2016 allows remote attackers to execute arbitrary code via crafted packets, aka \"Windows SMB Remote Code Execution Vulnerability.\" This vulnerability is different from those described in CVE-2017-0143, CVE-2017-0144, CVE-2017-0146, and CVE-2017-0148. ", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "threats": [ + { + "category": "impact", + "details": "The vulnerable code is not present in these products.", + "product_ids": [ + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-04.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-04.json new file mode 100644 index 000000000..caecdfea2 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-04.json @@ -0,0 +1,70 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Impact Statement (failing example 4)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-09-04", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "flags": [ + { + "label": "vulnerable_code_not_present", + "product_ids": [ + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + } + ], + "notes": [ + { + "category": "description", + "text": "The SMBv1 server in Microsoft Windows Vista SP2; Windows Server 2008 SP2 and R2 SP1; Windows 7 SP1; Windows 8.1; Windows Server 2012 Gold and R2; Windows RT 8.1; and Windows 10 Gold, 1511, and 1607; and Windows Server 2016 allows remote attackers to execute arbitrary code via crafted packets, aka \"Windows SMB Remote Code Execution Vulnerability.\" This vulnerability is different from those described in CVE-2017-0143, CVE-2017-0144, CVE-2017-0146, and CVE-2017-0148. ", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-05.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-05.json new file mode 100644 index 000000000..b35c11724 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-05.json @@ -0,0 +1,78 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Impact Statement (failing example 5)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-09-05", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "flags": [ + { + "label": "vulnerable_code_not_present", + "product_ids": [ + "CSAFPID-9080701" + ] + } + ], + "notes": [ + { + "category": "description", + "text": "The SMBv1 server in Microsoft Windows Vista SP2; Windows Server 2008 SP2 and R2 SP1; Windows 7 SP1; Windows 8.1; Windows Server 2012 Gold and R2; Windows RT 8.1; and Windows 10 Gold, 1511, and 1607; and Windows Server 2016 allows remote attackers to execute arbitrary code via crafted packets, aka \"Windows SMB Remote Code Execution Vulnerability.\" This vulnerability is different from those described in CVE-2017-0143, CVE-2017-0144, CVE-2017-0146, and CVE-2017-0148. ", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "threats": [ + { + "category": "impact", + "details": "The vulnerable code is not present in these products.", + "product_ids": [ + "CSAFPID-9080702" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-06.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-06.json new file mode 100644 index 000000000..bf5a284a5 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-06.json @@ -0,0 +1,148 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Impact Statement (failing example 6)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-09-06", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0143", + "flags": [ + { + "label": "vulnerable_code_not_present", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ], + "notes": [ + { + "category": "description", + "text": "The SMBv1 server in Microsoft Windows Vista SP2; Windows Server 2008 SP2 and R2 SP1; Windows 7 SP1; Windows 8.1; Windows Server 2012 Gold and R2; Windows RT 8.1; and Windows 10 Gold, 1511, and 1607; and Windows Server 2016 allows remote attackers to execute arbitrary code via crafted packets, aka \"Windows SMB Remote Code Execution Vulnerability.\" This vulnerability is different from those described in CVE-2017-0144, CVE-2017-0145, CVE-2017-0146, and CVE-2017-0148.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "threats": [ + { + "category": "impact", + "details": "The vulnerable code is not present in these products.", + "product_ids": [ + "CSAFPID-9080702" + ] + } + ] + }, + { + "cve": "CVE-2017-0145", + "flags": [ + { + "label": "vulnerable_code_not_present", + "product_ids": [ + "CSAFPID-9080700" + ] + } + ], + "notes": [ + { + "category": "description", + "text": "The SMBv1 server in Microsoft Windows Vista SP2; Windows Server 2008 SP2 and R2 SP1; Windows 7 SP1; Windows 8.1; Windows Server 2012 Gold and R2; Windows RT 8.1; and Windows 10 Gold, 1511, and 1607; and Windows Server 2016 allows remote attackers to execute arbitrary code via crafted packets, aka \"Windows SMB Remote Code Execution Vulnerability.\" This vulnerability is different from those described in CVE-2017-0143, CVE-2017-0144, CVE-2017-0146, and CVE-2017-0148. ", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "threats": [ + { + "category": "impact", + "details": "The vulnerable code is not present in these products.", + "product_ids": [ + "CSAFPID-9080702" + ] + } + ] + }, + { + "cve": "CVE-2017-0146", + "flags": [ + { + "label": "vulnerable_code_not_present", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ], + "notes": [ + { + "category": "description", + "text": "The SMBv1 server in Microsoft Windows Vista SP2; Windows Server 2008 SP2 and R2 SP1; Windows 7 SP1; Windows 8.1; Windows Server 2012 Gold and R2; Windows RT 8.1; and Windows 10 Gold, 1511, and 1607; and Windows Server 2016 allows remote attackers to execute arbitrary code via crafted packets, aka \"Windows SMB Remote Code Execution Vulnerability.\" This vulnerability is different from those described in CVE-2017-0143, CVE-2017-0144, CVE-2017-0145, and CVE-2017-0148.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "threats": [ + { + "category": "impact", + "details": "The vulnerable code is not present in these products.", + "product_ids": [ + "CSAFPID-9080702" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-11.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-11.json new file mode 100644 index 000000000..45925f5d7 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-11.json @@ -0,0 +1,82 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Impact Statement (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-09-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ], + "product_groups": [ + { + "group_id": "CSAFGID-0001", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "notes": [ + { + "category": "description", + "text": "The SMBv1 server in Microsoft Windows Vista SP2; Windows Server 2008 SP2 and R2 SP1; Windows 7 SP1; Windows 8.1; Windows Server 2012 Gold and R2; Windows RT 8.1; and Windows 10 Gold, 1511, and 1607; and Windows Server 2016 allows remote attackers to execute arbitrary code via crafted packets, aka \"Windows SMB Remote Code Execution Vulnerability.\" This vulnerability is different from those described in CVE-2017-0143, CVE-2017-0144, CVE-2017-0146, and CVE-2017-0148. ", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "threats": [ + { + "category": "impact", + "details": "The vulnerable code is not present in these products.", + "product_ids": [ + "CSAFPID-9080702" + ], + "group_ids": [ + "CSAFGID-0001" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-12.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-12.json new file mode 100644 index 000000000..97c47a3a2 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-12.json @@ -0,0 +1,81 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Impact Statement (valid example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-09-12", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ], + "product_groups": [ + { + "group_id": "CSAFGID-0001", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "flags": [ + { + "label": "vulnerable_code_not_present", + "product_ids": [ + "CSAFPID-9080702" + ], + "group_ids": [ + "CSAFGID-0001" + ] + } + ], + "notes": [ + { + "category": "description", + "text": "The SMBv1 server in Microsoft Windows Vista SP2; Windows Server 2008 SP2 and R2 SP1; Windows 7 SP1; Windows 8.1; Windows Server 2012 Gold and R2; Windows RT 8.1; and Windows 10 Gold, 1511, and 1607; and Windows Server 2016 allows remote attackers to execute arbitrary code via crafted packets, aka \"Windows SMB Remote Code Execution Vulnerability.\" This vulnerability is different from those described in CVE-2017-0143, CVE-2017-0144, CVE-2017-0146, and CVE-2017-0148. ", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-13.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-13.json new file mode 100644 index 000000000..64da6f4ea --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-13.json @@ -0,0 +1,72 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Impact Statement (valid example 3)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-09-13", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "notes": [ + { + "category": "description", + "text": "The SMBv1 server in Microsoft Windows Vista SP2; Windows Server 2008 SP2 and R2 SP1; Windows 7 SP1; Windows 8.1; Windows Server 2012 Gold and R2; Windows RT 8.1; and Windows 10 Gold, 1511, and 1607; and Windows Server 2016 allows remote attackers to execute arbitrary code via crafted packets, aka \"Windows SMB Remote Code Execution Vulnerability.\" This vulnerability is different from those described in CVE-2017-0143, CVE-2017-0144, CVE-2017-0146, and CVE-2017-0148. ", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "threats": [ + { + "category": "impact", + "details": "The vulnerable code is not present in these products.", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-14.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-14.json new file mode 100644 index 000000000..bddee4c08 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-14.json @@ -0,0 +1,71 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Impact Statement (valid example 4)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-09-14", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "flags": [ + { + "label": "vulnerable_code_not_present", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + } + ], + "notes": [ + { + "category": "description", + "text": "The SMBv1 server in Microsoft Windows Vista SP2; Windows Server 2008 SP2 and R2 SP1; Windows 7 SP1; Windows 8.1; Windows Server 2012 Gold and R2; Windows RT 8.1; and Windows 10 Gold, 1511, and 1607; and Windows Server 2016 allows remote attackers to execute arbitrary code via crafted packets, aka \"Windows SMB Remote Code Execution Vulnerability.\" This vulnerability is different from those described in CVE-2017-0143, CVE-2017-0144, CVE-2017-0146, and CVE-2017-0148. ", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-15.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-15.json new file mode 100644 index 000000000..dd385e1d2 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-15.json @@ -0,0 +1,79 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Impact Statement (valid example 5)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-09-15", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "flags": [ + { + "label": "vulnerable_code_not_present", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ], + "notes": [ + { + "category": "description", + "text": "The SMBv1 server in Microsoft Windows Vista SP2; Windows Server 2008 SP2 and R2 SP1; Windows 7 SP1; Windows 8.1; Windows Server 2012 Gold and R2; Windows RT 8.1; and Windows 10 Gold, 1511, and 1607; and Windows Server 2016 allows remote attackers to execute arbitrary code via crafted packets, aka \"Windows SMB Remote Code Execution Vulnerability.\" This vulnerability is different from those described in CVE-2017-0143, CVE-2017-0144, CVE-2017-0146, and CVE-2017-0148. ", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "threats": [ + { + "category": "impact", + "details": "The vulnerable code is not present in these products.", + "product_ids": [ + "CSAFPID-9080702" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-16.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-16.json new file mode 100644 index 000000000..01359ce51 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-16.json @@ -0,0 +1,149 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Impact Statement (valid example 6)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-09-16", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0143", + "flags": [ + { + "label": "vulnerable_code_not_present", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ], + "notes": [ + { + "category": "description", + "text": "The SMBv1 server in Microsoft Windows Vista SP2; Windows Server 2008 SP2 and R2 SP1; Windows 7 SP1; Windows 8.1; Windows Server 2012 Gold and R2; Windows RT 8.1; and Windows 10 Gold, 1511, and 1607; and Windows Server 2016 allows remote attackers to execute arbitrary code via crafted packets, aka \"Windows SMB Remote Code Execution Vulnerability.\" This vulnerability is different from those described in CVE-2017-0144, CVE-2017-0145, CVE-2017-0146, and CVE-2017-0148.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "threats": [ + { + "category": "impact", + "details": "The vulnerable code is not present in these products.", + "product_ids": [ + "CSAFPID-9080702" + ] + } + ] + }, + { + "cve": "CVE-2017-0145", + "flags": [ + { + "label": "vulnerable_code_not_present", + "product_ids": [ + "CSAFPID-9080700" + ] + } + ], + "notes": [ + { + "category": "description", + "text": "The SMBv1 server in Microsoft Windows Vista SP2; Windows Server 2008 SP2 and R2 SP1; Windows 7 SP1; Windows 8.1; Windows Server 2012 Gold and R2; Windows RT 8.1; and Windows 10 Gold, 1511, and 1607; and Windows Server 2016 allows remote attackers to execute arbitrary code via crafted packets, aka \"Windows SMB Remote Code Execution Vulnerability.\" This vulnerability is different from those described in CVE-2017-0143, CVE-2017-0144, CVE-2017-0146, and CVE-2017-0148. ", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "threats": [ + { + "category": "impact", + "details": "The vulnerable code is not present in these products.", + "product_ids": [ + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + } + ] + }, + { + "cve": "CVE-2017-0146", + "flags": [ + { + "label": "vulnerable_code_not_present", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ], + "notes": [ + { + "category": "description", + "text": "The SMBv1 server in Microsoft Windows Vista SP2; Windows Server 2008 SP2 and R2 SP1; Windows 7 SP1; Windows 8.1; Windows Server 2012 Gold and R2; Windows RT 8.1; and Windows 10 Gold, 1511, and 1607; and Windows Server 2016 allows remote attackers to execute arbitrary code via crafted packets, aka \"Windows SMB Remote Code Execution Vulnerability.\" This vulnerability is different from those described in CVE-2017-0143, CVE-2017-0144, CVE-2017-0145, and CVE-2017-0148.", + "title": "CVE description" + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "threats": [ + { + "category": "impact", + "details": "The vulnerable code is not present in these products.", + "product_ids": [ + "CSAFPID-9080702" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-10-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-10-01.json new file mode 100644 index 000000000..ec0139539 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-10-01.json @@ -0,0 +1,73 @@ +{ + "document": { + "category": "csaf_vex", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Action Statement (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-10-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ], + "product_groups": [ + { + "group_id": "CSAFGID-0001", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ], + "summary": "EOL products" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "product_status": { + "known_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "remediations": [ + { + "category": "no_fix_planned", + "details": "These products are end-of-life. Therefore, no fix will be provided.", + "group_ids": [ + "CSAFGID-0001" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-11-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-11-01.json new file mode 100644 index 000000000..e39c0f9e7 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-11-01.json @@ -0,0 +1,34 @@ +{ + "document": { + "category": "csaf_security_advisory", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Vulnerabilities (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-27-11-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-28-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-28-01.json new file mode 100644 index 000000000..fd6841e4f --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-28-01.json @@ -0,0 +1,28 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "en-US", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "source_lang": "en-US", + "title": "Mandatory test: Translation (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-28-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-28-11.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-28-11.json new file mode 100644 index 000000000..431162d86 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-28-11.json @@ -0,0 +1,28 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "en-US", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "source_lang": "en-GB", + "title": "Mandatory test: Translation (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-28-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-29-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-29-01.json new file mode 100644 index 000000000..a9f89e97d --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-29-01.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Remediation without Product Reference (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-29-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "product_status": { + "known_affected": [ + "CSAFPID-9080700" + ] + }, + "remediations": [ + { + "category": "no_fix_planned", + "details": "These products are end-of-life. Therefore, no fix will be provided." + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-29-11.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-29-11.json new file mode 100644 index 000000000..d8bd5bf01 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-29-11.json @@ -0,0 +1,53 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Remediation without Product Reference (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-29-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "product_status": { + "known_affected": [ + "CSAFPID-9080700" + ] + }, + "remediations": [ + { + "category": "no_fix_planned", + "details": "These products are end-of-life. Therefore, no fix will be provided.", + "product_ids": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-29-12.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-29-12.json new file mode 100644 index 000000000..c1dbbf7cb --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-29-12.json @@ -0,0 +1,44 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Remediation without Product Reference (valid example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-29-12", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "product_status": { + "known_affected": [ + "CSAFPID-9080700" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-30-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-30-01.json new file mode 100644 index 000000000..63018526f --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-30-01.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Mixed Integer and Semantic Versioning (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-30-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T09:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + "status": "final", + "version": "2" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-30-11.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-30-11.json new file mode 100644 index 000000000..c0d4df1c0 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-30-11.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Mixed Integer and Semantic Versioning (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-30-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T09:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2.0.0", + "summary": "Second version." + } + ], + "status": "final", + "version": "2.0.0" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-01.json new file mode 100644 index 000000000..6bf84c2ce --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-01.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Version Range in Product Version (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-31-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "prior to 4.2", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A prior to 4.2" + } + } + ] + } + ] + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-02.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-02.json new file mode 100644 index 000000000..b25c146cc --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-02.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Version Range in Product Version (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-31-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "<4.2", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A prior to 4.2" + } + } + ] + } + ] + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-03.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-03.json new file mode 100644 index 000000000..30ff0be0d --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-03.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Version Range in Product Version (failing example 3)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-31-03", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "<=4.1", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A <= 4.1" + } + } + ] + } + ] + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-04.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-04.json new file mode 100644 index 000000000..92a824e38 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-04.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Version Range in Product Version (failing example 4)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-31-04", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "<= 4.1", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A <= 4.1" + } + } + ] + } + ] + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-05.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-05.json new file mode 100644 index 000000000..3f619b7c4 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-05.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Version Range in Product Version (failing example 5)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-31-05", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "4.1 and earlier", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A 4.1 and earlier" + } + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-06.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-06.json new file mode 100644 index 000000000..593c36b19 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-06.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Version Range in Product Version (failing example 6)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-31-06", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "all", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A all versions" + } + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-07.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-07.json new file mode 100644 index 000000000..122896e9b --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-07.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Version Range in Product Version (failing example 7)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-31-07", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "before 4.2", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A before 4.2" + } + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-08.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-08.json new file mode 100644 index 000000000..0d30320ea --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-08.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Version Range in Product Version (failing example 8)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-31-08", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "4.2 and later", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A 4.2 and later" + } + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-09.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-09.json new file mode 100644 index 000000000..27a4ba19d --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-09.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Version Range in Product Version (failing example 9)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-31-09", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "3.X versions", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A 3.X versions" + } + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-11.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-11.json new file mode 100644 index 000000000..940837db0 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-11.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Version Range in Product Version (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-31-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version_range", + "name": "<4.2", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A prior to 4.2" + } + } + ] + } + ] + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-12.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-12.json new file mode 100644 index 000000000..c5c9cb50d --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-12.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Version Range in Product Version (valid example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-31-12", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "after-eight", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A after-eight" + } + } + ] + } + ] + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-32-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-32-01.json new file mode 100644 index 000000000..794a77c90 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-32-01.json @@ -0,0 +1,49 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Flag without Product Reference (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-32-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700" + ] + }, + "flags": [ + { + "label": "component_not_present" + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-32-11.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-32-11.json new file mode 100644 index 000000000..932e7fc56 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-32-11.json @@ -0,0 +1,52 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Flag without Product Reference (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-32-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700" + ] + }, + "flags": [ + { + "label": "component_not_present", + "product_ids": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-33-01.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-33-01.json new file mode 100644 index 000000000..63e4c7730 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-33-01.json @@ -0,0 +1,72 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Multiple Flags with VEX Justification Codes per Product (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-33-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + } + ], + "product_groups": [ + { + "group_id": "CSAFGID-0001", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "flags": [ + { + "label": "component_not_present", + "group_ids": [ + "CSAFGID-0001" + ] + }, + { + "label": "vulnerable_code_cannot_be_controlled_by_adversary", + "product_ids": [ + "CSAFPID-9080700" + ] + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-33-11.json b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-33-11.json new file mode 100644 index 000000000..ab28a4061 --- /dev/null +++ b/csaf_2.1/test/validator/data/mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-33-11.json @@ -0,0 +1,82 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Mandatory test: Multiple Flags with VEX Justification Codes per Product (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-1-33-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + } + ], + "product_groups": [ + { + "group_id": "CSAFGID-0001", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ] + }, + "vulnerabilities": [ + { + "cve": "CVE-2017-0145", + "flags": [ + { + "label": "component_not_present", + "group_ids": [ + "CSAFGID-0001" + ] + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + }, + { + "cve": "CVE-2020-44228", + "flags": [ + { + "label": "vulnerable_code_cannot_be_controlled_by_adversary", + "product_ids": [ + "CSAFPID-9080700" + ] + } + ], + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/oasis_csaf_tc-csaf_2_0-2021-TEMPLATE.json b/csaf_2.1/test/validator/data/oasis_csaf_tc-csaf_2_0-2021-TEMPLATE.json new file mode 100644 index 000000000..d82d179e3 --- /dev/null +++ b/csaf_2.1/test/validator/data/oasis_csaf_tc-csaf_2_0-2021-TEMPLATE.json @@ -0,0 +1,26 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Template for generating CSAF files for Validator examples", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-TEMPLATE", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-01-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-01-01.json new file mode 100644 index 000000000..4de44cbec --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-01-01.json @@ -0,0 +1,34 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Unused Definition of Product ID (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-01-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-01-11.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-01-11.json new file mode 100644 index 000000000..432c0eaa6 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-01-11.json @@ -0,0 +1,47 @@ +{ + "document": { + "category": "csaf_informational_advisory", + "csaf_version": "2.0", + "notes": [ + { + "category": "summary", + "text": "A summary of the informational advisory." + } + ], + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "references": [ + { + "category": "external", + "summary": "A valid reference.", + "url": "https://example.net" + } + ], + "title": "Optional test: Unused Definition of Product ID (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-01-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700" + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-02-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-02-01.json new file mode 100644 index 000000000..ac94b85bf --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-02-01.json @@ -0,0 +1,43 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Missing Remediation (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-02-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "last_affected": [ + "CSAFPID-9080700" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-03-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-03-01.json new file mode 100644 index 000000000..f567731d9 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-03-01.json @@ -0,0 +1,43 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Missing Score (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-03-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "first_affected": [ + "CSAFPID-9080700" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-04-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-04-01.json new file mode 100644 index 000000000..8e201e93a --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-04-01.json @@ -0,0 +1,26 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Build Metadata in Revision History (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-04-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-04-23T10:00:00.000Z", + "number": "1.0.0+exp.sha.ac00785", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1.0.0" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-05-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-05-01.json new file mode 100644 index 000000000..8acaeedee --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-05-01.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Older Initial Release Date than Revision History (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-05-01", + "initial_release_date": "2021-04-22T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-05-06T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T11:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + "status": "final", + "version": "2" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-06-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-06-01.json new file mode 100644 index 000000000..7e560e1cd --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-06-01.json @@ -0,0 +1,31 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Older Current Release Date than Revision History (failing example 1)", + "tracking": { + "current_release_date": "2021-05-06T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-06-01", + "initial_release_date": "2021-05-06T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-05-06T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T11:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + "status": "final", + "version": "2" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-07-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-07-01.json new file mode 100644 index 000000000..ab270a081 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-07-01.json @@ -0,0 +1,36 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Missing Date in Involvements (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-07-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "involvements": [ + { + "party": "vendor", + "status": "in_progress" + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-08-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-08-01.json new file mode 100644 index 000000000..a2720f3e5 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-08-01.json @@ -0,0 +1,47 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Use of MD5 as the only Hash Algorithm (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-08-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "hashes": [ + { + "file_hashes": [ + { + "algorithm": "md5", + "value": "6ae24620ea9656230f49234efd078935" + } + ], + "filename": "product_a.so" + } + ] + } + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-08-02.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-08-02.json new file mode 100644 index 000000000..bdb6a4a5d --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-08-02.json @@ -0,0 +1,51 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Use of MD5 as the only Hash Algorithm (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-08-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "hashes": [ + { + "file_hashes": [ + { + "algorithm": "md5", + "value": "6ae24620ea9656230f49234efd078935" + }, + { + "algorithm": "md5", + "value": "e1b027e19683bf1c3c8df2d62fc500cf" + } + ], + "filename": "product_a.so" + } + ] + } + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-09-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-09-01.json new file mode 100644 index 000000000..f03dadf1c --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-09-01.json @@ -0,0 +1,47 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Use of SHA-1 as the only Hash Algorithm (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-09-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "hashes": [ + { + "file_hashes": [ + { + "algorithm": "sha1", + "value": "e067035314dd8673fe1c9fc6b01414fe0950fdc4" + } + ], + "filename": "product_a.so" + } + ] + } + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-09-02.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-09-02.json new file mode 100644 index 000000000..4a5e96c98 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-09-02.json @@ -0,0 +1,51 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Use of SHA-1 as the only Hash Algorithm (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-09-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "hashes": [ + { + "file_hashes": [ + { + "algorithm": "sha1", + "value": "e067035314dd8673fe1c9fc6b01414fe0950fdc4" + }, + { + "algorithm": "sha1", + "value": "0ea8daf2551fdd075aefa894e8c51b99b71e1be0" + } + ], + "filename": "product_a.so" + } + ] + } + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-10-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-10-01.json new file mode 100644 index 000000000..ae685b176 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-10-01.json @@ -0,0 +1,29 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "distribution": { + "text": "Distribute freely." + }, + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Missing TLP label (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-10-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-11-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-11-01.json new file mode 100644 index 000000000..d7d5d9438 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-11-01.json @@ -0,0 +1,33 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "references": [ + { + "category": "self", + "summary": "A non-canonical URL.", + "url": "https://example.com/security/data/csaf/2021/OASIS_CSAF_TC-CSAF_2.0-2021-6-2-11-01_1.json" + } + ], + "title": "Optional test: Missing Canonical URL (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-11-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-11-11.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-11-11.json new file mode 100644 index 000000000..ee529d2a9 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-11-11.json @@ -0,0 +1,33 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "references": [ + { + "category": "self", + "summary": "A canonical URL.", + "url": "https://example.com/security/data/csaf/2021/oasis_csaf_tc-csaf_2_0-2021-6-2-11-11.json" + } + ], + "title": "Optional test: Missing Canonical URL (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-11-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-12-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-12-01.json new file mode 100644 index 000000000..c774f5c10 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-12-01.json @@ -0,0 +1,26 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Missing Document Language (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-12-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-13-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-13-01.json new file mode 100644 index 000000000..d1f929b70 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-13-01.json @@ -0,0 +1,26 @@ +{ + "document": { + "csaf_version": "2.0", + "category": "csaf_base", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Sorting (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-13-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-01.json new file mode 100644 index 000000000..d85b0b326 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-01.json @@ -0,0 +1,27 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "qtx", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Use of Private Language (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-14-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-02.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-02.json new file mode 100644 index 000000000..cef54404b --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-02.json @@ -0,0 +1,28 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "en", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "source_lang": "qcb", + "title": "Optional test: Use of Private Language (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-14-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-03.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-03.json new file mode 100644 index 000000000..adf3815a2 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-03.json @@ -0,0 +1,28 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "qdq", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "source_lang": "qcb", + "title": "Optional test: Use of Private Language (failing example 3)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-14-03", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-04.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-04.json new file mode 100644 index 000000000..7010ef30b --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-04.json @@ -0,0 +1,27 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "en-QM", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Use of Private Language (failing example 4)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-14-04", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-05.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-05.json new file mode 100644 index 000000000..4499b889d --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-05.json @@ -0,0 +1,27 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "en-XP", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Use of Private Language (failing example 5)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-14-05", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-06.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-06.json new file mode 100644 index 000000000..bb6b1c4c8 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-06.json @@ -0,0 +1,27 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "en-Qabc", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Use of Private Language (failing example 6)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-14-06", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-07.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-07.json new file mode 100644 index 000000000..317393949 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-07.json @@ -0,0 +1,27 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "en-AA", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Use of Private Language (failing example 7)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-14-07", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-08.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-08.json new file mode 100644 index 000000000..1255cb6a1 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-08.json @@ -0,0 +1,27 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "fr-ZZ", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Use of Private Language (failing example 8)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-14-08", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-11.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-11.json new file mode 100644 index 000000000..fcd773d5c --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-11.json @@ -0,0 +1,27 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "en-US", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Use of Private Language (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-14-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-12.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-12.json new file mode 100644 index 000000000..836045cee --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-12.json @@ -0,0 +1,28 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "en-US", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "source_lang": "de-DE", + "title": "Optional test: Use of Private Language (valid example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-14-12", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-15-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-15-01.json new file mode 100644 index 000000000..528694f56 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-15-01.json @@ -0,0 +1,27 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "i-default", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Use of Default Language (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-15-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-15-02.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-15-02.json new file mode 100644 index 000000000..c5934c3c8 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-15-02.json @@ -0,0 +1,28 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "en", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "source_lang": "i-default", + "title": "Optional test: Use of Default Language (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-15-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-15-11.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-15-11.json new file mode 100644 index 000000000..9699204e7 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-15-11.json @@ -0,0 +1,27 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "lang": "en", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Use of Default Language (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-15-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-16-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-16-01.json new file mode 100644 index 000000000..e30025bc1 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-16-01.json @@ -0,0 +1,43 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Missing Product Identification Helper (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-16-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "fixed": [ + "CSAFPID-9080700" + ] + } + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-16-02.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-16-02.json new file mode 100644 index 000000000..3d22f849b --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-16-02.json @@ -0,0 +1,59 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Missing Product Identification Helper (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-16-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version", + "name": "6.7", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A 6.7" + } + } + ] + } + ] + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "fixed": [ + "CSAFPID-9080700" + ] + } + } + ] +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-16-11.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-16-11.json new file mode 100644 index 000000000..d95508869 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-16-11.json @@ -0,0 +1,48 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Missing Product Identification Helper (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-16-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A", + "product_identification_helper": { + "serial_numbers": [ + "98765?43210-BCD*" + ] + } + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "fixed": [ + "CSAFPID-9080700" + ] + } + } + ] +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-17-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-17-01.json new file mode 100644 index 000000000..46e6888b0 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-17-01.json @@ -0,0 +1,36 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: CVE in field IDs (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-17-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "ids": [ + { + "system_name": "CVE Project", + "text": "CVE-2021-44228" + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-17-11.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-17-11.json new file mode 100644 index 000000000..2d73d04a1 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-17-11.json @@ -0,0 +1,36 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: CVE in field IDs (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-17-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "vulnerabilities": [ + { + "ids": [ + { + "system_name": "GitHub Issue", + "text": "csaf-tools/CVRF-CSAF-Converter#78" + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-18-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-18-01.json new file mode 100644 index 000000000..17dae9ffe --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-18-01.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Product Version Range without vers (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-18-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version_range", + "name": ">4.2", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A later than 4.2" + } + } + ] + } + ] + } + ] + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-18-11.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-18-11.json new file mode 100644 index 000000000..d79110c9a --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-18-11.json @@ -0,0 +1,50 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Product Version Range without vers (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-18-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "product_version_range", + "name": "vers:generic/>4.2", + "product": { + "product_id": "CSAFPID-9080700", + "name": "Example Company Product A later than 4.2" + } + } + ] + } + ] + } + ] + } +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-01.json new file mode 100644 index 000000000..de745d48d --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-01.json @@ -0,0 +1,56 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: CVSS for Fixed Products (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-19-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "fixed": [ + "CSAFPID-9080700" + ] + }, + "scores": [ + { + "cvss_v3": { + "baseScore": 6.5, + "baseSeverity": "MEDIUM", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "version": "3.1" + }, + "products": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-02.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-02.json new file mode 100644 index 000000000..d6a9c65c6 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-02.json @@ -0,0 +1,58 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: CVSS for Fixed Products (failing example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-19-02", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "fixed": [ + "CSAFPID-9080700" + ] + }, + "scores": [ + { + "cvss_v3": { + "baseScore": 6.5, + "baseSeverity": "MEDIUM", + "modifiedConfidentialality": "NONE", + "modifiedIntegrity": "NONE", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "version": "3.1" + }, + "products": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-03.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-03.json new file mode 100644 index 000000000..f3c4bb154 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-03.json @@ -0,0 +1,56 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: CVSS for Fixed Products (failing example 3)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-19-03", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "fixed": [ + "CSAFPID-9080700" + ] + }, + "scores": [ + { + "cvss_v2": { + "baseScore": 6.8, + "targetDistribution": "LOW", + "vectorString": "AV:A/AC:L/Au:N/C:P/I:N/A:C", + "version": "2.0" + }, + "products": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-04.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-04.json new file mode 100644 index 000000000..32f88fea6 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-04.json @@ -0,0 +1,55 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: CVSS for Fixed Products (failing example 4)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-19-04", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "fixed": [ + "CSAFPID-9080700" + ] + }, + "scores": [ + { + "cvss_v2": { + "baseScore": 6.8, + "vectorString": "AV:A/AC:L/Au:N/C:P/I:N/A:C", + "version": "2.0" + }, + "products": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-05.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-05.json new file mode 100644 index 000000000..642e059cc --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-05.json @@ -0,0 +1,56 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: CVSS for Fixed Products (failing example 5)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-19-05", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "first_fixed": [ + "CSAFPID-9080700" + ] + }, + "scores": [ + { + "cvss_v3": { + "baseScore": 6.5, + "baseSeverity": "MEDIUM", + "vectorString": "CVSS:3.0/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "version": "3.0" + }, + "products": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-06.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-06.json new file mode 100644 index 000000000..31aba2ea4 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-06.json @@ -0,0 +1,58 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: CVSS for Fixed Products (failing example 6)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-19-06", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "fixed": [ + "CSAFPID-9080700" + ] + }, + "scores": [ + { + "cvss_v3": { + "baseScore": 6.5, + "baseSeverity": "MEDIUM", + "modifiedConfidentialality": "NONE", + "modifiedIntegrity": "NONE", + "vectorString": "CVSS:3.0/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "version": "3.0" + }, + "products": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-11.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-11.json new file mode 100644 index 000000000..67c06a10c --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-11.json @@ -0,0 +1,56 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: CVSS for Fixed Products (valid example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-19-11", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "fixed": [ + "CSAFPID-9080700" + ] + }, + "scores": [ + { + "cvss_v3": { + "baseScore": 6.5, + "baseSeverity": "MEDIUM", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H/MC:N/MI:N/MA:N", + "version": "3.1" + }, + "products": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-12.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-12.json new file mode 100644 index 000000000..c06745c3e --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-12.json @@ -0,0 +1,59 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: CVSS for Fixed Products (valid example 2)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-19-12", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "fixed": [ + "CSAFPID-9080700" + ] + }, + "scores": [ + { + "cvss_v3": { + "baseScore": 6.5, + "baseSeverity": "MEDIUM", + "modifiedAvailabilityImpact": "NONE", + "modifiedConfidentialityImpact": "NONE", + "modifiedIntegrityImpact": "NONE", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "version": "3.1" + }, + "products": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-13.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-13.json new file mode 100644 index 000000000..5acf96fae --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-13.json @@ -0,0 +1,56 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: CVSS for Fixed Products (valid example 3)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-19-13", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "fixed": [ + "CSAFPID-9080700" + ] + }, + "scores": [ + { + "cvss_v2": { + "baseScore": 6.8, + "targetDistribution": "NONE", + "vectorString": "AV:A/AC:L/Au:N/C:P/I:N/A:C", + "version": "2.0" + }, + "products": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-14.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-14.json new file mode 100644 index 000000000..aa48735b1 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-14.json @@ -0,0 +1,55 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: CVSS for Fixed Products (valid example 4)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-19-14", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "fixed": [ + "CSAFPID-9080700" + ] + }, + "scores": [ + { + "cvss_v2": { + "baseScore": 6.8, + "vectorString": "AV:A/AC:L/Au:N/C:P/I:N/A:C/TD:N", + "version": "2.0" + }, + "products": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-15.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-15.json new file mode 100644 index 000000000..ebeb9d0fa --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-15.json @@ -0,0 +1,56 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: CVSS for Fixed Products (valid example 5)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-19-15", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "first_fixed": [ + "CSAFPID-9080700" + ] + }, + "scores": [ + { + "cvss_v3": { + "baseScore": 6.5, + "baseSeverity": "MEDIUM", + "vectorString": "CVSS:3.0/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H/MC:N/MI:N/MA:N", + "version": "3.0" + }, + "products": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-16.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-16.json new file mode 100644 index 000000000..cb7fa1eec --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-16.json @@ -0,0 +1,59 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: CVSS for Fixed Products (valid example 6)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-19-16", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "fixed": [ + "CSAFPID-9080700" + ] + }, + "scores": [ + { + "cvss_v3": { + "baseScore": 6.5, + "baseSeverity": "MEDIUM", + "modifiedAvailabilityImpact": "NONE", + "modifiedConfidentialityImpact": "NONE", + "modifiedIntegrityImpact": "NONE", + "vectorString": "CVSS:3.0/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "version": "3.0" + }, + "products": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-17.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-17.json new file mode 100644 index 000000000..2928fa31b --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-17.json @@ -0,0 +1,56 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: CVSS for Fixed Products (valid example 7)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-19-17", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + }, + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "known_affected": [ + "CSAFPID-9080700" + ] + }, + "scores": [ + { + "cvss_v3": { + "baseScore": 6.5, + "baseSeverity": "MEDIUM", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "version": "3.1" + }, + "products": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +} diff --git a/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-20-01.json b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-20-01.json new file mode 100644 index 000000000..2471fbc25 --- /dev/null +++ b/csaf_2.1/test/validator/data/optional/oasis_csaf_tc-csaf_2_0-2021-6-2-20-01.json @@ -0,0 +1,27 @@ +{ + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "custom_property": "any", + "publisher": { + "category": "other", + "name": "OASIS CSAF TC", + "namespace": "https://csaf.io" + }, + "title": "Optional test: Additional Properties (failing example 1)", + "tracking": { + "current_release_date": "2021-07-21T10:00:00.000Z", + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-20-01", + "initial_release_date": "2021-07-21T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } + } +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/data/testcases.json b/csaf_2.1/test/validator/data/testcases.json new file mode 100644 index 000000000..a806147aa --- /dev/null +++ b/csaf_2.1/test/validator/data/testcases.json @@ -0,0 +1,1294 @@ +{ + "$schema": "https://raw.githubusercontent.com/oasis-tcs/csaf/master/csaf_2.0/test/validator/testcases_json_schema.json", + "testschema_version": "2.0", + "tests": [ + { + "id": "6.1.1", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-01-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.2", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-02-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.3", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-03-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.4", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-04-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.5", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-05-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.6", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-01.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-02.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-03.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-04.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-05.json", + "valid": false + } + ], + "valid": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-11.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-12.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-13.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-14.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-06-15.json", + "valid": true + } + ] + }, + { + "id": "6.1.7", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-07-01.json", + "valid": false + } + ], + "valid": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-07-11.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-07-12.json", + "valid": true + } + ] + }, + { + "id": "6.1.8", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-08-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.9", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-09-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.10", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-10-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.11", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-11-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.12", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-12-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.13", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-13-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.14", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-14-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.15", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-15-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.16", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-01.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-02.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-03.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-04.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-05.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-06.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-07.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-08.json", + "valid": false + } + ], + "valid": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-11.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-12.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-13.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-14.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-15.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-16.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-17.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-18.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-19.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-16-31.json", + "valid": true + } + ] + }, + { + "id": "6.1.17", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-17-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.18", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-18-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.19", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-19-01.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-19-02.json", + "valid": false + } + ] + }, + { + "id": "6.1.20", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-20-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.21", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-01.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-02.json", + "valid": false + } + ], + "valid": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-11.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-12.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-21-13.json", + "valid": true + } + ] + }, + { + "id": "6.1.22", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-22-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.23", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-23-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.24", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-01.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-02.json", + "valid": false + } + ], + "valid": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-11.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-24-12.json", + "valid": true + } + ] + }, + { + "id": "6.1.25", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-25-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.26", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-26-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.27.1", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-01-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.27.2", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-02-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.27.3", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-03-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.27.4", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-04-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.27.5", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-05-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.27.6", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-06-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.27.7", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-07-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.27.8", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-08-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.27.9", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-01.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-02.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-03.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-04.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-05.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-06.json", + "valid": false + } + ], + "valid": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-11.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-12.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-13.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-14.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-15.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-09-16.json", + "valid": true + } + ] + }, + { + "id": "6.1.27.10", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-10-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.27.11", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-27-11-01.json", + "valid": false + } + ] + }, + { + "id": "6.1.28", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-28-01.json", + "valid": false + } + ], + "valid": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-28-11.json", + "valid": true + } + ] + }, + { + "id": "6.1.29", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-29-01.json", + "valid": false + } + ], + "valid": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-29-11.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-29-12.json", + "valid": true + } + ] + }, + { + "id": "6.1.30", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-30-01.json", + "valid": false + } + ], + "valid": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-30-11.json", + "valid": true + } + ] + }, + { + "id": "6.1.31", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-01.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-02.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-03.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-04.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-05.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-06.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-07.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-08.json", + "valid": false + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-09.json", + "valid": false + } + ], + "valid": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-11.json", + "valid": true + }, + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-31-12.json", + "valid": true + } + ] + }, + { + "id": "6.1.32", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-32-01.json", + "valid": false + } + ], + "valid": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-32-11.json", + "valid": true + } + ] + }, + { + "id": "6.1.33", + "group": "mandatory", + "failures": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-33-01.json", + "valid": false + } + ], + "valid": [ + { + "name": "mandatory/oasis_csaf_tc-csaf_2_0-2021-6-1-33-11.json", + "valid": true + } + ] + }, + { + "id": "6.2.1", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-01-01.json", + "valid": true + } + ], + "valid": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-01-11.json", + "valid": true + } + ] + }, + { + "id": "6.2.2", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-02-01.json", + "valid": true + } + ] + }, + { + "id": "6.2.3", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-03-01.json", + "valid": true + } + ] + }, + { + "id": "6.2.4", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-04-01.json", + "valid": true + } + ] + }, + { + "id": "6.2.5", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-05-01.json", + "valid": true + } + ] + }, + { + "id": "6.2.6", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-06-01.json", + "valid": true + } + ] + }, + { + "id": "6.2.7", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-07-01.json", + "valid": true + } + ] + }, + { + "id": "6.2.8", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-08-01.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-08-02.json", + "valid": true + } + ] + }, + { + "id": "6.2.9", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-09-01.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-09-02.json", + "valid": true + } + ] + }, + { + "id": "6.2.10", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-10-01.json", + "valid": true + } + ] + }, + { + "id": "6.2.11", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-11-01.json", + "valid": true + } + ], + "valid": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-11-11.json", + "valid": true + } + ] + }, + { + "id": "6.2.12", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-12-01.json", + "valid": true + } + ] + }, + { + "id": "6.2.13", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-13-01.json", + "valid": true + } + ] + }, + { + "id": "6.2.14", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-01.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-02.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-03.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-04.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-05.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-06.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-07.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-08.json", + "valid": true + } + ], + "valid": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-11.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-14-12.json", + "valid": true + } + ] + }, + { + "id": "6.2.15", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-15-01.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-15-02.json", + "valid": true + } + ], + "valid": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-15-11.json", + "valid": true + } + ] + }, + { + "id": "6.2.16", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-16-01.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-16-02.json", + "valid": true + } + ], + "valid": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-16-11.json", + "valid": true + } + ] + }, + { + "id": "6.2.17", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-17-01.json", + "valid": true + } + ], + "valid": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-17-11.json", + "valid": true + } + ] + }, + { + "id": "6.2.18", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-18-01.json", + "valid": true + } + ], + "valid": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-18-11.json", + "valid": true + } + ] + }, + { + "id": "6.2.19", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-01.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-02.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-03.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-04.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-05.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-06.json", + "valid": true + } + ], + "valid": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-11.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-12.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-13.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-14.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-15.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-16.json", + "valid": true + }, + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-19-17.json", + "valid": true + } + ] + }, + { + "id": "6.2.20", + "group": "optional", + "failures": [ + { + "name": "optional/oasis_csaf_tc-csaf_2_0-2021-6-2-20-01.json", + "valid": true + } + ] + }, + { + "id": "6.3.1", + "group": "informative", + "failures": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-01.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-02.json", + "valid": true + } + ], + "valid": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-11.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-01-12.json", + "valid": true + } + ] + }, + { + "id": "6.3.2", + "group": "informative", + "failures": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-01.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-02.json", + "valid": true + } + ], + "valid": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-11.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-02-12.json", + "valid": true + } + ] + }, + { + "id": "6.3.3", + "group": "informative", + "failures": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-01.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-02.json", + "valid": true + } + ], + "valid": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-11.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-03-12.json", + "valid": true + } + ] + }, + { + "id": "6.3.4", + "group": "informative", + "failures": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-01.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-02.json", + "valid": true + } + ], + "valid": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-11.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-04-12.json", + "valid": true + } + ] + }, + { + "id": "6.3.5", + "group": "informative", + "failures": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-05-01.json", + "valid": true + } + ] + }, + { + "id": "6.3.6", + "group": "informative", + "failures": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-06-01.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-06-02.json", + "valid": true + } + ], + "valid": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-06-11.json", + "valid": true + } + ] + }, + { + "id": "6.3.7", + "group": "informative", + "failures": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-07-01.json", + "valid": true + } + ], + "valid": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-07-11.json", + "valid": true + } + ] + }, + { + "id": "6.3.8", + "group": "informative", + "failures": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-08-01.json", + "valid": true + } + ], + "valid": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-08-11.json", + "valid": true + } + ] + }, + { + "id": "6.3.9", + "group": "informative", + "failures": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-01.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-02.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-03.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-04.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-05.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-06.json", + "valid": true + } + ], + "valid": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-11.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-12.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-13.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-14.json", + "valid": true + }, + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-09-15.json", + "valid": true + } + ] + }, + { + "id": "6.3.10", + "group": "informative", + "failures": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-10-01.json", + "valid": true + } + ], + "valid": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-10-11.json", + "valid": true + } + ] + }, + { + "id": "6.3.11", + "group": "informative", + "failures": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-11-01.json", + "valid": true + } + ], + "valid": [ + { + "name": "informative/oasis_csaf_tc-csaf_2_0-2021-6-3-11-11.json", + "valid": true + } + ] + } + ] +} \ No newline at end of file diff --git a/csaf_2.1/test/validator/run_tests.sh b/csaf_2.1/test/validator/run_tests.sh new file mode 100755 index 000000000..ef8977ca6 --- /dev/null +++ b/csaf_2.1/test/validator/run_tests.sh @@ -0,0 +1,52 @@ +#!/bin/bash + +ORIG_SCHEMA=csaf_2.0/json_schema/csaf_json_schema.json +STRICT_SCHEMA=csaf_strict_schema.json +VALIDATOR=csaf_2.0/test/validator.py +STRICT_GENERATOR=csaf_2.0/test/generate_strict_schema.py +TESTPATH=csaf_2.0/test/validator/data/$1/*.json +EXCLUDE=oasis_csaf_tc-csaf_2_0-2021-6-1-08-01.json +EXCLUDE_STRICT=oasis_csaf_tc-csaf_2_0-2021-6-2-20-01.json + +FAIL=0 + +# go to root of git repository +cd `dirname $0`/../../.. + +validate() { + printf "%s" "Testing file $1 against schema ${SCHEMA} ... " + if python3 $VALIDATOR $SCHEMA $1; then + printf "%s\n" SUCCESS + else + printf "%s\n" FAILED + FAIL=1 + fi + +} + +test_all() { + for i in $(ls -1 ${TESTPATH} | grep -v $EXCLUDE) + do + validate $i + done +} + +test_all_strict() { + for i in $(ls -1 ${TESTPATH} | grep -v $EXCLUDE | grep -v ${EXCLUDE_STRICT}) + do + validate $i + done +} + +SCHEMA=$ORIG_SCHEMA +test_all + + +printf "%s" "Generating strict schema ... " +python3 "${STRICT_GENERATOR}" "${ORIG_SCHEMA}" > "${STRICT_SCHEMA}" +printf "%s\n" "done" + +SCHEMA=${STRICT_SCHEMA} +test_all_strict + +exit ${FAIL} diff --git a/csaf_2.1/test/validator/testcases_json_schema.json b/csaf_2.1/test/validator/testcases_json_schema.json new file mode 100644 index 000000000..b66e05e90 --- /dev/null +++ b/csaf_2.1/test/validator/testcases_json_schema.json @@ -0,0 +1,103 @@ +{ + "$schema": "https://json-schema.org/draft/2020-12/schema", + "$id": "https://raw.githubusercontent.com/oasis-tcs/csaf/master/csaf_2.0/test/validator/testcases_json_schema.json", + "title": "Test cases for CSAF", + "description": "Representation of the data provided for test cases from section 6 of the specification.", + "type": "object", + "$defs": { + "file_t": { + "title": "File information", + "description": "Contains information about a single test file.", + "type": "object", + "required": [ + "name", + "valid" + ], + "properties": { + "name": { + "title": "Name of the test file", + "description": "Contains the filename and path relative to the JSON that includes this object.", + "type": "string", + "pattern": "^.+\\.json$" + }, + "valid": { + "title": "Evaluation result", + "description": "States whether the test file is valid according to the CSAF standard.", + "type": "boolean" + } + }, + "additionalProperties": false + }, + "test_t": { + "title": "Test", + "description": "Contains test data for a single test.", + "type": "object", + "required": [ + "failures", + "id", + "group" + ], + "properties": { + "failures": { + "title": "List of failing examples", + "description": "Contains a list of files of examples that fail that specific test.", + "type": "array", + "uniqueItems": true, + "minItems": 1, + "items": { + "$ref": "#/$defs/file_t" + } + }, + "group": { + "title": "Test group", + "description": "Contains the name of the group the test belongs to.", + "type": "string", + "enum": [ + "mandatory", + "informative", + "optional" + ] + }, + "id": { + "title": "Number of the test", + "description": "Contains the section number of the test in the specification.", + "type": "string", + "pattern": "^6\\.(([1-3]\\.[1-9])|([12]\\.1[0-9])|(3\\.1[01])|([12]\\.20)|(1\\.2[1-68-9])|(1\\.27\\.([1-9]|10|11))|(1\\.3[0-3]))$" + }, + "valid": { + "title": "List of valid examples", + "description": "Contains a list of files of examples that pass that specific test.", + "type": "array", + "uniqueItems": true, + "minItems": 1, + "items": { + "$ref": "#/$defs/file_t" + } + } + }, + "additionalProperties": false + } + }, + "required": [ + "tests", + "testschema_version" + ], + "properties": { + "tests": { + "title": "List of tests", + "description": "Contains a list of test data.", + "type": "array", + "minItems": 1, + "uniqueItems": true, + "items": { + "$ref": "#/$defs/test_t" + } + }, + "testschema_version": { + "title": "Test schema version", + "description": "Contains the current version of this schema", + "type": "string", + "enum": ["2.0"] + } + } +} \ No newline at end of file From d831aa40929ec8956cc5a75d2dc7408f2f260390 Mon Sep 17 00:00:00 2001 From: Stefan Hagen Date: Sun, 13 Aug 2023 18:49:29 +0200 Subject: [PATCH 04/74] config: added lint and spell check configs - added a minimal vale config file for spell checks - added a plausible markdownlint config file Signed-off-by: Stefan Hagen --- csaf_2.1/prose/edit/etc/markdownlint.json | 58 +++++++++++++++++++++++ csaf_2.1/prose/edit/etc/vale.ini | 4 ++ 2 files changed, 62 insertions(+) create mode 100644 csaf_2.1/prose/edit/etc/markdownlint.json create mode 100644 csaf_2.1/prose/edit/etc/vale.ini diff --git a/csaf_2.1/prose/edit/etc/markdownlint.json b/csaf_2.1/prose/edit/etc/markdownlint.json new file mode 100644 index 000000000..92382da78 --- /dev/null +++ b/csaf_2.1/prose/edit/etc/markdownlint.json @@ -0,0 +1,58 @@ +{ + "blanks-around-fences": false, + "blanks-around-lists": false, + "code-block-style": false, + "code-fence-style": { + "style": "backtick" + }, + "emphasis-style": { + "style": "asterisk" + }, + "fenced-code-language": false, + "first-line-heading": false, + "heading-style": { + "style": "atx" + }, + "hr-style": { + "style": "---" + }, + "line-length": false, + "link-fragments": false, + "link-image-reference-definitions": false, + "list-marker-space": false, + "no-blanks-blockquote": false, + "no-duplicate-heading": { + "siblings_only": true + }, + "no-emphasis-as-heading": false, + "no-hard-tabs": false, + "no-inline-html": { + "allowed_elements": [ + "a", + "br", + "em", + "col", + "colgroup", + "img", + "p", + "pre", + "span", + "strong", + "sub", + "sup", + "table", + "tbody", + "td", + "th", + "thead", + "tr" + ] + }, + "ol-prefix": false, + "strong-style": { + "style": "asterisk" + }, + "ul-style": { + "style": "asterisk" + } +} diff --git a/csaf_2.1/prose/edit/etc/vale.ini b/csaf_2.1/prose/edit/etc/vale.ini new file mode 100644 index 000000000..4011b8fb4 --- /dev/null +++ b/csaf_2.1/prose/edit/etc/vale.ini @@ -0,0 +1,4 @@ +MinAlertLevel = suggestion + +[*] +BasedOnStyles = Vale From 767e101809f8c13bfe5be0b28825bc458d547b67 Mon Sep 17 00:00:00 2001 From: Stefan Hagen Date: Sun, 13 Aug 2023 19:27:27 +0200 Subject: [PATCH 05/74] config: adapted markdownlint rules to unfortunate reality (for now) - to reduce the noise (esp. dealing with the OASIS boilerplate like e.g. frontmatter and the past practice of using bare URLs some exemptions were added to the markdownlint configuration file (still the hack for references triggers a rule we will want to keep, namely blanks-around-headings/blanks-around-headers Signed-off-by: Stefan Hagen --- csaf_2.1/prose/edit/etc/markdownlint.json | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/csaf_2.1/prose/edit/etc/markdownlint.json b/csaf_2.1/prose/edit/etc/markdownlint.json index 92382da78..eeb146319 100644 --- a/csaf_2.1/prose/edit/etc/markdownlint.json +++ b/csaf_2.1/prose/edit/etc/markdownlint.json @@ -6,7 +6,7 @@ "style": "backtick" }, "emphasis-style": { - "style": "asterisk" + "style": "underscore" }, "fenced-code-language": false, "first-line-heading": false, @@ -14,12 +14,13 @@ "style": "atx" }, "hr-style": { - "style": "---" + "style": "-------" }, "line-length": false, "link-fragments": false, "link-image-reference-definitions": false, "list-marker-space": false, + "no-bare-urls": false, "no-blanks-blockquote": false, "no-duplicate-heading": { "siblings_only": true @@ -48,6 +49,7 @@ "tr" ] }, + "no-trailing-punctuation": false, "ol-prefix": false, "strong-style": { "style": "asterisk" From 85d09963d5242bd2c56dfb123c98b85be34a2ade Mon Sep 17 00:00:00 2001 From: Stefan Hagen Date: Sun, 13 Aug 2023 19:30:12 +0200 Subject: [PATCH 06/74] refactor: added inital source segregation with binder file - cut the elephant markdown file into per level 1 or 2 section sliced files and added a binder file at etc/bind.txt to declare the order for the concatenation - added YAML metadata to the appendix files to ease processing - markdowlint shows the same findings for the elephant and for all source files Sogned-off-by: Stefan Hagen --- csaf_2.1/prose/edit/etc/bind.txt | 25 + csaf_2.1/prose/edit/src/acknowledgements.md | 134 ++ .../prose/edit/src/additional-conventions.md | 46 + csaf_2.1/prose/edit/src/conformance.md | 403 +++++ .../edit/src/design-considerations-00.md | 14 + ...nsiderations-01-construction-principles.md | 48 + csaf_2.1/prose/edit/src/distributing.md | 601 +++++++ csaf_2.1/prose/edit/src/frontmatter.md | 106 ++ csaf_2.1/prose/edit/src/guidance-on-size.md | 344 ++++ csaf_2.1/prose/edit/src/introduction-00.md | 2 + .../edit/src/introduction-01-ipr-policy.md | 4 + .../edit/src/introduction-02-terminology.md | 152 ++ .../introduction-03-normative-references.md | 19 + .../introduction-04-informative-references.md | 85 + ...troduction-05-typographical-conventions.md | 24 + csaf_2.1/prose/edit/src/profiles.md | 118 ++ csaf_2.1/prose/edit/src/revision-history.md | 20 + .../safety-security-and-data-protection.md | 18 + csaf_2.1/prose/edit/src/schema-elements-00.md | 26 + .../src/schema-elements-01-definitions.md | 1055 ++++++++++++ .../edit/src/schema-elements-02-properties.md | 1398 +++++++++++++++ csaf_2.1/prose/edit/src/table-of-contents.md | 7 + csaf_2.1/prose/edit/src/tests-00.md | 4 + csaf_2.1/prose/edit/src/tests-01-mandatory.md | 1529 +++++++++++++++++ csaf_2.1/prose/edit/src/tests-02-optional.md | 626 +++++++ .../prose/edit/src/tests-03-informative.md | 394 +++++ 26 files changed, 7202 insertions(+) create mode 100644 csaf_2.1/prose/edit/etc/bind.txt create mode 100644 csaf_2.1/prose/edit/src/acknowledgements.md create mode 100644 csaf_2.1/prose/edit/src/additional-conventions.md create mode 100644 csaf_2.1/prose/edit/src/conformance.md create mode 100644 csaf_2.1/prose/edit/src/design-considerations-00.md create mode 100644 csaf_2.1/prose/edit/src/design-considerations-01-construction-principles.md create mode 100644 csaf_2.1/prose/edit/src/distributing.md create mode 100644 csaf_2.1/prose/edit/src/frontmatter.md create mode 100644 csaf_2.1/prose/edit/src/guidance-on-size.md create mode 100644 csaf_2.1/prose/edit/src/introduction-00.md create mode 100644 csaf_2.1/prose/edit/src/introduction-01-ipr-policy.md create mode 100644 csaf_2.1/prose/edit/src/introduction-02-terminology.md create mode 100644 csaf_2.1/prose/edit/src/introduction-03-normative-references.md create mode 100644 csaf_2.1/prose/edit/src/introduction-04-informative-references.md create mode 100644 csaf_2.1/prose/edit/src/introduction-05-typographical-conventions.md create mode 100644 csaf_2.1/prose/edit/src/profiles.md create mode 100644 csaf_2.1/prose/edit/src/revision-history.md create mode 100644 csaf_2.1/prose/edit/src/safety-security-and-data-protection.md create mode 100644 csaf_2.1/prose/edit/src/schema-elements-00.md create mode 100644 csaf_2.1/prose/edit/src/schema-elements-01-definitions.md create mode 100644 csaf_2.1/prose/edit/src/schema-elements-02-properties.md create mode 100644 csaf_2.1/prose/edit/src/table-of-contents.md create mode 100644 csaf_2.1/prose/edit/src/tests-00.md create mode 100644 csaf_2.1/prose/edit/src/tests-01-mandatory.md create mode 100644 csaf_2.1/prose/edit/src/tests-02-optional.md create mode 100644 csaf_2.1/prose/edit/src/tests-03-informative.md diff --git a/csaf_2.1/prose/edit/etc/bind.txt b/csaf_2.1/prose/edit/etc/bind.txt new file mode 100644 index 000000000..95452d559 --- /dev/null +++ b/csaf_2.1/prose/edit/etc/bind.txt @@ -0,0 +1,25 @@ +frontmatter.md +table-of-contents.md +introduction-00.md +introduction-01-ipr-policy.md +introduction-02-terminology.md +introduction-03-normative-references.md +introduction-04-informative-references.md +introduction-05-typographical-conventions.md +design-considerations-00.md +design-considerations-01-construction-principles.md +schema-elements-00.md +schema-elements-01-definitions.md +schema-elements-02-properties.md +profiles.md +additional-conventions.md +tests-00.md +tests-01-mandatory.md +tests-02-optional.md +tests-03-informative.md +distributing.md +safety-security-and-data-protection.md +conformance.md +acknowledgements.md +revision-history.md +guidance-on-size.md diff --git a/csaf_2.1/prose/edit/src/acknowledgements.md b/csaf_2.1/prose/edit/src/acknowledgements.md new file mode 100644 index 000000000..b757e73da --- /dev/null +++ b/csaf_2.1/prose/edit/src/acknowledgements.md @@ -0,0 +1,134 @@ + +# Appendix A. Acknowledgments + +The following individuals were members of the OASIS CSAF Technical Committee during the creation of this specification and their contributions are gratefully acknowledged: + +**CSAF TC Members:** + +| First Name | Last Name | Company | +| :--- | :--- | :--- | +|Alexandre | Dulaunoy | CIRCL| +|Anthony | Berglas | Cryptsoft Pty Ltd.| +|Art | Manion | Carnegie Mellon University| +|Aukjan | van Belkum | EclecticIQ| +|Ben | Sooter | Electric Power Research Institute (EPRI)| +|Bernd | Grobauer | Siemens AG| +|Bruce | Rich | Cryptsoft Pty Ltd.| +|Chok | Poh | Oracle| +|Dan | West | Microsoft| +|David | Waltermire | NIST| +|Denny | Page | TIBCO Software Inc.| +|Duncan | Sparrell | sFractal Consulting LLC| +|Eric | Johnson | TIBCO Software Inc.| +|Ethan | Rahn | Arista Networks| +|Feng | Cao | Oracle| +|Greg | Scott | Cryptsoft Pty Ltd.| +|Harold | Booth | NIST| +|Jason | Masters | TELUS| +|Jennifer | Victor | Dell| +|Jessica | Fitzgerald-McKay | National Security Agency| +|Jonathan | Bitle | Kaiser Permanente| +|Justin | Corlett | Cryptsoft Pty Ltd.| +|Kazuo | Noguchi | Hitachi, Ltd.| +|Kent | Landfield | McAfee| +|Langley | Rock | Red Hat| +|Martin | Prpic | Red Hat| +|Masato | Terada | Hitachi, Ltd.| +|Mike | Gorski | Cisco Systems| +|Nicole | Parrish | Mitre Corporation| +|Omar | Santos | Cisco Systems| +|Patrick | Maroney | AT&T| +|Rhonda | Levy | Cisco Systems| +|Richard | Struse | Mitre Corporation| +|Ritwik | Ghoshal | Oracle| +|Robert | Coderre | Accenture| +|Robert | Keith | Accenture| +|Stefan | Hagen | Individual| +|Tania | Ward | Dell| +|Ted | Bedwell | Cisco Systems| +|Thomas | Proell | Siemens AG| +|Thomas | Schmidt | Federal Office for Information Security (BSI) Germany| +|Tim | Hudson | Cryptsoft Pty Ltd.| +|Tobias | Limmer | Siemens AG| +|Tony | Cox | Cryptsoft Pty Ltd.| +|Vincent | Danen | Red Hat| +|Will | Rideout | Arista Networks| +|Xiaoyu | Ge | Huawei Technologies Co., Ltd.| + +The following individuals were members of the OASIS CSAF Technical Committee during the creation of the previous version (CVRF v1.2) of this specification and their contributions are gratefully acknowledged: + +**CSAF TC Members:** + +| First Name | Last Name | Company | +| :--- | :--- | :--- | +|Adam | Montville | CIS| +|Allan | Thomson | LookingGlass| +|Anthony | Berglas | Cryptsoft Pty Ltd.| +|Art | Manion | Carnegie Mellon University| +|Aukjan | van Belkum | EclecticIQ| +|Ben | Sooter | Electric Power Research Institute| +|Bernd | Grobauer | Siemens AG| +|Beth | Pumo | Kaiser Permanente| +|Bret | Jordan | Symantec Corp.| +|Bruce | Rich | Cryptsoft Pty Ltd.| +|Chet | Ensign | OASIS| +|Chok | Poh | Oracle| +|Chris | Rouland | Individual| +|David | Waltermire | NIST| +|Denny | Page | TIBCO Software Inc.| +|Doron | Shiloach | IBM| +|Duncan | Sparrell | sFractal Consulting LLC| +|Eric | Johnson | TIBCO Software Inc.| +|Feng | Cao | Oracle| +|Greg | Reaume | TELUS| +|Greg | Scott | Cryptsoft Pty Ltd.| +|Harold | Booth | NIST| +|Jamison | Day | LookingGlass| +|Jared | Semrau | "FireEye, Inc."| +|Jason | Masters | TELUS| +|Jerome | Athias | Individual| +|Jessica | Fitzgerald-McKay | National Security Agency| +|Jonathan | Bitle | Kaiser Permanente| +|Justin | Corlett | Cryptsoft Pty Ltd.| +|Karen | Scarfone | Individual| +|Kazuo | Noguchi | "Hitachi, Ltd."| +|Kent | Landfield | McAfee| +|Lothar | Braun | Siemens AG| +|Louis | Ronnau | Cisco Systems| +|Mark | Davidson | NC4| +|Mark-David | McLaughlin | Cisco Systems| +|Masato | Terada | "Hitachi, Ltd."| +|Masood | Nasir | TELUS| +|Nicole | Gong | Mitre Corporation| +|Omar | Santos | Cisco Systems| +|Patrick | Maroney | Wapack Labs LLC| +|Paul | Patrick | "FireEye, Inc."| +|Peter | Allor | IBM| +|Phillip | Boles | "FireEye, Inc."| +|Ravi | Balupari | Netskope| +|Rich | Reybok | ServiceNow| +|Richard | Struse | DHS Office of Cybersecurity and Communications (CS&C)| +|Ritwik | Ghoshal | Oracle| +|Robert | Coderre | VeriSign| +|Robin | Cover | OASIS| +|Rupert | Wimmer | Siemens AG| +|Sanjiv | Kalkar | Individual| +|Sean | Barnum | Mitre Corporation| +|Stefan | Hagen | Individual| +|Ted | Bedwell | Cisco Systems| +|Thomas | Schreck | Siemens AG| +|Tim | Hudson | Cryptsoft Pty Ltd.| +|Tony | Cox | Cryptsoft Pty Ltd.| +|Trey | Darley | "Kingfisher Operations, sprl"| +|Vincent | Danen | Red Hat| +|Zach | Turk | Microsoft| + +------- + diff --git a/csaf_2.1/prose/edit/src/additional-conventions.md b/csaf_2.1/prose/edit/src/additional-conventions.md new file mode 100644 index 000000000..db9b8ba7d --- /dev/null +++ b/csaf_2.1/prose/edit/src/additional-conventions.md @@ -0,0 +1,46 @@ +# 5 Additional Conventions + +This section provides additional rules for handling CSAF documents. + +## 5.1 Filename + +The following rules MUST be applied to determine the filename for the CSAF document: + +1. The value `/document/tracking/id` is converted into lower case. +2. Any character sequence which is not part of one of the following groups MUST be replaced by a single underscore (`_`): + * Lower case ASCII letters (0x61 - 0x7A) + * digits (0x30 - 0x39) + * special characters: `+` (0x2B), `-` (0x2D) + > The regex `[^+\-a-z0-9]+` can be used to find a character sequence which has to be replaced by an underscore. However, it SHALL NOT be applied before completing the first step. + > + > Even though the underscore `_` (0x5F) is a valid character in the filename it is replaced to avoid situations where the conversion rule might lead to multiple consecutive underscores. As a result, a `/document/tracking/id` with the value `2022_#01-A` is converted into `2022_01-a` instead of `2022__01-a`. +3. The file extension `.json` MUST be appended. + +*Examples 47:* + +``` + cisco-sa-20190513-secureboot.json + example_company_-_2019-yh3234.json + rhba-2019_0024.json +``` + +> It is currently considered best practice to indicate that a CSAF document is invalid by inserting `_invalid` into the filename in front of the file extension. + +*Examples 48:* + +``` + cisco-sa-20190513-secureboot_invalid.json + example_company_-_2019-yh3234_invalid.json + rhba-2019_0024_invalid.json +``` + +## 5.2 Separation in Data Stream + +If multiple CSAF documents are transported via a data stream in a sequence without requests inbetween, they MUST be separated by the Record Separator in accordance with [RFC7464]. + +## 5.3 Sorting + +The keys within a CSAF document SHOULD be sorted alphabetically. + +------- + diff --git a/csaf_2.1/prose/edit/src/conformance.md b/csaf_2.1/prose/edit/src/conformance.md new file mode 100644 index 000000000..223b8df03 --- /dev/null +++ b/csaf_2.1/prose/edit/src/conformance.md @@ -0,0 +1,403 @@ +# 9 Conformance + +In the only subsection of this section, the conformance targets and clauses are listed. +The clauses, matching the targets one to one, are listed in separate sub-subsections of the targets listing subsection. + +Informative Comments: + +> The order in which targets, and their corresponding clauses appear is somewhat arbitrary as there is no natural order on such diverse roles participating in the document exchanging ecosystem. +> +> Except for the target **CSAF document**, all other 16 targets span a taxonomy of the complex CSAF ecosystems existing in and between diverse security advisory generating, sharing, and consuming communities. +> +> In any case, there are no capabilities organized in increasing quality levels for targets because the security advisory sharing communities follow the chain link model. +> Instead, a single minimum capability level for every target is given to maintain important goals of providing a common framework for security advisories: +> +> * Fast production, sharing, and actionable consumption of security advisories +> * Consistent end to end automation through collaborating actors +> * Clear baseline across the communities per this specification +> * Additional per-community cooperative extensions which may flow back into future updates of this specification + +## 9.1 Conformance Targets + +This document defines requirements for the CSAF file format and for certain software components that interact with it. +The entities ("conformance targets") for which this document defines requirements are: + +* **CSAF document**: A security advisory text document in the format defined by this document. +* **CSAF producer**: A program which emits output in the CSAF format. +* **CSAF direct producer**: An analysis tool which acts as a CSAF producer. +* **CSAF converter**: A CSAF producer that transforms the output of an analysis tool from its native output format into the CSAF format. +* **CVRF CSAF converter**: A CSAF producer which takes a CVRF document as input and converts it into a valid CSAF document. +* **CSAF content management system**: A program that is able to create, review and manage CSAF documents and is able to preview their details as required by CSAF viewer. +* **CSAF post-processor**: A CSAF producer that transforms an existing CSAF document into a new CSAF document, for example, by removing or redacting elements according to sharing policies. +* **CSAF modifier**: A CSAF post-processor which takes a CSAF document as input and modifies the structure or values of properties. The output is a valid CSAF document. +* **CSAF translator**: A CSAF post-processor which takes a CSAF document as input and translates values of properties into another language. The output is a valid CSAF document. +* **CSAF consumer**: A program that reads and interprets a CSAF document. +* **CSAF viewer**: A CSAF consumer that reads a CSAF document, displays a list of the results it contains, and allows an end user to view each result in the context of the artifact in which it occurs. +* **CSAF management system**: A program that is able to manage CSAF documents and is able to display their details as required by CSAF viewer. +* **CSAF asset matching system**: A program that connects to or is an asset database and is able to manage CSAF documents as required by CSAF management system as well as matching them to assets of the asset database. +* **CSAF basic validator**: A program that reads a document and checks it against the JSON schema and performs mandatory tests. +* **CSAF extended validator**: A CSAF basic validator that additionally performs optional tests. +* **CSAF full validator**: A CSAF extended validator that additionally performs informative tests. +* **CSAF SBOM matching system**: A program that connects to or is an SBOM database and is able to manage CSAF documents as required by CSAF management system as well as matching them to SBOM components of the SBOM database. + +### 9.1.1 Conformance Clause 1: CSAF document + +A text file or data stream satisfies the "CSAF document" conformance profile if it: + +* conforms to the syntax and semantics defined in section 3. +* satisfies at least one profile defined in section 4. +* does not fail any mandatory test defined in section 6.1. + +### 9.1.2 Conformance Clause 2: CSAF producer + +A program satisfies the "CSAF producer" conformance profile if the program: + +* produces output in the CSAF format, according to the conformance profile "CSAF document" . +* satisfies those normative requirements in section 3 and 8 that are designated as applying to CSAF producers. + +### 9.1.3 Conformance Clause 3: CSAF direct producer + +An analysis tool satisfies the "CSAF direct producer" conformance profile if the analysis tool: + +* satisfies the "CSAF producer" conformance profile. +* additionally satisfies those normative requirements in section 3 that are designated as applying to "direct producers" or to "analysis tools". +* does not emit any objects, properties, or values which, according to section 3, are intended to be produced only by converters. + +### 9.1.4 Conformance Clause 4: CSAF converter + +A converter satisfies the “CSAF converter” conformance profile if the converter: + +* satisfies the "CSAF producer" conformance profile. +* additionally satisfies those normative requirements in section 3 that are designated as applying to converters. +* does not emit any objects, properties, or values which, according to section 3, are intended to be produced only by direct producers. + +### 9.1.5 Conformance Clause 5: CVRF CSAF converter + +A program satisfies the "CVRF CSAF converter" conformance profile if the program fulfills the following two groups of requirements: + +Firstly, the program: + +* satisfies the "CSAF producer" conformance profile. +* takes only CVRF documents as input. +* additionally satisfies the normative requirements given below. + +Secondly, the program fulfills the following for all items of: + +* type `/$defs/branches_t`: If any `prod:Branch` instance has the type `Realm` or `Resource`, the CVRF CSAF converter replaces those with the category `product_name`. In addition, the converter outputs a warning that that those types do not exist in CSAF and have been replaced with the category `product_name`. +* type `/$defs/version_t`: If any element doesn't match the semantic versioning, replace the all elements of type `/$defs/version_t` with the corresponding integer version. For that, CVRF CSAF converter sorts the items of `/document/tracking/revision_history` by `number` ascending according to the rules of CVRF. Then, it replaces the value of `number` with the index number in the array (starting with 1). The value of `/document/tracking/version` is replaced by value of `number` of the corresponding revision item. The match MUST be calculated by the original values used in the CVRF document. If this conversion was applied, for each Revision the original value of `cvrf:Number` MUST be set as `legacy_version` in the converted document. +* `/document/acknowledgments[]/organization` and `/vulnerabilities[]/acknowledgments[]/organization`: If more than one `cvrf:Organization` instance is given, the CVRF CSAF converter converts the first one into the `organization`. In addition, the converter outputs a warning that information might be lost during conversion of document or vulnerability acknowledgment. +* `/document/lang`: If one or more CVRF element containing an `xml:lang` attribute exist and contain the exact same value, the CVRF CSAF converter converts this value into `lang`. If the values of `xml:lang` attributes are not equal, the CVRF CSAF converter outputs a warning that the language could not be determined and possibly a document with multiple languages was produced. In addition, it SHOULD also present all values of `xml:lang` attributes as a set in the warning. +* `/document/publisher/name` and `/document/publisher/namespace`: Sets the value as given in the configuration of the program or the corresponding argument the program was invoked with. If values from both sources are present, the program SHOULD prefer the latter one. The program SHALL NOT use hard-coded values. +* `/document/tracking/id`: If the element `cvrf:ID` contains any line breaks or leading or trailing white space, the CVRF CSAF converter removes those characters. In addition, the converter outputs a warning that the ID was changed. +* `/product_tree/relationships[]`: If more than one `prod:FullProductName` instance is given, the CVRF CSAF converter converts the first one into the `full_product_name`. In addition, the converter outputs a warning that information might be lost during conversion of product relationships. +* `/vulnerabilities[]/cwe`: If more than one `vuln:CWE` instance is given, the CVRF CSAF converter converts the first one into `cwe`. In addition, the converter outputs a warning that information might be lost during conversion of the CWE. +* `/vulnerabilities[]/ids`: If a `vuln:ID` element is given, the CVRF CSAF converter converts it into the first item of the `ids` array. +* `/vulnerabilities[]/remediation[]`: If no `product_ids` or `group_ids` is given, the CVRF CSAF converter appends all Product IDs which are listed under `../product_status` in the arrays `known_affected`, `first_affected` and `last_affected` into `product_ids`. If none of these arrays exist, the CVRF CSAF converter outputs an error that no matching Product ID was found for this remediation element. +* `/vulnerabilities[]/scores[]`: + * For any CVSS v3 element, the CVRF CSAF converter MUST compute the `baseSeverity` from the `baseScore` according to the rules of the applicable CVSS standard. + * If no `product_id` is given, the CVRF CSAF converter appends all Product IDs which are listed under `../product_status` in the arrays `known_affected`, `first_affected` and `last_affected`. If none of these arrays exist, the CVRF CSAF converter outputs an error that no matching Product ID was found for this score element. + * If a `vectorString` is missing, the CVRF CSAF converter outputs an error that the CVSS element could not be converted as the CVSS vector was missing. A CVRF CSAF converter MAY offer a configuration option to delete such elements. + * If there are CVSS v3.0 and CVSS v3.1 Vectors available for the same product, the CVRF CSAF converter discards the CVSS v3.0 information and provide in CSAF only the CVSS v3.1 information. + * To determine, which minor version of CVSS v3 is used, the CVRF CSAF converter uses the following steps: + 1. Retrieve the CVSS version from the CVSS vector, if present. + + *Example 140:* + + ``` + CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H => 3.1 + ``` + + 2. Retrieve the CVSS version from the CVSS element's namespace, if present. The CVRF CSAF converter outputs a warning that this value was guessed from the element's namespace. + + *Example 141:* + + ``` + xmlns:cvssv31="https://www.first.org/cvss/cvss-v3.1.xsd" + + + ``` + + is handled the same as + + *Example 142:* + + ``` + + ``` + + 3. Retrieve the CVSS version from the CVSS namespace given in the root element, if present. The CVRF CSAF converter outputs a warning that this value was guessed from the global namespace. If more than one CVSS namespace is present and the element is not clearly defined via the namespace, this step MUST be skipped without a decision. + + *Example 143:* + + ``` + xmlns:cvssv3="https://www.first.org/cvss/cvss-v3.0.xsd" => 3.0 + ``` + + 4. Retrieve the CVSS version from a config value, which defaults to `3.0`. (As CSAF CVRF v1.2 predates CVSS v3.1.) The CVRF CSAF converter outputs a warning that this value was taken from the config. + +### 9.1.6 Conformance Clause 6: CSAF content management system + +A CSAF content management system satisfies the "CSAF content management system" conformance profile if the content management system: + +* satisfies the "CSAF producer" conformance profile. +* satisfies the "CSAF viewer" conformance profile. +* provides at least the following management functions: + + * create new CSAF documents + * prefill CSAF documents based on values given in the configuration (see below) + * create a new version of an existing CSAF document + * checkout old versions of a CSAF document + * show all differences between versions of a CSAF document + * list all CSAF documents within the system + * delete CSAF documents from the system + * review CSAF documents in the system + * approve CSAF documents + * search for CSAF documents by values of required fields at `document`-level or their children within the system + * search for CSAF documents by values of `cve` within the system + * search for CSAF documents based on properties of `product_tree` + * filter on all properties which it is required to search for + * export of CSAF documents + * show an audit log for each CSAF document + * identify the latest version of CSAF documents with the same `/document/tracking/id` + * suggest a `/document/tracking/id` based on the given configuration. + * track of the version of CSAF documents automatically and increment according to the versioning scheme (see also subsections of 3.1.11) selected in the configuration. + * check that the document version is set correctly based on the changes in comparison to the previous version (see also subsections of 3.1.11). + * suggest to use the document status `interim` if a CSAF document is updated more frequent than the given threshold in the configuration (default: 3 weeks) + * suggest to publish a new version of the CSAF document with the document status `final` if the document status was `interim` and no new release has be done during the the given threshold in the configuration (default: 6 weeks) + * support the following workflows: + + * "New Advisory": create a new advisory, request a review, provide review comments or approve it, resolve review comments; if the review approved it, the approval for publication can be requested; if granted the document status changes to `final` (or `ìnterim` based on the selection in approval or configuration) and the advisory is provided for publication (manual or time-based) + * "Update Advisory": open an existing advisory, create new revision & change content, request a review, provide review comments or approve it, resolve review comments; if the review approved it, the approval for publication can be requested; if granted the document status changes to `final` (or `ìnterim` based on the selection in approval or configuration) and the advisory is provided for publication (manual or time-based) + +* offers both: publication immediately or at a given date/time. +* automates handling of date/time and version. +* provides an API to retrieve all CSAF documents which are currently in the status published. +* optionally provides an API to import or create new advisories from outside systems (e.g. bug tracker, CVD platform,...). +* provides a user management and support at least the following roles: + + * _Registered_: Able to see all published CSAF documents (but only in the published version). + * _Author_: inherits _Registered_ permissions and also can Create and Edit Own (mostly used for automated creation, see above) + * _Editor_: inherits _Author_ permissions and can Edit (mostly used in PSIRT) + * _Publisher_: inherits _Editor_ permissions and can Change state and Review any (mostly used as HEAD of PSIRT or team lead) + * _Reviewer_: inherits _Registered_ permissions and can Review advisories assigned to him (might be a subject matter expert or management) + * _Manager_: inherits _Publisher_ permissions and can Delete; User management up to _Publisher_ + * _Administrator_: inherits _Manager_ permissions and can Change the configuration + +* may use groups to support client separation (multitenancy) and therefore restrict the roles to actions within their group. In this case, there MUST be a _Group configurator_ which is able to change the values which are used to prefill fields in new advisories for that group. He might also do the user management for the group up to a configured level. +* prefills the following fields in new CSAF documents with the values given below or based on the templates from configuration: + + * `/document/csaf_version` with the value `2.0` + * `/document/language` + * `/document/notes` + * `legal_disclaimer` (Terms of use from the configuration) + * `general` (General Security recommendations from the configuration) + * `/document/tracking/current_release_date` with the current date + * `/document/tracking/generator` and children + * `/document/tracking/initial_release_date` with the current date + * `/document/tracking/revision_history` + * `date` with the current date + * `number` (based on the templates according to the versioning scheme configured) + * `summary` (based on the templates from configuration; default: "Initial version.") + * `/document/tracking/status` with `draft` + * `/document/tracking/version` with the value of `number` the latest `/document/tracking/revision_history[]` element + * `/document/publisher` and children + * `/document/category` (based on the templates from configuration) + +* When updating an existing CSAF document: + + * prefills all fields which have be present in the existing CSAF document + * adds a new item in `/document/tracking/revision_history[]` + * updates the following fields with the values given below or based on the templates from configuration: + * `/document/csaf_version` with the value `2.0` + * `/document/language` + * `/document/notes` + * `legal_disclaimer` (Terms of use from the configuration) + * `general` (General Security recommendations from the configuration) + * `/document/tracking/current_release_date` with the current date + * `/document/tracking/generator` and children + * the new item in `/document/tracking/revision_history[]` + * `date` with the current date + * `number` (based on the templates according to the versioning scheme configured) + * `/document/tracking/status` with `draft` + * `/document/tracking/version` with the value of `number` the latest `/document/tracking/revision_history[]` element + * `/document/publisher` and children + +### 9.1.7 Conformance Clause 7: CSAF post-processor + +A CSAF post-processor satisfies the "CSAF post-processor" conformance profile if the post-processor: + +* satisfies the "CSAF consumer" conformance profile. +* satisfies the "CSAF producer" conformance profile. +* additionally satisfies those normative requirements in section 3 that are designated as applying to post-processors. + +### 9.1.8 Conformance Clause 8: CSAF modifier + +A program satisfies the "CSAF modifier" conformance profile if the program fulfills the two following groups of requirements: + +The program: + +* satisfies the "CSAF post-processor" conformance profile. +* adds, deletes or modifies at least one property, array, object or value of a property or item of an array. +* does not emit any objects, properties, or values which, according to section 9, are intended to be produced only by CSAF translators. +* satisfies the normative requirements given below. + +The resulting modified document: + +* does not have the same `/document/tracking/id` as the original document. The modified document can use a completely new `/document/tracking/id` or compute one by appending the original `/document/tracking/id` as a suffix after an ID from the naming scheme of the issuer of the modified version. It SHOULD NOT use the original `/document/tracking/id` as a prefix. +* includes a reference to the original advisory as first element of the array `/document/references[]`. + +### 9.1.9 Conformance Clause 9: CSAF translator + +A program satisfies the "CSAF translator" conformance profile if the program fulfills the two following groups of requirements: + +The program: + +* satisfies the "CSAF post-processor" conformance profile. +* translates at least one value. +* preserves the same semantics and form across translations. +* satisfies the normative requirements given below and does not add or remove other elements than required below. + +The resulting translated document: + +* does not use the same `/document/tracking/id` as the original document. The translated document can use a completely new `/document/tracking/id` or compute one by using the original `/document/tracking/id` as a prefix and adding an ID from the naming scheme of the issuer of the translated version. It SHOULD NOT use the original `/document/tracking/id` as a suffix. If an issuer uses a CSAF translator to publish his advisories in multiple languages they MAY use the combination of the original `/document/tracking/id` and translated `/document/lang` as a `/document/tracking/id` for the translated document. +* provides the `/document/lang` property with a value matching the language of the translation. +* provides the `/document/source_lang` to contain the language of the original document (and SHOULD only be set by CSAF translators). +* has the value `translator` set in `/document/publisher/category` +* includes a reference to the original advisory as first element of the array `/document/references[]`. +* MAY contain translations for elements in arrays of `references_t` after the first element. However, it MUST keep the original URLs as references at the end. + +### 9.1.10 Conformance Clause 10: CSAF consumer + +A processor satisfies the "CSAF consumer" conformance profile if the processor: + +* reads CSAF documents and interprets them according to the semantics defined in section 3. +* satisfies those normative requirements in section 3 and 8 that are designated as applying to CSAF consumers. + +### 9.1.11 Conformance Clause 11: CSAF viewer + +A viewer satisfies the "CSAF viewer" conformance profile if the viewer fulfills the two following groups of requirements: + +The viewer: + +* satisfies the "CSAF consumer" conformance profile. +* satisfies the normative requirements given below. + +For each CVSS-Score in `/vulnerabilities[]/scores[]` the viewer: + +* preferably shows the `vector` if there is an inconsistency between the `vector` and any other sibling attribute. +* SHOULD prefer the item of `scores[]` for each `product_id` which has the highest CVSS Base Score and newest CVSS version (in that order) if a `product_id` is listed in more than one item of `scores[]`. + +### 9.1.12 Conformance Clause 12: CSAF management system + +A CSAF management system satisfies the "CSAF management system" conformance profile if the management system: + +* satisfies the "CSAF viewer" conformance profile. +* provides at least the following management functions: + * add new CSAF documents (e.g. from file system or URL) to the system + * list all CSAF documents within the system + * delete CSAF documents from the system + * comment on CSAF documents in the system + * mark CSAF documents as read in the system + * search for CSAF documents by values of required fields at `document`-level or their children within the system + * search for CSAF documents by values of `cve` within the system + * search for CSAF documents based on properties of `/product_tree` + * filter on all properties which it is required to search for + * sort on all properties which it is required to search for + * sort on CVSS scores and `/document/aggregate_severity/text` +* identifies the latest version of CSAF documents with the same `/document/tracking/id`. +* is able to show the difference between 2 versions of a CSAF document with the same `/document/tracking/id`. + +### 9.1.13 Conformance Clause 13: CSAF asset matching system + +A CSAF asset matching system satisfies the "CSAF asset matching system" conformance profile if the asset matching system: + +* satisfies the "CSAF management system" conformance profile. +* is an asset database or connects to one. +* matches the CSAF documents within the system to the respective assets. This might be done with a probability which gives the end user the chance to broaden or narrow the results. The process of matching is also referred to as "run of the asset matching module". +* provides for each product of the asset database a list of matched advisories. +* provides for each asset of the asset database a list of matched advisories. +* provides for each CSAF document a list of matched product of the asset database. +* provides for each CSAF document a list of matched asset of the asset database. +* provides for each vulnerability within a CSAF document the option to mark a matched asset in the asset database as "not remediated", "remediation in progress", or "remediation done". A switch to mark all assets at once MAY be implemented. +* does not bring up a newer revision of a CSAF document as a new match if the remediation for the matched product or asset has not changed. +* detects the usage semantic version (as described in section 3.1.11.2). +* is able to trigger a run of the asset matching module: + * manually: + * per CSAF document + * per list of CSAF documents + * per asset + * per list of assets + * automatically: + * when a new CSAF document is inserted (for this CSAF document) + * when a new asset is inserted (for this asset) + * when the Major version in a CSAF document with semantic versioning changes (for this CSAF document) + > These also apply if more than one CSAF document or asset was added. To reduce the computational efforts the runs can be pooled into one run which fulfills all the tasks at once (batch mode). + * Manually and automatically triggered runs SHOULD NOT be pooled. +* provides at least the following statistics for the count of assets: + * matching that CSAF document at all + * marked with a given status + +### 9.1.14 Conformance Clause 14: CSAF basic validator + +A program satisfies the "CSAF basic validator" conformance profile if the program: + +* reads documents and performs a check against the JSON schema. +* performs all mandatory tests as given in section 6.1. +* does not change the CSAF documents. + +A CSAF basic validator MAY provide one or more additional functions: + +* Only run one or more selected mandatory tests. +* Apply quick fixes as specified in the standard. +* Apply additional quick fixes as implemented by the vendor. + +### 9.1.15 Conformance Clause 15: CSAF extended validator + +A CSAF basic validator satisfies the "CSAF extended validator" conformance profile if the CSAF basic validator: + +* satisfies the "CSAF basic validator" conformance profile. +* additionally performs all optional tests as given in section 6.2. + +A CSAF extended validator MAY provide an additional function to only run one or more selected optional tests. + +### 9.1.16 Conformance Clause 16: CSAF full validator + +A CSAF extended validator satisfies the "CSAF full validator" conformance profile if the CSAF extended validator: + +* satisfies the "CSAF extended validator" conformance profile. +* additionally performs all informative tests as given in section 6.3. + +A CSAF full validator MAY provide an additional function to only run one or more selected informative tests. + +### 9.1.17 Conformance Clause 17: CSAF SBOM matching system + +A CSAF SBOM matching system satisfies the "CSAF SBOM matching system" conformance profile if the SBOM matching system: + +* satisfies the "CSAF management system" conformance profile. +* is an SBOM database or connects to one. + > A repository or any other location that can be queried for SBOMs and their content is also considered an SBOM database. +* matches the CSAF documents within the system to the respective SBOM components. This might be done with a probability which gives the user the chance to broaden or narrow the results. The process of matching is also referred to as "run of the SBOM matching module". +* provides for each SBOM of the SBOM database a list of matched advisories. +* provides for each SBOM component of the SBOM database a list of matched advisories. +* provides for each CSAF document a list of matched SBOMs of the SBOM database. +* provides for each CSAF document a list of matched SBOM components of the SBOM database. +* provides for each vulnerability within a CSAF document the option to mark a matched SBOM component in the SBOM database as "not remediated", "remediation in progress", or "remediation done". A switch to mark all SBOM component at once MAY be implemented. +* does not bring up a newer revision of a CSAF document as a new match if the remediation for the matched SBOM or SBOM component has not changed. +* detects the usage semantic version (as described in section 3.1.11.2). +* is able to trigger a run of the asset matching module: + * manually: + * per CSAF document + * per list of CSAF documents + * per SBOM component + * per list of SBOM components + * automatically: + * when a new CSAF document is inserted (for this CSAF document) + * when a new SBOM component is inserted (for this SBOM component) + * when the Major version in a CSAF document with semantic versioning changes (for this CSAF document) + > These also apply if more than one CSAF document or SBOM component was added. To reduce the computational efforts the runs can be pooled into one run which fulfills all the tasks at once (batch mode). + > Manually and automatically triggered runs should not be pooled. +* provides at least the following statistics for the count of SBOM component: + * matching that CSAF document at all + * marked with a given status + +------- diff --git a/csaf_2.1/prose/edit/src/design-considerations-00.md b/csaf_2.1/prose/edit/src/design-considerations-00.md new file mode 100644 index 000000000..33b7436da --- /dev/null +++ b/csaf_2.1/prose/edit/src/design-considerations-00.md @@ -0,0 +1,14 @@ +# 2 Design Considerations + +The Common Security Advisory Framework (CSAF) is a language to exchange Security Advisories formulated in JSON. + +The term Security Advisory as used in this document describes any notification of security issues in products of and by providers. Anyone providing a product is considered in this document as a vendor, i.e. developers or maintainers of information system products or services. This includes all authoritative product vendors, Product Security Incident Response Teams (PSIRTs), and product resellers and distributors, including authoritative vendor partners. +A security issue is not necessarily constrained to a problem statement, the focus of the term is on the security aspect impacting (or not impacting) specific product-platform-version combinations. Information on presence or absence of workarounds is also considered part of the security issue. +This document is the definitive reference for the language elements of CSAF version 2.0. The encompassing JSON schema file noted in the Additional Artifacts section of the title page SHALL be taken as normative in the case a gap or an inconsistency in this explanatory document becomes evident. +The following presentation in this section is grouped by topical area, and is not simply derivative documentation from the schema document itself. The information contained aims to be more descriptive and complete. Where applicable, common conventions are stated and known common issues in usage are pointed out informatively to support implementers of document producers and consumers alike. + +This minimal required information set does not provide any useful information on products, vulnerabilities, or security advisories. Thus, any real-world Security Advisory will carry additional information as specified in section 3 Schema elements. + +Care has been taken, to design the containers for product and vulnerability information to support fine-grained mapping of security advisories onto product and vulnerability and minimize data duplication through referencing. +The display of the elements representing Product Tree and Vulnerability information has been placed in the sections named accordingly. + diff --git a/csaf_2.1/prose/edit/src/design-considerations-01-construction-principles.md b/csaf_2.1/prose/edit/src/design-considerations-01-construction-principles.md new file mode 100644 index 000000000..91319333d --- /dev/null +++ b/csaf_2.1/prose/edit/src/design-considerations-01-construction-principles.md @@ -0,0 +1,48 @@ +## 2.1 Construction Principles + +A Security Advisory defined as a CSAF document is the result of complex orchestration of many players and distinct and partially difficult to play schemas. + +The format chosen is [JSONSchema] which allows validation and delegation to sub schema providers. The latter aligns well with separation of concerns and shares the format family of information interchange utilized by the providers of product and vulnerability information which migrated from XML to JSON since the creation of CSAF CVRF version 1.2, the predecessor of this specification. + +The acronym CSAF, “Common Security Advisory Framework”, stands for the target of concerted mitigation and remediation accomplishment. + +Technically, the use of JSON schema allows validation and proof of model conformance (through established schema based validation) of the declared information inside CSAF documents. + +The CSAF schema structures its derived documents into three main classes of the information conveyed: + +1. The frame, aggregation, and reference information of the document +2. Product information considered relevant by the creator +3. Vulnerability information and its relation to the products declared in 2. + +Wherever possible repetition of data has been replaced by linkage through ID elements. Consistency on the content level thus is in the responsibility of the producer of such documents, to link e.g. vulnerability information to the matching product. + +A dictionary like presentation of all defined schema elements is given in the section 3. Any expected relations to other elements (linkage) is described there. This linking relies on setting attribute values accordingly (mostly guided by industry best practice and conventions) and thus implies, that any deep validation on a semantic level (e.g. does the CWE match the described vulnerability) is to be ensured by the producer and consumer of CSAF documents. It is out of scope for this specification. + +Proven and intended usage patterns from practice are given where possible. + +Delegation to industry best practices technologies is used in referencing schemas for: + +* Platform Data: + * Common Platform Enumeration (CPE) Version 2.3 [CPE23-N] +* Vulnerability Scoring: + * Common Vulnerability Scoring System (CVSS) Version 3.1 [CVSS31] + * JSON Schema Reference https://www.first.org/cvss/cvss-v3.1.json + * Common Vulnerability Scoring System (CVSS) Version 3.0 [CVSS30] + * JSON Schema Reference https://www.first.org/cvss/cvss-v3.0.json + * Common Vulnerability Scoring System (CVSS) Version 2.0 [CVSS2] + * JSON Schema Reference https://www.first.org/cvss/cvss-v2.0.json +* Vulnerability Classification + * Common Weakness Enumeration (CWE) [CWE] + * CWE List: http://cwe.mitre.org/data/index.html +* Classification for Document Distribution + * Traffic Light Protocol (TLP) + * Default Definition: https://www.first.org/tlp/ + +Even though the JSON schema does not prohibit specifically additional properties and custom keywords, it is strongly recommended not to use them. Suggestions for new fields SHOULD be made through issues in the TC's GitHub. + +> The standardized fields allow for scalability across different issuing parties and dramatically reduce the human effort and need for dedicated parsers as well as other tools on the side of the consuming parties. + +Section 4 defined profiles that are used to ensure a common understanding of which fields are required in a given use case. Additional conventions are stated in section 5. The tests given in section 6 support CSAF producers and consumers to verify rules from the specification which can not be tested by the schema. Section 7 states how to distribute and where to find CSAF documents. Safety, Security and Data Protection are considered in section 8. Finally, a set of conformance targets describes tools in the ecosystem. + +------- + diff --git a/csaf_2.1/prose/edit/src/distributing.md b/csaf_2.1/prose/edit/src/distributing.md new file mode 100644 index 000000000..27ef26fec --- /dev/null +++ b/csaf_2.1/prose/edit/src/distributing.md @@ -0,0 +1,601 @@ +# 7 Distributing CSAF documents + +This section lists requirements and roles defined for distributing CSAF documents. The first subsection provides all requirements - the second one the roles. It is mandatory to fulfill the basic role "CSAF publisher". The last section provides specific rules for the process of retrieving CSAF documents. + +## 7.1 Requirements + +The requirements in this subsection are consecutively numbered to be able to refer to them directly. The order does not give any hint about the importance. Not all requirements have to be fulfilled to conform to this specification - the sets of requirements per conformance clause are defined in section 7.2. + +### 7.1.1 Requirement 1: Valid CSAF document + +The document is a valid CSAF document (cf. Conformance clause 1). + +### 7.1.2 Requirement 2: Filename + +The CSAF document has a filename according to the rules in section 5.1. + +### 7.1.3 Requirement 3: TLS + +The CSAF document is per default retrievable from a website which uses TLS for encryption and server authenticity. The CSAF document MUST NOT be downloadable from a location which does not encrypt the transport when crossing organizational boundaries to maintain the chain of custody. + +### 7.1.4 Requirement 4: TLP:WHITE + +If the CSAF document is labeled TLP:WHITE, it MUST be freely accessible. + +This does not exclude that such a document is also available in an access protected customer portal. However, there MUST be one copy of the document available for people without access to the portal. + +> Reasoning: If an advisory is already in the media, an end user should not be forced to collect the pieces of information from a press release but be able to retrieve the CSAF document. + +### 7.1.5 Requirement 5: TLP:AMBER and TLP:RED + +CSAF documents labeled TLP:AMBER or TLP:RED MUST be access protected. If they are provided via a web server this SHALL be done under a different path than for TLP:WHITE, TLP:GREEN and unlabeled CSAF documents. TLS client authentication, access tokens or any other automatable authentication method SHALL be used. + +An issuing party MAY agree with the recipients to use any kind of secured drop at the recipients' side to avoid putting them on their own website. However, it MUST be ensured that the documents are still access protected. + +### 7.1.6 Requirement 6: No Redirects + +Redirects SHOULD NOT be used. If they are inevitable only HTTP Header redirects are allowed. + +> Reasoning: Clients should not parse the payload for navigation and some, as e.g. `curl`, do not follow any other kind of redirects. + +### 7.1.7 Requirement 7: provider-metadata.json + +The party MUST provide a valid `provider-metadata.json` according to the schema [CSAF provider metadata](https://docs.oasis-open.org/csaf/csaf/v2.0/provider_json_schema.json) for its own metadata. The `publisher` object SHOULD match the one used in the CSAF documents of the issuing party but can be set to whatever value a CSAF aggregator SHOULD display over any individual `publisher` values in the CSAF documents themselves. + +> This information is used to collect the data for CSAF aggregators, listers and end users. The CSAF provider metadata schema ensures the consistency of the metadata for a CSAF provider across the ecosystem. Other approaches, like extracting the `publisher` object from CSAF documents, are likely to fail if the object differs between CSAF documents. +> +> It is suggested to put the file `provider-metadata.json` adjacent to the ROLIE feed documents (requirement 15) or in the main directory adjacent to the year folders (requirement 14), `changes.csv` (requirement 13) and the `index.txt` (requirement 12). +> Suggested locations to store the `provider-metadata.json` are: +> +> * https://www.example.com/.well-known/csaf/provider-metadata.json +> * https://domain.tld/security/data/csaf/provider-metadata.json +> * https://psirt.domain.tld/advisories/csaf/provider-metadata.json +> * https://domain.tld/security/csaf/provider-metadata.json + +*Example 124 Minimal with ROLIE document:* + +``` + { + "canonical_url": "https://www.example.com/.well-known/csaf/provider-metadata.json", + "distributions": [ + { + "rolie":{ + "feeds": [ + { + "summary":"All TLP:WHITE advisories of Example Company.", + "tlp_label": "WHITE", + "url": "https://www.example.com/.well-known/csaf/feed-tlp-white.json" + } + ] + } + } + ], + "last_updated": "2021-07-12T20:20:56.169Z", + "list_on_CSAF_aggregators": true, + "metadata_version": "2.0", + "mirror_on_CSAF_aggregators": true, + "public_openpgp_keys": [ + { + "fingerprint": "8F5F267907B2C4559DB360DB2294BA7D2B2298B1", + "url": "https://keys.example.net/vks/v1/by-fingerprint/8F5F267907B2C4559DB360DB2294BA7D2B2298B1" + } + ], + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace":"https://psirt.example.com" + }, + "role": "csaf_trusted_provider" + } +``` + +If a CSAF publisher (cf. section 7.2.1) does not provide the `provider-metadata.json`, an aggregator SHOULD contact the CSAF publisher in question to determine the values for `list_on_CSAF_aggregators` and `mirror_on_CSAF_aggregators`. If that is impossible or if the CSAF publisher is unresponsive the following values MUST be used: + +``` + "list_on_CSAF_aggregators": true, + "mirror_on_CSAF_aggregators": false +``` + +> This prevents that CSAF documents of a CSAF publisher which have been collected by one CSAF aggregator A are mirrored again on a second CSAF aggregator B. Such cascades are prone to outdated information. +> If the first aggregator A collects the CSAF documents on best effort and B copies the files from A and announces that this is done weekly, one might assume that B's CSAF documents are more recent. However, that is not the case as B's information depends on A. + +### 7.1.8 Requirement 8: security.txt + +In the security.txt there MUST be at least one field `CSAF` which points to the `provider-metadata.json` (requirement 7). If this field indicates a web URI, then it MUST begin with "https://" (as per section 2.7.2 of [RFC7230]). See [SECURITY-TXT] for more details. + +> The security.txt was published as [RFC9116] in April 2022. At the time of this writing, the `CSAF` field is in the process of being officially added. + +*Examples 125:* + +``` +CSAF: https://domain.tld/security/data/csaf/provider-metadata.json +CSAF: https://psirt.domain.tld/advisories/csaf/provider-metadata.json +CSAF: https://domain.tld/security/csaf/provider-metadata.json +CSAF: https://www.example.com/.well-known/csaf/provider-metadata.json +``` + +It is possible to advertise more than one `provider-metadata.json` by adding multiple `CSAF` fields, e.g. in case of changes to the organizational structure through merges or acquisitions. However, this SHOULD NOT be done and removed as soon as possible. If one of the URLs fulfills requirement 9, this MUST be used as the first CSAF entry in the security.txt. + +### 7.1.9 Requirement 9: Well-known URL for provider-metadata.json + +The URL path `/.well-known/csaf/provider-metadata.json` under the main domain of the issuing authority serves directly the `provider-metadata.json` according to requirement 7. The use of the scheme "HTTPS" is required. See [RFC8615] for more details. + +*Example 126:* + +``` + https://www.example.com/.well-known/csaf/provider-metadata.json +``` + +### 7.1.10 Requirement 10: DNS path + +The DNS record `csaf.data.security.domain.tld` SHALL resolve as a web server which serves directly the `provider-metadata.json` according to requirement 7. The use of the scheme "HTTPS" is required. + +### 7.1.11 Requirement 11: One folder per year + +The CSAF documents MUST be located within folders named `` where `` is the year given in the value of `/document/tracking/initial_release_date`. + +*Examples 127:* + +``` +2021 +2020 +``` + +### 7.1.12 Requirement 12: index.txt + +The index.txt file within MUST provide a list of all filenames of CSAF documents which are located in the sub-directories with their filenames. + +*Example 128:* + +``` +2020/example_company_-_2020-yh4711.json +2019/example_company_-_2019-yh3234.json +2018/example_company_-_2018-yh2312.json +``` + +> This can be used to download all CSAF documents. + +### 7.1.13 Requirement 13: changes.csv + +The file changes.csv MUST contain the filename as well as the value of `/document/tracking/current_release_date` for each CSAF document in the sub-directories without a heading; lines MUST be sorted by the `current_release_date` timestamp with the latest one first. + +*Example 129:* + +``` +"2020/example_company_-_2020-yh4711.json","2020-07-01T10:09:07Z" +"2018/example_company_-_2018-yh2312.json","2020-07-01T10:09:01Z" +"2019/example_company_-_2019-yh3234.json","2019-04-17T15:08:41Z" +"2018/example_company_-_2018-yh2312.json","2019-03-01T06:01:00Z" +``` + +### 7.1.14 Requirement 14: Directory listings + +Directory listing SHALL be enabled to support manual navigation. + +### 7.1.15 Requirement 15: ROLIE feed + +Resource-Oriented Lightweight Information Exchange (ROLIE) is a standard to ease discovery of security content. ROLIE is built on top of the Atom Publishing Format and Protocol, with specific requirements that support publishing security content. All CSAF documents with the same TLP level MUST be listed in a single ROLIE feed. At least one of the feeds + +* TLP:WHITE +* TLP:GREEN +* unlabeled + +MUST exist. Each ROLIE feed document MUST be a JSON file that conforms with [RFC8322]. + +*Example 130:* + +``` + { + "feed": { + "id": "example-csaf-feed-tlp-white", + "title": "Example CSAF feed (TLP:WHITE)", + "link": [ + { + "rel": "self", + "href": "https://psirt.domain.tld/advisories/csaf/feed-tlp-white.json" + } + ], + "category": [ + { + "scheme": "urn:ietf:params:rolie:category:information-type", + "term": "csaf" + } + ], + "updated": "2021-01-01T12:00:00.000Z", + "entry": [ + { + "id": "2020-ESA-001", + "title": "Example Security Advisory 001", + "link": [ + { + "rel": "self", + "href": "https://psirt.domain.tld/advisories/csaf/2020/2020-ESA-001.json" + }, + { + "rel": "hash", + "href": "https://psirt.domain.tld/advisories/csaf/2020/2020-ESA-001.json.sha512" + }, + { + "rel": "signature", + "href": "https://psirt.domain.tld/advisories/csaf/2020/2020-ESA-001.json.asc" + } + ], + "published": "2021-01-01T11:00:00.000Z", + "updated": "2021-01-01T12:00:00.000Z", + "summary": { + "content": "Vulnerabilities fixed in ABC 0.0.1" + }, + "content": { + "type": "application/json", + "src": "https://psirt.domain.tld/advisories/csaf/2020/2020-ESA-001.json" + }, + "format": { + "schema": "https://docs.oasis-open.org/csaf/csaf/v2.0/csaf_json_schema.json", + "version": "2.0" + } + } + ] + } + } +``` + +Any existing hash file (requirement 18) MUST be listed in the corresponding entry of the ROLIE feed as an item of the array `link` having the `rel` value of `hash`. +Any existing signature file (requirement 19) MUST be listed in the corresponding entry of the ROLIE feed as an item of the array `link` having the `rel` value of `signature`. + +### 7.1.16 Requirement 16: ROLIE service document + +The use and therefore the existence of ROLIE service document is optional. If it is used, each ROLIE service document MUST be a JSON file that conforms with [RFC8322] and lists the ROLIE feed documents. + +*Example 131:* + +``` + { + "service": { + "workspace": [ + { + "title": "Public CSAF feed", + "collection": [ + { + "title": "Example CSAF feed (TLP:WHITE)", + "href": "https://psirt.domain.tld/advisories/csaf/feed-tlp-white.json", + "categories": { + "category": [ + { + "scheme": "urn:ietf:params:rolie:category:information-type", + "term": "csaf" + } + ] + } + } + ] + } + ] + } + } +``` + +### 7.1.17 Requirement 17: ROLIE category document + +The use and therefore the existence of ROLIE category document is optional. If it is used, each ROLIE category document MUST be a JSON file that conforms with [RFC8322]. ROLIE categories SHOULD be used for to further dissect CSAF documents by one or more of the following criteria: + +* document category +* document language +* values of the branch category within the Product Tree including but not limited to + * `vendor` + * `product_family` + * `product_name` + * `product_version` +* type of product + + *Example 132:* + + ``` + CPU + Firewall + Monitor + PLC + Printer + Router + Sensor + Server + ``` + +* areas or sectors, the products are used in + + *Example 133:* + + ``` + Chemical + Commercial + Communication + Critical Manufacturing + Dams + Energy + Healthcare + Water + ``` + +* any other categorization useful to the consumers + +*Example 134:* + +``` + { + "categories": { + "category": [ + { + "term": "Example Company Product A" + }, + { + "term": "Example Company Product B" + } + ] + } + } +``` + +### 7.1.18 Requirement 18: Integrity + +All CSAF documents SHALL have at least one hash file computed with a secure cryptographic hash algorithm (e.g. SHA-512 or SHA-3) to ensure their integrity. The filename is constructed by appending the file extension which is given by the algorithm. + +MD5 and SHA1 SHOULD NOT be used. + +*Example 135:* + +``` +File name of CSAF document: example_company_-_2019-yh3234.json +File name of SHA-256 hash file: example_company_-_2019-yh3234.json.sha256 +File name of SHA-512 hash file: example_company_-_2019-yh3234.json.sha512 +``` + +The file content SHALL start with the first byte of the hexadecimal hash value. Any subsequent data (like a filename) which is optional SHALL be separated by at least one space. + +*Example 136:* + +``` +ea6a209dba30a958a78d82309d6cdcc6929fcb81673b3dc4d6b16fac18b6ff38 example_company_-_2019-yh3234.json +``` + +If a ROLIE feed exists, each hash file MUST be listed in it as described in requirement 15. + +### 7.1.19 Requirement 19: Signatures + +All CSAF documents SHALL have at least one OpenPGP signature file which is provided under the same filename which is extended by the appropriate extension. See [RFC4880] for more details. + +*Example 137:* + +``` +File name of CSAF document: example_company_-_2019-yh3234.json +File name of signature file: example_company_-_2019-yh3234.json.asc +``` + +If a ROLIE feed exists, each signature file MUST be listed in it as described in requirement 15. + +### 7.1.20 Requirement 20: Public OpenPGP Key + +The public part of the OpenPGP key used to sign the CSAF documents MUST be available. It SHOULD also be available at a public key server. + +> For example, the public part of the OpenPGP key could be placed in a directory `openpgp` adjacent to the `provider-metadata.json`. + +The OpenPGP key SHOULD have a strength that is considered secure. + +> Guidance on OpenPGP key strength can be retrieved from technical guidelines of competent authorities. + +### 7.1.21 Requirement 21: List of CSAF providers + +The file `aggregator.json` MUST be present and valid according to the JSON schema [CSAF aggregator](https://docs.oasis-open.org/csaf/csaf/v2.0/aggregator_json_schema.json). It MUST NOT be stored adjacent to a `provider-metadata.json`. + +> Suggested locations to store the `aggregator.json` are: +> +> * https://www.example.com/.well-known/csaf-aggregator/aggregator.json +> * https://domain.tld/security/data/aggregator/csaf/aggregator.json +> * https://psirt.domain.tld/advisories/aggregator/csaf/aggregator.json +> * https://domain.tld/security/aggregator/csaf/aggregator.json + +The file `aggregator.json` SHOULD only list the latest version of the metadata of a CSAF provider. + +*Example 138:* + +``` + { + "aggregator": { + "category": "lister", + "contact_details": "Example CSAF Lister can be reached at contact_us@lister.example, or via our website at https://lister.example/security/csaf/aggregator/contact.", + "issuing_authority": "This service is provided as it is. It is free for everybody.", + "name": "Example CSAF Lister", + "namespace": "https://lister.example" + }, + "aggregator_version": "2.0", + "canonical_url": "https://aggregator.example/.well-known/csaf-aggregator/aggregator.json", + "csaf_providers": [ + { + "metadata": { + "last_updated": "2021-07-12T20:20:56.169Z", + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "url": "https://www.example.com/.well-known/csaf/provider-metadata.json" + } + }, + { + "metadata": { + "last_updated": "2021-07-12T21:35:38.000Z", + "publisher": { + "category": "coordinator", + "name": "Example Coordinator CERT", + "namespace": "https://cert.example" + }, + "url": "https://cert.example/advisories/csaf/provider-metadata.json" + } + } + ], + "last_updated":"2021-07-12T22:35:38.978Z" + } +``` + +### 7.1.22 Requirement 22: Two disjoint issuing parties + +The file `aggregator.json` (requirement 21) lists at least two disjoint CSAF providers (including CSAF trusted providers) or one CSAF publisher and one CSAF provider (including CSAF trusted provider). + +### 7.1.23 Requirement 23: Mirror + +The CSAF documents for each issuing party that is mirrored MUST be in a different folder. The folder name SHOULD be retrieved from the name of the issuing authority. This folders MUST be adjacent to the `aggregator.json` (requirement 21). Each such folder MUST at least: + +* provide a `provider-metadata.json` for the current issuing party. +* provide the ROLIE feed document according to requirement 15 which links to the local copy of the CSAF document. + +*Example 139:* + +``` + { + "aggregator": { + "category": "aggregator", + "contact_details": "Example Aggregator can be reached at contact_us@aggregator.example, or via our website at https://aggregator.example/security/csaf/aggregator/contact.", + "issuing_authority": "This service is provided as it is. It is free for everybody.", + "name": "Example Aggregator", + "namespace": "https://aggregator.example" + }, + "aggregator_version": "2.0", + "canonical_url": "https://aggregator.example/.well-known/csaf-aggregator/aggregator.json", + "csaf_providers": [ + { + "metadata": { + "last_updated": "2021-07-12T20:20:56.169Z", + "publisher": { + "category": "vendor", + "name": "Example Company ProductCERT", + "namespace": "https://psirt.example.com" + }, + "url": "https://www.example.com/.well-known/csaf/provider-metadata.json" + }, + "mirrors": [ + "https://aggregator.example/.well-known/csaf-aggregator/Example_Company_ProductCERT/provider-metadata.json" + ] + }, + { + "metadata": { + "last_updated": "2021-07-12T21:35:38.000Z", + "publisher": { + "category": "coordinator", + "name": "Example Coordinator CERT", + "namespace": "https://cert.example" + }, + "url": "https://cert.example/advisories/csaf/provider-metadata.json" + }, + "mirrors": [ + "https://aggregator.example/.well-known/csaf-aggregator/Example_Coordinator_CERT/provider-metadata.json" + ] + } + ], + "last_updated":"2021-07-12T22:35:38.978Z" + } +``` + +## 7.2 Roles + +This subsection groups the requirements from the previous subsection into named sets which target the roles with the same name. This allows end users to request their suppliers to fulfill a certain set of requirements. A supplier can use roles for advertising and marketing. + +The roles "CSAF publisher", "CSAF provider", and "CSAF trusted provider" are intended directly for issuing parties and form the first group. The second group consists of the roles "CSAF lister" and "CSAF aggregator". They collect data from the aforementioned issuing parties of the first group and provide them in a single place to aid in automation. Parties of the second group can also issue their own advisories. However, they MUST follow the rules for the first group for that. + +Both, a CSAF lister and a CSAF aggregator, decide based on their own rules which issuing parties to list respectively to mirror. However, an issuing party MAY apply to be listed or mirrored. + +Issuing parties MUST indicate through the value `false` in `list_on_CSAF_aggregators` if they do not want to be listed. +Issuing parties MUST indicate through the value `false` in `mirror_on_CSAF_aggregators` if they do not want to be mirrored. + +The values are independent. The combination of the value `false` in `list_on_CSAF_aggregators` and `true` in `mirror_on_CSAF_aggregators` implies that the issuing party does not want to be listed without having the CSAF documents mirrored. Therefore, a CSAF aggregator can list that issuing party if it mirrors the files. + +### 7.2.1 Role: CSAF publisher + +A distributing party satisfies the "CSAF publisher" role if the party: + +* satisfies the requirements 1 to 4 in section 7.1. +* distributes only CSAF documents on behalf of its own. + +### 7.2.2 Role: CSAF provider + +A CSAF publisher satisfies the "CSAF provider" role if the party fulfills the following three groups of requirements: + +Firstly, the party: + +* satisfies the "CSAF publisher" role profile. +* additionally satisfies the requirements 5 to 7 in section 7.1. + +Secondly, the party: + +* satisfies at least one of the requirements 8 to 10 in section 7.1. + +Thirdly, the party: + +* satisfies the requirements 11 to 14 in section 7.1 or requirements 15 to 17 in section 7.1. + +> If the party uses the ROLIE-based distribution, it MUST also satisfy requirements 15 to 17. If it uses the directory-based distribution, it MUST also satisfy requirements 11 to 14. + +### 7.2.3 Role: CSAF trusted provider + +A CSAF provider satisfies the "CSAF trusted provider" role if the party: + +* satisfies the "CSAF provider" role profile. +* additionally satisfies the requirements 18 to 20 in section 7.1. + +### 7.2.4 Role: CSAF lister + +A distributing party satisfies the "CSAF lister" role if the party: + +* satisfies the requirements 6, 21 and 22 in section 7.1. +* uses the value `lister` for `/aggregator/category`. +* does not list any mirror pointing to a domain under its own control. + +> The purpose of this role is to provide a list of URLs where to find CSAF documents. It is not assumed that the list will be complete. + +### 7.2.5 Role: CSAF aggregator + +A distributing party satisfies the "CSAF aggregator" role if the party: + +* satisfies the requirements 1 to 6 and 21 to 23 in section 7.1. +* uses the value `aggregator` for `/aggregator/category`. +* lists a mirror for at least two disjoint issuing parties pointing to a domain under its own control. +* links the public part of the OpenPGP key used to sign CSAF documents for each mirrored issuing party in the corresponding `provider-metadata.json`. +* provides for each CSAF document that is mirrored a signature (requirement 19) and a hash (requirement 18). Both SHALL be listed in the ROLIE feed. If the issuing party provides those files for a CSAF document, they SHOULD be copied as well. If the issuing party does not provide those files, they SHALL be created by the CSAF aggregator. Such a signature does not imply any liability of CSAF aggregator for the content of the corresponding CSAF document. It just confirms that the CSAF document provided has not been modified after being downloaded from the issuing party. A CSAF aggregator MAY add additional signatures and hashes for a CSAF document. + +Additionally, a CSAF aggregator MAY list one or more issuing parties that it does not mirror. + +> The purpose of this role is to provide a single point where CSAF documents can be retrieved. Multiple CSAF aggregators are expected to exist around the world. None of them is required to mirror all CSAF documents of all issuing parties. +> CSAF aggregators can be provided for free or as a paid service. +> +> To aid in automation, CSAF aggregators MAY mirror CSAF documents from CSAF publishers. Regarding the terms of use they SHOULD consult with the issuing party. +> The purpose of this option is that a consumer can retrieve CSAF documents from a CSAF publisher as if this issuing party would be a CSAF trusted provider. To reach that goal, a CSAF aggregator collects the CSAF documents from the CSAF publisher and mirrors it. The collection process MAY be automated or manual. CSAF aggregators announce the collection interval through the field `update_interval` in the corresponding item of the CSAF publishers list (`csaf_publishers`) in their `aggregator.json`. +> To minimize the implementation efforts and process overhead, a CSAF aggregator MAY upload the CSAF documents of a CSAF publisher into an internal instance of a CSAF provider software. Such construct is called "CSAF proxy provider" as it can be mirrored by the CSAF aggregator software. However, such a CSAF proxy provider MUST NOT be accessible from anyone else than the CSAF aggregator itself. Otherwise, that would violate the second rule of section 7.2.1. Therefore, it is recommended to expose the CSAF proxy provider only on localhost and allow the access only from the CSAF aggregator software. + +## 7.3 Retrieving rules + +The retrieving process executes in two phases: Finding the `provider-metadata.json` (requirement 7 in section 7.1) and retrieving CSAF documents. + +> A retrieving party SHOULD do the first phase every time. Based on the setup and use case of the retrieving party it MAY choose to do it less often, e.g. only when adding new or updating distributing parties. In that case, it SHOULD to check regularly whether new information is available. + +### 7.3.1 Finding provider-metadata.json + +**Direct locating**: The following process SHOULD be used to determine the location of a `provider-metadata.json` (requirement 7 in section 7.1) based on the main domain of the issuing party: + +1. Checking the Well-known URL (requirement 9 in section 7.1) +2. Checking the security.txt (requirement 8 in section 7.1) +3. Checking the DNS path (requirement 10 in section 7.1) +4. Select one or more `provider-metadata.json` to use. + +> The term "checking" used in the listing above SHOULD be understood as follows: Try to access the resource and test whether the response provides an expected result as defined in the requirement in section 7.1. If that is the case, the step was successful - otherwise not. + +The first two steps SHOULD be performed in all cases as the security.txt MAY advertise additional `provider-metadata.json`. The third step SHOULD only be performed if the first two did not result in the location of at least one `provider-metadata.json`. + +**Indirect locating**: A retrieving party MAY choose to determine the location of a `provider-metadata.json` by retrieving its location from an `aggregator.json` (requirement 21 in section 7.1) of a CSAF lister or CSAF aggregator. + +### 7.3.2 Retrieving CSAF documents + +Given a `provider-metadata.json`, the following process SHOULD be used to retrieve CSAF documents: + +1. Parse the `provider-metadata.json` to determine whether the directory-based (requirements 11 to 14 in section 7.1) or ROLIE-based distribution (requirements 15 to 17 in section 7.1) is used. If both are present, the ROLIE information SHOULD be preferred. +2. For any CSAF trusted provider, the hash and signature files (requirements 18 to 19 in section 7.1) SHOULD be retrieved together with the CSAF document. They MUST be checked before further processing the CSAF document. +3. Test the CSAF document against the schema. +4. Execute mandatory tests on the CSAF document. + +------- diff --git a/csaf_2.1/prose/edit/src/frontmatter.md b/csaf_2.1/prose/edit/src/frontmatter.md new file mode 100644 index 000000000..584db5956 --- /dev/null +++ b/csaf_2.1/prose/edit/src/frontmatter.md @@ -0,0 +1,106 @@ + +![OASIS Logo](https://docs.oasis-open.org/templates/OASISLogo-v3.0.png) + +------- + +# Common Security Advisory Framework Version 2.0 + +## OASIS Standard + +## 18 November 2022 + +#### This stage: +https://docs.oasis-open.org/csaf/csaf/v2.0/os/csaf-v2.0-os.md (Authoritative) \ +https://docs.oasis-open.org/csaf/csaf/v2.0/os/csaf-v2.0-os.html \ +https://docs.oasis-open.org/csaf/csaf/v2.0/os/csaf-v2.0-os.pdf + +#### Previous stage: +https://docs.oasis-open.org/csaf/csaf/v2.0/cs03/csaf-v2.0-cs03.md (Authoritative) \ +https://docs.oasis-open.org/csaf/csaf/v2.0/cs03/csaf-v2.0-cs03.html \ +https://docs.oasis-open.org/csaf/csaf/v2.0/cs03/csaf-v2.0-cs03.pdf + +#### Latest stage: +https://docs.oasis-open.org/csaf/csaf/v2.0/csaf-v2.0.md (Authoritative) \ +https://docs.oasis-open.org/csaf/csaf/v2.0/csaf-v2.0.html \ +https://docs.oasis-open.org/csaf/csaf/v2.0/csaf-v2.0.pdf + +#### Technical Committee: +[OASIS Common Security Advisory Framework (CSAF) TC](https://www.oasis-open.org/committees/csaf/) + +#### Chair: +Omar Santos (osantos@cisco.com), [Cisco Systems](https://cisco.com/) + +#### Editors: +Langley Rock (lrock@redhat.com), [Red Hat](https://redhat.com/) \ +Stefan Hagen (stefan@hagen.link), [Individual](https://stefan-hagen.website/) \ +Thomas Schmidt (thomas.schmidt@bsi.bund.de), [Federal Office for Information Security (BSI) Germany](https://www.bsi.bund.de/) + +In Memory of Eric Johnson, TIBCO Software Inc. and Mike Gorski, Cisco Systems both active members of the OASIS CSAF Technical Committee. + +#### Additional artifacts: +This prose specification is one component of a Work Product that also includes: + +* Aggregator JSON schema: https://docs.oasis-open.org/csaf/csaf/v2.0/os/schemas/aggregator_json_schema.json. \ +Latest stage: https://docs.oasis-open.org/csaf/csaf/v2.0/aggregator_json_schema.json. +* CSAF JSON schema: https://docs.oasis-open.org/csaf/csaf/v2.0/os/schemas/csaf_json_schema.json. \ +Latest stage: https://docs.oasis-open.org/csaf/csaf/v2.0/csaf_json_schema.json. +* Provider JSON schema: https://docs.oasis-open.org/csaf/csaf/v2.0/os/schemas/provider_json_schema.json. \ +Latest stage: https://docs.oasis-open.org/csaf/csaf/v2.0/provider_json_schema.json. + +#### Related work: +This specification replaces or supersedes: + +* _CSAF Common Vulnerability Reporting Framework (CVRF) Version 1.2_. Edited by Stefan Hagen. Latest stage: https://docs.oasis-open.org/csaf/csaf-cvrf/v1.2/csaf-cvrf-v1.2.html. + +#### Declared JSON namespaces: + +* [https://docs.oasis-open.org/csaf/csaf/v2.0/aggregator_json_schema.json](https://docs.oasis-open.org/csaf/csaf/v2.0/aggregator_json_schema.json) +* [https://docs.oasis-open.org/csaf/csaf/v2.0/csaf_json_schema.json](https://docs.oasis-open.org/csaf/csaf/v2.0/csaf_json_schema.json) +* [https://docs.oasis-open.org/csaf/csaf/v2.0/provider_json_schema.json](https://docs.oasis-open.org/csaf/csaf/v2.0/provider_json_schema.json) + + +#### Abstract: +The Common Security Advisory Framework (CSAF) Version 2.0 is the definitive reference for the language which supports creation, update, and interoperable exchange of security advisories as structured information on products, vulnerabilities and the status of impact and remediation among interested parties. + +#### Status: +This document was last revised or approved by the membership of OASIS on the above date. The level of approval is also listed above. Check the "Latest stage" location noted above for possible later revisions of this document. Any other numbered Versions and other technical work produced by the Technical Committee (TC) are listed at https://www.oasis-open.org/committees/tc_home.php?wg_abbrev=csaf#technical. + +TC members should send comments on this specification to the TC's email list. Others should send comments to the TC's public comment list, after subscribing to it by following the instructions at the "Send A Comment" button on the TC's web page at https://www.oasis-open.org/committees/csaf/. + +This specification is provided under the [Non-Assertion](https://www.oasis-open.org/policies-guidelines/ipr/#Non-Assertion-Mode) Mode of the [OASIS IPR Policy](https://www.oasis-open.org/policies-guidelines/ipr/), the mode chosen when the Technical Committee was established. For information on whether any patents have been disclosed that may be essential to implementing this specification, and any offers of patent licensing terms, please refer to the Intellectual Property Rights section of the TC's web page (https://www.oasis-open.org/committees/csaf/ipr.php). + +Note that any machine-readable content ([Computer Language Definitions](https://www.oasis-open.org/policies-guidelines/tc-process-2017-05-26/#wpComponentsCompLang)) declared Normative for this Work Product is provided in separate plain text files. In the event of a discrepancy between any such plain text file and display content in the Work Product's prose narrative document(s), the content in the separate plain text file prevails. + +#### Citation format: +When referencing this specification the following citation format should be used: + +**[csaf-v2.0]** + +_Common Security Advisory Framework Version 2.0_. Edited by Langley Rock, Stefan Hagen, and Thomas Schmidt. 18 November 2022. OASIS Standard. https://docs.oasis-open.org/csaf/csaf/v2.0/os/csaf-v2.0-os.html. Latest stage: https://docs.oasis-open.org/csaf/csaf/v2.0/csaf-v2.0.html. + + +------- + +## Notices + +Copyright © OASIS Open 2022. All Rights Reserved. + +All capitalized terms in the following text have the meanings assigned to them in the OASIS Intellectual Property Rights Policy (the "OASIS IPR Policy"). The full [Policy](https://www.oasis-open.org/policies-guidelines/ipr/) may be found at the OASIS website. + +This document and translations of it may be copied and furnished to others, and derivative works that comment on or otherwise explain it or assist in its implementation may be prepared, copied, published, and distributed, in whole or in part, without restriction of any kind, provided that the above copyright notice and this section are included on all such copies and derivative works. However, this document itself may not be modified in any way, including by removing the copyright notice or references to OASIS, except as needed for the purpose of developing any document or deliverable produced by an OASIS Technical Committee (in which case the rules applicable to copyrights, as set forth in the OASIS IPR Policy, must be followed) or as required to translate it into languages other than English. + +The limited permissions granted above are perpetual and will not be revoked by OASIS or its successors or assigns. + +This document and the information contained herein is provided on an "AS IS" basis and OASIS DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION HEREIN WILL NOT INFRINGE ANY OWNERSHIP RIGHTS OR ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. + +As stated in the OASIS IPR Policy, the following three paragraphs in brackets apply to OASIS Standards Final Deliverable documents (Committee Specification, Candidate OASIS Standard, OASIS Standard, or Approved Errata). + +\[OASIS requests that any OASIS Party or any other party that believes it has patent claims that would necessarily be infringed by implementations of this OASIS Standards Final Deliverable, to notify OASIS TC Administrator and provide an indication of its willingness to grant patent licenses to such patent claims in a manner consistent with the IPR Mode of the OASIS Technical Committee that produced this deliverable.\] + +\[OASIS invites any party to contact the OASIS TC Administrator if it is aware of a claim of ownership of any patent claims that would necessarily be infringed by implementations of this OASIS Standards Final Deliverable by a patent holder that is not willing to provide a license to such patent claims in a manner consistent with the IPR Mode of the OASIS Technical Committee that produced this OASIS Standards Final Deliverable. OASIS may include such claims on its website, but disclaims any obligation to do so.\] + +\[OASIS takes no position regarding the validity or scope of any intellectual property or other rights that might be claimed to pertain to the implementation or use of the technology described in this OASIS Standards Final Deliverable or the extent to which any license under such rights might or might not be available; neither does it represent that it has made any effort to identify any such rights. Information on OASIS' procedures with respect to rights in any document or deliverable produced by an OASIS Technical Committee can be found on the OASIS website. Copies of claims of rights made available for publication and any assurances of licenses to be made available, or the result of an attempt made to obtain a general license or permission for the use of such proprietary rights by implementers or users of this OASIS Standards Final Deliverable, can be obtained from the OASIS TC Administrator. OASIS makes no representation that any information or list of intellectual property rights will at any time be complete, or that any claims in such list are, in fact, Essential Claims.\] + +The name "OASIS" is a trademark of [OASIS](https://www.oasis-open.org/), the owner and developer of this specification, and should be used only to refer to the organization and its official outputs. OASIS welcomes reference to, and implementation and use of, specifications, while reserving the right to enforce its marks against misleading uses. Please see https://www.oasis-open.org/policies-guidelines/trademark/ for above guidance. + +------- diff --git a/csaf_2.1/prose/edit/src/guidance-on-size.md b/csaf_2.1/prose/edit/src/guidance-on-size.md new file mode 100644 index 000000000..a2700d73a --- /dev/null +++ b/csaf_2.1/prose/edit/src/guidance-on-size.md @@ -0,0 +1,344 @@ + +# Appendix C. Guidance on the Size of CSAF Documents + +This appendix provides informative guidance on the size of CSAF documents. + +The TC carefully considered all known aspects to provide size limits for CSAF documents for this version of the specification with the result that hard limits SHOULD NOT be enforced. However, since there is the need for guidance to ensure interoperability in the ecosystem, the TC provides a set of soft limits. A CSAF document which exceeds those, can still be valid but it might not be processable for some parties. + +All _CSAF consumers_ SHOULD be able to process CSAF documents which comply with the limits below. All _CSAF producers_ SHOULD NOT produce CSAF documents which exceed those limits. + +> If you come across a case where these limits are exceeded, please provide feedback to the TC. + +## C.1 File size + +A CSAF document in the specified JSON format encoded in UTF-8 SHOULD conform to known size limits of current technologies parsing JSON content, e.g.: 15 MB. + +> At least one database technology in wide use for storing CSAF documents rejects insert attempts when the transformed BSON size exceeds 16 megabytes. The BSON format optimizes for accessibility and not size. So, small integers and small strings may incur more overhead in the BSON format than in JSON. In addition, the BSON format adds length information for the entries inside the document, which adds to the size when storing CSAF document content in a BSON format. + +## C.2 Array length + +An array SHOULD NOT have more than: + +* 10 000 items for + * `/document/acknowledgments` + * `/document/acknowledgments[]/names` + * `/document/acknowledgments[]/urls` + * `/document/tracking/aliases` + * `/product_tree/branches[]/product/product_identification_helper/hashes` + * `/product_tree/branches[]/product/product_identification_helper/hashes[]/file_hashes` + * `/product_tree/branches[]/product/product_identification_helper/sbom_urls` + * `/product_tree/branches[]/product/product_identification_helper/x_generic_uris` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/hashes` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/hashes[]/file_hashes` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/sbom_urls` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/x_generic_uris` + * `/product_tree/full_product_names[]/product_identification_helper/hashes` + * `/product_tree/full_product_names[]/product_identification_helper/hashes[]/file_hashes` + * `/product_tree/full_product_names[]/product_identification_helper/sbom_urls` + * `/product_tree/full_product_names[]/product_identification_helper/x_generic_uris` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/hashes` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/hashes[]/file_hashes` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/sbom_urls` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/x_generic_uris` + * `/vulnerabilities[]/acknowledgments` + * `/vulnerabilities[]/acknowledgments[]/names` + * `/vulnerabilities[]/acknowledgments[]/urls` + * `/vulnerabilities[]/ids` + * `/vulnerabilities[]/remediations[]/entitlements` + +* 40 000 items for + * `/document/notes` + * `/document/references` + * `/vulnerabilities[]/involvements` + * `/vulnerabilities[]/notes` + * `/vulnerabilities[]/references` + +* 100 000 for + * `/document/tracking/revision_history` + * `/product_tree/branches` + * `/product_tree(/branches[])*/branches` + * `/product_tree/branches[]/product/product_identification_helper/model_numbers` + * `/product_tree/branches[]/product/product_identification_helper/serial_numbers` + * `/product_tree/branches[]/product/product_identification_helper/skus` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/model_numbers` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/serial_numbers` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/skus` + * `/product_tree/full_product_names` + * `/product_tree/full_product_names[]/product_identification_helper/model_numbers` + * `/product_tree/full_product_names[]/product_identification_helper/serial_numbers` + * `/product_tree/full_product_names[]/product_identification_helper/skus` + * `/product_tree/product_groups[]/product_ids` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/model_numbers` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/serial_numbers` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/skus` + * `/vulnerabilities` + +* 10 000 000 for + * `/product_tree/relationships` + * `/product_tree/product_groups` + * `/vulnerabilities[]/remediations[]/group_ids` + +* 100 000 000 for + * `/vulnerabilities[]/flags` + * `/vulnerabilities[]/flags[]/group_ids` + * `/vulnerabilities[]/flags[]/product_ids` + * `/vulnerabilities[]/product_status/first_affected` + * `/vulnerabilities[]/product_status/first_fixed` + * `/vulnerabilities[]/product_status/fixed` + * `/vulnerabilities[]/product_status/known_affected` + * `/vulnerabilities[]/product_status/known_not_affected` + * `/vulnerabilities[]/product_status/last_affected` + * `/vulnerabilities[]/product_status/recommended` + * `/vulnerabilities[]/product_status/under_investigation` + * `/vulnerabilities[]/remediations` + * `/vulnerabilities[]/remediations[]/product_ids` + * `/vulnerabilities[]/scores` + * `/vulnerabilities[]/scores[]/products` + * `/vulnerabilities[]/threats` + * `/vulnerabilities[]/threats[]/group_ids` + * `/vulnerabilities[]/threats[]/product_ids` + +## C.3 String length + +A string SHOULD NOT have a length greater than: + +* 1000 for + * `/document/acknowledgments[]/names[]` + * `/document/acknowledgments[]/organization` + * `/document/aggregate_severity/text` + * `/document/category` + * `/document/lang` + * `/document/notes[]/audience` + * `/document/notes[]/title` + * `/document/publisher/name` + * `/document/source_lang` + * `/document/title` + * `/document/tracking/aliases[]` + * `/document/tracking/generator/engine/name` + * `/document/tracking/generator/engine/version` + * `/document/tracking/id` + * `/document/tracking/revision_history[]/legacy_version` + * `/document/tracking/revision_history[]/number` + * `/document/tracking/version` + * `/product_tree/branches[]/name` + * `/product_tree/branches[]/product/name` + * `/product_tree/branches[]/product/product_id` + * `/product_tree/branches[]/product/product_identification_helper/hashes[]/file_hashes[]/algorithm` + * `/product_tree/branches[]/product/product_identification_helper/hashes[]/file_hashes[]/value` + * `/product_tree/branches[]/product/product_identification_helper/hashes[]/filename` + * `/product_tree/branches[]/product/product_identification_helper/model_numbers[]` + * `/product_tree/branches[]/product/product_identification_helper/serial_numbers[]` + * `/product_tree/branches[]/product/product_identification_helper/skus[]` + * `/product_tree/branches[](/branches[])*/name` + * `/product_tree/branches[](/branches[])*/product/name` + * `/product_tree/branches[](/branches[])*/product/product_id` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/hashes[]/file_hashes[]/algorithm` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/hashes[]/file_hashes[]/value` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/hashes[]/filename` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/model_numbers[]` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/serial_numbers[]` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/skus[]` + * `/product_tree/full_product_names[]/name` + * `/product_tree/full_product_names[]/product_id` + * `/product_tree/full_product_names[]/product_identification_helper/hashes[]/file_hashes[]/algorithm` + * `/product_tree/full_product_names[]/product_identification_helper/hashes[]/file_hashes[]/value` + * `/product_tree/full_product_names[]/product_identification_helper/hashes[]/filename` + * `/product_tree/full_product_names[]/product_identification_helper/model_numbers[]` + * `/product_tree/full_product_names[]/product_identification_helper/serial_numbers[]` + * `/product_tree/full_product_names[]/product_identification_helper/skus[]` + * `/product_tree/product_groups[]/group_id` + * `/product_tree/product_groups[]/product_ids[]` + * `/product_tree/relationships[]/full_product_name/name` + * `/product_tree/relationships[]/full_product_name/product_id` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/hashes[]/file_hashes[]/algorithm` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/hashes[]/file_hashes[]/value` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/hashes[]/filename` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/model_numbers[]` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/serial_numbers[]` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/skus[]` + * `/product_tree/relationships[]/product_reference` + * `/product_tree/relationships[]/relates_to_product_reference` + * `/vulnerabilities[]/acknowledgments[]/names[]` + * `/vulnerabilities[]/acknowledgments[]/organization` + * `/vulnerabilities[]/cve` + * `/vulnerabilities[]/cwe/id` + * `/vulnerabilities[]/cwe/name` + * `/vulnerabilities[]/flags[]/group_ids[]` + * `/vulnerabilities[]/flags[]/product_ids[]` + * `/vulnerabilities[]/ids[]/system_name` + * `/vulnerabilities[]/ids[]/text` + * `/vulnerabilities[]/notes[]/audience` + * `/vulnerabilities[]/notes[]/title` + * `/vulnerabilities[]/product_status/first_affected[]` + * `/vulnerabilities[]/product_status/first_fixed[]` + * `/vulnerabilities[]/product_status/fixed[]` + * `/vulnerabilities[]/product_status/known_affected[]` + * `/vulnerabilities[]/product_status/known_not_affected[]` + * `/vulnerabilities[]/product_status/last_affected[]` + * `/vulnerabilities[]/product_status/recommended[]` + * `/vulnerabilities[]/product_status/under_investigation[]` + * `/vulnerabilities[]/remediations[]/group_ids[]` + * `/vulnerabilities[]/remediations[]/product_ids[]` + * `/vulnerabilities[]/scores[]/cvss_v2/vectorString` + * `/vulnerabilities[]/scores[]/cvss_v3/vectorString` + * `/vulnerabilities[]/scores[]/products[]` + * `/vulnerabilities[]/threats[]/group_ids[]` + * `/vulnerabilities[]/threats[]/product_ids[]` + * `/vulnerabilities[]/title` + +* 10 000 for + * `/document/acknowledgments[]/summary` + * `/document/distribution/text` + * `/document/publisher/contact_details` + * `/document/publisher/issuing_authority` + * `/document/references[]/summary` + * `/document/tracking/revision_history[]/summary` + * `/product_tree/branches[]/product/product_identification_helper/cpe` + * `/product_tree/branches[]/product/product_identification_helper/purl` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/cpe` + * `/product_tree/branches[](/branches[])*/product/product_identification_helper/purl` + * `/product_tree/full_product_names[]/product_identification_helper/cpe` + * `/product_tree/full_product_names[]/product_identification_helper/purl` + * `/product_tree/product_groups[]/summary` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/cpe` + * `/product_tree/relationships[]/full_product_name/product_identification_helper/purl` + * `/vulnerabilities[]/acknowledgments[]/summary` + * `/vulnerabilities[]/involvements[]/summary` + * `/vulnerabilities[]/references[]/summary` + * `/vulnerabilities[]/remediations[]/entitlements[]` + +* 30 000 for + * `/document/notes[]/text` + * `/vulnerabilities[]/notes[]/text` + +* 250 000 for + * `/vulnerabilities[]/remediations[]/details` + * `/vulnerabilities[]/remediations[]/restart_required/details` + * `/vulnerabilities[]/threats[]/details` + +## C.4 URI length + +A string with format `uri` SHOULD NOT have a length greater than 20000. This applies to: + +* `/document/acknowledgments[]/urls[]` +* `/document/aggregate_severity/namespace` +* `/document/distribution/tlp/url` +* `/document/references[]/url` +* `/document/publisher/namespace` +* `/product_tree/branches[]/product/product_identification_helper/sbom_urls[]` +* `/product_tree/branches[]/product/product_identification_helper/x_generic_uris[]/namespace` +* `/product_tree/branches[]/product/product_identification_helper/x_generic_uris[]/uri` +* `/product_tree/branches[](/branches[])*/product/product_identification_helper/sbom_urls[]` +* `/product_tree/branches[](/branches[])*/product/product_identification_helper/x_generic_uris[]/namespace` +* `/product_tree/branches[](/branches[])*/product/product_identification_helper/x_generic_uris[]/uri` +* `/product_tree/full_product_names[]/product_identification_helper/sbom_urls[]` +* `/product_tree/full_product_names[]/product_identification_helper/x_generic_uris[]/namespace` +* `/product_tree/full_product_names[]/product_identification_helper/x_generic_uris[]/uri` +* `/product_tree/relationships[]/full_product_name/product_identification_helper/sbom_urls[]` +* `/product_tree/relationships[]/full_product_name/product_identification_helper/x_generic_uris[]/namespace` +* `/product_tree/relationships[]/full_product_name/product_identification_helper/x_generic_uris[]/uri` +* `/vulnerabilities[]/acknowledgments[]/urls[]` +* `/vulnerabilities[]/references[]/url` +* `/vulnerabilities[]/remediations[]/url` + +## C.5 Enum + +A string which is an enum has a fixed maximum length given by its longest value. + +> Later versions of CSAF might add, modify or delete possible value which could change the longest value. Therefore, this sizes should not be implemented as fixed limits if forward compatibility is desired. + +It seems to be safe to assume that the length of each value is not greater than 50. This applies to: + +* `/document/csaf_version` (3) +* `/document/distribution/tlp/label` (5) +* `/document/notes[]/category` (16) +* `/document/publisher/category` (11) +* `/document/references[]/category` (8) +* `/document/tracking/status` (7) +* `/product_tree/branches[]/category` (15) +* `/product_tree/branches[](/branches[])*/category` (15) +* `/product_tree/relationships[]/category` (21) +* `/vulnerabilities[]/flags[]/label` (49) +* `/vulnerabilities[]/involvements[]/party` (11) +* `/vulnerabilities[]/involvements[]/status` (17) +* `/vulnerabilities[]/notes[]/category` (16) +* `/vulnerabilities[]/references[]/category` (8) +* `/vulnerabilities[]/remediations[]/category` (14) +* `/vulnerabilities[]/remediations[]/restart_required/category` (20) +* `/vulnerabilities[]/scores[]/cvss_v2/version` (3) +* `/vulnerabilities[]/scores[]/cvss_v2/accessVector` (16) +* `/vulnerabilities[]/scores[]/cvss_v2/accessComplexity` (6) +* `/vulnerabilities[]/scores[]/cvss_v2/authentication` (8) +* `/vulnerabilities[]/scores[]/cvss_v2/confidentialityImpact` (8) +* `/vulnerabilities[]/scores[]/cvss_v2/integrityImpact` (8) +* `/vulnerabilities[]/scores[]/cvss_v2/availabilityImpact` (8) +* `/vulnerabilities[]/scores[]/cvss_v2/exploitability` (16) +* `/vulnerabilities[]/scores[]/cvss_v2/remediationLevel` (13) +* `/vulnerabilities[]/scores[]/cvss_v2/reportConfidence` (14) +* `/vulnerabilities[]/scores[]/cvss_v2/collateralDamagePotential` (11) +* `/vulnerabilities[]/scores[]/cvss_v2/targetDistribution` (11) +* `/vulnerabilities[]/scores[]/cvss_v2/confidentialityRequirement` (11) +* `/vulnerabilities[]/scores[]/cvss_v2/integrityRequirement` (11) +* `/vulnerabilities[]/scores[]/cvss_v2/availabilityRequirement` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/version` (3) +* `/vulnerabilities[]/scores[]/cvss_v3/attackVector` (16) +* `/vulnerabilities[]/scores[]/cvss_v3/attackComplexity` (4) +* `/vulnerabilities[]/scores[]/cvss_v3/privilegesRequired` (4) +* `/vulnerabilities[]/scores[]/cvss_v3/userInteraction` (8) +* `/vulnerabilities[]/scores[]/cvss_v3/scope` (9) +* `/vulnerabilities[]/scores[]/cvss_v3/confidentialityImpact` (4) +* `/vulnerabilities[]/scores[]/cvss_v3/integrityImpact` (4) +* `/vulnerabilities[]/scores[]/cvss_v3/availabilityImpact` (4) +* `/vulnerabilities[]/scores[]/cvss_v3/baseSeverity` (8) +* `/vulnerabilities[]/scores[]/cvss_v3/exploitCodeMaturity` (16) +* `/vulnerabilities[]/scores[]/cvss_v3/remediationLevel` (13) +* `/vulnerabilities[]/scores[]/cvss_v3/reportConfidence` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/temporalSeverity` (8) +* `/vulnerabilities[]/scores[]/cvss_v3/confidentialityRequirement` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/integrityRequirement` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/availabilityRequirement` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/modifiedAttackVector` (16) +* `/vulnerabilities[]/scores[]/cvss_v3/modifiedAttackComplexity` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/modifiedPrivilegesRequired` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/modifiedUserInteraction` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/modifiedScope` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/modifiedConfidentialityImpact` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/modifiedIntegrityImpact` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/modifiedAvailabilityImpact` (11) +* `/vulnerabilities[]/scores[]/cvss_v3/environmentalSeverity` (8) +* `/vulnerabilities[]/threats[]/category` (14) + +## C.6 Date + +The maximum length of strings representing a temporal value is given by the format specifier. This applies to: + +* `/document/tracking/current_release_date` +* `/document/tracking/generator/date` +* `/document/tracking/initial_release_date` +* `/document/tracking/revision_history[]/date` +* `/vulnerabilities[]/discovery_date` +* `/vulnerabilities[]/flags[]/date` +* `/vulnerabilities[]/release_date` +* `/vulnerabilities[]/involvements[]/date` +* `/vulnerabilities[]/remediations[]/date` +* `/vulnerabilities[]/threats[]/date` diff --git a/csaf_2.1/prose/edit/src/introduction-00.md b/csaf_2.1/prose/edit/src/introduction-00.md new file mode 100644 index 000000000..49f601b3b --- /dev/null +++ b/csaf_2.1/prose/edit/src/introduction-00.md @@ -0,0 +1,2 @@ +# 1 Introduction + diff --git a/csaf_2.1/prose/edit/src/introduction-01-ipr-policy.md b/csaf_2.1/prose/edit/src/introduction-01-ipr-policy.md new file mode 100644 index 000000000..30b2808e4 --- /dev/null +++ b/csaf_2.1/prose/edit/src/introduction-01-ipr-policy.md @@ -0,0 +1,4 @@ +## 1.1 IPR Policy + +This specification is provided under the [Non-Assertion](https://www.oasis-open.org/policies-guidelines/ipr/#Non-Assertion-Mode) Mode of the [OASIS IPR Policy](https://www.oasis-open.org/policies-guidelines/ipr/), the mode chosen when the Technical Committee was established. For information on whether any patents have been disclosed that may be essential to implementing this specification, and any offers of patent licensing terms, please refer to the Intellectual Property Rights section of the TC's web page ([https://www.oasis-open.org/committees/csaf/ipr.php](https://www.oasis-open.org/committees/csaf/ipr.php)). + diff --git a/csaf_2.1/prose/edit/src/introduction-02-terminology.md b/csaf_2.1/prose/edit/src/introduction-02-terminology.md new file mode 100644 index 000000000..c84fded5c --- /dev/null +++ b/csaf_2.1/prose/edit/src/introduction-02-terminology.md @@ -0,0 +1,152 @@ +## 1.2 Terminology + +The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 [[RFC2119](#rfc2119)] and [[RFC8174](#rfc8174)] when, and only when, they appear in all capitals, as shown here. + +For purposes of this document, the following terms and definitions apply: + +**advisory**: reporting item that describes a condition present in an artifact and that requires action by the consumers + +**advisory document**: artifact in which an analysis tool reports a result + +**advisory management system**: software system that consumes the documents produced by analysis tools, produces advisories that enable engineering and operating organizations to assess the quality of these software artifacts at a point in time, and performs functions such as filing security advisories and displaying information about individual advisories. **Note**: An advisory management system can interact with a document viewer to display information about individual advisories. + +**advisory matching**: process of determining whether two advisories are targeting the same products and conditions + +**artifact**: sequence of bytes addressable via a URI. _Examples_: A physical file in a file system such as a source file, an object file, a configuration file or a data file; a specific version of a file in a version control system; a database table accessed via an HTTP request; an arbitrary stream of bytes returned from an HTTP request, a product URL, a common product enumeration value. + +**CSAF asset matching system**: program that connects to or is an asset database and is able to manage CSAF documents as required by CSAF management system as well as matching them to assets of the asset database. + +**CSAF basic validator**: A program that reads a document and checks it against the JSON schema and performs mandatory tests. + +**CSAF consumer**: program that reads and interprets a CSAF document + +**CSAF content management system**: program that is able to create, review and manage CSAF documents and is able to preview their details as required by CSAF viewer. + +**CSAF converter**: CSAF producer that transforms the output of an analysis tool from its native output format into the CSAF format + +**CSAF direct producer**: analysis tool which acts as a CSAF producer + +**CSAF document**: security advisory text document in the format defined by this document. + +**CSAF extended validator**: A CSAF basic validator that additionally performs optional tests. + +**CSAF full validator**: A CSAF extended validator that additionally performs informative tests. + +**CSAF management system**: program that is able to manage CSAF documents and is able to display their details as required by CSAF viewer. + +**CSAF modifier**: CSAF post-processor which takes a CSAF document as input and modifies the structure or values of properties. The output is a valid CSAF document. + +**CSAF post-processor**: CSAF producer that transforms an existing CSAF document into a new CSAF document, for example, by removing or redacting elements according to sharing policies. + +**CSAF SBOM matching system**: A program that connects to or is an SBOM database and is able to manage CSAF documents as required by CSAF management system as well as matching them to SBOM components of the SBOM database. + +**CSAF producer**: program that emits output in the CSAF format + +**CSAF translator**: CSAF post-processor which takes a CSAF document as input and translates values of properties into another language. The output is a valid CSAF document. + +**CSAF viewer**: CSAF consumer that reads a CSAF document, displays a list of the results it contains, and allows an end user to view each result in the context of the artifact in which it occurs. + +**CVRF CSAF converter**: CSAF producer which takes a CVRF document as input and converts it into a valid CSAF document. + +**document**: output file produced by an analysis tool, which enumerates the results produced by the tool + +**driver**: tool component containing an analysis tool’s or converter’s primary executable, which controls the tool’s or converter’s execution, and which in the case of an analysis tool typically defines a set of analysis rules + +**embedded link**: syntactic construct which enables a message string to refer to a location mentioned in the document + +**empty array**: array that contains no elements, and so has a length of 0 + +**empty object**: object that contains no properties + +**empty string**: string that contains no characters, and so has a length of 0 + +**(end) user**: person who uses the information in a document to investigate, triage, or resolve results + +**engineering system**: software analysis environment within which analysis tools execute. **Note**: An engineering system might include a build system, a source control system, a result management system, a bug tracking system, a test execution system, and so on. + +**extension**: tool component other than the driver (for example, a plugin, a configuration file, or a taxonomy) + +**external property file**: file containing the values of one or more externalized properties + +**externalizable property**: property that can be contained in an external property file + +**externalized property**: property stored outside of the CSAF document to which it logically belongs + +**false positive**: result which an end user decides does not actually represent a problem + +**fingerprint**: stable value that can be used by a result management system to uniquely identify a result over time, even if a relevant artifact is modified + +**formatted message**: message string which contains formatting information such as Markdown formatting characters + +**fully qualified logical name**: string that fully identifies the programmatic construct specified by a logical location, typically by means of a hierarchical identifier. + +**hierarchical string**: string in the format <component>{/<component>}* + +**line**: contiguous sequence of characters, starting either at the beginning of an artifact or immediately after a newline sequence, and ending at and including the nearest subsequent newline sequence, if one is present, or else extending to the end of the artifact + +**line (number)**: 1-based index of a line within a file. **Note**: Abbreviated to "line" when there is no danger of ambiguity with "line" in the sense of a sequence of characters. + +**localizable**: subject to being translated from one natural language to another + +**message string**: human-readable string that conveys information relevant to an element in a CSAF document + +**nested artifact**: artifact that is contained within another artifact + +**newline sequence**: sequence of one or more characters representing the end of a line of text. **Note**: Some systems represent a newline sequence with a single newline character; others represent it as a carriage return character followed by a newline character. + +**notification**: reporting item that describes a condition encountered by a tool during its execution + +**opaque**: neither human-readable nor machine-parsable into constituent parts + +**parent (artifact)**: artifact which contains one or more nested artifacts + +**plain text message**: message string which does not contain any formatting information + +**plugin**: tool component that defines additional rules + +**policy**: set of rule configurations that specify how results that violate the rules defined by a particular tool component are to be treated + +**problem**: result which indicates a condition that has the potential to detract from the quality of the program. _Examples_: A security vulnerability, a deviation from contractual or legal requirements. + +**product**: is any deliverable (e.g. software, hardware, specification,...) which can be referred to with a name. This applies regardless of the origin, the license model, or the mode of distribution of the deliverable. + +**property**: attribute of an object consisting of a name and a value associated with the name + +**redactable property**: property that potentially contains sensitive information that a CSAF direct producer or a CSAF post-processor might wish to redact + +**reporting item**: unit of output produced by a tool, either a result or a notification + +**reporting configuration**: the subset of reporting metadata that a tool can configure at runtime, before performing its scan. _Examples_: severity level, rank + +**repository** container for a related set of files in a version control system + +**taxonomy**: classification of analysis results into a set of categories + +**tag**: string that conveys additional information about the CSAF document element to which it applies + +**text artifact**: artifact considered as a sequence of characters organized into lines and columns + +**text region**: region representing a contiguous range of zero or more characters in a text artifact + +**tool component**: component of an analysis tool or converter, either its driver or an extension, consisting of one or more files + +**top-level artifact**: artifact which is not contained within any other artifact + +**translation**: rendering of a tool component's localizable strings into another language + +**triage**: decide whether a result indicates a problem that needs to be corrected + +**user**: see end user. + +**VCS**: version control system + +**vendor**: the community, individual, or organization that created or maintains a product (including open source software and hardware providers) + +**VEX**: Vulnerability Exploitability eXchange - enables a supplier or other party to assert whether or not a particular product is affected by a specific vulnerability, especially helpful in efficiently consuming SBOM data. + +**viewer**: see CSAF viewer. + +**vulnerability**: functional behavior of a product or service that violates an implicit or explicit security policy (conforming to ISO/IEC 29147 [ISO29147]) + +**XML**: eXtensible Markup Language - the format used by the predecessors of this standard, namely CVRF 1.1 and CVRF 1.2. + diff --git a/csaf_2.1/prose/edit/src/introduction-03-normative-references.md b/csaf_2.1/prose/edit/src/introduction-03-normative-references.md new file mode 100644 index 000000000..6cfb1ee69 --- /dev/null +++ b/csaf_2.1/prose/edit/src/introduction-03-normative-references.md @@ -0,0 +1,19 @@ +## 1.3 Normative References + +###### [JSON-Schema-Core] +_JSON Schema: A Media Type for Describing JSON Documents_, draft-bhutton-json-schema-00, December 2020, https://datatracker.ietf.org/doc/html/draft-bhutton-json-schema-00. +###### [JSON-Schema-Validation] +_JSON Schema Validation: A Vocabulary for Structural Validation of JSON_, draft-bhutton-json-schema-validation-00, December 2020, https://datatracker.ietf.org/doc/html/draft-bhutton-json-schema-validation-00. +###### [JSON-Hyper-Schema] +_JSON Hyper-Schema: A Vocabulary for Hypermedia Annotation of JSON_, draft-handrews-json-schema-hyperschema-02, September 2019, https://json-schema.org/draft/2019-09/json-schema-hypermedia.html. +###### [Relative-JSON-Pointers] +_Relative JSON Pointers_, draft-bhutton-relative-json-pointer-00, December 2020, https://datatracker.ietf.org/doc/html/draft-bhutton-relative-json-pointer-00. +###### [RFC2119] +Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, DOI 10.17487/RFC2119, March 1997, https://www.rfc-editor.org/info/rfc2119. +###### [RFC7464] +Williams, N., "JavaScript Object Notation (JSON) Text Sequences", RFC 7464, DOI 10.17487/RFC7464, February 2015, https://www.rfc-editor.org/info/rfc7464. +###### [RFC8174] +Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174, May 2017, https://www.rfc-editor.org/info/rfc8174. +###### [RFC8259] +T. Bray, Ed., "The JavaScript Object Notation (JSON) Data Interchange Format", RFC 8259, DOI 10.17487/RFC8259, December 2017, https://www.rfc-editor.org/info/rfc8259. + diff --git a/csaf_2.1/prose/edit/src/introduction-04-informative-references.md b/csaf_2.1/prose/edit/src/introduction-04-informative-references.md new file mode 100644 index 000000000..4e804c6f9 --- /dev/null +++ b/csaf_2.1/prose/edit/src/introduction-04-informative-references.md @@ -0,0 +1,85 @@ +## 1.4 Informative References + +###### [CPE23-A] +_Common Platform Enumeration: Applicability Language Specification Version 2.3 (NISTIR 7698)_, D. Waltermire, P. Cichonski, K. Scarfone, Editors, NIST Interagency Report 7698, August 2011, https://dx.doi.org/10.6028/NIST.IR.7698. +###### [CPE23-D] +_Common Platform Enumeration: Dictionary Specification Version 2.3_, P. Cichonski, D. Waltermire, K. Scarfone, Editors, NIST Interagency Report 7697, August 2011, https://dx.doi.org/10.6028/NIST.IR.7697. +###### [CPE23-M] +_Common Platform Enumeration: Naming Matching Specification Version 2.3_, M. Parmelee, H. Booth, D. Waltermire, K. Scarfone, Editors, NIST Interagency Report 7696, August 2011, https://dx.doi.org/10.6028/NIST.IR.7696. +###### [CPE23-N] +_Common Platform Enumeration: Naming Specification Version 2.3_, B. Cheikes, D. Waltermire, K. Scarfone, Editors, NIST Interagency Report 7695, August 2011, https://dx.doi.org/10.6028/NIST.IR.7695. +###### [CVE] +_Common Vulnerability and Exposures (CVE) – The Standard for Information Security Vulnerability Names_, MITRE, 1999, https://cve.mitre.org/about/. +###### [CVE-NF] +_Common Vulnerability and Exposures (CVE) – The Standard for Information Security Vulnerability Names - CVE ID Syntax Change_, MITRE, January 01, 2014, https://cve.mitre.org/cve/identifiers/syntaxchange.html. +###### [CVRF-1-1] +_The Common Vulnerability Reporting Framework (CVRF) Version 1.1_, M. Schiffman, Editor, May 2012, Internet Consortium for Advancement of Security on the Internet (ICASI), https://www.icasi.org/the-common-vulnerability-reporting-framework-cvrf-v1-1/. +###### [CVRF-v1.2] +_CSAF Common Vulnerability Reporting Framework (CVRF) Version 1.2_. Edited by Stefan Hagen. 13 September 2017. OASIS Committee Specification 01. https://docs.oasis-open.org/csaf/csaf-cvrf/v1.2/cs01/csaf-cvrf-v1.2-cs01.html. Latest version: https://docs.oasis-open.org/csaf/csaf-cvrf/v1.2/csaf-cvrf-v1.2.html. +###### [CVSS2] +_A Complete Guide to the Common Vulnerability Scoring System Version 2.0_, P. Mell, K. Scarfone, S. Romanosky, Editors, First.org, Inc., June 2007, https://www.first.org/cvss/cvss-v2-guide.pdf. +###### [CVSS30] +_Common Vulnerability Scoring System v3.0: Specification Document_, FIRST.Org, Inc., June 2019, https://www.first.org/cvss/v3.0/cvss-v30-specification_v1.9.pdf. +###### [CVSS31] +_Common Vulnerability Scoring System v3.1: Specification Document_, FIRST.Org, Inc., June 2019, https://www.first.org/cvss/v3-1/cvss-v31-specification_r1.pdf. +###### [CWE] +_Common Weakness Enumeration (CWE) – A Community-Developed List of Software Weakness Types_, MITRE, 2005, http://cwe.mitre.org/about/. +###### [CYCLONEDX13] +_CycloneDX Software Bill-of-Material Specification JSON schema version 1.3_, cyclonedx.org, May 2021, https://github.com/CycloneDX/specification/blob/1.3/schema/bom-1.3.schema.json. +###### [GFMCMARK] +_GitHub's fork of cmark, a CommonMark parsing and rendering library and program in C_, https://github.com/github/cmark. +###### [GFMENG] +_GitHub Engineering: A formal spec for GitHub Flavored Markdown_, https://githubengineering.com/a-formal-spec-for-github-markdown/. +###### [ISO8601] +_Data elements and interchange formats — Information interchange — Representation of dates and times_, International Standard, ISO 8601:2004(E), December 1, 2004, https://www.iso.org/standard/40874.html. +###### [ISO19770-2] +_Information technology — IT asset management — Part 2: Software identification tag_, International Standard, ISO 19770-2:2015, September 30, 2015, +https://www.iso.org/standard/65666.html. +###### [ISO29147] +_Information technology — Security techniques — Vulnerability disclosure_, International Standard, ISO/IEC 29147:2018, October, 2018, +https://www.iso.org/standard/72311.html. +###### [OPENSSL] +_GTLS/SSL and crypto library_, OpenSSL Software Foundation, https://www.openssl.org/. +###### [PURL] +_Package URL (PURL)_, GitHub Project, https://github.com/package-url/purl-spec. +###### [RFC3339] +Klyne, G. and C. Newman, "Date and Time on the Internet: Timestamps", RFC 3339, DOI 10.17487/RFC3339, July 2002, https://www.rfc-editor.org/info/rfc3339. +###### [RFC3552] +Rescorla, E. and B. Korver, "Guidelines for Writing RFC Text on Security Considerations", BCP 72, RFC 3552, DOI 10.17487/RFC3552, July 2003, https://www.rfc-editor.org/info/rfc3552. +###### [RFC3986] +Berners-Lee, T., Fielding, R., and L. Masinter, "Uniform Resource Identifier (URI): Generic Syntax", STD 66, RFC 3986, DOI 10.17487/RFC3986, January 2005, https://www.rfc-editor.org/info/rfc3986. +###### [RFC4880] +Callas, J., Donnerhacke, L., Finney, H., Shaw, D., and R. Thayer, "OpenPGP Message Format", RFC 4880, DOI 10.17487/RFC4880, November 2007, https://www.rfc-editor.org/info/rfc4880. +###### [RFC7231] +Fielding, R., Ed., and J. Reschke, Ed., "Hypertext Transfer Protocol (HTTP/1.1): Semantics and Content", RFC 7231, DOI 10.17487/RFC7231, June 2014, https://www.rfc-editor.org/info/rfc7231. +###### [RFC7464] +N. Williams., "JavaScript Object Notation (JSON) Text Sequences", RFC 7464, DOI 10.17487/RFC7464, February 2015, https://www.rfc-editor.org/info/rfc7464. +###### [RFC8615] +Nottingham, M., "Well-Known Uniform Resource Identifiers (URIs)", RFC 8615, DOI 10.17487/RFC8615, May 2019, https://www.rfc-editor.org/info/rfc8615. +###### [RFC9116] +Foudil, E. and Y. Shafranovich, "A File Format to Aid in Security Vulnerability Disclosure", RFC 9116, DOI 10.17487/RFC9116, April 2022, https://www.rfc-editor.org/info/rfc9116. +###### [SCAP12] +_The Technical Specification for the Security Content Automation Protocol (SCAP): SCAP Version 1.2_, D. Waltermire, S. Quinn, K. Scarfone, A. Halbardier, Editors, NIST Spec. Publ. 800‑126 rev. 2, September 2011, https://dx.doi.org/10.6028/NIST.SP.800-126r2. +###### [SECURITY-TXT] +Foudil, E. and Shafranovich, Y., _Security.txt Project_, https://securitytxt.org/. +###### [SemVer] +_Semantic Versioning 2.0.0_, T. Preston-Werner, June 2013, https://semver.org/. +###### [SPDX22] +_The Software Package Data Exchange (SPDX®) Specification Version 2.2_, Linux Foundation and its Contributors, 2020, https://spdx.github.io/spdx-spec/. +###### [VERS] +_vers: a mostly universal version range specifier_, Part of the PURL GitHub Project, https://github.com/package-url/purl-spec/blob/version-range-spec/VERSION-RANGE-SPEC.rst. +###### [VEX] +_Vulnerability-Exploitability eXchange (VEX) - An Overview_, VEX sub-group of the Framing Working Group in the NTIA SBOM initiative, 27 September 2021, +https://ntia.gov/files/ntia/publications/vex_one-page_summary.pdf. +###### [VEX-Justification] +_Vulnerability Exploitability eXchange (VEX) - Status Justifications_, VEX sub-group of the Framing Working Group in the CISA SBOM initiative, XX May 2022, https://www.cisa.gov/sites/default/files/publications/VEX_Status_Justification_Jun22.pdf. +###### [XML] +_Extensible Markup Language (XML) 1.0 (Fifth Edition)_, T. Bray, J. Paoli, M. Sperberg-McQueen, E. Maler, F. Yergeau, Editors, W3C Recommendation, November 26, 2008, https://www.w3.org/TR/2008/REC-xml-20081126/. +Latest version available at https://www.w3.org/TR/xml. +###### [XML-Schema-1] +_W3C XML Schema Definition Language (XSD) 1.1 Part 1: Structures_, S. Gao, M. Sperberg-McQueen, H. Thompson, N. Mendelsohn, D. Beech, M. Maloney, Editors, W3C Recommendation, April 5, 2012, https://www.w3.org/TR/2012/REC-xmlschema11-1-20120405/. +Latest version available at https://www.w3.org/TR/xmlschema11-1/. +###### [XML-Schema-2] +_W3C XML Schema Definition Language (XSD) 1.1 Part 2_: Datatypes W3C XML Schema Definition Language (XSD) 1.1 Part 2: Datatypes, D. Peterson, S. Gao, A. Malhotra, M. Sperberg-McQueen, H. Thompson, Paul V. Biron, Editors, W3C Recommendation, April 5, 2012, https://www.w3.org/TR/2012/REC-xmlschema11-2-20120405/. +Latest version available at https://www.w3.org/TR/xmlschema11-2/. + diff --git a/csaf_2.1/prose/edit/src/introduction-05-typographical-conventions.md b/csaf_2.1/prose/edit/src/introduction-05-typographical-conventions.md new file mode 100644 index 000000000..618b07b61 --- /dev/null +++ b/csaf_2.1/prose/edit/src/introduction-05-typographical-conventions.md @@ -0,0 +1,24 @@ +## 1.5 Typographical Conventions + +Keywords defined by this specification use this `monospaced` font. + +``` + Normative source code uses this paragraph style. +``` + +Some sections of this specification are illustrated with non-normative examples introduced with "Example" or "Examples" like so: + +*Examples 4321:* + +``` + Informative examples also use this paragraph style but preceded by the text "Example(s)". +``` + +All examples in this document are informative only. + +All other text is normative unless otherwise labeled e.g. like the following informative comment: + +>This is a pure informative comment that may be present, because the information conveyed is deemed useful advice or common pitfalls learned from implementer or operator experience and often given including the rationale. + +------- + diff --git a/csaf_2.1/prose/edit/src/profiles.md b/csaf_2.1/prose/edit/src/profiles.md new file mode 100644 index 000000000..2f576a36c --- /dev/null +++ b/csaf_2.1/prose/edit/src/profiles.md @@ -0,0 +1,118 @@ +# 4 Profiles + +CSAF documents do not have many required fields as they can be used for different purposes. To ensure a common understanding of which fields are required in a given use case the standard defines profiles. Each subsection describes such a profile by describing necessary content for that specific use case and providing insights into its purpose. The value of `/document/category` is used to identify a CSAF document's profile. The following rules apply: + +1. Each CSAF document MUST conform the **CSAF Base** profile. +2. Each profile extends the base profile "CSAF Base" - directly or indirect through another profile from the standard - by making additional fields from the standard mandatory. A profile can always add, but never subtract nor overwrite requirements defined in the profile it extends. +3. Any optional field from the standard can also be added to a CSAF document which conforms with a profile without breaking conformance with the profile. One and only exempt is when the profile requires not to have a certain set of fields. +4. Values of `/document/category` starting with `csaf_` are reserved for existing, upcoming and future profiles defined in the CSAF standard. +5. Values of `/document/category` that do not match any of the values defined in section 4 of this standard SHALL be validated against the "CSAF Base" profile. +6. Local or private profiles MAY exist and tools MAY choose to support them. +7. If an official profile and a private profile exists, tools MUST validate against the official one from the standard. + +## 4.1 Profile 1: CSAF Base + +This profile defines the default required fields for any CSAF document. Therefore, it is a "catch all" for CSAF documents that do not satisfy any other profile. Furthermore, it is the foundation all other profiles are build on. + +A CSAF document SHALL fulfill the following requirements to satisfy the profile "CSAF Base": + +* The following elements MUST exist and be valid: + * `/document/category` + * `/document/csaf_version` + * `/document/publisher/category` + * `/document/publisher/name` + * `/document/publisher/namespace` + * `/document/title` + * `/document/tracking/current_release_date` + * `/document/tracking/id` + * `/document/tracking/initial_release_date` + * `/document/tracking/revision_history[]/date` + * `/document/tracking/revision_history[]/number` + * `/document/tracking/revision_history[]/summary` + * `/document/tracking/status` + * `/document/tracking/version` +* The value of `/document/category` SHALL NOT be equal to any value that is intended to only be used by another profile nor to the (case insensitive) name of any other profile from the standard. This does not differentiate between underscore, dash or whitespace. To explicitly select the use of this profile the value `csaf_base` SHOULD be used. + +> Neither `CSAF Security Advisory` nor `csaf security advisory` are valid values for `/document/category`. + +An issuing party might choose to set `/document/publisher/name` in front of a value that is intended to only be used by another profile to state that the CSAF document does not use the profile associated with this value. In this case, the (case insensitive) string "CSAF" MUST be removed from the value. This SHOULD be done if the issuing party is unable or unwilling to use the value `csaf_base`, e.g. due to legal or cooperate identity reasons. + +> Both values `Example Company Security Advisory` and `Example Company security_advisory` in `/document/category` use the profile "CSAF Base". This is important to prepare forward compatibility as later versions of CSAF might add new profiles. Therefore, the values which can be used for the profile "CSAF Base" might change. + +## 4.2 Profile 2: Security incident response + +This profile SHOULD be used to provide a response to a security breach or incident. This MAY also be used to convey information about an incident that is unrelated to the issuing party's own products or infrastructure. + +> Example Company might use a CSAF document satisfying this profile to respond to a security incident at ACME Inc. and the implications on its own products and infrastructure. + +A CSAF document SHALL fulfill the following requirements to satisfy the profile "Security incident response": + +* The following elements MUST exist and be valid: + * all elements required by the profile "CSAF Base". + * `/document/notes` with at least one item which has a `category` of `description`, `details`, `general` or `summary` + > Reasoning: Without at least one note item which contains information about response to the event referred to this doesn't provide any useful information. + * `/document/references` with at least one item which has a `category` of `external` + > The intended use for this field is to refer to one or more documents or websites which provides more details about the incident. +* The value of `/document/category` SHALL be `csaf_security_incident_response`. + +## 4.3 Profile 3: Informational Advisory + +This profile SHOULD be used to provide information which are **not related to a vulnerability** but e.g. a misconfiguration. + +A CSAF document SHALL fulfill the following requirements to satisfy the profile "Informational Advisory": + +* The following elements MUST exist and be valid: + * all elements required by the profile "CSAF Base". + * `/document/notes` with at least one item which has a `category` of `description`, `details`, `general` or `summary` + > Reasoning: Without at least one note item which contains information about the "issue" which is the topic of the advisory it is useless. + * `/document/references` with at least one item which has a `category` of `external` + > The intended use for this field is to refer to one or more documents or websites which provide more details about the issue or its remediation (if possible). This could be a hardening guide, a manual, best practices or any other helpful information. +* The value of `/document/category` SHALL be `csaf_informational_advisory`. +* The element `/vulnerabilities` SHALL NOT exist. If there is any information that would reside in the element `/vulnerabilities` the CSAF document SHOULD use another profile, e.g. "Security Advisory". + +If the element `/product_tree` exists, a user MUST assume that all products mentioned are affected. + +## 4.4 Profile 4: Security Advisory + +This profile SHOULD be used to provide information which is related to vulnerabilities and corresponding remediations. + +A CSAF document SHALL fulfill the following requirements to satisfy the profile "Security Advisory": + +* The following elements MUST exist and be valid: + * all elements required by the profile "CSAF Base". + * `/product_tree` which lists all products referenced later on in the CSAF document regardless of their state. + * `/vulnerabilities` which lists all vulnerabilities. + * `/vulnerabilities[]/notes` + > Provides details about the vulnerability. + * `/vulnerabilities[]/product_status` + > Lists each product's status in regard to the vulnerability. +* The value of `/document/category` SHALL be `csaf_security_advisory`. + +## 4.5 Profile 5: VEX + +This profile SHOULD be used to provide information of the "Vulnerability Exploitability eXchange". The main purpose of the VEX format is to state that and why a certain product is, or is not, affected by a vulnerability. See [VEX] for details. + +A CSAF document SHALL fulfill the following requirements to satisfy the profile "VEX": + +* The following elements MUST exist and be valid: + * all elements required by the profile "CSAF Base". + * `/product_tree` which lists all products referenced later on in the CSAF document regardless of their state. + * `/vulnerabilities` which lists all vulnerabilities. + * at least one of + * `/vulnerabilities[]/product_status/fixed` + * `/vulnerabilities[]/product_status/known_affected` + * `/vulnerabilities[]/product_status/known_not_affected` + * `/vulnerabilities[]/product_status/under_investigation` + * at least one of + * `/vulnerabilities[]/cve` + * `/vulnerabilities[]/ids` + * `/vulnerabilities[]/notes` + > Provides details about the vulnerability. +* For each item in + * `/vulnerabilities[]/product_status/known_not_affected` an impact statement SHALL exist as machine readable flag in `/vulnerabilities[]/flags` or as human readable justification in `/vulnerabilities[]/threats`. For the latter one, the `category` value for such a statement MUST be `impact` and the `details` field SHALL contain a a description why the vulnerability cannot be exploited. + * `/vulnerabilities[]/product_status/known_affected` additional product specific information SHALL be provided in `/vulnerabilities[]/remediations` as an action statement. Optional, additional information MAY also be provide through `/vulnerabilities[]/notes` and `/vulnerabilities[]/threats`. + > The use of the categories `no_fix_planned` and `none_available` for an action statement is permitted. + > Even though Product status lists Product IDs, Product Group IDs can be used in the `remediations` and `threats` object. However, it MUST be ensured that for each Product ID the required information according to its product status as stated in the two points above is available. This implies that all products with the status `known_not_affected` MUST have an impact statement and all products with the status `known_affected` MUST have additional product specific information regardless of whether that is referenced through the Product ID or a Product Group ID. +* The value of `/document/category` SHALL be `csaf_vex`. + +------- diff --git a/csaf_2.1/prose/edit/src/revision-history.md b/csaf_2.1/prose/edit/src/revision-history.md new file mode 100644 index 000000000..e92590e53 --- /dev/null +++ b/csaf_2.1/prose/edit/src/revision-history.md @@ -0,0 +1,20 @@ + +# Appendix B. Revision History + +| Revision | Date | Editor | Changes Made | +|:-------------------------|:-----------|:--------------------------------|:--------------------------------------------------------------------------------------| +| csaf-v2.0-wd20210927-dev | 2021-09-27 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS for public review | +| csaf-v2.0-wd20220329-dev | 2022-03-29 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CSD02 for public review | +| csaf-v2.0-wd20220514-dev | 2022-05-14 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | +| csaf-v2.0-wd20220715-dev | 2022-07-15 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | +| csaf-v2.0-wd20220720-dev | 2022-07-20 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | + +------- + diff --git a/csaf_2.1/prose/edit/src/safety-security-and-data-protection.md b/csaf_2.1/prose/edit/src/safety-security-and-data-protection.md new file mode 100644 index 000000000..b35c9efdd --- /dev/null +++ b/csaf_2.1/prose/edit/src/safety-security-and-data-protection.md @@ -0,0 +1,18 @@ +# 8 Safety, Security, and Data Protection Considerations + +CSAF documents are based on JSON, thus the security considerations of [RFC8259] apply and are repeated here as service for the reader: +>Generally, there are security issues with scripting languages. JSON is a subset of JavaScript but excludes assignment and invocation. +> +>Since JSON's syntax is borrowed from JavaScript, it is possible to use that language's `eval()` function to parse most JSON texts (but not all; certain characters such as `U+2028 LINE SEPARATOR` and `U+2029 PARAGRAPH SEPARATOR` are legal in JSON but not JavaScript). This generally constitutes an unacceptable security risk, since the text could contain executable code along with data declarations. The same consideration applies to the use of eval()-like functions in any other programming language in which JSON texts conform to that language's syntax. + +In addition, CSAF documents may be rendered by consumers in various human-readable formats like HTML or PDF. +Thus, for security reasons, CSAF producers and consumers SHALL adhere to the following: + +* CSAF producers SHOULD NOT emit messages that contain HTML, even though all variants of Markdown permit it. To include HTML, source code, or any other content that may be interpreted or executed by a CSAF consumer, e.g. to provide a proof-of-concept, the issuing party SHALL use Markdown's fenced code blocks or inline code option. +* Deeply nested markup can cause a stack overflow in the Markdown processor [GFMENG]. To reduce this risk, CSAF consumers SHALL use a Markdown processor that is hardened against such attacks. + **Note**: One example is the GitHub fork of the `cmark` Markdown processor [GFMCMARK]. +* To reduce the risk posed by possibly malicious CSAF files that do contain arbitrary HTML (including, for example, javascript: links), CSAF consumers SHALL either disable HTML processing (for example, by using an option such as the --safe option in the cmark Markdown processor) or run the resulting HTML through an HTML sanitizer. +CSAF consumers that are not prepared to deal with the security implications of formatted messages SHALL NOT attempt to render them and SHALL instead fall back to the corresponding plain text messages. As also any other programming code can be contained within a CSAF document, CSAF consumers SHALL ensure that none of the values of a CSAF document is run as code. Moreover, it SHALL be treated as unsafe (user) input. + > Additional, supporting mitigation measures like retrieving only CSAF documents from trusted sources and check their integrity and signature before parsing the document SHOULD be in place to reduce the risk further. + +------- diff --git a/csaf_2.1/prose/edit/src/schema-elements-00.md b/csaf_2.1/prose/edit/src/schema-elements-00.md new file mode 100644 index 000000000..80eea063d --- /dev/null +++ b/csaf_2.1/prose/edit/src/schema-elements-00.md @@ -0,0 +1,26 @@ +# 3 Schema Elements + +The CSAF schema describes how to represent security advisory information as a JSON document. + +The CSAF schema Version 2.0 builds on the JSON Schema draft 2020-12 rules. + +``` + "$schema": "https://json-schema.org/draft/2020-12/schema" +``` + +The schema identifier is: + +``` + "$id": "https://docs.oasis-open.org/csaf/csaf/v2.0/csaf_json_schema.json" +``` + +The further documentation of the schema is organized via Definitions and Properties. + +* Definitions provide types that extend the JSON schema model +* Properties use these types to support assembling security advisories + +Types and properties together provide the vocabulary for the domain specific language supporting security advisories. + +The single mandatory property is `document`. +The optional two additional properties are `product_tree` and `vulnerabilities`. + diff --git a/csaf_2.1/prose/edit/src/schema-elements-01-definitions.md b/csaf_2.1/prose/edit/src/schema-elements-01-definitions.md new file mode 100644 index 000000000..d530771ae --- /dev/null +++ b/csaf_2.1/prose/edit/src/schema-elements-01-definitions.md @@ -0,0 +1,1055 @@ +## 3.1 Definitions + +The definitions (`$defs`) introduce the following domain specific types into the CSAF language: +Acknowledgments (`acknowledgments_t`), Branches (`branches_t`), Full Product Name (`full_product_name_t`), Language (`lang_t`), Notes (`notes_t`), +Product Group ID (`product_group_id_t`), Product Groups (`product_groups_t`), Product ID (`product_id_t`), Products (`products_t`), References (`references_t`), +and Version (`version_t`). + +``` + "$defs": { + "acknowledgments_t": { + // ... + }, + "branches_t": { + // ... + }, + "full_product_name_t": { + // ... + }, + "lang_t": { + // ... + }, + "notes_t": { + // ... + }, + "product_group_id_t": { + // ... + }, + "product_groups_t": { + // ... + }, + "product_id_t": { + // ... + }, + "products_t": { + // ... + }, + "references_t": { + // ... + }, + "version_t": { + // ... + } + }, +``` + +### 3.1.1 Acknowledgments Type + +List of Acknowledgments (`acknowledgments_t`) type instances of value type `array` with 1 or more elements contain a list of `Acknowledgment` elements. + +``` + "acknowledgments_t": { + // ... + "items": { + // ... + } + }, +``` + +The value type of Acknowledgment is `object` with at least 1 and at most 4 properties. Every such element acknowledges contributions by describing those that contributed. +The properties are: `names`, `organization`, `summary`, and `urls`. + +``` + "properties": { + "names": { + // ... + }, + "organization": { + // ... + }, + "summary": { + // ... + }, + "urls": { + // ... + } + } +``` + +#### 3.1.1.1 Acknowledgments Type - Names + +List of acknowledged names (`names`) has value type `array` with 1 or more items holds the names of contributors being recognized. +Every such item of value type `string` with 1 or more characters represents the name of the contributor and contains the name of a single contributor being recognized. + +*Examples 1:* + +``` + Albert Einstein + Johann Sebastian Bach +``` + +#### 3.1.1.2 Acknowledgments Type - Organization + +The contributing organization (`organization`) has value type `string` with 1 or more characters and holds the name of the contributing organization being recognized. + +*Examples 2:* + +``` + CISA + Google Project Zero + Talos +``` + +#### 3.1.1.3 Acknowledgments Type - Summary + +Summary of the acknowledgment (`summary`) of value type `string` with 1 or more characters SHOULD represent any contextual details the document producers wish to make known about the acknowledgment or acknowledged parties. + +*Example 3:* + +``` + First analysis of Coordinated Multi-Stream Attack (CMSA) +``` + +#### 3.1.1.4 Acknowledgments Type - URLs + +List of URLs (`urls`) of acknowledgment is a container (value type `array`) for 1 or more `string` of type URL that specifies a list of URLs or location of the reference to be acknowledged. +Any URL of acknowledgment contains the URL or location of the reference to be acknowledged. +Value type is string with format URI (`uri`). + +#### 3.1.1.5 Acknowledgments Type - Example + +*Example 4:* + +``` + "acknowledgments": [ + { + "names": [ + "Johann Sebastian Bach", + "Georg Philipp Telemann", + "Georg Friedrich Händel" + ], + "organization": "Baroque composers", + "summary": "wonderful music" + }, + { + "organization": "CISA", + "summary": "coordination efforts", + "urls": [ + "https://cisa.gov" + ] + }, + { + "organization": "BSI", + "summary": "assistance in coordination" + }, + { + "names": [ + "Antonio Vivaldi" + ], + "summary": "influencing other composers" + } + ], +``` + +The example 4 above SHOULD lead to the following outcome in a human-readable advisory: + +> We thank the following parties for their efforts: +> +> * Johann Sebastian Bach, Georg Philipp Telemann, Georg Friedrich Händel from Baroque composers for wonderful music +> * CISA for coordination efforts (see: https://cisa.gov) +> * BSI for assistance in coordination +> * Antonio Vivaldi for influencing other composers + +### 3.1.2 Branches Type + +List of branches (`branches_t`) with value type `array` contains 1 or more branch elements as children of the current element. + +``` + "branches_t": { + //... + "items": { + // ... + } + }, +``` + +Every Branch holds exactly 3 properties and is a part of the hierarchical structure of the product tree. +The properties `name` and `category` are mandatory. In addition, the object contains either a `branches` or a `product` property. + +``` + "properties": { + "branches": { + // ... + }, + "category": { + // ... + }, + "name": { + // ... + }, + "product": { + // ... + } + } +``` + +> `branches_t` supports building a hierarchical structure of products that allows to indicate the relationship of products to each other and enables grouping for simpler referencing. As an example, the structure MAY use the following levels: `vendor` -> `product_family` -> `product_name` -> `product_version`. +> It is recommended to use the hierarchical structure of `vendor` -> `product_name` -> `product_version` whenever possible to support the identification and matching of products on the consumer side. + +#### 3.1.2.1 Branches Type - Branches + +List of branches (`branches`) has the value type `branches_t`. + +#### 3.1.2.2 Branches Type - Category + +Category of the branch (`category`) of value type `string` and `enum` describes the characteristics of the labeled branch. +Valid `enum` values are: + +``` + architecture + host_name + language + legacy + patch_level + product_family + product_name + product_version + product_version_range + service_pack + specification + vendor +``` + +The value `architecture` indicates the architecture for which the product is intended. + +The value `host_name` indicates the host name of a system/service. + +The value `language` indicates the language of the product. + +The value `legacy` indicates an entry that has reached its end of life. + +The value `patch_level` indicates the patch level of the product. + +The value `product_family` indicates the product family that the product falls into. + +The value `product_name` indicates the name of the product. + +The value `product_version` indicates exactly a single version of the product. The value of the adjacent `name` property can be numeric or some other descriptor. However, it MUST NOT contain version ranges of any kind. + +> It is recommended to enumerate versions wherever possible. Nevertheless, the TC understands that this is sometimes impossible. To reflect that in the specification and aid in automatic processing of CSAF documents the value `product_version_range` was introduced. See next section for details. + +The value `product_version_range` indicates a range of versions for the product. The value of the adjacent `name` property SHOULD NOT be used to convey a single version. + +The value `service_pack` indicates the service pack of the product. + +The value `specification` indicates the specification such as a standard, best common practice, etc. + +The value `vendor` indicates the name of the vendor or manufacturer that makes the product. + +#### 3.1.2.3 Branches Type - Name + +Name of the branch (`name`) of value type `string` with 1 or more characters contains the canonical descriptor or 'friendly name' of the branch. + +*Examples 5:* + +``` + 10 + 365 + Microsoft + Office + PCS 7 + SIMATIC + Siemens + Windows +``` + +A leading `v` or `V` in the value of `name` SHOULD only exist for the categories `product_version` or `product_version_range` if it is part of the product version as given by the vendor. + +##### 3.1.2.3.1 Branches Type - Name under Product Version + +If adjacent property `category` has the value `product_version`, the value of `name` MUST NOT contain version ranges of any kind. + +*Examples 6 for `name` when using `product_version`:* + +``` + 10 + 17.4 + v3 +``` + +> The `product_version` is the easiest way for users to determine whether their version is meant (provided that the given ancestors in the product tree matched): If both version strings are the same, it is a match - otherwise not. Therefore, it is always recommended to enumerate product versions instead of providing version ranges. + +*Examples 7 for `name` when using `product_version` which are invalid:* + +``` + 8.0.0 - 8.0.1 + 8.1.5 and later + <= 2 + prior to 4.2 + All versions < V3.0.29 + V3.0, V4.0, V4.1, V4.2 +``` + +> All the examples above contain some kind of a version range and are therefore invalid under the category `product_version`. + +##### 3.1.2.3.2 Branches Type - Name under Product Version Range + +If adjacent property `category` has the value `product_version_range`, the value of `name` MUST contain version ranges. The value of MUST obey to exactly one of the following options: + +1. Version Range Specifier (vers) + + > vers is an ongoing community effort to address the problem of version ranges. Its draft specification is available at [VERS]. + + vers MUST be used in its canonical form. To convey the term "all versions" the special string `vers:all/*` MUST be used. + + *Examples 8 for `name` when using `product_version_range` with vers:* + + ``` + vers:gem/>=2.2.0|!= 2.2.1|<2.3.0 + vers:npm/1.2.3|>=2.0.0|<5.0.0 + vers:pypi/0.0.0|0.0.1|0.0.2|0.0.3|1.0|2.0pre1 + vers:tomee/>=8.0.0-M1|<=8.0.1 + ``` + + > Through the definitions of the vers specification a user can compute whether a given version is in a given range. + +2. Vers-like Specifier (vls) + + This option uses only the `` part from the vers specification. It MUST NOT have an URI nor the `` part. It is a fallback option and SHOULD NOT be used unless really necessary. + > The reason for that is, that it is nearly impossible for tools to reliable determine whether a given version is in the range or not. + + Tools MAY support this on best effort basis. + + *Examples 9 for `name` when using `product_version_range` with vls:* + + ``` + <=2 + <4.2 + =8.1.5 + ``` + +#### 3.1.2.4 Branches Type - Product + +Product (`product`) has the value type Full Product Name (`full_product_name_t`). + +### 3.1.3 Full Product Name Type + +Full Product Name (`full_product_name_t`) with value type `object` specifies information about the product and assigns the product ID. +The properties `name` and `product_id` are required. The property `product_identification_helper` is optional. + +``` + "full_product_name_t": { + // ... + "properties": { + "name": { + // ... + }, + "product_id": { + // ... + }, + "product_identification_helper": { + // ... + } + } + }, +``` + +#### 3.1.3.1 Full Product Name Type - Name + +Textual description of the product (`name`) has value type `string` with 1 or more characters. +The value SHOULD be the product's full canonical name, including version number and other attributes, as it would be used in a human-friendly document. + +*Examples 10:* + +``` + Cisco AnyConnect Secure Mobility Client 2.3.185 + Microsoft Host Integration Server 2006 Service Pack 1 +``` + +#### 3.1.3.2 Full Product Name Type - Product ID + +Product ID (`product_id`) holds a value of type Product ID (`product_id_t`). + +#### 3.1.3.3 Full Product Name Type - Product Identification Helper + +Helper to identify the product (`product_identification_helper`) of value type `object` provides in its properties at least one method which aids in identifying the product in an asset database. +Of the given eight properties `cpe`, `hashes`, `model_numbers`, `purl`, `sbom_urls`, `serial_numbers`, `skus`, and `x_generic_uris`, one is mandatory. + +``` + "product_identification_helper": { + // ... + "properties": { + "cpe": { + // ... + }, + "hashes": { + // ... + }, + "model_numbers": { + // ... + }, + "purl": { + // ... + }, + "sbom_urls": { + // ... + }, + "serial_numbers": { + // ... + }, + "skus": { + // ... + }, + "x_generic_uris": { + // ... + } + } +``` + +##### 3.1.3.3.1 Full Product Name Type - Product Identification Helper - CPE + +Common Platform Enumeration representation (`cpe`) of value type `string` of 5 or more characters with `pattern` (regular expression): + +``` + ^(cpe:2\\.3:[aho\\*\\-](:(((\\?*|\\*?)([a-zA-Z0-9\\-\\._]|(\\\\[\\\\\\*\\?!\"#\\$%&'\\(\\)\\+,/:;<=>@\\[\\]\\^`\\{\\|\\}~]))+(\\?*|\\*?))|[\\*\\-])){5}(:(([a-zA-Z]{2,3}(-([a-zA-Z]{2}|[0-9]{3}))?)|[\\*\\-]))(:(((\\?*|\\*?)([a-zA-Z0-9\\-\\._]|(\\\\[\\\\\\*\\?!\"#\\$%&'\\(\\)\\+,/:;<=>@\\[\\]\\^`\\{\\|\\}~]))+(\\?*|\\*?))|[\\*\\-])){4})|([c][pP][eE]:/[AHOaho]?(:[A-Za-z0-9\\._\\-~%]*){0,6})$ +``` + +The Common Platform Enumeration (CPE) attribute refers to a method for naming platforms external to this specification. See [CPE23-N] for details. + +##### 3.1.3.3.2 Full Product Name Type - Product Identification Helper - Hashes + +List of hashes (`hashes`) of value type `array` holding at least one item contains a list of cryptographic hashes usable to identify files. + +``` + "hashes": { + // ... + "items": { + // ... + } + }, +``` + +Cryptographic hashes of value type `object` contains all information to identify a file based on its cryptographic hash values. +Any cryptographic hashes object has the 2 mandatory properties `file_hashes` and `filename`. + +``` + "properties": { + "file_hashes": { + // ... + }, + "filename": { + // ... + } + } +``` + +List of file hashes (`file_hashes`) of value type `array` holding at least one item contains a list of cryptographic hashes for this file. + +``` + "file_hashes": { + // ... + "items": { + // ... + } + }, +``` + +Each File hash of value type `object` contains one hash value and algorithm of the file to be identified. Any File hash object has the 2 mandatory properties `algorithm` and `value`. + +``` + "properties": { + "algorithm": { + // ... + }, + "value": { + // ... + } + } +``` + +The algorithm of the cryptographic hash representation (`algorithm`) of value type `string` with one or more characters contains the name of the cryptographic hash algorithm used to calculate the value. +The default value for `algorithm` is `sha256`. + +*Examples 11:* + +``` + blake2b512 + sha256 + sha3-512 + sha384 + sha512 +``` + +These values are derived from the currently supported digests OpenSSL [OPENSSL]. Leading dashes were removed. + +> The command `openssl dgst -list` (Version 1.1.1f from 2020-03-31) outputs the following: +> +>``` +> Supported digests: +> -blake2b512 -blake2s256 -md4 +> -md5 -md5-sha1 -ripemd +> -ripemd160 -rmd160 -sha1 +> -sha224 -sha256 -sha3-224 +> -sha3-256 -sha3-384 -sha3-512 +> -sha384 -sha512 -sha512-224 +> -sha512-256 -shake128 -shake256 +> -sm3 -ssl3-md5 -ssl3-sha1 +> -whirlpool +>``` + +The Value of the cryptographic hash representation (`value`) of value type `string` of 32 or more characters with `pattern` (regular expression): + +``` + ^[0-9a-fA-F]{32,}$ +``` + +The Value of the cryptographic hash attribute contains the cryptographic hash value in hexadecimal representation. + +*Examples 12:* + +``` + 37df33cb7464da5c7f077f4d56a32bc84987ec1d85b234537c1c1a4d4fc8d09dc29e2e762cb5203677bf849a2855a0283710f1f5fe1d6ce8d5ac85c645d0fcb3 + 4775203615d9534a8bfca96a93dc8b461a489f69124a130d786b42204f3341cc + 9ea4c8200113d49d26505da0e02e2f49055dc078d1ad7a419b32e291c7afebbb84badfbd46dec42883bea0b2a1fa697c +``` + +The filename representation (`filename`) of value type `string` with one or more characters contains the name of the file which is identified by the hash values. + +*Examples 13:* + +``` + WINWORD.EXE + msotadddin.dll + sudoers.so +``` + +If the value of the hash matches and the filename does not, a user SHOULD prefer the hash value. In such cases, the filename SHOULD be used as informational property. + +##### 3.1.3.3.3 Full Product Name Type - Product Identification Helper - Model Numbers + +The list of models (`model_numbers`) of value type `array` with 1 or more unique items contains a list of full or abbreviated (partial) model numbers. + +A list of models SHOULD only be used if a certain range of model numbers with its corresponding software version is affected, or the model numbers change during update. + +This can also be used to identify hardware. If necessary, the software, or any other related part, SHALL be bind to that via a product relationship. + +``` + "model_numbers": { + //... + "items": { + //... + } + }, +``` + +Any given model number of value type `string` with at least 1 character represents a full or abbreviated (partial) model number of the component to identify. + +> The terms "model", "model number" and "model variant" are mostly used synonymously. Often it is abbreviated as "MN", M/N" or "model no.". + +If a part of a model number of the component to identify is given, it SHOULD begin with the first character of the model number and stop at any point. +Characters which SHOULD NOT be matched MUST be replaced by either `?` (for a single character) or `*` (for zero or more characters). +Two `*` MUST NOT follow each other. + +*Examples 14:* + +``` + 6RA8096-4MV62-0AA0 + 6RA801?-??V62-0AA0 + IC25T060ATCS05-0 +``` + +##### 3.1.3.3.4 Full Product Name Type - Product Identification Helper - PURL + +The package URL (PURL) representation (`purl`) is a `string` of 7 or more characters with `pattern` (regular expression): + +``` + ^pkg:[A-Za-z\\.\\-\\+][A-Za-z0-9\\.\\-\\+]*/.+ +``` + +> The given pattern does not completely evaluate whether a PURL is valid according to the [PURL] specification. It provides a more generic approach and general guidance to enable forward compatibility. +> CSAF uses only the canonical form of PURL to conform with section 3.3 of [RFC3986]. Therefore, URLs starting with `pkg://` are considered invalid. + +This package URL (PURL) attribute refers to a method for reliably identifying and locating software packages external to this specification. See [PURL] for details. + +##### 3.1.3.3.5 Full Product Name Type - Product Identification Helper - SBOM URLs + +The list of SBOM URLs (`sbom_urls`) of value type `array` with 1 or more items contains a list of URLs where SBOMs for this product can be retrieved. + +> The SBOMs might differ in format or depth of detail. Currently supported formats are SPDX, CycloneDX, and SWID. + +``` + "sbom_urls": { + //... + "items": { + //... + } + }, +``` + +Any given SBOM URL of value type `string` with format `uri` contains a URL of one SBOM for this product. + +*Examples 15:* + +``` + https://raw.githubusercontent.com/CycloneDX/bom-examples/master/SBOM/keycloak-10.0.2/bom.json + https://swinslow.net/spdx-examples/example4/main-bin-v2 +``` + +##### 3.1.3.3.6 Full Product Name Type - Product Identification Helper - Serial Numbers + +The list of serial numbers (`serial_numbers`) of value type `array` with 1 or more unique items contains a list of full or abbreviated (partial) serial numbers. + +A list of serial numbers SHOULD only be used if a certain range of serial numbers with its corresponding software version is affected, or the serial numbers change during update. + +``` + "serial_numbers": { + //... + "items": { + //... + } + }, +``` + +Any given serial number of value type `string` with at least 1 character represents a full or abbreviated (partial) serial number of the component to identify. + +If a part of a serial number of the component to identify is given, it SHOULD begin with the first character of the serial number and stop at any point. +Characters which SHOULD NOT be matched MUST be replaced by either `?` (for a single character) or `*` (for zero or more characters). +Two `*` MUST NOT follow each other. + +##### 3.1.3.3.7 Full Product Name Type - Product Identification Helper - SKUs + +The list of stock keeping units (`skus`) of value type `array` with 1 or more items contains a list of full or abbreviated (partial) stock keeping units. + +A list of stock keeping units SHOULD only be used if the list of relationships is used to decouple e.g. hardware from the software, or the stock keeping units change during update. In the latter case the remediations SHALL include the new stock keeping units is or a description how it can be obtained. + +> The use of the list of relationships in the first case is important. Otherwise, the end user is unable to identify which version (the affected or the not affected / fixed one) is used. + +``` + "skus": { + //... + "items": { + //... + } + }, +``` + +Any given stock keeping unit of value type `string` with at least 1 character represents a full or abbreviated (partial) stock keeping unit (SKU) of the component to identify. + +> Sometimes this is also called "item number", "article number" or "product number". + +If a part of a stock keeping unit of the component to identify is given, it SHOULD begin with the first character of the stock keeping unit and stop at any point. +Characters which SHOULD NOT be matched MUST be replaced by either `?` (for a single character) or `*` (for zero or more characters). +Two `*` MUST NOT follow each other. + +##### 3.1.3.3.8 Full Product Name Type - Product Identification Helper - Generic URIs + +List of generic URIs (`x_generic_uris`) of value type `array` with at least 1 item contains a list of identifiers which are either vendor-specific or derived from a standard not yet supported. + +``` + "x_generic_uris": { + // ... + "items": { + // ... + } + } +``` + +Any such Generic URI item of value type `object` provides the two mandatory properties Namespace (`namespace`) and URI (`uri`). + +``` + "properties": { + "namespace": { + // ... + }, + "uri": { + // ... + } + } +``` + +The namespace of the generic URI (`namespace`) of value type `string` with format `uri` refers to a URL which provides the name and knowledge about the specification used or is the namespace in which these values are valid. + +The URI (`uri`) of value type `string` with format `uri` contains the identifier itself. + +> These elements can be used to reference a specific component from an SBOM: + +*Example 16 linking a component from a CycloneDX SBOM using the bomlink mechanism:* + +``` + "x_generic_uris": [ + { + "namespace": "https://cyclonedx.org/capabilities/bomlink/", + "uri": "urn:cdx:411dafd2-c29f-491a-97d7-e97de5bc2289/1#pkg:maven/org.jboss.logging/jboss-logging@3.4.1.Final?type=jar" + } + ] +``` + +*Example 17 linking a component from an SPDX SBOM:* + +``` + "x_generic_uris": [ + { + "namespace": "https://spdx.github.io/spdx-spec/document-creation-information/#65-spdx-document-namespace-field", + "uri": "https://swinslow.net/spdx-examples/example4/main-bin-v2#SPDXRef-libc" + } + ] +``` + +### 3.1.4 Language Type + +Language type (`lang_t`) has value type `string` with `pattern` (regular expression): + +``` + ^(([A-Za-z]{2,3}(-[A-Za-z]{3}(-[A-Za-z]{3}){0,2})?|[A-Za-z]{4,8})(-[A-Za-z]{4})?(-([A-Za-z]{2}|[0-9]{3}))?(-([A-Za-z0-9]{5,8}|[0-9][A-Za-z0-9]{3}))*(-[A-WY-Za-wy-z0-9](-[A-Za-z0-9]{2,8})+)*(-[Xx](-[A-Za-z0-9]{1,8})+)?|[Xx](-[A-Za-z0-9]{1,8})+|[Ii]-[Dd][Ee][Ff][Aa][Uu][Ll][Tt]|[Ii]-[Mm][Ii][Nn][Gg][Oo])$ +``` + +The value identifies a language, corresponding to IETF BCP 47 / RFC 5646. +See IETF language registry: [https://www.iana.org/assignments/language-subtag-registry/language-subtag-registry](https://www.iana.org/assignments/language-subtag-registry/language-subtag-registry) + +> CSAF skips those grandfathered language tags that are deprecated at the time of writing the specification. Even though the private use language tags are supported they should not be used to ensure readability across the ecosystem. +> It is recommended to follow the conventions for the capitalization of the subtags even though it is not mandatory as most users are used to that. + +*Examples 18:* + +``` + de + en + fr + frc + jp +``` + +### 3.1.5 Notes Type + +List of notes (`notes_t`) of value type `array` with 1 or more items of type `Note` contains notes which are specific to the current context. + +``` + "notes_t": { + // ... + "items": { + // ... + } + }, +``` + +Value type of every such Note item is `object` with the mandatory properties `category` and `text` providing a place to put all manner of text blobs related to the current context. +A Note `object` MAY provide the optional properties `audience` and `title`. + +``` + "properties": { + "audience": { + // ... + }, + "category": { + // ... + }, + "text": { + // ... + }, + "title": { + // ... + } + } +``` + +Audience of note (`audience`) of value type `string` with 1 or more characters indicates who is intended to read it. + +*Examples 19:* + +``` + all + executives + operational management and system administrators + safety engineers +``` + +Note category (`category`) of value type `string` and `enum` contains the information of what kind of note this is. +Valid `enum` values are: + +``` + description + details + faq + general + legal_disclaimer + other + summary +``` + +The value `description` indicates the note is a description of something. The optional sibling property `title` MAY have more information in this case. + +The value `details` indicates the note is a low-level detailed discussion. The optional sibling property `title` MAY have more information in this case. + +The value `faq` indicates the note is a list of frequently asked questions. + +The value `general` indicates the note is a general, high-level note. The optional sibling property `title` MAY have more information in this case. + +The value `legal_disclaimer` indicates the note represents any possible legal discussion, including constraints, surrounding the document. + +The value `other` indicates the note is something that doesn’t fit the other categories. The optional sibling attribute `title` SHOULD have more information to indicate clearly what kind of note to expect in this case. + +The value `summary` indicates the note is a summary of something. The optional sibling property `title` MAY have more information in this case. + +Note content (`text`) of value type `string` with 1 or more characters holds the content of the note. Content varies depending on type. + +Title of note (`title`) of value type `string` with 1 or more characters provides a concise description of what is contained in the text of the note. + +*Examples 20:* + +``` + Details + Executive summary + Technical summary + Impact on safety systems +``` + +### 3.1.6 Product Group ID Type + +The Product Group ID Type (`product_group_id_t`) of value type `string` with 1 or more characters is a reference token for product group instances. +The value is a token required to identify a group of products so that it can be referred to from other parts in the document. +There is no predefined or required format for the Product Group ID (`product_group_id`) as long as it uniquely identifies a product group in the context of the current document. + +``` + "product_group_id_t": { + // ... + }, +``` + +*Examples 21:* + +``` + CSAFGID-0001 + CSAFGID-0002 + CSAFGID-0020 +``` + +> Even though the standard does not require a specific format it is recommended to use different prefixes for the Product ID and the Product Group ID to support reading and parsing the document. + +### 3.1.7 Product Groups Type + +List of Product Group ID (`product_groups_t`) of value type `array` with 1 or more unique items (a `set`) of type Product Group ID (`product_group_id_t`) specifies a list of `product_group_ids` to give context to the parent item. + +``` + "product_groups_t": { + // ... + "items": { + // ... + } + }, +``` + +### 3.1.8 Product ID Type + +The Product ID Type (`product_id_t`) of value type `string` with 1 or more characters is a reference token for product instances. +The value is a token required to identify a `full_product_name` so that it can be referred to from other parts in the document. There is no predefined or required format for the Product ID (`product_id`) as long as it uniquely identifies a product in the context of the current document. + +``` + "product_id_t": { + // ... + }, +``` + +*Examples 22:* + +``` + CSAFPID-0004 + CSAFPID-0008 +``` + +> Even though the standard does not require a specific format it is recommended to use different prefixes for the Product ID and the Product Group ID to support reading and parsing the document. + +### 3.1.9 Products Type + +List of Product IDs (`products_t`) of value type `array` with 1 or more unique items (a `set`) of type Product ID (`product_id_t`) specifies a list of `product_ids` to give context to the parent item. + +``` + "products_t": { + // ... + "items": { + // ... + } + }, +``` + +### 3.1.10 References Type + +List of references (`references_t`) of value type `array` with 1 or more items of type Reference holds a list of Reference objects. + +``` + "references_t": { + // ... + "items": { + // ... + } + }, +``` + +Value type of every such Reference item is `object` with the mandatory properties `url` and `summary` holding any reference to conferences, papers, advisories, and other resources that are related and considered related to either a surrounding part of or the entire document and to be of value to the document consumer. +A reference `object` MAY provide the optional property `category`. + +``` + "properties": { + "category": { + // ... + }, + "summary": { + // ... + }, + "url": { + // ... + } + } +``` + +Category of reference (`category`) of value type `string` and `enum` indicates whether the reference points to the same document or vulnerability in focus (depending on scope) or to an external resource. +Valid `enum` values are: + +``` + external + self +``` + +The default value for `category` is `external`. + +The value `external` indicates, that this document is an external reference to a document or vulnerability in focus (depending on scope). + +The value `self` indicates, that this document is a reference to this same document or vulnerability (also depending on scope). + +> This includes links to documents with the same content but different file format (e.g. advisories as PDF or HTML). + +Summary of the reference (`summary`) of value type `string` with 1 or more characters indicates what this reference refers to. + +URL of reference (`url`) of value type `string` with format `uri` provides the URL for the reference. + +### 3.1.11 Version Type + +The Version (`version_t`) type has value type `string` with `pattern` (regular expression): + +``` + ^(0|[1-9][0-9]*)$|^((0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?)$ +``` + +The version specifies a version string to denote clearly the evolution of the content of the document. There are two options how it can be used: + +* semantic versioning (preferred; according to the rules below) +* integer versioning + +A CSAF document MUST use only one versioning system. + +*Examples 23:* + +``` + 1 + 4 + 0.9.0 + 1.4.3 + 2.40.0+21AF26D3 +``` + +#### 3.1.11.1 Version Type - Integer versioning + +Integer versioning increments for each version where the `/document/tracking/status` is `final` the version number by one. The regular expression for this type is: + +``` +^(0|[1-9][0-9]*)$ +``` + +The following rules apply: + +1. Once a versioned document has been released, the contents of that version MUST NOT be modified. Any modifications MUST be released as a new version. +2. Version zero (0) is for initial development before the `initial_release_date`. The document status MUST be `draft`. Anything MAY change at any time. The document SHOULD NOT be considered stable. +3. Version 1 defines the initial public release. Each new version where `/document/tracking/status` is `final` has a version number incremented by one. +4. Pre-release versions (document status `draft`) MUST carry the new version number. Sole exception is before the initial release (see rule 2). The combination of document status `draft` and version 1 MAY be used to indicate that the content is unlikely to change. +5. Build metadata is never included in the version. +6. Precedence MUST be calculate by integer comparison. + +#### 3.1.11.2 Version Type - Semantic versioning + +Semantic versioning derived the rules from [SemVer]. The regular expression for this type is: + +``` +^((0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?)$ +``` + +The goal of this structure is to provide additional information to the end user whether a new comparison with the asset database is needed. The "public API" in regards to CSAF is the CSAF document with its structure and content. This results in the following rules: + +1. A normal version number MUST take the form X.Y.Z where X, Y, and Z are non-negative integers, and MUST NOT contain leading zeroes. X is the major version, Y is the minor version, and Z is the patch version. Each element MUST increase numerically. For instance: 1.9.0 -> 1.10.0 -> 1.11.0. +2. Once a versioned document has been released, the contents of that version MUST NOT be modified. Any modifications MUST be released as a new version. +3. Major version zero (0.y.z) is for initial development before the `initial_release_date`. The document status MUST be `draft`. Anything MAY change at any time. The document SHOULD NOT be considered stable. Changes which would increment the major version according to rule 7 are tracked in this stage with (0.y.z) by incrementing the minor version y instead. Changes that would increment the minor or patch version according to rule 6 or 5 are both tracked in this stage with (0.y.z) by incrementing the patch version z instead. +4. Version 1.0.0 defines the initial public release. The way in which the version number is incremented after this release is dependent on the content and structure of the document and how it changes. +5. Patch version Z (x.y.Z | x > 0) MUST be incremented if only backwards compatible bug fixes are introduced. A bug fix is defined as an internal change that fixes incorrect behavior. + + > In the context of the document this is the case e.g. for spelling mistakes. + +6. Minor version Y (x.Y.z | x > 0) MUST be incremented if the content of an existing element changes except for those which are covert through rule 7. It MUST be incremented if substantial new information are introduced or new elements are provided. It MAY include patch level changes. Patch version MUST be reset to 0 when minor version is incremented. +7. Major version X (X.y.z | X > 0) MUST be incremented if a new comparison with the end user's asset database is required. This includes: + + * changes (adding, removing elements or modifying content) in `/product_tree` or elements which contain `/product_tree` in their path + * adding or removing items of `/vulnerabilities` + * adding or removing elements in: + * `/vulnerabilities[]/product_status/first_affected` + * `/vulnerabilities[]/product_status/known_affected` + * `/vulnerabilities[]/product_status/last_affected` + * removing elements from: + * `/vulnerabilities[]/product_status/first_fixed` + * `/vulnerabilities[]/product_status/fixed` + * `/vulnerabilities[]/product_status/known_not_affected` + + It MAY also include minor and patch level changes. Patch and minor version MUST be reset to 0 when major version is incremented. +8. A pre-release version (document status `draft`) MAY be denoted by appending a hyphen and a series of dot separated identifiers immediately following the patch version. Identifiers MUST comprise only ASCII alphanumerics and hyphens [0-9A-Za-z-]. Identifiers MUST NOT be empty. Numeric identifiers MUST NOT include leading zeroes. Pre-release versions have a lower precedence than the associated normal version. A pre-release version indicates that the version is unstable and might not satisfy the intended compatibility requirements as denoted by its associated normal version. + + *Examples 24:* + + ``` + 1.0.0-0.3.7 + 1.0.0-alpha + 1.0.0-alpha.1 + 1.0.0-x-y-z.– + 1.0.0-x.7.z.92 + ``` + +9. Pre-release MUST NOT be included if `/document/tracking/status` is `final`. +10. Build metadata MAY be denoted by appending a plus sign and a series of dot separated identifiers immediately following the patch or pre-release version. Identifiers MUST comprise only ASCII alphanumerics and hyphens [0-9A-Za-z-]. Identifiers MUST NOT be empty. Build metadata MUST be ignored when determining version precedence. Thus two versions that differ only in the build metadata, have the same precedence. + + *Examples 25:* + + ``` + 1.0.0+20130313144700 + 1.0.0+21AF26D3—-117B344092BD + 1.0.0-alpha+001 + 1.0.0-beta+exp.sha.5114f85 + ``` + +11. Precedence refers to how versions are compared to each other when ordered. + + 1. Precedence MUST be calculated by separating the version into major, minor, patch and pre-release identifiers in that order (Build metadata does not figure into precedence). + 2. Precedence is determined by the first difference when comparing each of these identifiers from left to right as follows: Major, minor, and patch versions are always compared numerically. + + *Example 26:* + + ``` + 1.0.0 < 2.0.0 < 2.1.0 < 2.1.1 + ``` + + 3. When major, minor, and patch are equal, a pre-release version has lower precedence than a normal version: + + *Example 27:* + + ``` + 1.0.0-alpha < 1.0.0 + ``` + + 4. Precedence for two pre-release versions with the same major, minor, and patch version MUST be determined by comparing each dot separated identifier from left to right until a difference is found as follows: + + 1. Identifiers consisting of only digits are compared numerically. + 2. Identifiers with letters or hyphens are compared lexically in ASCII sort order. + 3. Numeric identifiers always have lower precedence than non-numeric identifiers. + 4. A larger set of pre-release fields has a higher precedence than a smaller set, if all of the preceding identifiers are equal. + + *Example 28:* + + ``` + 1.0.0-alpha < 1.0.0-alpha.1 < 1.0.0-alpha.beta < 1.0.0-beta < 1.0.0-beta.2 < 1.0.0-beta.11 < 1.0.0-rc.1 < 1.0.0 + ``` + diff --git a/csaf_2.1/prose/edit/src/schema-elements-02-properties.md b/csaf_2.1/prose/edit/src/schema-elements-02-properties.md new file mode 100644 index 000000000..067dbe871 --- /dev/null +++ b/csaf_2.1/prose/edit/src/schema-elements-02-properties.md @@ -0,0 +1,1398 @@ +## 3.2 Properties + +These final three subsections document the three properties of a CSAF document. The single mandatory property `document`, as well as the optional properties `product_tree` and `vulnerabilities` in that order. + +### 3.2.1 Document Property + +Document level meta-data (`document`) of value type `object` with the 5 mandatory properties Category (`category`), CSAF Version (`csaf_version`), Publisher (`publisher`), Title (`title`), and Tracking (`tracking`) captures the meta-data about this document describing a particular set of security advisories. +In addition, the `document` object MAY provide the 7 optional properties Acknowledgments (`acknowledgments`), Aggregate Severity (`aggregate_severity`), Distribution (`distribution`), Language (`lang`), Notes (`notes`), References (`references`), and Source Language (`source_lang`). + +``` + "document": { + // ... + "properties": { + "acknowledgments": { + // ... + }, + "aggregate_severity" : { + // ... + }, + "category": { + // ... + }, + "csaf_version": { + // ... + }, + "distribution": { + // ... + }, + "lang": { + // ... + }, + "notes": { + // ... + }, + "publisher": { + // ... + }, + "references": { + // ... + }, + "source_lang": { + // ... + }, + "title": { + // ... + }, + "tracking": { + // ... + } + } + }, +``` + +#### 3.2.1.1 Document Property - Acknowledgments + +Document acknowledgments (`acknowledgments`) of value type Acknowledgments Type (`acknowledgments_t`) contains a list of acknowledgment elements associated with the whole document. + +``` + "acknowledgments": { + // ... + }, +``` + +#### 3.2.1.2 Document Property - Aggregate Severity + +Aggregate severity (`aggregate_severity`) of value type `object` with the mandatory property `text` and the optional property `namespace` is a vehicle that is provided by the document producer to convey the urgency and criticality with which the one or more vulnerabilities reported should be addressed. It is a document-level metric and applied to the document as a whole — not any specific vulnerability. The range of values in this field is defined according to the document producer's policies and procedures. + +``` + "aggregate_severity": { + // ... + "properties": { + "namespace": { + // ... + }, + "text": { + // ... + } + } + }, +``` + +The Namespace of aggregate severity (`namespace`) of value type `string` with format `uri` points to the namespace so referenced. + +The Text of aggregate severity (`text`) of value type `string` with 1 or more characters provides a severity which is independent of - and in addition to - any other standard metric for determining the impact or severity of a given vulnerability (such as CVSS). + +*Examples 29:* + +``` + Critical + Important + Moderate +``` + +#### 3.2.1.3 Document Property - Category + +Document category (`category`) with value type `string` of 1 or more characters with `pattern` (regular expression): + +``` + ^[^\\s\\-_\\.](.*[^\\s\\-_\\.])?$ +``` + +Document category defines a short canonical name, chosen by the document producer, which will inform the end user as to the category of document. + +> It is directly related to the profiles defined in section 4. + +``` + "category": { + // ... + } +``` + +*Examples 30*: + +``` + csaf_base + csaf_security_advisory + csaf_vex + Example Company Security Notice +``` + +#### 3.2.1.4 Document Property - CSAF Version + +CSAF version (`csaf_version`) of value type `string` and `enum` gives the version of the CSAF specification which the document was generated for. +The single valid value for this `enum` is: + +``` + 2.0 +``` + +#### 3.2.1.5 Document Property - Distribution + +Rules for sharing document (`distribution`) of value type `object` with at least 1 of the 2 properties Text (`text`) and Traffic Light Protocol (TLP) (`tlp`) describes any constraints on how this document might be shared. + +``` + "distribution": { + // ... + "properties": { + "text": { + // ... + }, + "tlp": { + // ... + } + } + }, +``` + +If both values are present, the TLP information SHOULD be preferred as this aids in automation. + +##### 3.2.1.5.1 Document Property - Distribution - Text + +The Textual description (`text`) of value type `string` with 1 or more characters provides a textual description of additional constraints. + +*Examples 31:* + +``` + Copyright 2021, Example Company, All Rights Reserved. + Distribute freely. + Share only on a need-to-know-basis only. +``` + +##### 3.2.1.5.2 Document Property - Distribution - TLP + +Traffic Light Protocol (TLP) (`tlp`) of value type `object` with the mandatory property Label (`label`) and the optional property URL (`url`) provides details about the TLP classification of the document. + +``` + "tlp": { + // ... + "properties": { + "label": { + // ... + }, + "url": { + // ... + } + } + } +``` + +The Label of TLP (`label`) with value type `string` and `enum` provides the TLP label of the document. +Valid values of the `enum` are: + +``` + AMBER + GREEN + RED + WHITE +``` + +The URL of TLP version (`url`) with value type `string` with format `uri` provides a URL where to find the textual description of the TLP version which is used in this document. The default value is the URL to the definition by FIRST: + +``` + https://www.first.org/tlp/ +``` + +*Examples 32:* + +``` + https://www.us-cert.gov/tlp + https://www.bsi.bund.de/SharedDocs/Downloads/DE/BSI/Kritis/Merkblatt_TLP.pdf +``` + +#### 3.2.1.6 Document Property - Language + +Document language (`lang`) of value type Language Type (`lang_t`) identifies the language used by this document, corresponding to IETF BCP 47 / RFC 5646. + +#### 3.2.1.7 Document Property - Notes + +Document notes (`notes`) of value type Notes Type (`notes_t`) holds notes associated with the whole document. + +``` + "notes": { + // ... + }, +``` + +#### 3.2.1.8 Document Property - Publisher + +Publisher (`publisher`) has value type `object` with the mandatory properties Category (`category`), Name (`name`) and Namespace (`namespace`) and provides information on the publishing entity. +The 2 other optional properties are: `contact_details` and `issuing_authority`. + +``` + "publisher": { + // ... + "properties": { + "category": { + // ... + }, + "contact_details": { + // ... + }, + "issuing_authority": { + // ... + }, + "name": { + // ... + } + "namespace": { + // ... + } + } + }, +``` + +##### 3.2.1.8.1 Document Property - Publisher - Category + +The Category of publisher (`category`) of value type `string` and `enum` provides information about the category of publisher releasing the document. +The valid values are: + +``` + coordinator + discoverer + other + translator + user + vendor +``` + +The value `coordinator` indicates individuals or organizations that manage a single vendor’s response or multiple vendors’ responses to a vulnerability, a security flaw, or an incident. This includes all Computer Emergency/Incident Response Teams (CERTs/CIRTs) or agents acting on the behalf of a researcher. + +The value `discoverer` indicates individuals or organizations that find vulnerabilities or security weaknesses. This includes all manner of researchers. + +The value `translator` indicates individuals or organizations that translate CSAF documents. This includes all manner of language translators, also those who work for the party issuing the original advisory. + +The value `other` indicates a catchall for everyone else. Currently this includes editors, reviewers, forwarders, republishers, and miscellaneous contributors. + +The value `user` indicates anyone using a vendor’s product. + +The value `vendor` indicates developers or maintainers of information system products or services. This includes all authoritative product vendors, Product Security Incident Response Teams (PSIRTs), and product resellers and distributors, including authoritative vendor partners. + +##### 3.2.1.8.2 Document Property - Publisher - Contact Details + +Contact details (`contact_details`) of value type `string` with 1 or more characters provides information on how to contact the publisher, possibly including details such as web sites, email addresses, phone numbers, and postal mail addresses. + +*Example 33:* + +``` + Example Company can be reached at contact_us@example.com, or via our website at https://www.example.com/contact. +``` + +##### 3.2.1.8.3 Document Property - Publisher - Issuing Authority + +Issuing authority (`issuing_authority`) of value type `string` with 1 or more characters Provides information about the authority of the issuing party to release the document, in particular, the party's constituency and responsibilities or other obligations. + +##### 3.2.1.8.4 Document Property - Publisher - Name + +The Name of publisher (`name`) of value type `string` with 1 or more characters contains the name of the issuing party. + +*Example 34:* + +``` + BSI + Cisco PSIRT + Siemens ProductCERT +``` + +##### 3.2.1.8.5 Document Property - Publisher - Namespace + +The Namespace of publisher (`namespace`) of value type `string` with format `uri` contains a URL which is under control of the issuing party and can be used as a globally unique identifier for that issuing party. The URL SHALL be normalized. + +An issuing party can choose any URL which fulfills the requirements state above. The URL MAY be dereferenceable. If an issuing party has chosen a URL, it SHOULD NOT change. Tools can make use of the combination of `/document/publisher/namespace` and `/document/tracking/id` as it identifies a CSAF document globally unique. + +If an issuing party decides to change its Namespace it SHOULD reissue all CSAF documents with an incremented (patch) version which has no other changes than: + +* the new publisher information +* the updated revision history +* the updated item in `/document/references[]` which points to the new version of the CSAF document +* an added item in `/document/references[]` which points to the previous version of the CSAF document (if the URL changed) + +*Example 35:* + +``` + https://csaf.io + https://www.example.com +``` + +#### 3.2.1.9 Document Property - References + +Document references (`references`) of value type References Type (`references_t`) holds a list of references associated with the whole document. + +``` + "references": { + // ... + }, +``` + +#### 3.2.1.10 Document Property - Source Language + +Source language (`source_lang`) of value type Language Type (`lang_t`) identifies if this copy of the document is a translation then the value of this property describes from which language this document was translated. + +The property MUST be present and set for any CSAF document with the value `translator` in `/document/publisher/category`. The property SHALL NOT be present if the document was not translated. + +> If an issuing party publishes a CSAF document with the same content in more than one language, one of these documents SHOULD be deemed the "original", the other ones SHOULD be considered translations from the "original". The issuing party can retain its original publisher information including the `category`. However, other rules defined in the conformance clause "CSAF translator" SHOULD be applied. + +#### 3.2.1.11 Document Property - Title + +Title of this document (`title`) of value type `string` with 1 or more characters SHOULD be a canonical name for the document, and sufficiently unique to distinguish it from similar documents. + +*Examples 36:* + +``` + Cisco IPv6 Crafted Packet Denial of Service Vulnerability + Example Company Cross-Site-Scripting Vulnerability in Example Generator +``` + +#### 3.2.1.12 Document Property - Tracking + +Tracking (`tracking`) of value type `object` with the six mandatory properties: Current Release Date (`current_release_date`), Identifier (`id`), Initial Release Date (`initial_release_date`), Revision History (`revision_history`), Status (`status`), and Version (`version`) is a container designated to hold all management attributes necessary to track a CSAF document as a whole. +The two optional additional properties are Aliases (`aliases`) and Generator (`generator`). + +``` + "tracking": { + // ... + "properties": { + "aliases": { + // ... + }, + "current_release_date": { + // ... + }, + "generator": { + // ... + }, + "id": { + // ... + }, + "initial_release_date": { + // ... + }, + "revision_history": { + // ... + }, + "status": { + // ... + }, + "version": { + // ... + } + } + }, +``` + +##### 3.2.1.12.1 Document Property - Tracking - Aliases + +Aliases (`aliases`) of value type `array` with 1 or more unique items (a `set`) representing Alternate Names contains a list of alternate names for the same document. + +``` + "aliases": { + // ... + "items": { + // ... + } + }, +``` + +Every such Alternate Name of value type `string` with 1 or more characters specifies a non-empty string that represents a distinct optional alternative ID used to refer to the document. + +*Example 37:* + +``` + CVE-2019-12345 +``` + +##### 3.2.1.12.2 Document Property - Tracking - Current Release Date + +Current release date (`current_release_date`) with value type `string` with format `date-time` holds the date when the current revision of this document was released. + +##### 3.2.1.12.3 Document Property - Tracking - Generator + +Document Generator (`generator`) of value type `object` with mandatory property Engine (`engine`) and optional property Date (`date`) is a container to hold all elements related to the generation of the document. These items will reference when the document was actually created, including the date it was generated and the entity that generated it. + +``` + "generator": { + // ... + "properties": { + "date": { + // ... + }, + "engine": { + // ... + } + } + }, +``` + +Date of document generation (`date`) of value type `string` with format `date-time` SHOULD be the current date that the document was generated. +Because documents are often generated internally by a document producer and exist for a nonzero amount of time before being released, this field MAY be different from the Initial Release Date and Current Release Date. + +Engine of document generation (`engine`) of value type `object` with mandatory property Engine name (`name`) and optional property Engine version (`version`) contains information about the engine that generated the CSAF document. + +``` + "engine": { + // ... + "properties": { + "name": { + // ... + }, + "version": { + // ... + } + } + }, +``` + +Engine name (`name`) of value type `string` with 1 or more characters represents the name of the engine that generated the CSAF document. + +*Examples 38:* + +``` + Red Hat rhsa-to-cvrf + Secvisogram + TVCE +``` + +Engine version (`version`) of value type `string` with 1 or more characters contains the version of the engine that generated the CSAF document. + +> Although it is not formally required, the TC suggests to use a versioning which compatible wth Semantic Versioning as described in the external specification [SemVer]. This could help the end user to identify when CSAF consumers have to be updated. + +*Examples 39:* + +``` + 0.6.0 + 1.0.0-beta+exp.sha.a1c44f85 + 2 +``` + +##### 3.2.1.12.4 Document Property - Tracking - ID + +Unique identifier for the document (`id`) of value type `string` with 1 or more characters with `pattern` (regular expression): + +``` + ^[\\S](.*[\\S])?$ +``` + +Unique identifier for the document holds the Identifier. + +> It SHALL NOT start or end with a white space and SHALL NOT contain a line break. + +The ID is a simple label that provides for a wide range of numbering values, types, and schemes. +Its value SHOULD be assigned and maintained by the original document issuing authority. It MUST be unique for that organization. + +*Examples 40:* + +``` + Example Company - 2019-YH3234 + RHBA-2019:0024 + cisco-sa-20190513-secureboot +``` + +> The combination of `/document/publisher/namespace` and `/document/tracking/id` identifies a CSAF document globally unique. + +This value is also used to determine the filename for the CSAF document (cf. section 5.1). + +##### 3.2.1.12.5 Document Property - Tracking - Initial Release Date + +Initial release date (`initial_release_date`) with value type `string` with format `date-time` holds the date when this document was first published. + +##### 3.2.1.12.6 Document Property - Tracking - Revision History + +The Revision History (`revision_history`) with value type `array` of 1 or more Revision History Entries holds one revision item for each version of the CSAF document, including the initial one. + +``` + "revision_history": { + // ... + "items": { + // ... + } + }, +``` + +Each Revision contains all the information elements required to track the evolution of a CSAF document. Revision History Entry items are of value type `object` with the three mandatory properties: Date (`date`), Number (`number`), and Summary (`summary`). In addition, a Revision MAY expose the optional property `legacy_version`. + +``` + "properties": { + "date": { + // ... + }, + "legacy_version": { + // ... + }, + "number": { + // ... + }, + "summary": { + // ... + } + } +``` + +The Date of the revision (`date`) of value type `string` with format `date-time` states the date of the revision entry. + +Legacy version of the revision (`legacy_version`) of value type `string` with 1 or more characters contains the version string used in an existing document with the same content. + +> This SHOULD be used to aid in the mapping between existing (human-readable) documents which might use a different version scheme and CSAF documents with the same content. It is recommended, to use the CSAF revision number to describe the revision history for any new human-readable equivalent. + +The Number (`number`) has value type Version (`version_t`). + +The Summary of the revision (`summary`) of value type `string` with 1 or more characters holds a single non-empty string representing a short description of the changes. + +Each Revision item which has a `number` of `0` or `0.y.z` MUST be removed from the document if the document status is `final`. Versions of the document which are pre-release SHALL NOT have its own revision item. All changes MUST be tracked in the item for the next release version. Build metadata SHOULD NOT be included in the `number` of any revision item. + +##### 3.2.1.12.7 Document Property - Tracking - Status + +Document status (`status`) of value type `string` and `enum` defines the draft status of the document. +The value MUST be one of the following: + +``` + draft + final + interim +``` + +The value `draft` indicates, that this is a pre-release, intended for issuing party's internal use only, or possibly used externally when the party is seeking feedback or indicating its intentions regarding a specific issue. + +The value `final` indicates, that the issuing party asserts the content is unlikely to change. “Final” status is an indication only, and does not preclude updates. This SHOULD be used if the issuing party expects no, slow or few changes. + +The value `interim` indicates, that the issuing party expects rapid updates. This SHOULD be used if the expected rate of release for this document is significant higher than for other documents. Once the rate slows down it MUST be changed to `final`. This MAY be done in a patch version. + +> This is extremely useful for downstream vendors to constantly inform the end users about ongoing investigation. It can be used as an indication to pull the CSAF document more frequently. + +##### 3.2.1.12.8 Document Property - Tracking - Version + +Version has the value type Version (`version_t`). + +### 3.2.2 Product Tree Property + +Product Tree (`product_tree`) has value type `object` with 1 or more properties is a container for all fully qualified product names that can be referenced elsewhere in the document. +The properties are Branches (`branches`), Full Product Names (`full_product_names`), Product Groups (`product_groups`), and Relationships (`relationships`). + +``` + "product_tree": { + // ... + "properties": { + "branches": { + // ... + }, + "full_product_names": { + // ... + }, + "product_groups": { + // ... + }, + "relationships": { + // ... + } + } + }, +``` + +#### 3.2.2.1 Product Tree Property - Branches + +List of branches (`branches`) has the value type `branches_t`. + +#### 3.2.2.2 Product Tree Property - Full Product Names + +List of full product names (`full_product_names`) of value type `array` with 1 or more items of type `full_product_name_t` contains a list of full product names. + +#### 3.2.2.3 Product Tree Property - Product Groups + +List of product groups (`product_groups`) of value type `array` with 1 or more items of value type `object` contains a list of product groups. + +``` + "product_groups": { + // ... + "items": { + // ... + } + }, +``` + +The product group items are of value type `object` with the 2 mandatory properties Group ID (`group_id`) and Product IDs (`product_ids`) and the optional Summary (`summary`) property. + +``` + "properties": { + "group_id": { + // ... + }, + "product_ids": { + // ... + }, + "summary": { + // ... + } + } +``` + +The summary of the product group (`summary`) of value type `string` with 1 or more characters gives a short, optional description of the group. + +*Examples 41:* + +``` + Products supporting Modbus. + The x64 versions of the operating system. +``` + +Group ID (`group_id`) has value type Product Group ID (`product_group_id_t`). + +List of Product IDs (`product_ids`) of value type `array` with 2 or more unique items of value type Product ID (`product_id_t`) lists the product_ids of those products which known as one group in the document. + +#### 3.2.2.4 Product Tree Property - Relationships + +List of relationships (`relationships`) of value type `array` with 1 or more items contains a list of relationships. + +``` + "relationships": { + // ... + "items": { + // ... + } + } +``` + +The Relationship item is of value type `object` and has four mandatory properties: Relationship category (`category`), Full Product Name (`full_product_name`), Product Reference (`product_reference`), and Relates to Product Reference (`relates_to_product_reference`). The Relationship item establishes a link between two existing `full_product_name_t` elements, allowing the document producer to define a combination of two products that form a new `full_product_name` entry. + +``` + "properties": { + "category": { + // ... + }, + "full_product_name": { + // ... + }, + "product_reference": { + // ... + }, + "relates_to_product_reference": { + // ... + } + } +``` + +> The situation where a need for declaring a Relationship arises, is given when a product is e.g. vulnerable only when installed together with another, or to describe operating system components. + +Relationship category (`category`) of value type `string` and `enum` defines the category of relationship for the referenced component. +The valid values are: + +``` + default_component_of + external_component_of + installed_on + installed_with + optional_component_of +``` + +The value `default_component_of` indicates that the entity labeled with one Product ID (e.g. CSAFPID-0001) is a default component of an entity with another Product ID (e.g. CSAFPID-0002). These Product IDs SHOULD NOT be identical to provide minimal redundancy. + +The value `external_component_of` indicates that the entity labeled with one Product ID (e.g. CSAFPID-0001) is an external component of an entity with another Product ID (e.g. CSAFPID-0002). These Product IDs SHOULD NOT be identical to provide minimal redundancy. + +The value `installed_on` indicates that the entity labeled with one Product ID (e.g. CSAFPID-0001) is installed on a platform entity with another Product ID (e.g. CSAFPID-0002). These Product IDs SHOULD NOT be identical to provide minimal redundancy. + +The value `installed_with` indicates that the entity labeled with one Product ID (e.g. CSAFPID-0001) is installed alongside an entity with another Product ID (e.g. CSAFPID-0002). These Product IDs SHOULD NOT be identical to provide minimal redundancy. + +The value `optional_component_of` indicates that the entity labeled with one Product ID (e.g. CSAFPID-0001) is an optional component of an entity with another Product ID (e.g. CSAFPID-0002). These Product IDs SHOULD NOT be identical to provide minimal redundancy. + +Full Product Name (`full_product_name`) of value type Full Product Name Type (`full_product_name_t`). + +Product Reference (`product_reference`) of value type Product ID (`product_id_t`) holds a Product ID that refers to the Full Product Name element, which is referenced as the first element of the relationship. + +Relates to Product Reference (`relates_to_product_reference`) of value type Product ID (`product_id_t`) holds a Product ID that refers to the Full Product Name element, which is referenced as the second element of the relationship. + +*Example 42:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-908070601", + "name": "Cisco AnyConnect Secure Mobility Client 4.9.04053" + }, + { + "product_id": "CSAFPID-908070602", + "name": "Microsoft Windows" + } + ], + "relationships": [ + { + "product_reference": "CSAFPID-908070601", + "category": "installed_on", + "relates_to_product_reference": "CSAFPID-908070602", + "full_product_name": { + "product_id": "CSAFPID-908070603", + "name": "Cisco AnyConnect Secure Mobility Client 2.3.185 installed on Microsoft Windows" + } + } + ] + } +``` + +> The product `Cisco AnyConnect Secure Mobility Client 4.9.04053"` (Product ID: `CSAFPID-908070601`) and the product `Microsoft Windows` (Product ID: `CSAFPID-908070602`) form together a new product with the separate Product ID `CSAFPID-908070603`. The latter one can be used to refer to that combination in other parts of the CSAF document. In example 34, it might be the case that `Cisco AnyConnect Secure Mobility Client 4.9.04053"` is only vulnerable when installed on `Microsoft Windows`. + +### 3.2.3 Vulnerabilities Property + +Vulnerabilities (`vulnerabilities`) of value type `array` with 1 or more objects representing vulnerabilities and providing 1 or more properties represents a list of all relevant vulnerability information items. + +``` + "vulnerabilities": { + // ... + "items": { + // ... + } + } +``` + +The Vulnerability item of value type `object` with 1 or more properties is a container for the aggregation of all fields that are related to a single vulnerability in the document. +Any vulnerability MAY provide the optional properties Acknowledgments (`acknowledgments`), Common Vulnerabilities and Exposures (CVE) (`cve`), Common Weakness Enumeration (CWE) (`cwe`), Discovery Date (`discovery_date`), Flags (`flags`), IDs (`ids`), Involvements (`involvements`), Notes (`notes`), Product Status (`product_status`), References (`references`), Release Date (`release_date`), Remediations (`remediations`), Scores (`scores`), Threats (`threats`), and Title (`title`). + +``` + "properties": { + "acknowledgments": { + // ... + }, + "cve": { + // ... + }, + "cwe": { + // ... + }, + "discovery_date": { + // ... + }, + "flags": { + // ... + }, + "ids": { + // ... + }, + "involvements": { + // ... + }, + "notes": { + // ... + }, + "product_status": { + // ... + }, + "references": { + // ... + }, + "release_date": { + // ... + }, + "remediations": { + // ... + }, + "scores": { + // ... + }, + "threats": { + // ... + }, + "title": { + // ... + } + } +``` + +#### 3.2.3.1 Vulnerabilities Property - Acknowledgments + +Vulnerability acknowledgments (`acknowledgments`) of value type Acknowledgments Type (`acknowledgments_t`) contains a list of acknowledgment elements associated with this vulnerability item. + +``` + "acknowledgments": { + // ... + }, +``` + +#### 3.2.3.2 Vulnerabilities Property - CVE + +CVE (`cve`) of value type `string` with `pattern` (regular expression): + +``` + ^CVE-[0-9]{4}-[0-9]{4,}$ +``` + +holds the MITRE standard Common Vulnerabilities and Exposures (CVE) tracking number for the vulnerability. + +#### 3.2.3.3 Vulnerabilities Property - CWE + +CWE (`cwe`) of value type `object` with the 2 mandatory properties Weakness ID (`id`) and Weakness Name (`name`) holds the MITRE standard Common Weakness Enumeration (CWE) for the weakness associated. For more information cf. [CWE]. + +``` + "cwe": { + // ... + "properties": { + "id": { + // ... + }, + "name": { + // ... + } + } + }, +``` + +The Weakness ID (`id`) has value type `string` with `pattern` (regular expression): + +``` + ^CWE-[1-9]\\d{0,5}$ +``` + +and holds the ID for the weakness associated. + +*Examples 43:* + +``` + CWE-22 + CWE-352 + CWE-79 +``` + +The Weakness name (`name`) has value type `string` with 1 or more characters and holds the full name of the weakness as given in the CWE specification. + +*Examples 44:* + +``` + Cross-Site Request Forgery (CSRF) + Improper Limitation of a Pathname to a Restricted Directory ('Path Traversal') + Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting') +``` + +#### 3.2.3.4 Vulnerabilities Property - Discovery Date + +Discovery date (`discovery_date`) of value type `string` with format `date-time` holds the date and time the vulnerability was originally discovered. + +#### 3.2.3.5 Vulnerabilities Property - Flags + +List of flags (`flags`) of value type `array` with 1 or more unique items (a set) of value type `object` contains a list of machine readable flags. + +``` + "flags": { + // ... + "items": { + // ... + } + }, +``` + +Every Flag item of value type `object` with the mandatory property Label (`label`) contains product specific information in regard to this vulnerability as a single machine readable flag. +For example, this could be a machine readable justification code why a product is not affected. +At least one of the optional elements Group IDs (`group_ids`) and Product IDs (`product_ids`) MUST be present to state for which products or product groups this flag is applicable. + +> These flags enable the receiving party to automate the selection of actions to take. + +In addition, any Flag item MAY provide the three optional properties Date (`date`), Group IDs (`group_ids`) and Product IDs (`product_ids`). + +``` + "properties": { + "date": { + // ... + }, + "group_ids": { + // ... + }, + "label": { + // ... + }, + "product_ids": { + // ... + } + } +``` + +Date of the flag (`date`) of value type `string` with format `date-time` contains the date when assessment was done or the flag was assigned. + +Group IDs (`group_ids`) are of value type Product Groups (`product_groups_t`) and contain a list of Product Groups the current flag item applies to. + +Label of the flag (`label`) of value type `string` and `enum` specifies the machine readable label. Valid `enum` values are: + +``` + component_not_present + inline_mitigations_already_exist + vulnerable_code_cannot_be_controlled_by_adversary + vulnerable_code_not_in_execute_path + vulnerable_code_not_present +``` + +The given values reflect the VEX not affected justifications. See [VEX-Justification] for more details. The values MUST be used as follows: + +* `component_not_present`: The software is not affected because the vulnerable component is not in the product. +* `vulnerable_code_not_present`: The product is not affected because the code underlying the vulnerability is not present in the product. + > Unlike `component_not_present`, the component in question is present, but for whatever reason (e.g. compiler options) the specific code causing the vulnerability is not present in the component. +* `vulnerable_code_cannot_be_controlled_by_adversary`: The vulnerable component is present, and the component contains the vulnerable code. However, vulnerable code is used in such a way that an attacker cannot mount any anticipated attack. +* `vulnerable_code_not_in_execute_path`: The affected code is not reachable through the execution of the code, including non-anticipated states of the product. + > Components that are neither used nor executed by the product. +* `inline_mitigations_already_exist`: Built-in inline controls or mitigations prevent an adversary from leveraging the vulnerability. + +Product IDs (`product_ids`) are of value type Products (`products_t`) and contain a list of Products the current flag item applies to. + +#### 3.2.3.6 Vulnerabilities Property - IDs + +List of IDs (`ids`) of value type `array` with one or more unique ID items of value type `object` represents a list of unique labels or tracking IDs for the vulnerability (if such information exists). + +``` + "ids": { + // ... + "items": { + // ... + } + }, +``` + +Every ID item of value type `object` with the two mandatory properties System Name (`system_name`) and Text (`text`) contains a single unique label or tracking ID for the vulnerability. + +``` + "properties": { + "system_name": { + // ... + }, + "text": { + // ... + } + } +``` + +System name (`system_name`) of value type `string` with 1 or more characters indicates the name of the vulnerability tracking or numbering system. + +*Example 45:* + +``` + Cisco Bug ID + GitHub Issue +``` + +Text (`text`) of value type `string` with 1 or more characters is unique label or tracking ID for the vulnerability (if such information exists). + +*Example 46:* + +``` + CSCso66472 + oasis-tcs/csaf#210 +``` + +> General examples may include an identifier from a vulnerability tracking system that is available to customers, such as: +> +> * a Cisco bug ID, +> * a GitHub Issue number, +> * an ID from a Bugzilla system, or +> * an ID from a public vulnerability database such as the X-Force Database. +> +> The ID MAY be a vendor-specific value but is not to be used to publish the CVE tracking numbers (MITRE standard Common Vulnerabilities and Exposures), as these are specified inside the dedicated CVE element. + +#### 3.2.3.7 Vulnerabilities Property - Involvements + +List of involvements (`involvements`) of value type `array` with 1 or more items of value type `object` contains a list of involvements. + +``` + "involvements": { + // ... + "items": { + // ... + } + }, +``` + +Every Involvement item of value type `object` with the 2 mandatory properties Party (`party`), Status (`status`) and the 2 optional properties Date of involvement (`date`) and Summary (`summary`) is a container that allows the document producers to comment on the level of involvement (or engagement) of themselves (or third parties) in the vulnerability identification, scoping, and remediation process. It can also be used to convey the disclosure timeline. The ordered tuple of the values of `party` and `date` (if present) SHALL be unique within `involvements`. + +``` + "properties": { + "date": { + // ... + }, + "party": { + // ... + }, + "status": { + // ... + }, + "summary": { + // ... + }, + } +``` + +Date of involvement (`date`) of value type `string` with format `date-time` holds the date and time of the involvement entry. + +Party category (`party`) of value type `string` and `enum` defines the category of the involved party. +Valid values are: + +``` + coordinator + discoverer + other + user + vendor +``` + +These values follow the same definitions as given for the publisher category (cf. section 3.2.1.8.1). + +Party status (`status`) of value type `string` and `enum` defines contact status of the involved party. +Valid values are: + +``` + completed + contact_attempted + disputed + in_progress + not_contacted + open +``` + +Each status is mutually exclusive - only one status is valid for a particular vulnerability at a particular time. As the vulnerability ages, a party's involvement could move from state to state. However, in many cases, a document producer may choose not to issue CSAF documents at each state, or simply omit this element altogether. It is recommended, however, that vendors that issue CSAF documents indicating an open or in-progress involvement SHOULD eventually expect to issue a document containing one of the statuses `disputed` or `completed` as the latest one. + +> The two vulnerability involvement status states, `contact_attempted` and `not_contacted` are intended for use by document producers other than vendors (such as research or coordinating entities). + +The value `completed` indicates that the party asserts that investigation of the vulnerability is complete. No additional information, fixes, or documentation from the party about the vulnerability should be expected to be released. + +The value `contact_attempted` indicates that the document producer attempted to contact the party. + +The value `disputed` indicates that the party disputes the vulnerability report in its entirety. This status SHOULD be used when the party believes that a vulnerability report regarding a product is completely inaccurate (that there is no real underlying security vulnerability) or that the technical issue being reported has no security implications. + +The value `in_progress` indicates that some hotfixes, permanent fixes, mitigations, workarounds, or patches may have been made available by the party, but more information or fixes may be released in the future. The use of this status by a vendor indicates that future information from the vendor about the vulnerability is to be expected. + +The value `not_contacted` indicates that the document producer has not attempted to make contact with the party. + +The value `open` is the default status. It doesn’t indicate anything about the vulnerability remediation effort other than the fact that the party has acknowledged awareness of the vulnerability report. The use of this status by a vendor indicates that future updates from the vendor about the vulnerability are to be expected. + +Summary of involvement (`summary`) of value type `string` with 1 or more characters contains additional context regarding what is going on. + +#### 3.2.3.8 Vulnerabilities Property - Notes + +Vulnerability notes (`notes`) of value type Notes Type (`notes_t`) holds notes associated with this vulnerability item. + +``` + "notes": { + // ... + }, +``` + +#### 3.2.3.9 Vulnerabilities Property - Product Status + +Product status (`product_status`) of value type `object` with 1 or more properties contains different lists of product_ids which provide details on the status of the referenced product related to the current vulnerability. +The eight defined properties are First affected (`first_affected`), First fixed (`first_fixed`), Fixed (`fixed`), Known affected (`known_affected`), Known not affected (`known_not_affected`), Last affected (`last_affected`), Recommended (`recommended`), and Under investigation (`under_investigation`) are all of value type Products (`products_t`). + +``` + "product_status": { + // ... + "properties": { + "first_affected": { + // ... + }, + "first_fixed": { + // ... + }, + "fixed": { + // ... + }, + "known_affected": { + // ... + }, + "known_not_affected": { + // ... + }, + "last_affected": { + // ... + }, + "recommended": { + // ... + }, + "under_investigation": { + // .. + } + } + }, +``` + +First affected (`first_affected`) of value type Products (`products_t`) represents that these are the first versions of the releases known to be affected by the vulnerability. + +First fixed (`first_fixed`) of value type Products (`products_t`) represents that these versions contain the first fix for the vulnerability but may not be the recommended fixed versions. + +Fixed (`fixed`) of value type Products (`products_t`) represents that these versions contain a fix for the vulnerability but may not be the recommended fixed versions. + +Known affected (`known_affected`) of value type Products (`products_t`) represents that these versions are known to be affected by the vulnerability. Actions are recommended to remediate or address this vulnerability. + +> This could include for instance learning more about the vulnerability and context, and/or making a risk-based decision to patch or apply defense-in-depth measures. See `/vulnerabilities[]/remediations`, `/vulnerabilities[]/notes` and `/vulnerabilities[]/threats` for more details. + +Known not affected (`known_not_affected`) of value type Products (`products_t`) represents that these versions are known not to be affected by the vulnerability. No remediation is required regarding this vulnerability. + +> This could for instance be because the code referenced in the vulnerability is not present, not exposed, compensating controls exist, or other factors. +See `/vulnerabilities[]/threats` in category `impact` for more details. + +Last affected (`last_affected`) of value type Products (`products_t`) represents that these are the last versions in a release train known to be affected by the vulnerability. Subsequently released versions would contain a fix for the vulnerability. + +Recommended (`recommended`) of value type Products (`products_t`) represents that these versions have a fix for the vulnerability and are the vendor-recommended versions for fixing the vulnerability. + +Under investigation (`under_investigation`) of value type Products (`products_t`) represents that it is not known yet whether these versions are or are not affected by the vulnerability. However, it is still under investigation - the result will be provided in a later release of the document. + +#### 3.2.3.10 Vulnerabilities Property - References + +Vulnerability references (`references`) of value type References Type (`references_t`) holds a list of references associated with this vulnerability item. + +``` + "references": { + // ... + }, +``` + +#### 3.2.3.11 Vulnerabilities Property - Release Date + +Release date (`release_date`) with value type `string` of format `date-time` holds the date and time the vulnerability was originally released into the wild. + +#### 3.2.3.12 Vulnerabilities Property - Remediations + +List of remediations (`remediations`) of value type `array` with 1 or more Remediation items of value type `object` contains a list of remediations. + +``` + "remediations": { + // ... + "items": { + // ... + } + }, +``` + +Every Remediation item of value type `object` with the 2 mandatory properties Category (`category`) and Details (`details`) specifies details on how to handle (and presumably, fix) a vulnerability. At least one of the optional elements Group IDs (`group_ids`) and Product IDs (`product_ids`) MUST be present to state for which products or product groups this remediation is applicable. + +In addition, any Remediation MAY expose the six optional properties Date (`date`), Entitlements (`entitlements`), Group IDs (`group_ids`), Product IDs (`product_ids`), Restart required (`restart_required`), and URL (`url`). + +``` + "properties": { + "category": { + // ... + }, + "date": { + // ... + }, + "details": { + // ... + }, + "entitlements": { + // ... + }, + "group_ids": { + // ... + }, + "product_ids": { + // ... + }, + "restart_required": { + // ... + }, + "url": { + // ... + } + } +``` + +##### 3.2.3.12.1 Vulnerabilities Property - Remediations - Category + +Category of the remediation (`category`) of value type `string` and `enum` specifies the category which this remediation belongs to. +Valid values are: + +``` + mitigation + no_fix_planned + none_available + vendor_fix + workaround +``` + +The value `workaround` indicates that the remediation contains information about a configuration or specific deployment scenario that can be used to avoid exposure to the vulnerability. There MAY be none, one, or more workarounds available. This is typically the “first line of defense” against a new vulnerability before a mitigation or vendor fix has been issued or even discovered. + +The value `mitigation` indicates that the remediation contains information about a configuration or deployment scenario that helps to reduce the risk of the vulnerability but that does not resolve the vulnerability on the affected product. Mitigations MAY include using devices or access controls external to the affected product. Mitigations MAY or MAY NOT be issued by the original author of the affected product, and they MAY or MAY NOT be officially sanctioned by the document producer. + +The value `vendor_fix` indicates that the remediation contains information about an official fix that is issued by the original author of the affected product. Unless otherwise noted, it is assumed that this fix fully resolves the vulnerability. +This value contradicts with the categories `none_available` and `no_fix_planned` for the same product. Therefore, such a combination can't be used in the list of remediations. + +The value `none_available` indicates that there is currently no fix or other remediation available. The text in field `details` SHOULD contain details about why there is no fix or other remediation. +The values `none_available` and `vendor_fix` are mutually exclusive per product. + +> An issuing party might choose to use this category to announce that a fix is currently developed. It is recommended that this also includes a date when a customer can expect the fix to be ready and distributed. + +The value `no_fix_planned` indicates that there is no fix for the vulnerability and it is not planned to provide one at any time. This is often the case when a product has been orphaned, declared end-of-life, or otherwise deprecated. The text in field `details` SHOULD contain details about why there will be no fix issued. +The values `no_fix_planned` and `vendor_fix` are mutually exclusive per product. + +##### 3.2.3.12.2 Vulnerabilities Property - Remediations - Date + +Date of the remediation (`date`) of value type `string` with format `date-time` contains the date from which the remediation is available. + +##### 3.2.3.12.3 Vulnerabilities Property - Remediations - Details + +Details of the remediation (`details`) of value type `string` with 1 or more characters contains a thorough human-readable discussion of the remediation. + +##### 3.2.3.12.4 Vulnerabilities Property - Remediations - Entitlements + +List of entitlements (`entitlements`) of value type `array` with 1 or more items of type Entitlement of the remediation as `string` with 1 or more characters contains a list of entitlements. + +``` + "entitlements": { + // .... + "items": { + // ... + } + }, +``` + +Every Entitlement of the remediation contains any possible vendor-defined constraints for obtaining fixed software or hardware that fully resolves the vulnerability. + +##### 3.2.3.12.5 Vulnerabilities Property - Remediations - Group IDs + +Group IDs (`group_ids`) are of value type Product Groups (`product_groups_t`) and contain a list of Product Groups the current remediation item applies to. + +##### 3.2.3.12.6 Vulnerabilities Property - Remediations - Product IDs + +Product IDs (`product_ids`) are of value type Products (`products_t`) and contain a list of Products the current remediation item applies to. + +##### 3.2.3.12.7 Vulnerabilities Property - Remediations - Restart Required + +Restart required by remediation (`restart_required`) of value type `object` with the 1 mandatory property Category (`category`) and the optional property Details (`details`) provides information on category of restart is required by this remediation to become effective. + +``` + "restart_required": { + // ... + "properties": { + "category": { + // ... + } + "details": { + // ... + } + } + }, +``` + +Category of restart (`category`) of value type `string` and `enum` specifies what category of restart is required by this remediation to become effective. +Valid values are: + +``` + connected + dependencies + machine + none + parent + service + system + vulnerable_component + zone +``` + +The values MUST be used as follows: + +* `none`: No restart required. +* `vulnerable_component`: Only the vulnerable component (as given by the elements of `product_ids` or `group_ids` in the current remediation item) needs to be restarted. +* `service`: The vulnerable component and the background service used by the vulnerable component need to be restarted. +* `parent`: The vulnerable component and its parent process need to be restarted. This could be the case if the parent process has no build-in way to restart the vulnerable component or process values / context is only given at the start of the parent process. +* `dependencies`: The vulnerable component and all components which require the vulnerable component to work need to be restarted. This could be the case e.g. for a core service of a software. +* `connected`: The vulnerable component and all components connected (via network or any type of inter-process communication) to the vulnerable component need to be restarted. +* `machine`: The machine on which the vulnerable component is installed on needs to be restarted. This is the value which SHOULD be used if an OS needs to be restarted. It is typically the case for OS upgrades. +* `zone`: The security zone in which the machine resides on which the vulnerable component is installed needs to be restarted. This value might be useful for a remediation if no patch is available. If the malware can be wiped out by restarting the infected machines but the infection spreads fast the controlled shutdown of all machines at the same time and restart afterwards can leave one with a clean system. +* `system`: The whole system which the machine resides on which the vulnerable component is installed needs to be restarted. This MAY include multiple security zones. This could be the case for a major system upgrade in an ICS system or a protocol change. + +Additional restart information (`details`) of value type `string` with 1 or more characters provides additional information for the restart. This can include details on procedures, scope or impact. + +##### 3.2.3.12.8 Vulnerabilities Property - Remediations - URL + +URL (`url`) of value type `string` with format `uri` contains the URL where to obtain the remediation. + +#### 3.2.3.13 Vulnerabilities Property - Scores + +List of scores (`scores`) of value type `array` with 1 or more items of type score holds a list of score objects for the current vulnerability. + +``` + "scores": { + // ... + "items": { + // ... + } + }, +``` + +Value type of every such Score item is `object` with the mandatory property `products` and the optional properties `cvss_v2` and `cvss_v3` specifies information about (at least one) score of the vulnerability and for which products the given value applies. Each Score item has at least 2 properties. + +``` + "properties": { + "cvss_v2": { + // ... + }, + "cvss_v3": { + "oneOf": [ + // ... + ] + } + "products": { + // ... + } + } +``` + +The property CVSS v2 (`cvss_v2`) holding a CVSS v2.0 value abiding by the schema at [https://www.first.org/cvss/cvss-v2.0.json](https://www.first.org/cvss/cvss-v2.0.json). + +The property CVSS v3 (`cvss_v3`) holding a CVSS v3.x value abiding by one of the schemas at [https://www.first.org/cvss/cvss-v3.0.json](https://www.first.org/cvss/cvss-v3.0.json) or [https://www.first.org/cvss/cvss-v3.1.json](https://www.first.org/cvss/cvss-v3.1.json). + +Product IDs (`products`) of value type `products_t` with 1 or more items indicates for which products the given scores apply. A score object SHOULD reflect the associated product's status (for example, a fixed product no longer contains a vulnerability and should have a CVSS score of 0, or simply no score listed; the known affected versions of that product can list the vulnerability score as it applies to them). + +#### 3.2.3.14 Vulnerabilities Property - Threats + +List of threats (`threats`) of value type `array` with 1 or more items of value type `object` contains information about a vulnerability that can change with time. + +``` + "threats": { + // ... + "items": { + // ... + } + }, +``` + +Every Threat item of value type `object` with the two mandatory properties Category (`category`) and Details (`details`) contains the vulnerability kinetic information. +This information can change as the vulnerability ages and new information becomes available. +In addition, any Threat item MAY expose the three optional properties Date (`date`), Group IDs (`group_ids`), and Product IDs (`product_ids`). + +``` + "properties": { + "category": { + // ... + } + "date": { + // ... + }, + "details": { + // ... + }, + "group_ids": { + // ... + }, + "product_ids": { + // ... + } + } +``` + +Category of the threat (`category`) of value type `string` and `enum` categorizes the threat according to the rules of the specification. +Valid values are: + +``` + exploit_status + impact + target_set +``` + +The value `exploit_status` indicates that the `details` field contains a description of the degree to which an exploit for the vulnerability is known. This knowledge can range from information privately held among a very small group to an issue that has been described to the public at a major conference or is being widely exploited globally. For consistency and simplicity, this section can be a mirror image of the CVSS "Exploitability" metric. However, it can also contain a more contextual status, such as "Weaponized" or "Functioning Code". + +The value `impact` indicates that the `details` field contains an assessment of the impact on the user or the target set if the vulnerability is successfully exploited or a description why it cannot be exploited. If applicable, for consistency and simplicity, this section can be a textual summary of the three CVSS impact metrics. These metrics measure how a vulnerability detracts from the three core security properties of an information system: Confidentiality, Integrity, and Availability. + +The value `target_set` indicates that the `details` field contains a description of the currently known victim population in whatever terms are appropriate. Such terms MAY include: operating system platform, types of products, user segments, and geographic distribution. + +Date of the threat (`date`) of value type `string` with format `date-time` contains the date when the assessment was done or the threat appeared. + +Details of the threat (`details`) of value type `string` with 1 or more characters represents a thorough human-readable discussion of the threat. + +Group IDs (`group_ids`) are of value type Product Groups (`product_groups_t`) and contain a list of Product Groups the current threat item applies to. + +Product IDs (`product_ids`) are of value type Products (`products_t`) and contain a list of Products the current threat item applies to. + +#### 3.2.3.15 Vulnerabilities Property - Title + +Title (`title`) has value type `string` with 1 or more characters and gives the document producer the ability to apply a canonical name or title to the vulnerability. + +------- diff --git a/csaf_2.1/prose/edit/src/table-of-contents.md b/csaf_2.1/prose/edit/src/table-of-contents.md new file mode 100644 index 000000000..2657bf5e1 --- /dev/null +++ b/csaf_2.1/prose/edit/src/table-of-contents.md @@ -0,0 +1,7 @@ + +# Table of Contents + +[[TOC will be inserted here]] + +------- + diff --git a/csaf_2.1/prose/edit/src/tests-00.md b/csaf_2.1/prose/edit/src/tests-00.md new file mode 100644 index 000000000..812fd0a92 --- /dev/null +++ b/csaf_2.1/prose/edit/src/tests-00.md @@ -0,0 +1,4 @@ +# 6 Tests + +The following three subsections list a number of tests which all will have a short description and an excerpt of an example which fails the test. + diff --git a/csaf_2.1/prose/edit/src/tests-01-mandatory.md b/csaf_2.1/prose/edit/src/tests-01-mandatory.md new file mode 100644 index 000000000..0dd98ff26 --- /dev/null +++ b/csaf_2.1/prose/edit/src/tests-01-mandatory.md @@ -0,0 +1,1529 @@ +## 6.1 Mandatory Tests + +Mandatory tests MUST NOT fail at a valid CSAF document. A program MUST handle a test failure as an error. + +### 6.1.1 Missing Definition of Product ID + +For each element of type `/$defs/product_id_t` which is not inside a Full Product Name (type: `full_product_name_t`) and therefore reference an element within the `product_tree` it MUST be tested that the Full Product Name element with the matching `product_id` exists. The same applies for all items of elements of type `/$defs/products_t`. + +The relevant paths for this test are: + +``` + /product_tree/product_groups[]/product_ids[] + /product_tree/relationships[]/product_reference + /product_tree/relationships[]/relates_to_product_reference + /vulnerabilities[]/product_status/first_affected[] + /vulnerabilities[]/product_status/first_fixed[] + /vulnerabilities[]/product_status/fixed[] + /vulnerabilities[]/product_status/known_affected[] + /vulnerabilities[]/product_status/known_not_affected[] + /vulnerabilities[]/product_status/last_affected[] + /vulnerabilities[]/product_status/recommended[] + /vulnerabilities[]/product_status/under_investigation[] + /vulnerabilities[]/remediations[]/product_ids[] + /vulnerabilities[]/scores[]/products[] + /vulnerabilities[]/threats[]/product_ids[] +``` + +*Example 49 which fails the test:* + +``` + "product_tree": { + "product_groups": [ + { + "group_id": "CSAFGID-1020300", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ] + } +``` + +> Neither `CSAFPID-9080700` nor `CSAFPID-9080701` were defined in the `product_tree`. + +### 6.1.2 Multiple Definition of Product ID + +For each Product ID (type `/$defs/product_id_t`) in Full Product Name elements (type: `/$defs/full_product_name_t`) it MUST be tested that the `product_id` was not already defined within the same document. + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/product/product_id + /product_tree/full_product_names[]/product_id + /product_tree/relationships[]/full_product_name/product_id +``` + +*Example 50 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080700", + "name": "Product B" + } + ] + } +``` + +> `CSAFPID-9080700` was defined twice. + +### 6.1.3 Circular Definition of Product ID + +For each new defined Product ID (type `/$defs/product_id_t`) in items of relationships (`/product_tree/relationships`) it MUST be tested that the `product_id` does not end up in a circle. + +The relevant path for this test is: + +``` + /product_tree/relationships[]/full_product_name/product_id +``` + +> As this can be quite complex a program for large CSAF documents, a program could check first whether a Product ID defined in a relationship item is used as `product_reference` or `relates_to_product_reference`. Only for those which fulfill this condition it is necessary to run the full check following the references. + +*Example 51 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ], + "relationships": [ + { + "category": "installed_on", + "full_product_name": { + "name": "Product B", + "product_id": "CSAFPID-9080701" + }, + "product_reference": "CSAFPID-9080700", + "relates_to_product_reference": "CSAFPID-9080701" + } + ] + } +``` + +> `CSAFPID-9080701` refers to itself - this is a circular definition. + +### 6.1.4 Missing Definition of Product Group ID + +For each element of type `/$defs/product_group_id_t` which is not inside a Product Group (`/product_tree/product_groups[]`) and therefore reference an element within the `product_tree` it MUST be tested that the Product Group element with the matching `group_id` exists. The same applies for all items of elements of type `/$defs/product_groups_t`. + +The relevant paths for this test are: + +``` + /vulnerabilities[]/remediations[]/group_ids + /vulnerabilities[]/threats[]/group_ids +``` + +*Example 52 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "threats": [ + { + "category": "exploit_status", + "details": "Reliable exploits integrated in Metasploit.", + "group_ids": [ + "CSAFGID-1020301" + ] + } + ] + } + ] +``` + +> `CSAFGID-1020301` was not defined in the Product Tree. + +### 6.1.5 Multiple Definition of Product Group ID + +For each Product Group ID (type `/$defs/product_group_id_t`) Product Group elements (`/product_tree/product_groups[]`) it MUST be tested that the `group_id` was not already defined within the same document. + +The relevant path for this test is: + +``` + /product_tree/product_groups[]/group_id +``` + +*Example 53 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ], + "product_groups": [ + { + "group_id": "CSAFGID-1020300", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + }, + { + "group_id": "CSAFGID-1020300", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080702" + ] + } + ] + } +``` + +> `CSAFGID-1020300` was defined twice. + +### 6.1.6 Contradicting Product Status + +For each item in `/vulnerabilities` it MUST be tested that the same Product ID is not member of contradicting product status groups. The sets formed by the contradicting groups within one vulnerability item MUST be pairwise disjoint. + +Contradiction groups are: + +* Affected: + + ``` + /vulnerabilities[]/product_status/first_affected[] + /vulnerabilities[]/product_status/known_affected[] + /vulnerabilities[]/product_status/last_affected[] + ``` + +* Not affected: + + ``` + /vulnerabilities[]/product_status/known_not_affected[] + ``` + +* Fixed: + + ``` + /vulnerabilities[]/product_status/first_fixed[] + /vulnerabilities[]/product_status/fixed[] + ``` + +* Under investigation: + + ``` + /vulnerabilities[]/product_status/under_investigation[] + ``` + +> Note: An issuer might recommend (`/vulnerabilities[]/product_status/recommended`) a product version from any group - also from the affected group, i.e. if it was discovered that fixed versions introduce a more severe vulnerability. + +*Example 54 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "known_affected": [ + "CSAFPID-9080700" + ], + "known_not_affected": [ + "CSAFPID-9080700" + ] + } + } + ] +``` + +> `CSAFPID-9080700` is a member of the two contradicting groups "Affected" and "Not affected". + +### 6.1.7 Multiple Scores with same Version per Product + +For each item in `/vulnerabilities` it MUST be tested that the same Product ID is not member of more than one CVSS-Vectors with the same version. + +The relevant path for this test is: + +``` + /vulnerabilities[]/scores[] +``` + +*Example 55 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H", + "baseScore": 10, + "baseSeverity": "CRITICAL" + } + }, + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 6.5, + "baseSeverity": "MEDIUM" + } + } + ] + } + ] +``` + +> Two CVSS v3.1 scores are given for `CSAFPID-9080700`. + +### 6.1.8 Invalid CVSS + +It MUST be tested that the given CVSS object is valid according to the referenced schema. + +The relevant paths for this test are: + +``` + /vulnerabilities[]/scores[]/cvss_v2 + /vulnerabilities[]/scores[]/cvss_v3 +``` + +*Example 56 which fails the test:* + +``` + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 6.5 + } +``` + +> The required element `baseSeverity` is missing. + +> A tool MAY add one or more of the missing properties `version`, `baseScore` and `baseSeverity` based on the values given in `vectorString` as quick fix. + +### 6.1.9 Invalid CVSS computation + +It MUST be tested that the given CVSS object has the values computed correctly according to the definition. + +> The `vectorString` SHOULD take precedence. + +The relevant paths for this test are: + +``` + /vulnerabilities[]/scores[]/cvss_v2/baseScore + /vulnerabilities[]/scores[]/cvss_v2/temporalScore + /vulnerabilities[]/scores[]/cvss_v2/environmentalScore + /vulnerabilities[]/scores[]/cvss_v3/baseScore + /vulnerabilities[]/scores[]/cvss_v3/baseSeverity + /vulnerabilities[]/scores[]/cvss_v3/temporalScore + /vulnerabilities[]/scores[]/cvss_v3/temporalSeverity + /vulnerabilities[]/scores[]/cvss_v3/environmentalScore + /vulnerabilities[]/scores[]/cvss_v3/environmentalSeverity +``` + +*Example 57 which fails the test:* + +``` + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 10.0, + "baseSeverity": "LOW" + } +``` + +> Neither `baseScore` nor `baseSeverity` has the correct value according to the specification. + +> A tool MAY set the correct values as computed according to the specification as quick fix. + +### 6.1.10 Inconsistent CVSS + +It MUST be tested that the given CVSS properties do not contradict the CVSS vector. + +The relevant paths for this test are: + +``` + /vulnerabilities[]/scores[]/cvss_v2 + /vulnerabilities[]/scores[]/cvss_v3 +``` + +*Example 58 which fails the test:* + +``` + "cvss_v3": { + "version": "3.1", + "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H", + "baseScore": 9.8, + "baseSeverity": "CRITICAL", + "attackVector": "LOCAL", + "attackComplexity": "LOW", + "privilegesRequired": "NONE", + "userInteraction": "NONE", + "scope": "CHANGED", + "confidentialityImpact": "HIGH", + "integrityImpact": "HIGH", + "availabilityImpact": "LOW" + } +``` + +> The values in CVSS vector differs from values of the properties `attackVector`, `scope` and `availabilityImpact`. + +> A tool MAY overwrite contradicting values according to the `vectorString` as quick fix. + +### 6.1.11 CWE + +It MUST be tested that given CWE exists and is valid. + +The relevant path for this test is: + +``` + /vulnerabilities[]/cwe +``` + +*Example 59 which fails the test:* + +``` + "cwe": { + "id": "CWE-79", + "name": "Improper Input Validation" + } +``` + +> The `CWE-79` exists. However, its name is `Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')`. + +### 6.1.12 Language + +For each element of type `/$defs/language_t` it MUST be tested that the language code is valid and exists. + +The relevant paths for this test are: + +``` + /document/lang + /document/source_lang +``` + +*Example 60 which fails the test:* + +``` + "lang": "EZ" +``` + +> `EZ` is not a valid language. It is the subtag for the region "Eurozone". + +> For any deprecated subtag, a tool MAY replace it with its preferred value as a quick fix. + +### 6.1.13 PURL + +It MUST be tested that given PURL is valid. + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/product/product_identification_helper/purl + /product_tree/full_product_names[]/product_identification_helper/purl + /product_tree/relationships[]/full_product_name/product_identification_helper/purl +``` + +*Example 61 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "purl": "pkg:maven/@1.3.4" + } + } + ] + } +``` + +> Any valid purl has a name component. + +### 6.1.14 Sorted Revision History + +It MUST be tested that the value of `number` of items of the revision history are sorted ascending when the items are sorted ascending by `date`. + +The relevant path for this test is: + +``` + /document/tracking/revision_history +``` + +*Example 62 which fails the test:* + +``` + "revision_history": [ + { + "date": "2021-07-22T10:00:00.000Z", + "number": "2", + "summary": "Second version." + }, + { + "date": "2021-07-23T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ] +``` + +> The first item has a higher version number than the second. + +### 6.1.15 Translator + +It MUST be tested that `/document/source_lang` is present and set if the value `translator` is used for `/document/publisher/category`. + +The relevant path for this test is: + +``` + /document/source_lang +``` + +*Example 63 which fails the test:* + +``` + "document": { + // ... + "publisher": { + "category": "translator", + "name": "CSAF TC Translator", + "namespace": "https://csaf.io/translator" + }, + "title": "Mandatory test: Translator (failing example 1)", + // ... + } +``` + +> The required element `source_lang` is missing. + +### 6.1.16 Latest Document Version + +It MUST be tested that document version has the same value as the the `number` in the last item of Revision History when it is sorted ascending by `date`. Build metadata is ignored in the comparison. Any pre-release part is also ignored if the document status is `draft`. + +The relevant path for this test is: + +``` + /document/tracking/version +``` + +*Example 64 which fails the test:* + +``` + "tracking": { + // ... + "revision_history": [ + { + "date": "2021-07-21T09:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + // ... + "version": "1" + } +``` + +> The value of `number` of the last item after sorting is `2`. However, the document version is `1`. + +### 6.1.17 Document Status Draft + +It MUST be tested that document status is `draft` if the document version is `0` or `0.y.z` or contains the pre-release part. + +The relevant path for this test is: + +``` + /document/tracking/status +``` + +*Example 65 which fails the test:* + +``` + "tracking": { + // ... + "status": "final", + "version": "0.9.5" + } +``` + +> The `/document/tracking/version` is `0.9.5` but the document status is `final`. + +### 6.1.18 Released Revision History + +It MUST be tested that no item of the revision history has a `number` of `0` or `0.y.z` when the document status is `final` or `interim`. + +The relevant path for this test is: + +``` + /document/tracking/revision_history[]/number +``` + +*Example 66 which fails the test:* + +``` + "tracking": { + // ... + "revision_history": [ + { + "date": "2021-05-17T10:00:00.000Z", + "number": "0", + "summary": "First draft" + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + } + ], + "status": "final", + "version": "1" + } +``` + +> The document status is `final` but the revision history includes an item which has `0` as value for `number`. + +### 6.1.19 Revision History Entries for Pre-release Versions + +It MUST be tested that no item of the revision history has a `number` which includes pre-release information. + +The relevant path for this test is: + +``` + /document/tracking/revision_history[]/number +``` + +*Example 67 which fails the test:* + +``` + "revision_history": [ + { + "date": "2021-04-22T10:00:00.000Z", + "number": "1.0.0-rc", + "summary": "Release Candidate for initial version." + }, + { + "date": "2021-04-23T10:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + } + ] +``` + +> The revision history contains an item which has a `number` that indicates that this is pre-release. + +### 6.1.20 Non-draft Document Version + +It MUST be tested that document version does not contain a pre-release part if the document status is `final` or `interim`. + +The relevant path for this test is: + +``` + /document/tracking/version +``` + +*Example 68 which fails the test:* + +``` + "tracking": { + // ... + "status": "interim", + "version": "1.0.0-alpha" + } +``` + +> The document status is `interim` but the document version contains the pre-release part `-alpha`. + +### 6.1.21 Missing Item in Revision History + +It MUST be tested that items of the revision history do not omit a version number when the items are sorted ascending by `date`. In the case of semantic versioning, this applies only to the Major version. It MUST also be tested that the first item in such a sorted list has either the version number 0 or 1 in the case of integer versioning or a Major version of 0 or 1 in the case of semantic versioning. + +The relevant path for this test is: + +``` + /document/tracking/revision_history +``` + +*Example 69 which fails the test:* + +``` + "revision_history": [ + { + "date": "2021-04-22T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "3", + "summary": "Some other changes." + } + ] +``` + +> The item for version `2` is missing. + +### 6.1.22 Multiple Definition in Revision History + +It MUST be tested that items of the revision history do not contain the same version number. + +The relevant path for this test is: + +``` + /document/tracking/revision_history +``` + +*Example 70 which fails the test:* + +``` + "revision_history": [ + { + "date": "2021-07-20T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "1", + "summary": "Some other changes." + } + ] +``` + +> The revision history contains two items with the version number `1`. + +### 6.1.23 Multiple Use of Same CVE + +It MUST be tested that a CVE is not used in multiple vulnerability items. + +The relevant path for this test is: + +``` + /vulnerabilities[]/cve +``` + +*Example 71 which fails the test:* + +``` + "vulnerabilities": [ + { + "cve": "CVE-2017-0145" + }, + { + "cve": "CVE-2017-0145" + } + ] +``` + +> The vulnerabilities array contains two items with the same CVE identifier `CVE-2017-0145`. + +### 6.1.24 Multiple Definition in Involvements + +It MUST be tested that items of the list of involvements do not contain the same `party` regardless of its `status` more than once at any `date`. + +The relevant path for this test is: + +``` + /vulnerabilities[]/involvements +``` + +*Example 72 which fails the test:* + +``` + "vulnerabilities": [ + { + "involvements": [ + { + "date": "2021-04-23T10:00:00.000Z", + "party": "vendor", + "status": "completed" + }, + { + "date": "2021-04-23T10:00:00.000Z", + "party": "vendor", + "status": "in_progress", + "summary": "The vendor has released a mitigation and is working to fully resolve the issue." + } + ] + } + ] +``` + +> The list of involvements contains two items with the same tuple `party` and `date`. + +### 6.1.25 Multiple Use of Same Hash Algorithm + +It MUST be tested that the same hash algorithm is not used multiple times in one item of hashes. + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/product/product_identification_helper/hashes[]/file_hashes + /product_tree/full_product_names[]/product_identification_helper/hashes[]/file_hashes + /product_tree/relationships[]/full_product_name/product_identification_helper/hashes[]/file_hashes +``` + +*Example 73 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "hashes": [ + { + "file_hashes": [ + { + "algorithm": "sha256", + "value": "026a37919b182ef7c63791e82c9645e2f897a3f0b73c7a6028c7febf62e93838" + }, + { + "algorithm": "sha256", + "value": "0a853ce2337f0608489ac596a308dc5b7b19d35a52b10bf31261586ac368b175" + } + ], + "filename": "product_a.so" + } + ] + } + } + ] + } +``` + +> The hash algorithm `sha256` is used two times in one item of hashes. + +### 6.1.26 Prohibited Document Category Name + +It MUST be tested that the document category is not equal to the (case insensitive) name (without the prefix `csaf_`) or value of any other profile than "CSAF Base". Any occurrences of dash, whitespace, and underscore characters are removed from the values on both sides before the match. Also the value MUST NOT start with the reserved prefix `csaf_` except if the value is `csaf_base`. + +This test does only apply for CSAF documents with the profile "CSAF Base". Therefore, it MUST be skipped if the document category matches one of the values defined for the profile other than "CSAF Base". + +> For CSAF 2.0, the test must be skipped for the following values in `/document/category`: +> +> ``` +> csaf_base +> csaf_security_incident_response +> csaf_informational_advisory +> csaf_security_advisory +> csaf_vex +> ``` + +This is the only mandatory test related to the profile "CSAF Base" as the required fields SHALL be checked by validating the JSON schema. + +The relevant path for this test is: + +``` + /document/category +``` + +*Examples 74 for currently prohibited values:* + +``` + Csaf_a + Informational Advisory + security-incident-response + Security Advisory + veX + V_eX +``` + +*Example 75 which fails the test:* + +``` + "category": "Security_Incident_Response" +``` + +> The value `Security_Incident_Response` is the name of a profile where the space was replaced with underscores. + +### 6.1.27 Profile Tests + +This subsubsection structures the tests for the profiles. Not all tests apply for all profiles. Tests SHOULD be skipped if the document category does not match the one given in the test. Each of the following tests SHOULD be treated as they where listed similar to the other tests. + +> An application MAY group these tests by profiles when providing the additional function to only run one or more selected tests. This results in one virtual test per profile. + +#### 6.1.27.1 Document Notes + +It MUST be tested that at least one item in `/document/notes` exists which has a `category` of `description`, `details`, `general` or `summary`. + +The relevant values for `/document/category` are: + +``` + csaf_informational_advisory + csaf_security_incident_response +``` + +The relevant path for this test is: + +``` + /document/notes +``` + +*Example 76 which fails the test:* + +``` + "notes": [ + { + "category": "legal_disclaimer", + "text": "The CSAF document is provided to You \"AS IS\" and \"AS AVAILABLE\" and with all faults and defects without warranty of any kind.", + "title": "Terms of Use" + } + ] +``` + +> The document notes do not contain an item which has a `category` of `description`, `details`, `general` or `summary`. + +#### 6.1.27.2 Document References + +It MUST be tested that at least one item in `/document/references` exists that has links to an `external` source. + +The relevant values for `/document/category` are: + +``` + csaf_informational_advisory + csaf_security_incident_response +``` + +The relevant path for this test is: + +``` + /document/references +``` + +*Example 77 which fails the test:* + +``` + "references": [ + { + "category": "self", + "summary": "The canonical URL.", + "url": "https://example.com/security/data/csaf/2021/OASIS_CSAF_TC-CSAF_2_0-2021-6-1-27-02-01.json" + } + ] +``` + +> The document references do not contain any item which has the category `external`. + +#### 6.1.27.3 Vulnerabilities + +It MUST be tested that the element `/vulnerabilities` does not exist. + +The relevant value for `/document/category` is: + +``` + csaf_informational_advisory +``` + +The relevant path for this test is: + +``` + /vulnerabilities +``` + +*Example 78 which fails the test:* + +``` + "vulnerabilities": [ + { + "title": "A vulnerability item that SHALL NOT exist" + } + ] +``` + +> The element `/vulnerabilities` exists. + +> A tool MAY change the `/document/category` to `csaf_base` as a quick fix. + +#### 6.1.27.4 Product Tree + +It MUST be tested that the element `/product_tree` exists. + +The relevant values for `/document/category` are: + +``` + csaf_security_advisory + csaf_vex +``` + +The relevant path for this test is: + +``` + /product_tree +``` + +*Example 79 which fails the test:* + +``` + { + "document": { + // ... + }, + "vulnerabilities": [ + // ... + ] + } +``` + +> The element `/product_tree` does not exist. + +#### 6.1.27.5 Vulnerability Notes + +For each item in `/vulnerabilities` it MUST be tested that the element `notes` exists. + +The relevant values for `/document/category` are: + +``` + csaf_security_advisory + csaf_vex +``` + +The relevant path for this test is: + +``` + /vulnerabilities[]/notes +``` + +*Example 80 which fails the test:* + +``` + "vulnerabilities": [ + { + "title": "A vulnerability item without a note" + } + ] +``` + +> The vulnerability item has no `notes` element. + +#### 6.1.27.6 Product Status + +For each item in `/vulnerabilities` it MUST be tested that the element `product_status` exists. + +The relevant value for `/document/category` is: + +``` + csaf_security_advisory +``` + +The relevant path for this test is: + +``` + /vulnerabilities[]/product_status +``` + +*Example 81 which fails the test:* + +``` + "vulnerabilities": [ + { + "title": "A vulnerability item without a product status" + } + ] +``` + +> The vulnerability item has no `product_status` element. + +#### 6.1.27.7 VEX Product Status + +For each item in `/vulnerabilities` it MUST be tested that at least one of the elements `fixed`, `known_affected`, `known_not_affected`, or `under_investigation` is present in `product_status`. + +The relevant value for `/document/category` is: + +``` + csaf_vex +``` + +The relevant paths for this test are: + +``` + /vulnerabilities[]/product_status/fixed + /vulnerabilities[]/product_status/known_affected + /vulnerabilities[]/product_status/known_not_affected + /vulnerabilities[]/product_status/under_investigation +``` + +*Example 82 which fails the test:* + +``` + "product_status": { + "first_fixed": [ + // ... + ], + "recommended": [ + // ... + ] + } +``` + +> None of the elements `fixed`, `known_affected`, `known_not_affected`, or `under_investigation` is present in `product_status`. + +#### 6.1.27.8 Vulnerability ID + +For each item in `/vulnerabilities` it MUST be tested that at least one of the elements `cve` or `ids` is present. + +The relevant value for `/document/category` is: + +``` + csaf_vex +``` + +The relevant paths for this test are: + +``` + /vulnerabilities[]/cve + /vulnerabilities[]/ids +``` + +*Example 83 which fails the test:* + +``` + "vulnerabilities": [ + { + "title": "A vulnerability item without a CVE or ID" + } + ] +``` + +> None of the elements `cve` or `ids` is present. + +#### 6.1.27.9 Impact Statement + +For each item in `/vulnerabilities[]/product_status/known_not_affected` it MUST be tested that a corresponding impact statement exist in `/vulnerabilities[]/flags` or `/vulnerabilities[]/threats`. For the latter one, the `category` value for such a statement MUST be `impact`. + +The relevant value for `/document/category` is: + +``` + csaf_vex +``` + +The relevant path for this test is: + +``` + /vulnerabilities[]/flags + /vulnerabilities[]/threats +``` + +*Example 84 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ], + "product_groups": [ + { + "group_id": "CSAFGID-0001", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ] + }, + "vulnerabilities": [ + { + // ... + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "threats": [ + { + "category": "impact", + "details": "The vulnerable code is not present in these products.", + "group_ids": [ + "CSAFGID-0001" + ] + } + ] + } + ] +``` + +> There is no impact statement for `CSAFPID-9080702`. +> +> Note: The impact statement for `CSAFPID-9080700` and `CSAFPID-9080701` is given through `CSAFGID-0001`. + +#### 6.1.27.10 Action Statement + +For each item in `/vulnerabilities[]/product_status/known_affected` it MUST be tested that a corresponding action statement exist in `/vulnerabilities[]/remediations`. + +The relevant value for `/document/category` is: + +``` + csaf_vex +``` + +The relevant path for this test is: + +``` + /vulnerabilities[]/remediations +``` + +*Example 85 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + }, + { + "product_id": "CSAFPID-9080702", + "name": "Product C" + } + ], + "product_groups": [ + { + "group_id": "CSAFGID-0001", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ], + "summary": "EOL products" + } + ] + }, + "vulnerabilities": [ + { + // ... + "product_status": { + "known_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701", + "CSAFPID-9080702" + ] + }, + "remediations": [ + { + "category": "no_fix_planned", + "details": "These products are end-of-life. Therefore, no fix will be provided.", + "group_ids": [ + "CSAFGID-0001" + ] + } + ] + } + ] +``` + +> There is no action statement for `CSAFPID-9080702`. +> +> Note: The action statement for `CSAFPID-9080700` and `CSAFPID-9080701` is given through `CSAFGID-0001`. + +#### 6.1.27.11 Vulnerabilities + +It MUST be tested that the element `/vulnerabilities` exists. + +The relevant values for `/document/category` are: + +``` + csaf_security_advisory + csaf_vex +``` + +The relevant path for this test is: + +``` + /vulnerabilities +``` + +*Example 86 which fails the test:* + +``` + { + "document": { + // ... + }, + "product_tree": [ + // ... + ] + } +``` + +> The element `/vulnerabilities` does not exist. + +### 6.1.28 Translation + +It MUST be tested that the given source language and document language are not the same. + +The relevant path for this test is: + +``` + /document/lang + /document/source_lang +``` + +*Example 87 which fails the test:* + +``` + "document": { + // ... + "lang": "en-US", + // ... + "source_lang": "en-US", + // ... + } +``` + +> The document language and the source language have the same value `en-US`. +> +> Note: A translation from `en-US` to `en-GB` would pass the test. + +> A tool MAY remove the source language as quick fix. + +### 6.1.29 Remediation without Product Reference + +For each item in `/vulnerabilities[]/remediations` it MUST be tested that it includes at least one of the elements `group_ids` or `product_ids`. + +The relevant path for this test is: + +``` + /vulnerabilities[]/remediations[] +``` + +*Example 88 which fails the test:* + +``` + "remediations": [ + { + "category": "no_fix_planned", + "details": "These products are end-of-life. Therefore, no fix will be provided." + } + ] +``` + +> The given remediation does not specify to which products it should be applied. + +> A tool MAY add all products of the affected group of this vulnerability to the remediation as quick fix. + +### 6.1.30 Mixed Integer and Semantic Versioning + +It MUST be tested that all elements of type `/$defs/version_t` follow either integer versioning or semantic versioning homogeneously within the same document. + +The relevant paths for this test are: + +``` + /document/tracking/revision_history[]/number + /document/tracking/version +``` + +*Example 89 which fails the test:* + +``` + "tracking": { + // ... + "revision_history": [ + { + "date": "2021-07-21T09:00:00.000Z", + "number": "1.0.0", + "summary": "Initial version." + }, + { + "date": "2021-07-21T10:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + // ... + "version": "2" + } +``` + +> The document started with semantic versioning (`1.0.0`) and switched to integer versioning (`2`). + +> A tool MAY assign all items their corresponding value according to integer versioning as a quick fix. In such case, the old `number` SHOULD be stored in `legacy_version`. + +### 6.1.31 Version Range in Product Version + +For each element of type `/$defs/branches_t` with `category` of `product_version` it MUST be tested that the value of `name` does not contain a version range. + +> To implement this test it is deemed sufficient that, when converted to lower case, the value of `name` does not contain any of the following strings: +> +> ``` +> < +> <= +> > +> >= +> after +> all +> before +> earlier +> later +> prior +> versions +> ``` + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/name +``` + +*Example 90 which fails the test:* + +``` + "branches": [ + { + "category": "product_version", + "name": "prior to 4.2", + // ... + } + ] +``` + +> The version range `prior to 4.2` is given for the branch category `product_version`. + +### 6.1.32 Flag without Product Reference + +For each item in `/vulnerabilities[]/flags` it MUST be tested that it includes at least one of the elements `group_ids` or `product_ids`. + +The relevant path for this test is: + +``` + /vulnerabilities[]/flags[] +``` + +*Example 91 which fails the test:* + +``` + "flags": [ + { + "label": "component_not_present" + } + ] +``` + +> The given flag does not specify to which products it should be applied. + +### 6.1.33 Multiple Flags with VEX Justification Codes per Product + +For each item in `/vulnerabilities[]` it MUST be tested that a Product is not member of more than one Flag item with a VEX justification code (see section 3.2.3.5). This takes indirect relations through Product Groups into account. + +> Additional flags with a different purpose might be provided in later versions of CSAF. Through the explicit reference of VEX justification codes the test is specified to be forward-compatible. + +The relevant path for this test is: + +``` + /vulnerabilities[]/flags +``` + +*Example 92 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + }, + { + "product_id": "CSAFPID-9080701", + "name": "Product B" + } + ], + "product_groups": [ + { + "group_id": "CSAFGID-0001", + "product_ids": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + ] + }, + "vulnerabilities": [ + { + // ... + "flags": [ + { + "label": "component_not_present", + "group_ids": [ + "CSAFGID-0001" + ] + }, + { + "label": "vulnerable_code_cannot_be_controlled_by_adversary", + "product_ids": [ + "CSAFPID-9080700" + ] + } + ], + // ... + "product_status": { + "known_not_affected": [ + "CSAFPID-9080700", + "CSAFPID-9080701" + ] + } + } + ] +``` + +> There are two flags given for for `CSAFPID-9080700` - one indirect through `CSAFGID-0001` and one direct. + diff --git a/csaf_2.1/prose/edit/src/tests-02-optional.md b/csaf_2.1/prose/edit/src/tests-02-optional.md new file mode 100644 index 000000000..d1ce74230 --- /dev/null +++ b/csaf_2.1/prose/edit/src/tests-02-optional.md @@ -0,0 +1,626 @@ +## 6.2 Optional Tests + +Optional tests SHOULD NOT fail at a valid CSAF document without a good reason. Failing such a test does not make the CSAF document invalid. These tests may include information about features which are still supported but expected to be deprecated in a future version of CSAF. A program MUST handle a test failure as a warning. + +### 6.2.1 Unused Definition of Product ID + +For each Product ID (type `/$defs/product_id_t`) in Full Product Name elements (type: `/$defs/full_product_name_t`) it MUST be tested that the `product_id` is referenced somewhere within the same document. + +This test SHALL be skipped for CSAF documents conforming the profile "Informational Advisory". + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/product/product_id + /product_tree/full_product_names[]/product_id + /product_tree/relationships[]/full_product_name/product_id +``` + +*Example 93 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + } +``` + +> `CSAFPID-9080700` was defined but never used. + +> A tool MAY remove the unused definition as quick fix. However, such quick fix shall not be applied if the test was skipped. + +### 6.2.2 Missing Remediation + +For each Product ID (type `/$defs/product_id_t`) in the Product Status groups Affected and Under investigation it MUST be tested that a remediation exists. + +> The remediation might be of the category `none_available` or `no_fix_planned`. + +The relevant paths for this test are: + +``` + /vulnerabilities[]/product_status/first_affected[] + /vulnerabilities[]/product_status/known_affected[] + /vulnerabilities[]/product_status/last_affected[] + /vulnerabilities[]/product_status/under_investigation[] +``` + +*Example 94 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "last_affected": [ + "CSAFPID-9080700" + ] + } + } + ] +``` + +> `CSAFPID-9080700` has in Product Status `last_affected` but there is no remediation object for this Product ID. + +### 6.2.3 Missing Score + +For each Product ID (type `/$defs/product_id_t`) in the Product Status groups Affected it MUST be tested that a score object exists which covers this product. + +The relevant paths for this test are: + +``` + /vulnerabilities[]/product_status/first_affected[] + /vulnerabilities[]/product_status/known_affected[] + /vulnerabilities[]/product_status/last_affected[] +``` + +*Example 95 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "first_affected": [ + "CSAFPID-9080700" + ] + } + } + ] +``` + +> `CSAFPID-9080700` has in Product Status `first_affected` but there is no score object which covers this Product ID. + +### 6.2.4 Build Metadata in Revision History + +For each item in revision history it MUST be tested that `number` does not include build metadata. + +The relevant path for this test is: + +``` + /document/tracking/revision_history[]/number +``` + +*Example 96 which fails the test:* + +``` + "revision_history": [ + { + "date": "2021-04-23T10:00:00.000Z", + "number": "1.0.0+exp.sha.ac00785", + "summary": "Initial version." + } + ] +``` + +> The revision history contains an item which has a `number` that includes the build metadata `+exp.sha.ac00785`. + +### 6.2.5 Older Initial Release Date than Revision History + +It MUST be tested that the Initial Release Date is not older than the `date` of the oldest item in Revision History. + +The relevant path for this test is: + +``` + /document/tracking/initial_release_date +``` + +*Example 97 which fails the test:* + +``` + "tracking": { + // ... + "initial_release_date": "2021-04-22T10:00:00.000Z", + "revision_history": [ + { + "date": "2021-05-06T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T11:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + // ... + } +``` + +> The initial release date `2021-04-22T10:00:00.000Z` is older than `2021-05-06T10:00:00.000Z` which is the `date` of the oldest item in Revision History. + +### 6.2.6 Older Current Release Date than Revision History + +It MUST be tested that the Current Release Date is not older than the `date` of the newest item in Revision History. + +The relevant path for this test is: + +``` + /document/tracking/current_release_date +``` + +*Example 98 which fails the test:* + +``` + "tracking": { + "current_release_date": "2021-05-06T10:00:00.000Z", + // ... + "revision_history": [ + { + "date": "2021-05-06T10:00:00.000Z", + "number": "1", + "summary": "Initial version." + }, + { + "date": "2021-07-21T11:00:00.000Z", + "number": "2", + "summary": "Second version." + } + ], + // ... + } +``` + +> The current release date `2021-05-06T10:00:00.000Z` is older than `2021-05-23T1100:00.000Z` which is the `date` of the newest item in Revision History. + +### 6.2.7 Missing Date in Involvements + +For each item in the list of involvements it MUST be tested that it includes the property `date`. + +The relevant path for this test is: + +``` + /vulnerabilities[]/involvements +``` + +*Example 99 which fails the test:* + +``` + "vulnerabilities": [ + { + "involvements": [ + { + "party": "vendor", + "status": "in_progress" + } + ] + } + ] +``` + +> The list of involvements contains an item which does not contain the property `date`. + +### 6.2.8 Use of MD5 as the only Hash Algorithm + +It MUST be tested that the hash algorithm `md5` is not the only one present. + +> Since collision attacks exist for MD5 such value should be accompanied by a second cryptographically stronger hash. This will allow users to double check the results. + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/product/product_identification_helper/hashes[]/file_hashes + /product_tree/full_product_names[]/product_identification_helper/hashes[]/file_hashes + /product_tree/relationships[]/full_product_name/product_identification_helper/hashes[]/file_hashes +``` + +*Example 100 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "hashes": [ + { + "file_hashes": [ + { + "algorithm": "md5", + "value": "6ae24620ea9656230f49234efd078935" + } + ], + "filename": "product_a.so" + } + ] + } + } + ] + } +``` + +> The hash algorithm `md5` is used in one item of hashes without being accompanied by a second hash algorithm. + +### 6.2.9 Use of SHA-1 as the only Hash Algorithm + +It MUST be tested that the hash algorithm `sha1` is not the only one present. + +> Since collision attacks exist for SHA-1 such value should be accompanied by a second cryptographically stronger hash. This will allow users to double check the results. + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/product/product_identification_helper/hashes[]/file_hashes + /product_tree/full_product_names[]/product_identification_helper/hashes[]/file_hashes + /product_tree/relationships[]/full_product_name/product_identification_helper/hashes[]/file_hashes +``` + +*Example 101 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "hashes": [ + { + "file_hashes": [ + { + "algorithm": "sha1", + "value": "e067035314dd8673fe1c9fc6b01414fe0950fdc4" + } + ], + "filename": "product_a.so" + } + ] + } + } + ] + } +``` + +> The hash algorithm `sha1` is used in one item of hashes without being accompanied by a second hash algorithm. + +### 6.2.10 Missing TLP label + +It MUST be tested that `/document/distribution/tlp/label` is present and valid. + +> TLP labels support the machine-readability and automated distribution. + +The relevant path for this test is: + +``` + /document/distribution/tlp/label +``` + +*Example 102 which fails the test:* + +``` + "distribution": { + "text": "Distribute freely." + } +``` + +> The CSAF document has no TLP label. + +### 6.2.11 Missing Canonical URL + +It MUST be tested that the CSAF document has a canonical URL. + +> To implement this test it is deemed sufficient that one item in `/document/references` fulfills all of the following: +> +> * It has the category `self`. +> * The `url` starts with `https://`. +> * The `url` ends with the valid filename for the CSAF document according to the rules in section 5.1. + +The relevant path for this test is: + +``` + /document/references +``` + +*Example 103 which fails the test:* + +``` + "document": { + // ... + "references": [ + { + "category": "self", + "summary": "A non-canonical URL.", + "url": "https://example.com/security/data/csaf/2021/OASIS_CSAF_TC-CSAF_2.0-2021-6-2-11-01_1.json" + } + ], + // ... + "tracking": { + // ... + "id": "OASIS_CSAF_TC-CSAF_2.0-2021-6-2-11-01", + // ... + "version": "1" + }, + // ... + } +``` + +> The only element where the `category` is `self` has a URL that does not fulfill the requirement of a valid filename for a CSAF document. + +### 6.2.12 Missing Document Language + +It MUST be tested that the document language is present and set. + +The relevant path for this test is: + +``` + /document/lang +``` + +*Example 104 which fails the test:* + +``` + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "publisher": { + // ... + }, + // ... + } +``` + +> The document language is not defined. + +### 6.2.13 Sorting + +It MUST be tested that all keys in a CSAF document are sorted alphabetically. + +The relevant path for this test is: + +``` + / +``` + +*Example 105 which fails the test:* + +``` + "document": { + "csaf_version": "2.0", + "category": "csaf_base", + // ... + } +``` + +> The key `csaf_version` is not at the right place. + +> A tool MAY sort the keys as a quick fix. + +### 6.2.14 Use of Private Language + +For each element of type `/$defs/language_t` it MUST be tested that the language code does not contain subtags reserved for private use. + +The relevant paths for this test are: + +``` + /document/lang + /document/source_lang +``` + +*Example 106 which fails the test:* + +``` + "lang": "qtx" +``` + +> The language code `qtx` is reserved for private use. + +> A tool MAY remove such subtag as a quick fix. + +### 6.2.15 Use of Default Language + +For each element of type `/$defs/language_t` it MUST be tested that the language code is not `i-default`. + +The relevant paths for this test are: + +``` + /document/lang + /document/source_lang +``` + +*Example 107 which fails the test:* + +``` + "lang": "i-default" +``` + +> The language code `i-default` is used. + +> A tool MAY remove such element as a quick fix. + +### 6.2.16 Missing Product Identification Helper + +For each element of type `/$defs/full_product_name_t` it MUST be tested that it includes the property `product_identification_helper`. + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/product + /product_tree/full_product_names[] + /product_tree/relationships[]/full_product_name +``` + +*Example 108 which fails the test:* + +``` + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] +``` + +> The product `CSAFPID-9080700` does not provide any Product Identification Helper at all. + +### 6.2.17 CVE in field IDs + +For each item in `/vulnerabilities[]/ids` it MUST be tested that it is not a CVE ID. + +> It is sufficient to check, whether the property `text` matches the regex `^CVE-[0-9]{4}-[0-9]{4,}$`. + +The relevant paths for this test are: + +``` + /vulnerabilities[]/ids[] +``` + +*Example 109 which fails the test:* + +``` + "ids": [ + { + "system_name": "CVE Project", + "text": "CVE-2021-44228" + } + ] +``` + +> The `CVE-2021-44228` is listed in an item of the `ids` array instead under `cve`. + +> A tool MAY set such element as value for the `cve` property as a quick fix, if that didn't exist before. Alternatively, it MAY remove such element as a quick fix. + +### 6.2.18 Product Version Range without vers + +For each element of type `/$defs/branches_t` with `category` of `product_version_range` it MUST be tested that the value of `name` conforms the vers specification. + +> To implement this test it is deemed sufficient that the value of `name` matches the following regex: +> +> ``` +> ^vers:[a-z\\.\\-\\+][a-z0-9\\.\\-\\+]*/.+ +> ``` + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/name +``` + +*Example 110 which fails the test:* + +``` + "branches": [ + { + "category": "product_version_range", + "name": ">4.2", + // ... + } + ] +``` + +> The version range `>4.2` is a valid vsl but not valid according to the vers specification. + +### 6.2.19 CVSS for Fixed Products + +For each item the fixed products group (`first_fixed` and `fixed`) it MUST be tested that a CVSS applying to this product has an environmental score of `0`. The test SHALL pass if none of the Product IDs listed within product status `fixed` or `first_fixed` is found in `products` of any item of the `scores` element. + +The relevant path for this test is: + +``` + /vulnerabilities[]/product_status/first_fixed[] + /vulnerabilities[]/product_status/fixed[] +``` + +*Example 111 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "product_status": { + "fixed": [ + "CSAFPID-9080700" + ] + }, + "scores": [ + { + "cvss_v3": { + "baseScore": 6.5, + "baseSeverity": "MEDIUM", + "vectorString": "CVSS:3.1/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "version": "3.1" + }, + "products": [ + "CSAFPID-9080700" + ] + } + ] + } + ] +``` + +> Neither the `environmentalScore` nor the properties `modifiedIntegrityImpact`, `modifiedAvailabilityImpact`, `modifiedConfidentialityImpact` nor the corresponding attributes in the `vectorString` have been set. + +> A tool MAY set the properties `modifiedIntegrityImpact`, `modifiedAvailabilityImpact`, `modifiedConfidentialityImpact` accordingly and compute the `environmentalScore` as quick fix. + +### 6.2.20 Additional Properties + +It MUST be tested that there is no additional property in the CSAF document that was not defined in the CSAF JSON schema. + +The relevant path for this test is: + +``` + / +``` + +> To implement this test it is deemed sufficient to validate the CSAF document against a "strict" version schema that sets `additionalProperties` to `false` for every key of type `object`. + +*Example 112 which fails the test:* + +``` + "document": { + "category": "csaf_base", + "csaf_version": "2.0", + "custom_property": "any", + // ... + } +``` + +> The key `custom_property` is not defined in the JSON schema. + +> A tool MAY remove such keys as a quick fix. + diff --git a/csaf_2.1/prose/edit/src/tests-03-informative.md b/csaf_2.1/prose/edit/src/tests-03-informative.md new file mode 100644 index 000000000..c8d97e58e --- /dev/null +++ b/csaf_2.1/prose/edit/src/tests-03-informative.md @@ -0,0 +1,394 @@ +## 6.3 Informative Test + +Informative tests provide insights in common mistakes and bad practices. They MAY fail at a valid CSAF document. It is up to the issuing party to decide whether this was an intended behavior and can be ignore or should be treated. These tests MAY include information about recommended usage. A program MUST handle a test failure as a information. + +### 6.3.1 Use of CVSS v2 as the only Scoring System + +For each item in the list of scores which contains the `cvss_v2` object it MUST be tested that is not the only scoring item present. The test SHALL pass if a second scoring object is available. + +The relevant path for this test is: + +``` + /vulnerabilities[]/scores +``` + +*Example 113 which fails the test:* + +``` + "product_tree": { + "full_product_names": [ + { + "product_id": "CSAFPID-9080700", + "name": "Product A" + } + ] + }, + "vulnerabilities": [ + { + "scores": [ + { + "products": [ + "CSAFPID-9080700" + ], + "cvss_v2": { + "version": "2.0", + "vectorString": "AV:N/AC:L/Au:N/C:C/I:C/A:C", + "baseScore": 10 + } + } + ] + } + ] +``` + +> There is only a CVSS v2 score given for `CSAFPID-9080700`. + +Recommendation: + +It is recommended to (also) use the CVSS v3.1. + +### 6.3.2 Use of CVSS v3.0 + +For each item in the list of scores which contains the `cvss_v3` object it MUST be tested that CVSS v3.0 is not used. + +The relevant paths for this test are: + +``` + /vulnerabilities[]/scores[]/cvss_v3/version + /vulnerabilities[]/scores[]/cvss_v3/vectorString +``` + +*Example 114 which fails the test:* + +``` + "cvss_v3": { + "version": "3.0", + "vectorString": "CVSS:3.0/AV:L/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:H", + "baseScore": 6.5, + "baseSeverity": "MEDIUM" + } +``` + +> The CVSS v3.0 is used. + +Recommendation: + +It is recommended to upgrade to CVSS v3.1. + +> A tool MAY upgrade to CVSS v3.1 as quick fix. However, if such quick fix is supported the tool SHALL also recompute the `baseScore` and `baseSeverity`. The same applies for `temporalScore` and `temporalSeverity` respectively `environmentalScore` and `environmentalSeverity` if the necessary fields for computing their value are present and set. + +### 6.3.3 Missing CVE + +It MUST be tested that the CVE number is given. + +The relevant path for this test is: + +``` + /vulnerabilities[]/cve +``` + +*Example 115 which fails the test:* + +``` + "vulnerabilities": [ + { + "title": "BlueKeep" + } + ] +``` + +> The CVE number is not given. + +Recommendation: + +It is recommended to provide a CVE number to support the users efforts to find more details about a vulnerability and potentially track it through multiple advisories. If no CVE exists for that vulnerability, it is recommended to get one assigned. + +### 6.3.4 Missing CWE + +It MUST be tested that the CWE is given. + +The relevant path for this test is: + +``` + /vulnerabilities[]/cwe +``` + +*Example 116 which fails the test:* + +``` + "vulnerabilities": [ + { + "cve": "CVE-2019-0708", + "title": "BlueKeep" + } + ] +``` + +> The CWE number is not given. + +### 6.3.5 Use of Short Hash + +It MUST be tested that the length of the hash value is not shorter than 64 characters. + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/product/product_identification_helper/hashes[]/file_hashes[]/value + /product_tree/full_product_names[]/product_identification_helper/hashes[]/file_hashes[]/value + /product_tree/relationships[]/full_product_name/product_identification_helper/hashes[]/file_hashes[]/value +``` + +*Example 117 which fails the test*: + +``` + "product_tree": { + "full_product_names": [ + { + "name": "Product A", + "product_id": "CSAFPID-9080700", + "product_identification_helper": { + "hashes": [ + { + "file_hashes": [ + { + "algorithm": "md4", + "value": "3202b50e2e5b2fcd75e284c3d9d5f8d6" + } + ], + "filename": "product_a.so" + } + ] + } + } + ] + } +``` + +> The length of the hash value is only 32 characters long. + +### 6.3.6 Use of non-self referencing URLs Failing to Resolve + +For each URL which is not in the category `self` it MUST be tested that it resolves with a HTTP status code from the 2xx (Successful) or 3xx (Redirection) class. + +> This test does not apply for any item in an array of type `references_t` with the category `self`. For details about the HTTP status code classes see [RFC7231]. + +The relevant paths for this test are: + +``` + /document/acknowledgments[]/urls[] + /document/aggregate_severity/namespace + /document/distribution/tlp/url + /document/references[]/url + /document/publisher/namespace + /product_tree/branches[]/product/product_identification_helper/sbom_urls[] + /product_tree/branches[]/product/product_identification_helper/x_generic_uris[]/namespace + /product_tree/branches[]/product/product_identification_helper/x_generic_uris[]/uri + /product_tree/branches[](/branches[])*/product/product_identification_helper/sbom_urls[] + /product_tree/branches[](/branches[])*/product/product_identification_helper/x_generic_uris[]/namespace + /product_tree/branches[](/branches[])*/product/product_identification_helper/x_generic_uris[]/uri + /product_tree/full_product_names[]/product_identification_helper/sbom_urls[] + /product_tree/full_product_names[]/product_identification_helper/x_generic_uris[]/namespace + /product_tree/full_product_names[]/product_identification_helper/x_generic_uris[]/uri + /product_tree/relationships[]/full_product_name/product_identification_helper/sbom_urls[] + /product_tree/relationships[]/full_product_name/product_identification_helper/x_generic_uris[]/namespace + /product_tree/relationships[]/full_product_name/product_identification_helper/x_generic_uris[]/uri + /vulnerabilities[]/acknowledgments[]/urls[] + /vulnerabilities[]/references[]/url + /vulnerabilities[]/remediations[]/url +``` + +*Example 118 which fails the test:* + +``` + "references": [ + { + "summary": "A URL that does not resolve with HTTP status code in the interval between (including) 200 and (excluding) 400.", + "url": "https://example.invalid" + } + ] +``` + +> The `category` is not set and therefore treated as its default value `external`. A request to that URL does not resolve with a status code from the 2xx (Successful) or 3xx (Redirection) class. + +### 6.3.7 Use of self referencing URLs Failing to Resolve + +For each item in an array of type `references_t` with the category `self` it MUST be tested that the URL referenced resolves with a HTTP status code less than 400. + +> This test will most likely fail if the CSAF document is in a status before the initial release. For details about the HTTP status code classes see [RFC7231]. + +The relevant paths for this test are: + +``` + /document/references[]/url + /vulnerabilities[]/references[]/url +``` + +*Example 119 which fails the test:* + +``` + "references": [ + { + "category": "self", + "summary": "A URL that does not resolve with HTTP status code in the interval between (including) 200 and (excluding) 400.", + "url": "https://example.invalid" + } + ] +``` + +> The `category` is `self` and a request to that URL does not resolve with a status code from the 2xx (Successful) or 3xx (Redirection) class. + +### 6.3.8 Spell check + +If the document language is given it MUST be tested that a spell check for the given language does not find any mistakes. The test SHALL be skipped if not document language is set. It SHALL fail it the given language is not supported. The value of `/document/category` SHOULD NOT be tested if the CSAF document does not use the profile "CSAF Base". + +The relevant paths for this test are: + +``` + /document/acknowledgments[]/names[] + /document/acknowledgments[]/organization + /document/acknowledgments[]/summary + /document/aggregate_severity/text + /document/category + /document/distribution/text + /document/notes[]/audience + /document/notes[]/text + /document/notes[]/title + /document/publisher/issuing_authority + /document/publisher/name + /document/references[]/summary + /document/title + /document/tracking/aliases[] + /document/tracking/generator/engine/name + /document/tracking/revision_history[]/summary + /product_tree/branches[](/branches[])*/name + /product_tree/branches[](/branches[])*/product/name + /product_tree/branches[]/name + /product_tree/branches[]/product/name + /product_tree/full_product_names[]/name + /product_tree/product_groups[]/summary + /product_tree/relationships[]/full_product_name/name + /vulnerabilities[]/acknowledgments[]/names[] + /vulnerabilities[]/acknowledgments[]/organization + /vulnerabilities[]/acknowledgments[]/summary + /vulnerabilities[]/involvements[]/summary + /vulnerabilities[]/notes[]/audience + /vulnerabilities[]/notes[]/text + /vulnerabilities[]/notes[]/title + /vulnerabilities[]/references[]/summary + /vulnerabilities[]/remediations[]/details + /vulnerabilities[]/remediations[]/entitlements[] + /vulnerabilities[]/remediations[]/restart_required/details + /vulnerabilities[]/threats[]/details + /vulnerabilities[]/title +``` + +*Example 120 which fails the test:* + +``` + "document": { + // ... + "lang": "en", + "notes": [ + { + "category": "summary", + "text": "Secruity researchers found multiple vulnerabilities in XYZ." + } + ], + // ... + } +``` + +> There is a spelling mistake in `Secruity`. + +### 6.3.9 Branch Categories + +For each element of type `/$defs/full_product_name_t` in `/product_tree/branches` it MUST be tested that ancestor nodes along the path exist which use the following branch categories `vendor` -> `product_name` -> `product_version` in that order starting with the Product tree node. + +> Other branch categories can be used before, after or between the aforementioned branch categories without making the test invalid. + +The relevant paths for this test are: + +``` + /product_tree/branches +``` + +*Example 121 which fails the test:* + +``` + "branches": [ + { + "category": "vendor", + "name": "Example Company", + "branches": [ + { + "category": "product_name", + "name": "Product A", + "branches": [ + { + "category": "patch_level", + "name": "91", + "product": { + "product_id": "CSAFPID-0002", + "name": "Example Company Product A Update 91" + } + } + ] + } + ] + } + ] +``` + +> The product `CSAFPID-9080700` does not have any ancestor with the branch category `product_version`. + +### 6.3.10 Usage of Product Version Range + +For each element of type `/$defs/branches_t` it MUST be tested that the `category` is not `product_version_range`. + +> It is usually hard decide for machines whether a product version matches a product version ranges. Therefore, it is recommended to avoid version ranges and enumerate versions wherever possible. + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/category +``` + +*Example 122 which fails the test:* + +``` + "category": "product_version_range", +``` + +> The category `product_version_range` was used. + +### 6.3.11 Usage of V as Version Indicator + +For each element of type `/$defs/branches_t` with `category` of `product_version` it MUST be tested that the value of `name` does not start with `v` or `V` before the version. + +> To implement this test it is deemed sufficient that the value of `name` does not match the following regex: +> +> ``` +> ^[vV][0-9].*$ +> ``` + +The relevant paths for this test are: + +``` + /product_tree/branches[](/branches[])*/name +``` + +*Example 123 which fails the test:* + +``` + "branches": [ + { + "category": "product_version", + "name": "v4.2", + // ... + } + ] +``` + +> The product version starts with a `v`. + +------- From affebaa7768ba3b786a0c30e6007a4adf7e26ff1 Mon Sep 17 00:00:00 2001 From: Stefan Hagen Date: Mon, 14 Aug 2023 07:37:46 +0200 Subject: [PATCH 07/74] refactor: table hygiene, split of terminology section, definition lists, and unspacing - further split of introduction - terminology to obtain a homogeneous definition list file for the glossary part of that section (binder has been updated) - removal of doubled blank lines at the end of segregated source files - the tables in acknowledgements and revision history sections have been fixed to adhere to GFM format and have global per table column widths (both in segregated source files as in the elephant (user facing delivery item in GFM+gh_cosmetics format) - glossary as well as normative and informative references in source are now plain definition lists with URLs correctly wrapped into angle brackets. - no regression tests performed as any regressions can be detected and fixed later, when the transformers (generators for the user facing delivery items) are present and can execute. Signed-off-by: Stefan Hagen --- csaf_2.1/prose/csaf-v2.1-editor-draft.md | 230 ++++++++-------- csaf_2.1/prose/edit/etc/bind.txt | 1 + csaf_2.1/prose/edit/src/acknowledgements.md | 225 ++++++++-------- .../prose/edit/src/additional-conventions.md | 1 - .../edit/src/design-considerations-00.md | 1 - ...nsiderations-01-construction-principles.md | 1 - csaf_2.1/prose/edit/src/introduction-00.md | 1 - .../edit/src/introduction-01-ipr-policy.md | 1 - .../introduction-02-terminology-glossary.md | 252 ++++++++++++++++++ .../edit/src/introduction-02-terminology.md | 147 ---------- .../introduction-03-normative-references.md | 38 +-- .../introduction-04-informative-references.md | 200 ++++++++------ ...troduction-05-typographical-conventions.md | 1 - csaf_2.1/prose/edit/src/revision-history.md | 7 +- csaf_2.1/prose/edit/src/schema-elements-00.md | 1 - .../src/schema-elements-01-definitions.md | 1 - csaf_2.1/prose/edit/src/table-of-contents.md | 1 - csaf_2.1/prose/edit/src/tests-00.md | 1 - csaf_2.1/prose/edit/src/tests-01-mandatory.md | 1 - csaf_2.1/prose/edit/src/tests-02-optional.md | 1 - 20 files changed, 623 insertions(+), 489 deletions(-) create mode 100644 csaf_2.1/prose/edit/src/introduction-02-terminology-glossary.md diff --git a/csaf_2.1/prose/csaf-v2.1-editor-draft.md b/csaf_2.1/prose/csaf-v2.1-editor-draft.md index 3eda7a4f8..f41656ab4 100644 --- a/csaf_2.1/prose/csaf-v2.1-editor-draft.md +++ b/csaf_2.1/prose/csaf-v2.1-editor-draft.md @@ -6689,123 +6689,123 @@ The following individuals were members of the OASIS CSAF Technical Committee dur **CSAF TC Members:** -| First Name | Last Name | Company | -| :--- | :--- | :--- | -|Alexandre | Dulaunoy | CIRCL| -|Anthony | Berglas | Cryptsoft Pty Ltd.| -|Art | Manion | Carnegie Mellon University| -|Aukjan | van Belkum | EclecticIQ| -|Ben | Sooter | Electric Power Research Institute (EPRI)| -|Bernd | Grobauer | Siemens AG| -|Bruce | Rich | Cryptsoft Pty Ltd.| -|Chok | Poh | Oracle| -|Dan | West | Microsoft| -|David | Waltermire | NIST| -|Denny | Page | TIBCO Software Inc.| -|Duncan | Sparrell | sFractal Consulting LLC| -|Eric | Johnson | TIBCO Software Inc.| -|Ethan | Rahn | Arista Networks| -|Feng | Cao | Oracle| -|Greg | Scott | Cryptsoft Pty Ltd.| -|Harold | Booth | NIST| -|Jason | Masters | TELUS| -|Jennifer | Victor | Dell| -|Jessica | Fitzgerald-McKay | National Security Agency| -|Jonathan | Bitle | Kaiser Permanente| -|Justin | Corlett | Cryptsoft Pty Ltd.| -|Kazuo | Noguchi | Hitachi, Ltd.| -|Kent | Landfield | McAfee| -|Langley | Rock | Red Hat| -|Martin | Prpic | Red Hat| -|Masato | Terada | Hitachi, Ltd.| -|Mike | Gorski | Cisco Systems| -|Nicole | Parrish | Mitre Corporation| -|Omar | Santos | Cisco Systems| -|Patrick | Maroney | AT&T| -|Rhonda | Levy | Cisco Systems| -|Richard | Struse | Mitre Corporation| -|Ritwik | Ghoshal | Oracle| -|Robert | Coderre | Accenture| -|Robert | Keith | Accenture| -|Stefan | Hagen | Individual| -|Tania | Ward | Dell| -|Ted | Bedwell | Cisco Systems| -|Thomas | Proell | Siemens AG| -|Thomas | Schmidt | Federal Office for Information Security (BSI) Germany| -|Tim | Hudson | Cryptsoft Pty Ltd.| -|Tobias | Limmer | Siemens AG| -|Tony | Cox | Cryptsoft Pty Ltd.| -|Vincent | Danen | Red Hat| -|Will | Rideout | Arista Networks| -|Xiaoyu | Ge | Huawei Technologies Co., Ltd.| +| First Name | Last Name | Company | +|:-----------|:-----------------|:------------------------------------------------------| +| Alexandre | Dulaunoy | CIRCL | +| Anthony | Berglas | Cryptsoft Pty Ltd. | +| Art | Manion | Carnegie Mellon University | +| Aukjan | van Belkum | EclecticIQ | +| Ben | Sooter | Electric Power Research Institute (EPRI) | +| Bernd | Grobauer | Siemens AG | +| Bruce | Rich | Cryptsoft Pty Ltd. | +| Chok | Poh | Oracle | +| Dan | West | Microsoft | +| David | Waltermire | NIST | +| Denny | Page | TIBCO Software Inc. | +| Duncan | Sparrell | sFractal Consulting LLC | +| Eric | Johnson | TIBCO Software Inc. | +| Ethan | Rahn | Arista Networks | +| Feng | Cao | Oracle | +| Greg | Scott | Cryptsoft Pty Ltd. | +| Harold | Booth | NIST | +| Jason | Masters | TELUS | +| Jennifer | Victor | Dell | +| Jessica | Fitzgerald-McKay | National Security Agency | +| Jonathan | Bitle | Kaiser Permanente | +| Justin | Corlett | Cryptsoft Pty Ltd. | +| Kazuo | Noguchi | Hitachi, Ltd. | +| Kent | Landfield | McAfee | +| Langley | Rock | Red Hat | +| Martin | Prpic | Red Hat | +| Masato | Terada | Hitachi, Ltd. | +| Mike | Gorski | Cisco Systems | +| Nicole | Parrish | Mitre Corporation | +| Omar | Santos | Cisco Systems | +| Patrick | Maroney | AT&T | +| Rhonda | Levy | Cisco Systems | +| Richard | Struse | Mitre Corporation | +| Ritwik | Ghoshal | Oracle | +| Robert | Coderre | Accenture | +| Robert | Keith | Accenture | +| Stefan | Hagen | Individual | +| Tania | Ward | Dell | +| Ted | Bedwell | Cisco Systems | +| Thomas | Proell | Siemens AG | +| Thomas | Schmidt | Federal Office for Information Security (BSI) Germany | +| Tim | Hudson | Cryptsoft Pty Ltd. | +| Tobias | Limmer | Siemens AG | +| Tony | Cox | Cryptsoft Pty Ltd. | +| Vincent | Danen | Red Hat | +| Will | Rideout | Arista Networks | +| Xiaoyu | Ge | Huawei Technologies Co., Ltd. | The following individuals were members of the OASIS CSAF Technical Committee during the creation of the previous version (CVRF v1.2) of this specification and their contributions are gratefully acknowledged: **CSAF TC Members:** -| First Name | Last Name | Company | -| :--- | :--- | :--- | -|Adam | Montville | CIS| -|Allan | Thomson | LookingGlass| -|Anthony | Berglas | Cryptsoft Pty Ltd.| -|Art | Manion | Carnegie Mellon University| -|Aukjan | van Belkum | EclecticIQ| -|Ben | Sooter | Electric Power Research Institute| -|Bernd | Grobauer | Siemens AG| -|Beth | Pumo | Kaiser Permanente| -|Bret | Jordan | Symantec Corp.| -|Bruce | Rich | Cryptsoft Pty Ltd.| -|Chet | Ensign | OASIS| -|Chok | Poh | Oracle| -|Chris | Rouland | Individual| -|David | Waltermire | NIST| -|Denny | Page | TIBCO Software Inc.| -|Doron | Shiloach | IBM| -|Duncan | Sparrell | sFractal Consulting LLC| -|Eric | Johnson | TIBCO Software Inc.| -|Feng | Cao | Oracle| -|Greg | Reaume | TELUS| -|Greg | Scott | Cryptsoft Pty Ltd.| -|Harold | Booth | NIST| -|Jamison | Day | LookingGlass| -|Jared | Semrau | "FireEye, Inc."| -|Jason | Masters | TELUS| -|Jerome | Athias | Individual| -|Jessica | Fitzgerald-McKay | National Security Agency| -|Jonathan | Bitle | Kaiser Permanente| -|Justin | Corlett | Cryptsoft Pty Ltd.| -|Karen | Scarfone | Individual| -|Kazuo | Noguchi | "Hitachi, Ltd."| -|Kent | Landfield | McAfee| -|Lothar | Braun | Siemens AG| -|Louis | Ronnau | Cisco Systems| -|Mark | Davidson | NC4| -|Mark-David | McLaughlin | Cisco Systems| -|Masato | Terada | "Hitachi, Ltd."| -|Masood | Nasir | TELUS| -|Nicole | Gong | Mitre Corporation| -|Omar | Santos | Cisco Systems| -|Patrick | Maroney | Wapack Labs LLC| -|Paul | Patrick | "FireEye, Inc."| -|Peter | Allor | IBM| -|Phillip | Boles | "FireEye, Inc."| -|Ravi | Balupari | Netskope| -|Rich | Reybok | ServiceNow| -|Richard | Struse | DHS Office of Cybersecurity and Communications (CS&C)| -|Ritwik | Ghoshal | Oracle| -|Robert | Coderre | VeriSign| -|Robin | Cover | OASIS| -|Rupert | Wimmer | Siemens AG| -|Sanjiv | Kalkar | Individual| -|Sean | Barnum | Mitre Corporation| -|Stefan | Hagen | Individual| -|Ted | Bedwell | Cisco Systems| -|Thomas | Schreck | Siemens AG| -|Tim | Hudson | Cryptsoft Pty Ltd.| -|Tony | Cox | Cryptsoft Pty Ltd.| -|Trey | Darley | "Kingfisher Operations, sprl"| -|Vincent | Danen | Red Hat| -|Zach | Turk | Microsoft| +| First Name | Last Name | Company | +|:-----------|:-----------------|:------------------------------------------------------| +| Adam | Montville | CIS | +| Allan | Thomson | LookingGlass | +| Anthony | Berglas | Cryptsoft Pty Ltd. | +| Art | Manion | Carnegie Mellon University | +| Aukjan | van Belkum | EclecticIQ | +| Ben | Sooter | Electric Power Research Institute | +| Bernd | Grobauer | Siemens AG | +| Beth | Pumo | Kaiser Permanente | +| Bret | Jordan | Symantec Corp. | +| Bruce | Rich | Cryptsoft Pty Ltd. | +| Chet | Ensign | OASIS | +| Chok | Poh | Oracle | +| Chris | Rouland | Individual | +| David | Waltermire | NIST | +| Denny | Page | TIBCO Software Inc. | +| Doron | Shiloach | IBM | +| Duncan | Sparrell | sFractal Consulting LLC | +| Eric | Johnson | TIBCO Software Inc. | +| Feng | Cao | Oracle | +| Greg | Reaume | TELUS | +| Greg | Scott | Cryptsoft Pty Ltd. | +| Harold | Booth | NIST | +| Jamison | Day | LookingGlass | +| Jared | Semrau | "FireEye, Inc." | +| Jason | Masters | TELUS | +| Jerome | Athias | Individual | +| Jessica | Fitzgerald-McKay | National Security Agency | +| Jonathan | Bitle | Kaiser Permanente | +| Justin | Corlett | Cryptsoft Pty Ltd. | +| Karen | Scarfone | Individual | +| Kazuo | Noguchi | "Hitachi, Ltd." | +| Kent | Landfield | McAfee | +| Lothar | Braun | Siemens AG | +| Louis | Ronnau | Cisco Systems | +| Mark | Davidson | NC4 | +| Mark-David | McLaughlin | Cisco Systems | +| Masato | Terada | "Hitachi, Ltd." | +| Masood | Nasir | TELUS | +| Nicole | Gong | Mitre Corporation | +| Omar | Santos | Cisco Systems | +| Patrick | Maroney | Wapack Labs LLC | +| Paul | Patrick | "FireEye, Inc." | +| Peter | Allor | IBM | +| Phillip | Boles | "FireEye, Inc." | +| Ravi | Balupari | Netskope | +| Rich | Reybok | ServiceNow | +| Richard | Struse | DHS Office of Cybersecurity and Communications (CS&C) | +| Ritwik | Ghoshal | Oracle | +| Robert | Coderre | VeriSign | +| Robin | Cover | OASIS | +| Rupert | Wimmer | Siemens AG | +| Sanjiv | Kalkar | Individual | +| Sean | Barnum | Mitre Corporation | +| Stefan | Hagen | Individual | +| Ted | Bedwell | Cisco Systems | +| Thomas | Schreck | Siemens AG | +| Tim | Hudson | Cryptsoft Pty Ltd. | +| Tony | Cox | Cryptsoft Pty Ltd. | +| Trey | Darley | "Kingfisher Operations, sprl" | +| Vincent | Danen | Red Hat | +| Zach | Turk | Microsoft | ------- @@ -6815,9 +6815,9 @@ The following individuals were members of the OASIS CSAF Technical Committee dur |:-------------------------|:-----------|:--------------------------------|:--------------------------------------------------------------------------------------| | csaf-v2.0-wd20210927-dev | 2021-09-27 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS for public review | | csaf-v2.0-wd20220329-dev | 2022-03-29 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CSD02 for public review | -| csaf-v2.0-wd20220514-dev | 2022-05-14 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | -| csaf-v2.0-wd20220715-dev | 2022-07-15 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | -| csaf-v2.0-wd20220720-dev | 2022-07-20 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | +| csaf-v2.0-wd20220514-dev | 2022-05-14 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | +| csaf-v2.0-wd20220715-dev | 2022-07-15 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | +| csaf-v2.0-wd20220720-dev | 2022-07-20 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | ------- diff --git a/csaf_2.1/prose/edit/etc/bind.txt b/csaf_2.1/prose/edit/etc/bind.txt index 95452d559..4a3cd769a 100644 --- a/csaf_2.1/prose/edit/etc/bind.txt +++ b/csaf_2.1/prose/edit/etc/bind.txt @@ -3,6 +3,7 @@ table-of-contents.md introduction-00.md introduction-01-ipr-policy.md introduction-02-terminology.md +introduction-02-terminology-glossary.md introduction-03-normative-references.md introduction-04-informative-references.md introduction-05-typographical-conventions.md diff --git a/csaf_2.1/prose/edit/src/acknowledgements.md b/csaf_2.1/prose/edit/src/acknowledgements.md index b757e73da..97c4abbc4 100644 --- a/csaf_2.1/prose/edit/src/acknowledgements.md +++ b/csaf_2.1/prose/edit/src/acknowledgements.md @@ -12,123 +12,122 @@ The following individuals were members of the OASIS CSAF Technical Committee dur **CSAF TC Members:** -| First Name | Last Name | Company | -| :--- | :--- | :--- | -|Alexandre | Dulaunoy | CIRCL| -|Anthony | Berglas | Cryptsoft Pty Ltd.| -|Art | Manion | Carnegie Mellon University| -|Aukjan | van Belkum | EclecticIQ| -|Ben | Sooter | Electric Power Research Institute (EPRI)| -|Bernd | Grobauer | Siemens AG| -|Bruce | Rich | Cryptsoft Pty Ltd.| -|Chok | Poh | Oracle| -|Dan | West | Microsoft| -|David | Waltermire | NIST| -|Denny | Page | TIBCO Software Inc.| -|Duncan | Sparrell | sFractal Consulting LLC| -|Eric | Johnson | TIBCO Software Inc.| -|Ethan | Rahn | Arista Networks| -|Feng | Cao | Oracle| -|Greg | Scott | Cryptsoft Pty Ltd.| -|Harold | Booth | NIST| -|Jason | Masters | TELUS| -|Jennifer | Victor | Dell| -|Jessica | Fitzgerald-McKay | National Security Agency| -|Jonathan | Bitle | Kaiser Permanente| -|Justin | Corlett | Cryptsoft Pty Ltd.| -|Kazuo | Noguchi | Hitachi, Ltd.| -|Kent | Landfield | McAfee| -|Langley | Rock | Red Hat| -|Martin | Prpic | Red Hat| -|Masato | Terada | Hitachi, Ltd.| -|Mike | Gorski | Cisco Systems| -|Nicole | Parrish | Mitre Corporation| -|Omar | Santos | Cisco Systems| -|Patrick | Maroney | AT&T| -|Rhonda | Levy | Cisco Systems| -|Richard | Struse | Mitre Corporation| -|Ritwik | Ghoshal | Oracle| -|Robert | Coderre | Accenture| -|Robert | Keith | Accenture| -|Stefan | Hagen | Individual| -|Tania | Ward | Dell| -|Ted | Bedwell | Cisco Systems| -|Thomas | Proell | Siemens AG| -|Thomas | Schmidt | Federal Office for Information Security (BSI) Germany| -|Tim | Hudson | Cryptsoft Pty Ltd.| -|Tobias | Limmer | Siemens AG| -|Tony | Cox | Cryptsoft Pty Ltd.| -|Vincent | Danen | Red Hat| -|Will | Rideout | Arista Networks| -|Xiaoyu | Ge | Huawei Technologies Co., Ltd.| +| First Name | Last Name | Company | +|:-----------|:-----------------|:------------------------------------------------------| +| Alexandre | Dulaunoy | CIRCL | +| Anthony | Berglas | Cryptsoft Pty Ltd. | +| Art | Manion | Carnegie Mellon University | +| Aukjan | van Belkum | EclecticIQ | +| Ben | Sooter | Electric Power Research Institute (EPRI) | +| Bernd | Grobauer | Siemens AG | +| Bruce | Rich | Cryptsoft Pty Ltd. | +| Chok | Poh | Oracle | +| Dan | West | Microsoft | +| David | Waltermire | NIST | +| Denny | Page | TIBCO Software Inc. | +| Duncan | Sparrell | sFractal Consulting LLC | +| Eric | Johnson | TIBCO Software Inc. | +| Ethan | Rahn | Arista Networks | +| Feng | Cao | Oracle | +| Greg | Scott | Cryptsoft Pty Ltd. | +| Harold | Booth | NIST | +| Jason | Masters | TELUS | +| Jennifer | Victor | Dell | +| Jessica | Fitzgerald-McKay | National Security Agency | +| Jonathan | Bitle | Kaiser Permanente | +| Justin | Corlett | Cryptsoft Pty Ltd. | +| Kazuo | Noguchi | Hitachi, Ltd. | +| Kent | Landfield | McAfee | +| Langley | Rock | Red Hat | +| Martin | Prpic | Red Hat | +| Masato | Terada | Hitachi, Ltd. | +| Mike | Gorski | Cisco Systems | +| Nicole | Parrish | Mitre Corporation | +| Omar | Santos | Cisco Systems | +| Patrick | Maroney | AT&T | +| Rhonda | Levy | Cisco Systems | +| Richard | Struse | Mitre Corporation | +| Ritwik | Ghoshal | Oracle | +| Robert | Coderre | Accenture | +| Robert | Keith | Accenture | +| Stefan | Hagen | Individual | +| Tania | Ward | Dell | +| Ted | Bedwell | Cisco Systems | +| Thomas | Proell | Siemens AG | +| Thomas | Schmidt | Federal Office for Information Security (BSI) Germany | +| Tim | Hudson | Cryptsoft Pty Ltd. | +| Tobias | Limmer | Siemens AG | +| Tony | Cox | Cryptsoft Pty Ltd. | +| Vincent | Danen | Red Hat | +| Will | Rideout | Arista Networks | +| Xiaoyu | Ge | Huawei Technologies Co., Ltd. | The following individuals were members of the OASIS CSAF Technical Committee during the creation of the previous version (CVRF v1.2) of this specification and their contributions are gratefully acknowledged: **CSAF TC Members:** -| First Name | Last Name | Company | -| :--- | :--- | :--- | -|Adam | Montville | CIS| -|Allan | Thomson | LookingGlass| -|Anthony | Berglas | Cryptsoft Pty Ltd.| -|Art | Manion | Carnegie Mellon University| -|Aukjan | van Belkum | EclecticIQ| -|Ben | Sooter | Electric Power Research Institute| -|Bernd | Grobauer | Siemens AG| -|Beth | Pumo | Kaiser Permanente| -|Bret | Jordan | Symantec Corp.| -|Bruce | Rich | Cryptsoft Pty Ltd.| -|Chet | Ensign | OASIS| -|Chok | Poh | Oracle| -|Chris | Rouland | Individual| -|David | Waltermire | NIST| -|Denny | Page | TIBCO Software Inc.| -|Doron | Shiloach | IBM| -|Duncan | Sparrell | sFractal Consulting LLC| -|Eric | Johnson | TIBCO Software Inc.| -|Feng | Cao | Oracle| -|Greg | Reaume | TELUS| -|Greg | Scott | Cryptsoft Pty Ltd.| -|Harold | Booth | NIST| -|Jamison | Day | LookingGlass| -|Jared | Semrau | "FireEye, Inc."| -|Jason | Masters | TELUS| -|Jerome | Athias | Individual| -|Jessica | Fitzgerald-McKay | National Security Agency| -|Jonathan | Bitle | Kaiser Permanente| -|Justin | Corlett | Cryptsoft Pty Ltd.| -|Karen | Scarfone | Individual| -|Kazuo | Noguchi | "Hitachi, Ltd."| -|Kent | Landfield | McAfee| -|Lothar | Braun | Siemens AG| -|Louis | Ronnau | Cisco Systems| -|Mark | Davidson | NC4| -|Mark-David | McLaughlin | Cisco Systems| -|Masato | Terada | "Hitachi, Ltd."| -|Masood | Nasir | TELUS| -|Nicole | Gong | Mitre Corporation| -|Omar | Santos | Cisco Systems| -|Patrick | Maroney | Wapack Labs LLC| -|Paul | Patrick | "FireEye, Inc."| -|Peter | Allor | IBM| -|Phillip | Boles | "FireEye, Inc."| -|Ravi | Balupari | Netskope| -|Rich | Reybok | ServiceNow| -|Richard | Struse | DHS Office of Cybersecurity and Communications (CS&C)| -|Ritwik | Ghoshal | Oracle| -|Robert | Coderre | VeriSign| -|Robin | Cover | OASIS| -|Rupert | Wimmer | Siemens AG| -|Sanjiv | Kalkar | Individual| -|Sean | Barnum | Mitre Corporation| -|Stefan | Hagen | Individual| -|Ted | Bedwell | Cisco Systems| -|Thomas | Schreck | Siemens AG| -|Tim | Hudson | Cryptsoft Pty Ltd.| -|Tony | Cox | Cryptsoft Pty Ltd.| -|Trey | Darley | "Kingfisher Operations, sprl"| -|Vincent | Danen | Red Hat| -|Zach | Turk | Microsoft| +| First Name | Last Name | Company | +|:-----------|:-----------------|:------------------------------------------------------| +| Adam | Montville | CIS | +| Allan | Thomson | LookingGlass | +| Anthony | Berglas | Cryptsoft Pty Ltd. | +| Art | Manion | Carnegie Mellon University | +| Aukjan | van Belkum | EclecticIQ | +| Ben | Sooter | Electric Power Research Institute | +| Bernd | Grobauer | Siemens AG | +| Beth | Pumo | Kaiser Permanente | +| Bret | Jordan | Symantec Corp. | +| Bruce | Rich | Cryptsoft Pty Ltd. | +| Chet | Ensign | OASIS | +| Chok | Poh | Oracle | +| Chris | Rouland | Individual | +| David | Waltermire | NIST | +| Denny | Page | TIBCO Software Inc. | +| Doron | Shiloach | IBM | +| Duncan | Sparrell | sFractal Consulting LLC | +| Eric | Johnson | TIBCO Software Inc. | +| Feng | Cao | Oracle | +| Greg | Reaume | TELUS | +| Greg | Scott | Cryptsoft Pty Ltd. | +| Harold | Booth | NIST | +| Jamison | Day | LookingGlass | +| Jared | Semrau | "FireEye, Inc." | +| Jason | Masters | TELUS | +| Jerome | Athias | Individual | +| Jessica | Fitzgerald-McKay | National Security Agency | +| Jonathan | Bitle | Kaiser Permanente | +| Justin | Corlett | Cryptsoft Pty Ltd. | +| Karen | Scarfone | Individual | +| Kazuo | Noguchi | "Hitachi, Ltd." | +| Kent | Landfield | McAfee | +| Lothar | Braun | Siemens AG | +| Louis | Ronnau | Cisco Systems | +| Mark | Davidson | NC4 | +| Mark-David | McLaughlin | Cisco Systems | +| Masato | Terada | "Hitachi, Ltd." | +| Masood | Nasir | TELUS | +| Nicole | Gong | Mitre Corporation | +| Omar | Santos | Cisco Systems | +| Patrick | Maroney | Wapack Labs LLC | +| Paul | Patrick | "FireEye, Inc." | +| Peter | Allor | IBM | +| Phillip | Boles | "FireEye, Inc." | +| Ravi | Balupari | Netskope | +| Rich | Reybok | ServiceNow | +| Richard | Struse | DHS Office of Cybersecurity and Communications (CS&C) | +| Ritwik | Ghoshal | Oracle | +| Robert | Coderre | VeriSign | +| Robin | Cover | OASIS | +| Rupert | Wimmer | Siemens AG | +| Sanjiv | Kalkar | Individual | +| Sean | Barnum | Mitre Corporation | +| Stefan | Hagen | Individual | +| Ted | Bedwell | Cisco Systems | +| Thomas | Schreck | Siemens AG | +| Tim | Hudson | Cryptsoft Pty Ltd. | +| Tony | Cox | Cryptsoft Pty Ltd. | +| Trey | Darley | "Kingfisher Operations, sprl" | +| Vincent | Danen | Red Hat | +| Zach | Turk | Microsoft | ------- - diff --git a/csaf_2.1/prose/edit/src/additional-conventions.md b/csaf_2.1/prose/edit/src/additional-conventions.md index db9b8ba7d..be0577c44 100644 --- a/csaf_2.1/prose/edit/src/additional-conventions.md +++ b/csaf_2.1/prose/edit/src/additional-conventions.md @@ -43,4 +43,3 @@ If multiple CSAF documents are transported via a data stream in a sequence witho The keys within a CSAF document SHOULD be sorted alphabetically. ------- - diff --git a/csaf_2.1/prose/edit/src/design-considerations-00.md b/csaf_2.1/prose/edit/src/design-considerations-00.md index 33b7436da..48882ed79 100644 --- a/csaf_2.1/prose/edit/src/design-considerations-00.md +++ b/csaf_2.1/prose/edit/src/design-considerations-00.md @@ -11,4 +11,3 @@ This minimal required information set does not provide any useful information on Care has been taken, to design the containers for product and vulnerability information to support fine-grained mapping of security advisories onto product and vulnerability and minimize data duplication through referencing. The display of the elements representing Product Tree and Vulnerability information has been placed in the sections named accordingly. - diff --git a/csaf_2.1/prose/edit/src/design-considerations-01-construction-principles.md b/csaf_2.1/prose/edit/src/design-considerations-01-construction-principles.md index 91319333d..c54e30ace 100644 --- a/csaf_2.1/prose/edit/src/design-considerations-01-construction-principles.md +++ b/csaf_2.1/prose/edit/src/design-considerations-01-construction-principles.md @@ -45,4 +45,3 @@ Even though the JSON schema does not prohibit specifically additional properties Section 4 defined profiles that are used to ensure a common understanding of which fields are required in a given use case. Additional conventions are stated in section 5. The tests given in section 6 support CSAF producers and consumers to verify rules from the specification which can not be tested by the schema. Section 7 states how to distribute and where to find CSAF documents. Safety, Security and Data Protection are considered in section 8. Finally, a set of conformance targets describes tools in the ecosystem. ------- - diff --git a/csaf_2.1/prose/edit/src/introduction-00.md b/csaf_2.1/prose/edit/src/introduction-00.md index 49f601b3b..69a5e8993 100644 --- a/csaf_2.1/prose/edit/src/introduction-00.md +++ b/csaf_2.1/prose/edit/src/introduction-00.md @@ -1,2 +1 @@ # 1 Introduction - diff --git a/csaf_2.1/prose/edit/src/introduction-01-ipr-policy.md b/csaf_2.1/prose/edit/src/introduction-01-ipr-policy.md index 30b2808e4..b920ce620 100644 --- a/csaf_2.1/prose/edit/src/introduction-01-ipr-policy.md +++ b/csaf_2.1/prose/edit/src/introduction-01-ipr-policy.md @@ -1,4 +1,3 @@ ## 1.1 IPR Policy This specification is provided under the [Non-Assertion](https://www.oasis-open.org/policies-guidelines/ipr/#Non-Assertion-Mode) Mode of the [OASIS IPR Policy](https://www.oasis-open.org/policies-guidelines/ipr/), the mode chosen when the Technical Committee was established. For information on whether any patents have been disclosed that may be essential to implementing this specification, and any offers of patent licensing terms, please refer to the Intellectual Property Rights section of the TC's web page ([https://www.oasis-open.org/committees/csaf/ipr.php](https://www.oasis-open.org/committees/csaf/ipr.php)). - diff --git a/csaf_2.1/prose/edit/src/introduction-02-terminology-glossary.md b/csaf_2.1/prose/edit/src/introduction-02-terminology-glossary.md new file mode 100644 index 000000000..41e0f1217 --- /dev/null +++ b/csaf_2.1/prose/edit/src/introduction-02-terminology-glossary.md @@ -0,0 +1,252 @@ +advisory +: reporting item that describes a condition present in an artifact and that requires action by the consumers + +advisory document +: artifact in which an analysis tool reports a result + +advisory management system* +: software system that consumes the documents produced by analysis tools, +produces advisories that enable engineering and operating organizations to assess the quality of these +software artifacts at a point in time, and performs functions such as filing security advisories and +displaying information about individual advisories. +**Note**: An advisory management system can interact with a document viewer to display information about individual advisories. + +advisory matching +: process of determining whether two advisories are targeting the same products and conditions + +artifact +: sequence of bytes addressable via a URI. +_Examples_: A physical file in a file system such as a source file, an object file, a configuration file or a data file; +a specific version of a file in a version control system; a database table accessed via an HTTP request; +an arbitrary stream of bytes returned from an HTTP request, a product URL, a common product enumeration value. + +CSAF asset matching system* +: program that connects to or is an asset database and is able to manage CSAF documents as +required by CSAF management system +as well as matching them to assets of the asset database. + +CSAF basic validator +: A program that reads a document and checks it against the JSON schema and performs mandatory tests. + +CSAF consumer* +: program that reads and interprets a CSAF document + +CSAF content management system +: program that is able to create, review and manage CSAF documents and is able to preview their details as +required by CSAF viewer. + +CSAF converter +: CSAF producer that transforms the output of an analysis tool from its native output format into the CSAF format + +CSAF direct producer +: analysis tool which acts as a CSAF producer + +CSAF document +: security advisory text document in the format defined by this document. + +CSAF extended validator +: A CSAF basic validator that additionally performs optional tests. + +CSAF full validator +: A CSAF extended validator that additionally performs informative tests. + +CSAF management system +: program that is able to manage CSAF documents and is able to display their details as required by CSAF viewer. + +CSAF modifier +: CSAF post-processor which takes a CSAF document as input and modifies the structure or values of properties. +The output is a valid CSAF document. + +CSAF post-processor +: CSAF producer that transforms an existing CSAF document into a new CSAF document, +for example, by removing or redacting elements according to sharing policies. + +CSAF SBOM matching system +: A program that connects to or is an SBOM database and is able to manage CSAF documents as +required by CSAF management system as well as matching them to SBOM components of the SBOM database. + +CSAF producer +: program that emits output in the CSAF format + +CSAF translator +: CSAF post-processor which takes a CSAF document as input and translates values of properties into another language. +The output is a valid CSAF document. + +CSAF viewer +: CSAF consumer that reads a CSAF document, displays a list of the results it contains, +and allows an end user to view each result in the context of the artifact in which it occurs. + +CVRF CSAF converter +: CSAF producer which takes a CVRF document as input and converts it into a valid CSAF document. + +document +: output file produced by an analysis tool, which enumerates the results produced by the tool + +driver +: tool component containing an analysis tool’s or converter’s primary executable, +which controls the tool’s or converter’s execution, +and which in the case of an analysis tool typically defines a set of analysis rules + +embedded link +: syntactic construct which enables a message string to refer to a location mentioned in the document + +empty array +: array that contains no elements, and so has a length of 0 + +empty object +: object that contains no properties + +empty string +: string that contains no characters, and so has a length of 0 + +(end) user +: person who uses the information in a document to investigate, triage, or resolve results + +engineering system +: software analysis environment within which analysis tools execute. +**Note**: An engineering system might include a build system, a source control system, a result management system, +a bug tracking system, a test execution system, and so on. + +extension +: tool component other than the driver (for example, a plugin, a configuration file, or a taxonomy) + +external property file +: file containing the values of one or more externalized properties + +externalizable property +: property that can be contained in an external property file + +externalized property +: property stored outside of the CSAF document to which it logically belongs + +false positive +: result which an end user decides does not actually represent a problem + +fingerprint +: stable value that can be used by a result management system to uniquely identify a result over time, +even if a relevant artifact is modified + +formatted message +: message string which contains formatting information such as Markdown formatting characters + +fully qualified logical name +: string that fully identifies the programmatic construct specified by a logical location, +typically by means of a hierarchical identifier. + +hierarchical string +: string in the format <component>{/<component>}* + +line +: contiguous sequence of characters, starting either at the beginning of an artifact or immediately after +a newline sequence, and ending at and including the nearest subsequent newline sequence, if one is present, +or else extending to the end of the artifact + +line (number) +: 1-based index of a line within a file. +**Note**: Abbreviated to "line" when there is no danger of ambiguity with "line" in the sense of a sequence of characters. + +localizable +: subject to being translated from one natural language to another + +message string +: human-readable string that conveys information relevant to an element in a CSAF document + +nested artifact +: artifact that is contained within another artifact + +newline sequence +: sequence of one or more characters representing the end of a line of text. +**Note**: Some systems represent a newline sequence with a single newline character; others represent it as +a carriage return character followed by a newline character. + +notification +: reporting item that describes a condition encountered by a tool during its execution + +opaque +: neither human-readable nor machine-parsable into constituent parts + +parent (artifact) +: artifact which contains one or more nested artifacts + +plain text message +: message string which does not contain any formatting information + +plugin +: tool component that defines additional rules + +policy +: set of rule configurations that specify how results that +violate the rules defined by a particular tool component are to be treated + +problem +: result which indicates a condition that has the potential to detract from the quality of the program. +_Examples_: A security vulnerability, a deviation from contractual or legal requirements. + +product +: is any deliverable (e.g. software, hardware, specification,...) which can be referred to with a name. +This applies regardless of the origin, the license model, or the mode of distribution of the deliverable. + +property +: attribute of an object consisting of a name and a value associated with the name + +redactable property +: property that potentially contains sensitive information that a CSAF direct producer or +a CSAF post-processor might wish to redact + +reporting item +: unit of output produced by a tool, either a result or a notification + +reporting configuration +: the subset of reporting metadata that a tool can configure at runtime, before performing its scan. +_Examples_: severity level, rank + +repository +: container for a related set of files in a version control system + +taxonomy +: classification of analysis results into a set of categories + +tag +: string that conveys additional information about the CSAF document element to which it applies + +text artifact +: artifact considered as a sequence of characters organized into lines and columns + +text region +: region representing a contiguous range of zero or more characters in a text artifact + +tool component +: component of an analysis tool or converter, either its driver or an extension, consisting of one or more files + +top-level artifact +: artifact which is not contained within any other artifact + +translation +: rendering of a tool component's localizable strings into another language + +triage +: decide whether a result indicates a problem that needs to be corrected + +user +: see end user. + +VCS +: version control system + +vendor +: the community, individual, or organization that created or maintains a product +(including open source software and hardware providers) + +VEX +: Vulnerability Exploitability eXchange - enables a supplier or other party to assert whether or not +a particular product is affected by a specific vulnerability, especially helpful in efficiently consuming SBOM data. + +viewer +: see CSAF viewer. + +vulnerability +: functional behavior of a product or service that violates an implicit or explicit security policy +(conforming to ISO/IEC 29147 [ISO29147]) + +XML +: eXtensible Markup Language - the format used by the predecessors of this standard, namely CVRF 1.1 and CVRF 1.2. diff --git a/csaf_2.1/prose/edit/src/introduction-02-terminology.md b/csaf_2.1/prose/edit/src/introduction-02-terminology.md index c84fded5c..cc586c363 100644 --- a/csaf_2.1/prose/edit/src/introduction-02-terminology.md +++ b/csaf_2.1/prose/edit/src/introduction-02-terminology.md @@ -3,150 +3,3 @@ The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 [[RFC2119](#rfc2119)] and [[RFC8174](#rfc8174)] when, and only when, they appear in all capitals, as shown here. For purposes of this document, the following terms and definitions apply: - -**advisory**: reporting item that describes a condition present in an artifact and that requires action by the consumers - -**advisory document**: artifact in which an analysis tool reports a result - -**advisory management system**: software system that consumes the documents produced by analysis tools, produces advisories that enable engineering and operating organizations to assess the quality of these software artifacts at a point in time, and performs functions such as filing security advisories and displaying information about individual advisories. **Note**: An advisory management system can interact with a document viewer to display information about individual advisories. - -**advisory matching**: process of determining whether two advisories are targeting the same products and conditions - -**artifact**: sequence of bytes addressable via a URI. _Examples_: A physical file in a file system such as a source file, an object file, a configuration file or a data file; a specific version of a file in a version control system; a database table accessed via an HTTP request; an arbitrary stream of bytes returned from an HTTP request, a product URL, a common product enumeration value. - -**CSAF asset matching system**: program that connects to or is an asset database and is able to manage CSAF documents as required by CSAF management system as well as matching them to assets of the asset database. - -**CSAF basic validator**: A program that reads a document and checks it against the JSON schema and performs mandatory tests. - -**CSAF consumer**: program that reads and interprets a CSAF document - -**CSAF content management system**: program that is able to create, review and manage CSAF documents and is able to preview their details as required by CSAF viewer. - -**CSAF converter**: CSAF producer that transforms the output of an analysis tool from its native output format into the CSAF format - -**CSAF direct producer**: analysis tool which acts as a CSAF producer - -**CSAF document**: security advisory text document in the format defined by this document. - -**CSAF extended validator**: A CSAF basic validator that additionally performs optional tests. - -**CSAF full validator**: A CSAF extended validator that additionally performs informative tests. - -**CSAF management system**: program that is able to manage CSAF documents and is able to display their details as required by CSAF viewer. - -**CSAF modifier**: CSAF post-processor which takes a CSAF document as input and modifies the structure or values of properties. The output is a valid CSAF document. - -**CSAF post-processor**: CSAF producer that transforms an existing CSAF document into a new CSAF document, for example, by removing or redacting elements according to sharing policies. - -**CSAF SBOM matching system**: A program that connects to or is an SBOM database and is able to manage CSAF documents as required by CSAF management system as well as matching them to SBOM components of the SBOM database. - -**CSAF producer**: program that emits output in the CSAF format - -**CSAF translator**: CSAF post-processor which takes a CSAF document as input and translates values of properties into another language. The output is a valid CSAF document. - -**CSAF viewer**: CSAF consumer that reads a CSAF document, displays a list of the results it contains, and allows an end user to view each result in the context of the artifact in which it occurs. - -**CVRF CSAF converter**: CSAF producer which takes a CVRF document as input and converts it into a valid CSAF document. - -**document**: output file produced by an analysis tool, which enumerates the results produced by the tool - -**driver**: tool component containing an analysis tool’s or converter’s primary executable, which controls the tool’s or converter’s execution, and which in the case of an analysis tool typically defines a set of analysis rules - -**embedded link**: syntactic construct which enables a message string to refer to a location mentioned in the document - -**empty array**: array that contains no elements, and so has a length of 0 - -**empty object**: object that contains no properties - -**empty string**: string that contains no characters, and so has a length of 0 - -**(end) user**: person who uses the information in a document to investigate, triage, or resolve results - -**engineering system**: software analysis environment within which analysis tools execute. **Note**: An engineering system might include a build system, a source control system, a result management system, a bug tracking system, a test execution system, and so on. - -**extension**: tool component other than the driver (for example, a plugin, a configuration file, or a taxonomy) - -**external property file**: file containing the values of one or more externalized properties - -**externalizable property**: property that can be contained in an external property file - -**externalized property**: property stored outside of the CSAF document to which it logically belongs - -**false positive**: result which an end user decides does not actually represent a problem - -**fingerprint**: stable value that can be used by a result management system to uniquely identify a result over time, even if a relevant artifact is modified - -**formatted message**: message string which contains formatting information such as Markdown formatting characters - -**fully qualified logical name**: string that fully identifies the programmatic construct specified by a logical location, typically by means of a hierarchical identifier. - -**hierarchical string**: string in the format <component>{/<component>}* - -**line**: contiguous sequence of characters, starting either at the beginning of an artifact or immediately after a newline sequence, and ending at and including the nearest subsequent newline sequence, if one is present, or else extending to the end of the artifact - -**line (number)**: 1-based index of a line within a file. **Note**: Abbreviated to "line" when there is no danger of ambiguity with "line" in the sense of a sequence of characters. - -**localizable**: subject to being translated from one natural language to another - -**message string**: human-readable string that conveys information relevant to an element in a CSAF document - -**nested artifact**: artifact that is contained within another artifact - -**newline sequence**: sequence of one or more characters representing the end of a line of text. **Note**: Some systems represent a newline sequence with a single newline character; others represent it as a carriage return character followed by a newline character. - -**notification**: reporting item that describes a condition encountered by a tool during its execution - -**opaque**: neither human-readable nor machine-parsable into constituent parts - -**parent (artifact)**: artifact which contains one or more nested artifacts - -**plain text message**: message string which does not contain any formatting information - -**plugin**: tool component that defines additional rules - -**policy**: set of rule configurations that specify how results that violate the rules defined by a particular tool component are to be treated - -**problem**: result which indicates a condition that has the potential to detract from the quality of the program. _Examples_: A security vulnerability, a deviation from contractual or legal requirements. - -**product**: is any deliverable (e.g. software, hardware, specification,...) which can be referred to with a name. This applies regardless of the origin, the license model, or the mode of distribution of the deliverable. - -**property**: attribute of an object consisting of a name and a value associated with the name - -**redactable property**: property that potentially contains sensitive information that a CSAF direct producer or a CSAF post-processor might wish to redact - -**reporting item**: unit of output produced by a tool, either a result or a notification - -**reporting configuration**: the subset of reporting metadata that a tool can configure at runtime, before performing its scan. _Examples_: severity level, rank - -**repository** container for a related set of files in a version control system - -**taxonomy**: classification of analysis results into a set of categories - -**tag**: string that conveys additional information about the CSAF document element to which it applies - -**text artifact**: artifact considered as a sequence of characters organized into lines and columns - -**text region**: region representing a contiguous range of zero or more characters in a text artifact - -**tool component**: component of an analysis tool or converter, either its driver or an extension, consisting of one or more files - -**top-level artifact**: artifact which is not contained within any other artifact - -**translation**: rendering of a tool component's localizable strings into another language - -**triage**: decide whether a result indicates a problem that needs to be corrected - -**user**: see end user. - -**VCS**: version control system - -**vendor**: the community, individual, or organization that created or maintains a product (including open source software and hardware providers) - -**VEX**: Vulnerability Exploitability eXchange - enables a supplier or other party to assert whether or not a particular product is affected by a specific vulnerability, especially helpful in efficiently consuming SBOM data. - -**viewer**: see CSAF viewer. - -**vulnerability**: functional behavior of a product or service that violates an implicit or explicit security policy (conforming to ISO/IEC 29147 [ISO29147]) - -**XML**: eXtensible Markup Language - the format used by the predecessors of this standard, namely CVRF 1.1 and CVRF 1.2. - diff --git a/csaf_2.1/prose/edit/src/introduction-03-normative-references.md b/csaf_2.1/prose/edit/src/introduction-03-normative-references.md index 6cfb1ee69..6d9d82a53 100644 --- a/csaf_2.1/prose/edit/src/introduction-03-normative-references.md +++ b/csaf_2.1/prose/edit/src/introduction-03-normative-references.md @@ -1,19 +1,25 @@ ## 1.3 Normative References -###### [JSON-Schema-Core] -_JSON Schema: A Media Type for Describing JSON Documents_, draft-bhutton-json-schema-00, December 2020, https://datatracker.ietf.org/doc/html/draft-bhutton-json-schema-00. -###### [JSON-Schema-Validation] -_JSON Schema Validation: A Vocabulary for Structural Validation of JSON_, draft-bhutton-json-schema-validation-00, December 2020, https://datatracker.ietf.org/doc/html/draft-bhutton-json-schema-validation-00. -###### [JSON-Hyper-Schema] -_JSON Hyper-Schema: A Vocabulary for Hypermedia Annotation of JSON_, draft-handrews-json-schema-hyperschema-02, September 2019, https://json-schema.org/draft/2019-09/json-schema-hypermedia.html. -###### [Relative-JSON-Pointers] -_Relative JSON Pointers_, draft-bhutton-relative-json-pointer-00, December 2020, https://datatracker.ietf.org/doc/html/draft-bhutton-relative-json-pointer-00. -###### [RFC2119] -Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, DOI 10.17487/RFC2119, March 1997, https://www.rfc-editor.org/info/rfc2119. -###### [RFC7464] -Williams, N., "JavaScript Object Notation (JSON) Text Sequences", RFC 7464, DOI 10.17487/RFC7464, February 2015, https://www.rfc-editor.org/info/rfc7464. -###### [RFC8174] -Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174, May 2017, https://www.rfc-editor.org/info/rfc8174. -###### [RFC8259] -T. Bray, Ed., "The JavaScript Object Notation (JSON) Data Interchange Format", RFC 8259, DOI 10.17487/RFC8259, December 2017, https://www.rfc-editor.org/info/rfc8259. +JSON-Schema-Core +: _JSON Schema: A Media Type for Describing JSON Documents_, draft-bhutton-json-schema-00, December 2020, https://datatracker.ietf.org/doc/html/draft-bhutton-json-schema-00. +JSON-Schema-Validation +: _JSON Schema Validation: A Vocabulary for Structural Validation of JSON_, draft-bhutton-json-schema-validation-00, December 2020, https://datatracker.ietf.org/doc/html/draft-bhutton-json-schema-validation-00. + +JSON-Hyper-Schema +: _JSON Hyper-Schema: A Vocabulary for Hypermedia Annotation of JSON_, draft-handrews-json-schema-hyperschema-02, September 2019, https://json-schema.org/draft/2019-09/json-schema-hypermedia.html. + +Relative-JSON-Pointers +: _Relative JSON Pointers_, draft-bhutton-relative-json-pointer-00, December 2020, https://datatracker.ietf.org/doc/html/draft-bhutton-relative-json-pointer-00. + +RFC2119 +: Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, DOI 10.17487/RFC2119, March 1997, https://www.rfc-editor.org/info/rfc2119. + +RFC7464 +: Williams, N., "JavaScript Object Notation (JSON) Text Sequences", RFC 7464, DOI 10.17487/RFC7464, February 2015, https://www.rfc-editor.org/info/rfc7464. + +RFC8174 +: Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174, May 2017, https://www.rfc-editor.org/info/rfc8174. + +RFC8259 +: T. Bray, Ed., "The JavaScript Object Notation (JSON) Data Interchange Format", RFC 8259, DOI 10.17487/RFC8259, December 2017, https://www.rfc-editor.org/info/rfc8259. diff --git a/csaf_2.1/prose/edit/src/introduction-04-informative-references.md b/csaf_2.1/prose/edit/src/introduction-04-informative-references.md index 4e804c6f9..91e96834f 100644 --- a/csaf_2.1/prose/edit/src/introduction-04-informative-references.md +++ b/csaf_2.1/prose/edit/src/introduction-04-informative-references.md @@ -1,85 +1,121 @@ ## 1.4 Informative References -###### [CPE23-A] -_Common Platform Enumeration: Applicability Language Specification Version 2.3 (NISTIR 7698)_, D. Waltermire, P. Cichonski, K. Scarfone, Editors, NIST Interagency Report 7698, August 2011, https://dx.doi.org/10.6028/NIST.IR.7698. -###### [CPE23-D] -_Common Platform Enumeration: Dictionary Specification Version 2.3_, P. Cichonski, D. Waltermire, K. Scarfone, Editors, NIST Interagency Report 7697, August 2011, https://dx.doi.org/10.6028/NIST.IR.7697. -###### [CPE23-M] -_Common Platform Enumeration: Naming Matching Specification Version 2.3_, M. Parmelee, H. Booth, D. Waltermire, K. Scarfone, Editors, NIST Interagency Report 7696, August 2011, https://dx.doi.org/10.6028/NIST.IR.7696. -###### [CPE23-N] -_Common Platform Enumeration: Naming Specification Version 2.3_, B. Cheikes, D. Waltermire, K. Scarfone, Editors, NIST Interagency Report 7695, August 2011, https://dx.doi.org/10.6028/NIST.IR.7695. -###### [CVE] -_Common Vulnerability and Exposures (CVE) – The Standard for Information Security Vulnerability Names_, MITRE, 1999, https://cve.mitre.org/about/. -###### [CVE-NF] -_Common Vulnerability and Exposures (CVE) – The Standard for Information Security Vulnerability Names - CVE ID Syntax Change_, MITRE, January 01, 2014, https://cve.mitre.org/cve/identifiers/syntaxchange.html. -###### [CVRF-1-1] -_The Common Vulnerability Reporting Framework (CVRF) Version 1.1_, M. Schiffman, Editor, May 2012, Internet Consortium for Advancement of Security on the Internet (ICASI), https://www.icasi.org/the-common-vulnerability-reporting-framework-cvrf-v1-1/. -###### [CVRF-v1.2] -_CSAF Common Vulnerability Reporting Framework (CVRF) Version 1.2_. Edited by Stefan Hagen. 13 September 2017. OASIS Committee Specification 01. https://docs.oasis-open.org/csaf/csaf-cvrf/v1.2/cs01/csaf-cvrf-v1.2-cs01.html. Latest version: https://docs.oasis-open.org/csaf/csaf-cvrf/v1.2/csaf-cvrf-v1.2.html. -###### [CVSS2] -_A Complete Guide to the Common Vulnerability Scoring System Version 2.0_, P. Mell, K. Scarfone, S. Romanosky, Editors, First.org, Inc., June 2007, https://www.first.org/cvss/cvss-v2-guide.pdf. -###### [CVSS30] -_Common Vulnerability Scoring System v3.0: Specification Document_, FIRST.Org, Inc., June 2019, https://www.first.org/cvss/v3.0/cvss-v30-specification_v1.9.pdf. -###### [CVSS31] -_Common Vulnerability Scoring System v3.1: Specification Document_, FIRST.Org, Inc., June 2019, https://www.first.org/cvss/v3-1/cvss-v31-specification_r1.pdf. -###### [CWE] -_Common Weakness Enumeration (CWE) – A Community-Developed List of Software Weakness Types_, MITRE, 2005, http://cwe.mitre.org/about/. -###### [CYCLONEDX13] -_CycloneDX Software Bill-of-Material Specification JSON schema version 1.3_, cyclonedx.org, May 2021, https://github.com/CycloneDX/specification/blob/1.3/schema/bom-1.3.schema.json. -###### [GFMCMARK] -_GitHub's fork of cmark, a CommonMark parsing and rendering library and program in C_, https://github.com/github/cmark. -###### [GFMENG] -_GitHub Engineering: A formal spec for GitHub Flavored Markdown_, https://githubengineering.com/a-formal-spec-for-github-markdown/. -###### [ISO8601] -_Data elements and interchange formats — Information interchange — Representation of dates and times_, International Standard, ISO 8601:2004(E), December 1, 2004, https://www.iso.org/standard/40874.html. -###### [ISO19770-2] -_Information technology — IT asset management — Part 2: Software identification tag_, International Standard, ISO 19770-2:2015, September 30, 2015, -https://www.iso.org/standard/65666.html. -###### [ISO29147] -_Information technology — Security techniques — Vulnerability disclosure_, International Standard, ISO/IEC 29147:2018, October, 2018, -https://www.iso.org/standard/72311.html. -###### [OPENSSL] -_GTLS/SSL and crypto library_, OpenSSL Software Foundation, https://www.openssl.org/. -###### [PURL] -_Package URL (PURL)_, GitHub Project, https://github.com/package-url/purl-spec. -###### [RFC3339] -Klyne, G. and C. Newman, "Date and Time on the Internet: Timestamps", RFC 3339, DOI 10.17487/RFC3339, July 2002, https://www.rfc-editor.org/info/rfc3339. -###### [RFC3552] -Rescorla, E. and B. Korver, "Guidelines for Writing RFC Text on Security Considerations", BCP 72, RFC 3552, DOI 10.17487/RFC3552, July 2003, https://www.rfc-editor.org/info/rfc3552. -###### [RFC3986] -Berners-Lee, T., Fielding, R., and L. Masinter, "Uniform Resource Identifier (URI): Generic Syntax", STD 66, RFC 3986, DOI 10.17487/RFC3986, January 2005, https://www.rfc-editor.org/info/rfc3986. -###### [RFC4880] -Callas, J., Donnerhacke, L., Finney, H., Shaw, D., and R. Thayer, "OpenPGP Message Format", RFC 4880, DOI 10.17487/RFC4880, November 2007, https://www.rfc-editor.org/info/rfc4880. -###### [RFC7231] -Fielding, R., Ed., and J. Reschke, Ed., "Hypertext Transfer Protocol (HTTP/1.1): Semantics and Content", RFC 7231, DOI 10.17487/RFC7231, June 2014, https://www.rfc-editor.org/info/rfc7231. -###### [RFC7464] -N. Williams., "JavaScript Object Notation (JSON) Text Sequences", RFC 7464, DOI 10.17487/RFC7464, February 2015, https://www.rfc-editor.org/info/rfc7464. -###### [RFC8615] -Nottingham, M., "Well-Known Uniform Resource Identifiers (URIs)", RFC 8615, DOI 10.17487/RFC8615, May 2019, https://www.rfc-editor.org/info/rfc8615. -###### [RFC9116] -Foudil, E. and Y. Shafranovich, "A File Format to Aid in Security Vulnerability Disclosure", RFC 9116, DOI 10.17487/RFC9116, April 2022, https://www.rfc-editor.org/info/rfc9116. -###### [SCAP12] -_The Technical Specification for the Security Content Automation Protocol (SCAP): SCAP Version 1.2_, D. Waltermire, S. Quinn, K. Scarfone, A. Halbardier, Editors, NIST Spec. Publ. 800‑126 rev. 2, September 2011, https://dx.doi.org/10.6028/NIST.SP.800-126r2. -###### [SECURITY-TXT] -Foudil, E. and Shafranovich, Y., _Security.txt Project_, https://securitytxt.org/. -###### [SemVer] -_Semantic Versioning 2.0.0_, T. Preston-Werner, June 2013, https://semver.org/. -###### [SPDX22] -_The Software Package Data Exchange (SPDX®) Specification Version 2.2_, Linux Foundation and its Contributors, 2020, https://spdx.github.io/spdx-spec/. -###### [VERS] -_vers: a mostly universal version range specifier_, Part of the PURL GitHub Project, https://github.com/package-url/purl-spec/blob/version-range-spec/VERSION-RANGE-SPEC.rst. -###### [VEX] -_Vulnerability-Exploitability eXchange (VEX) - An Overview_, VEX sub-group of the Framing Working Group in the NTIA SBOM initiative, 27 September 2021, -https://ntia.gov/files/ntia/publications/vex_one-page_summary.pdf. -###### [VEX-Justification] -_Vulnerability Exploitability eXchange (VEX) - Status Justifications_, VEX sub-group of the Framing Working Group in the CISA SBOM initiative, XX May 2022, https://www.cisa.gov/sites/default/files/publications/VEX_Status_Justification_Jun22.pdf. -###### [XML] -_Extensible Markup Language (XML) 1.0 (Fifth Edition)_, T. Bray, J. Paoli, M. Sperberg-McQueen, E. Maler, F. Yergeau, Editors, W3C Recommendation, November 26, 2008, https://www.w3.org/TR/2008/REC-xml-20081126/. -Latest version available at https://www.w3.org/TR/xml. -###### [XML-Schema-1] -_W3C XML Schema Definition Language (XSD) 1.1 Part 1: Structures_, S. Gao, M. Sperberg-McQueen, H. Thompson, N. Mendelsohn, D. Beech, M. Maloney, Editors, W3C Recommendation, April 5, 2012, https://www.w3.org/TR/2012/REC-xmlschema11-1-20120405/. -Latest version available at https://www.w3.org/TR/xmlschema11-1/. -###### [XML-Schema-2] -_W3C XML Schema Definition Language (XSD) 1.1 Part 2_: Datatypes W3C XML Schema Definition Language (XSD) 1.1 Part 2: Datatypes, D. Peterson, S. Gao, A. Malhotra, M. Sperberg-McQueen, H. Thompson, Paul V. Biron, Editors, W3C Recommendation, April 5, 2012, https://www.w3.org/TR/2012/REC-xmlschema11-2-20120405/. -Latest version available at https://www.w3.org/TR/xmlschema11-2/. +CPE23-A +: _Common Platform Enumeration: Applicability Language Specification Version 2.3 (NISTIR 7698)_, D. Waltermire, P. Cichonski, K. Scarfone, Editors, NIST Interagency Report 7698, August 2011, https://dx.doi.org/10.6028/NIST.IR.7698. +CPE23-D +: _Common Platform Enumeration: Dictionary Specification Version 2.3_, P. Cichonski, D. Waltermire, K. Scarfone, Editors, NIST Interagency Report 7697, August 2011, https://dx.doi.org/10.6028/NIST.IR.7697. + +CPE23-M +: _Common Platform Enumeration: Naming Matching Specification Version 2.3_, M. Parmelee, H. Booth, D. Waltermire, K. Scarfone, Editors, NIST Interagency Report 7696, August 2011, https://dx.doi.org/10.6028/NIST.IR.7696. + +CPE23-N +: _Common Platform Enumeration: Naming Specification Version 2.3_, B. Cheikes, D. Waltermire, K. Scarfone, Editors, NIST Interagency Report 7695, August 2011, https://dx.doi.org/10.6028/NIST.IR.7695. + +CVE +: _Common Vulnerability and Exposures (CVE) – The Standard for Information Security Vulnerability Names_, MITRE, 1999, https://cve.mitre.org/about/. + +CVE-NF +: _Common Vulnerability and Exposures (CVE) – The Standard for Information Security Vulnerability Names - CVE ID Syntax Change_, MITRE, January 01, 2014, https://cve.mitre.org/cve/identifiers/syntaxchange.html. + +CVRF-1-1 +: _The Common Vulnerability Reporting Framework (CVRF) Version 1.1_, M. Schiffman, Editor, May 2012, Internet Consortium for Advancement of Security on the Internet (ICASI), https://www.icasi.org/the-common-vulnerability-reporting-framework-cvrf-v1-1/. + +CVRF-v1.2 +: _CSAF Common Vulnerability Reporting Framework (CVRF) Version 1.2_. Edited by Stefan Hagen. 13 September 2017. OASIS Committee Specification 01. https://docs.oasis-open.org/csaf/csaf-cvrf/v1.2/cs01/csaf-cvrf-v1.2-cs01.html. Latest version: https://docs.oasis-open.org/csaf/csaf-cvrf/v1.2/csaf-cvrf-v1.2.html. + +CVSS2 +: _A Complete Guide to the Common Vulnerability Scoring System Version 2.0_, P. Mell, K. Scarfone, S. Romanosky, Editors, First.org, Inc., June 2007, https://www.first.org/cvss/cvss-v2-guide.pdf. + +CVSS30 +: _Common Vulnerability Scoring System v3.0: Specification Document_, FIRST.Org, Inc., June 2019, https://www.first.org/cvss/v3.0/cvss-v30-specification_v1.9.pdf. + +CVSS31 +: _Common Vulnerability Scoring System v3.1: Specification Document_, FIRST.Org, Inc., June 2019, https://www.first.org/cvss/v3-1/cvss-v31-specification_r1.pdf. + +CWE +: _Common Weakness Enumeration (CWE) – A Community-Developed List of Software Weakness Types_, MITRE, 2005, http://cwe.mitre.org/about/. + +CYCLONEDX13 +: _CycloneDX Software Bill-of-Material Specification JSON schema version 1.3_, cyclonedx.org, May 2021, https://github.com/CycloneDX/specification/blob/1.3/schema/bom-1.3.schema.json. + +GFMCMARK +: _GitHub's fork of cmark, a CommonMark parsing and rendering library and program in C_, https://github.com/github/cmark. + +GFMENG +: _GitHub Engineering: A formal spec for GitHub Flavored Markdown_, https://githubengineering.com/a-formal-spec-for-github-markdown/. + +ISO8601 +: _Data elements and interchange formats — Information interchange — Representation of dates and times_, International Standard, ISO 8601:2004(E), December 1, 2004, https://www.iso.org/standard/40874.html. + +ISO19770-2 +: _Information technology — IT asset management — Part 2: Software identification tag_, International Standard, ISO 19770-2:2015, September 30, 2015, +. + +ISO29147 +: _Information technology — Security techniques — Vulnerability disclosure_, International Standard, ISO/IEC 29147:2018, October, 2018, +. + +OPENSSL +: _GTLS/SSL and crypto library_, OpenSSL Software Foundation, https://www.openssl.org/. + +PURL +: _Package URL (PURL)_, GitHub Project, https://github.com/package-url/purl-spec. + +RFC3339 +: Klyne, G. and C. Newman, "Date and Time on the Internet: Timestamps", RFC 3339, DOI 10.17487/RFC3339, July 2002, https://www.rfc-editor.org/info/rfc3339. + +RFC3552 +: Rescorla, E. and B. Korver, "Guidelines for Writing RFC Text on Security Considerations", BCP 72, RFC 3552, DOI 10.17487/RFC3552, July 2003, https://www.rfc-editor.org/info/rfc3552. + +RFC3986 +: Berners-Lee, T., Fielding, R., and L. Masinter, "Uniform Resource Identifier (URI): Generic Syntax", STD 66, RFC 3986, DOI 10.17487/RFC3986, January 2005, https://www.rfc-editor.org/info/rfc3986. + +RFC4880 +: Callas, J., Donnerhacke, L., Finney, H., Shaw, D., and R. Thayer, "OpenPGP Message Format", RFC 4880, DOI 10.17487/RFC4880, November 2007, https://www.rfc-editor.org/info/rfc4880. + +RFC7231 +: Fielding, R., Ed., and J. Reschke, Ed., "Hypertext Transfer Protocol (HTTP/1.1): Semantics and Content", RFC 7231, DOI 10.17487/RFC7231, June 2014, https://www.rfc-editor.org/info/rfc7231. + +RFC7464 +: N. Williams., "JavaScript Object Notation (JSON) Text Sequences", RFC 7464, DOI 10.17487/RFC7464, February 2015, https://www.rfc-editor.org/info/rfc7464. + +RFC8615 +: Nottingham, M., "Well-Known Uniform Resource Identifiers (URIs)", RFC 8615, DOI 10.17487/RFC8615, May 2019, https://www.rfc-editor.org/info/rfc8615. + +RFC9116 +: Foudil, E. and Y. Shafranovich, "A File Format to Aid in Security Vulnerability Disclosure", RFC 9116, DOI 10.17487/RFC9116, April 2022, https://www.rfc-editor.org/info/rfc9116. + +SCAP12 +: _The Technical Specification for the Security Content Automation Protocol (SCAP): SCAP Version 1.2_, D. Waltermire, S. Quinn, K. Scarfone, A. Halbardier, Editors, NIST Spec. Publ. 800‑126 rev. 2, September 2011, https://dx.doi.org/10.6028/NIST.SP.800-126r2. + +SECURITY-TXT +: Foudil, E. and Shafranovich, Y., _Security.txt Project_, https://securitytxt.org/. + +SemVer +: _Semantic Versioning 2.0.0_, T. Preston-Werner, June 2013, https://semver.org/. + +SPDX22 +: _The Software Package Data Exchange (SPDX®) Specification Version 2.2_, Linux Foundation and its Contributors, 2020, https://spdx.github.io/spdx-spec/. + +VERS +: _vers: a mostly universal version range specifier_, Part of the PURL GitHub Project, https://github.com/package-url/purl-spec/blob/version-range-spec/VERSION-RANGE-SPEC.rst. + +VEX +: _Vulnerability-Exploitability eXchange (VEX) - An Overview_, VEX sub-group of the Framing Working Group in the NTIA SBOM initiative, 27 September 2021, +. + +VEX-Justification +: _Vulnerability Exploitability eXchange (VEX) - Status Justifications_, VEX sub-group of the Framing Working Group in the CISA SBOM initiative, XX May 2022, https://www.cisa.gov/sites/default/files/publications/VEX_Status_Justification_Jun22.pdf. + +XML +: _Extensible Markup Language (XML) 1.0 (Fifth Edition)_, T. Bray, J. Paoli, M. Sperberg-McQueen, E. Maler, F. Yergeau, Editors, W3C Recommendation, November 26, 2008, https://www.w3.org/TR/2008/REC-xml-20081126/. +Latest version available at . + +XML-Schema-1 +: _W3C XML Schema Definition Language (XSD) 1.1 Part 1: Structures_, S. Gao, M. Sperberg-McQueen, H. Thompson, N. Mendelsohn, D. Beech, M. Maloney, Editors, W3C Recommendation, April 5, 2012, https://www.w3.org/TR/2012/REC-xmlschema11-1-20120405/. +Latest version available at . + +XML-Schema-2 +: _W3C XML Schema Definition Language (XSD) 1.1 Part 2_: Datatypes W3C XML Schema Definition Language (XSD) 1.1 Part 2: Datatypes, D. Peterson, S. Gao, A. Malhotra, M. Sperberg-McQueen, H. Thompson, Paul V. Biron, Editors, W3C Recommendation, April 5, 2012, https://www.w3.org/TR/2012/REC-xmlschema11-2-20120405/. +Latest version available at . diff --git a/csaf_2.1/prose/edit/src/introduction-05-typographical-conventions.md b/csaf_2.1/prose/edit/src/introduction-05-typographical-conventions.md index 618b07b61..05f87cb83 100644 --- a/csaf_2.1/prose/edit/src/introduction-05-typographical-conventions.md +++ b/csaf_2.1/prose/edit/src/introduction-05-typographical-conventions.md @@ -21,4 +21,3 @@ All other text is normative unless otherwise labeled e.g. like the following inf >This is a pure informative comment that may be present, because the information conveyed is deemed useful advice or common pitfalls learned from implementer or operator experience and often given including the rationale. ------- - diff --git a/csaf_2.1/prose/edit/src/revision-history.md b/csaf_2.1/prose/edit/src/revision-history.md index e92590e53..e0a5af1d9 100644 --- a/csaf_2.1/prose/edit/src/revision-history.md +++ b/csaf_2.1/prose/edit/src/revision-history.md @@ -12,9 +12,8 @@ toc: |:-------------------------|:-----------|:--------------------------------|:--------------------------------------------------------------------------------------| | csaf-v2.0-wd20210927-dev | 2021-09-27 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS for public review | | csaf-v2.0-wd20220329-dev | 2022-03-29 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CSD02 for public review | -| csaf-v2.0-wd20220514-dev | 2022-05-14 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | -| csaf-v2.0-wd20220715-dev | 2022-07-15 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | -| csaf-v2.0-wd20220720-dev | 2022-07-20 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | +| csaf-v2.0-wd20220514-dev | 2022-05-14 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | +| csaf-v2.0-wd20220715-dev | 2022-07-15 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | +| csaf-v2.0-wd20220720-dev | 2022-07-20 | Stefan Hagen and Thomas Schmidt | Preparing next Editor revision for TC review and submittal as CS | ------- - diff --git a/csaf_2.1/prose/edit/src/schema-elements-00.md b/csaf_2.1/prose/edit/src/schema-elements-00.md index 80eea063d..f6916ce66 100644 --- a/csaf_2.1/prose/edit/src/schema-elements-00.md +++ b/csaf_2.1/prose/edit/src/schema-elements-00.md @@ -23,4 +23,3 @@ Types and properties together provide the vocabulary for the domain specific lan The single mandatory property is `document`. The optional two additional properties are `product_tree` and `vulnerabilities`. - diff --git a/csaf_2.1/prose/edit/src/schema-elements-01-definitions.md b/csaf_2.1/prose/edit/src/schema-elements-01-definitions.md index d530771ae..bc19013f9 100644 --- a/csaf_2.1/prose/edit/src/schema-elements-01-definitions.md +++ b/csaf_2.1/prose/edit/src/schema-elements-01-definitions.md @@ -1052,4 +1052,3 @@ The goal of this structure is to provide additional information to the end user ``` 1.0.0-alpha < 1.0.0-alpha.1 < 1.0.0-alpha.beta < 1.0.0-beta < 1.0.0-beta.2 < 1.0.0-beta.11 < 1.0.0-rc.1 < 1.0.0 ``` - diff --git a/csaf_2.1/prose/edit/src/table-of-contents.md b/csaf_2.1/prose/edit/src/table-of-contents.md index 2657bf5e1..b4991ee53 100644 --- a/csaf_2.1/prose/edit/src/table-of-contents.md +++ b/csaf_2.1/prose/edit/src/table-of-contents.md @@ -4,4 +4,3 @@ [[TOC will be inserted here]] ------- - diff --git a/csaf_2.1/prose/edit/src/tests-00.md b/csaf_2.1/prose/edit/src/tests-00.md index 812fd0a92..cef3c64ac 100644 --- a/csaf_2.1/prose/edit/src/tests-00.md +++ b/csaf_2.1/prose/edit/src/tests-00.md @@ -1,4 +1,3 @@ # 6 Tests The following three subsections list a number of tests which all will have a short description and an excerpt of an example which fails the test. - diff --git a/csaf_2.1/prose/edit/src/tests-01-mandatory.md b/csaf_2.1/prose/edit/src/tests-01-mandatory.md index 0dd98ff26..fda267a3f 100644 --- a/csaf_2.1/prose/edit/src/tests-01-mandatory.md +++ b/csaf_2.1/prose/edit/src/tests-01-mandatory.md @@ -1526,4 +1526,3 @@ The relevant path for this test is: ``` > There are two flags given for for `CSAFPID-9080700` - one indirect through `CSAFGID-0001` and one direct. - diff --git a/csaf_2.1/prose/edit/src/tests-02-optional.md b/csaf_2.1/prose/edit/src/tests-02-optional.md index d1ce74230..00a25b154 100644 --- a/csaf_2.1/prose/edit/src/tests-02-optional.md +++ b/csaf_2.1/prose/edit/src/tests-02-optional.md @@ -623,4 +623,3 @@ The relevant path for this test is: > The key `custom_property` is not defined in the JSON schema. > A tool MAY remove such keys as a quick fix. - From 0a6d63af8dfdd0fba05c662618945e94571fa303 Mon Sep 17 00:00:00 2001 From: Stefan Hagen Date: Mon, 14 Aug 2023 11:59:32 +0200 Subject: [PATCH 08/74] refactor: removed volatile section counter display from sources - removed all volatile section counter displays like '3.1', 'C.1', or 'Appendix A.' from the sources. These can be regenerated from the concat document, using the trigger heading detection post table of contents and the appendix files meta data. - added section mappings from counter display to label and reverse to the etc directory. These files are temporarily used as fall back, but in the subsequent editorial phase will become build time artifacts. - the two non-unique section texts 'Sorting' and 'Vulnerabilities' have been amended with labels that make them unique (and in the context of the latter provide a more descriptive text than the section title itself). Signed-off-by: Stefan Hagen --- .../edit/etc/section-display-to-label.json | 257 ++++++++++++++++++ .../edit/etc/section-label-to-display.json | 257 ++++++++++++++++++ csaf_2.1/prose/edit/src/acknowledgements.md | 2 +- .../prose/edit/src/additional-conventions.md | 8 +- csaf_2.1/prose/edit/src/conformance.md | 38 +-- .../edit/src/design-considerations-00.md | 2 +- ...nsiderations-01-construction-principles.md | 2 +- csaf_2.1/prose/edit/src/distributing.md | 68 ++--- csaf_2.1/prose/edit/src/guidance-on-size.md | 14 +- csaf_2.1/prose/edit/src/introduction-00.md | 2 +- .../edit/src/introduction-01-ipr-policy.md | 2 +- .../edit/src/introduction-02-terminology.md | 2 +- .../introduction-03-normative-references.md | 2 +- .../introduction-04-informative-references.md | 2 +- ...troduction-05-typographical-conventions.md | 2 +- csaf_2.1/prose/edit/src/profiles.md | 12 +- csaf_2.1/prose/edit/src/revision-history.md | 2 +- .../safety-security-and-data-protection.md | 2 +- csaf_2.1/prose/edit/src/schema-elements-00.md | 2 +- .../src/schema-elements-01-definitions.md | 72 ++--- .../edit/src/schema-elements-02-properties.md | 116 ++++---- csaf_2.1/prose/edit/src/tests-00.md | 2 +- csaf_2.1/prose/edit/src/tests-01-mandatory.md | 90 +++--- csaf_2.1/prose/edit/src/tests-02-optional.md | 42 +-- .../prose/edit/src/tests-03-informative.md | 24 +- 25 files changed, 769 insertions(+), 255 deletions(-) create mode 100644 csaf_2.1/prose/edit/etc/section-display-to-label.json create mode 100644 csaf_2.1/prose/edit/etc/section-label-to-display.json diff --git a/csaf_2.1/prose/edit/etc/section-display-to-label.json b/csaf_2.1/prose/edit/etc/section-display-to-label.json new file mode 100644 index 000000000..d8de853da --- /dev/null +++ b/csaf_2.1/prose/edit/etc/section-display-to-label.json @@ -0,0 +1,257 @@ +{ + "1": "introduction", + "1.1": "ipr-policy", + "1.2": "terminology", + "1.3": "normative-references", + "1.4": "informative-references", + "1.5": "typographical-conventions", + "2": "design-considerations", + "2.1": "construction-principles", + "3": "schema-elements", + "3.1": "definitions", + "3.1.1": "acknowledgments-type", + "3.1.1.1": "acknowledgments-type-names", + "3.1.1.2": "acknowledgments-type-organization", + "3.1.1.3": "acknowledgments-type-summary", + "3.1.1.4": "acknowledgments-type-urls", + "3.1.1.5": "acknowledgments-type-example", + "3.1.2": "branches-type", + "3.1.2.1": "branches-type-branches", + "3.1.2.2": "branches-type-category", + "3.1.2.3": "branches-type-name", + "3.1.2.3.1": "branches-type-name-under-product-version", + "3.1.2.3.2": "branches-type-name-under-product-version-range", + "3.1.2.4": "branches-type-product", + "3.1.3": "full-product-name-type", + "3.1.3.1": "full-product-name-type-name", + "3.1.3.2": "full-product-name-type-product-id", + "3.1.3.3": "full-product-name-type-product-identification-helper", + "3.1.3.3.1": "full-product-name-type-product-identification-helper-cpe", + "3.1.3.3.2": "full-product-name-type-product-identification-helper-hashes", + "3.1.3.3.3": "full-product-name-type-product-identification-helper-model-numbers", + "3.1.3.3.4": "full-product-name-type-product-identification-helper-purl", + "3.1.3.3.5": "full-product-name-type-product-identification-helper-sbom-urls", + "3.1.3.3.6": "full-product-name-type-product-identification-helper-serial-numbers", + "3.1.3.3.7": "full-product-name-type-product-identification-helper-skus", + "3.1.3.3.8": "full-product-name-type-product-identification-helper-generic-uris", + "3.1.4": "language-type", + "3.1.5": "notes-type", + "3.1.6": "product-group-id-type", + "3.1.7": "product-groups-type", + "3.1.8": "product-id-type", + "3.1.9": "products-type", + "3.1.10": "references-type", + "3.1.11": "version-type", + "3.1.11.1": "version-type-integer-versioning", + "3.1.11.2": "version-type-semantic-versioning", + "3.2": "properties", + "3.2.1": "document-property", + "3.2.1.1": "document-property-acknowledgments", + "3.2.1.2": "document-property-aggregate-severity", + "3.2.1.3": "document-property-category", + "3.2.1.4": "document-property-csaf-version", + "3.2.1.5": "document-property-distribution", + "3.2.1.5.1": "document-property-distribution-text", + "3.2.1.5.2": "document-property-distribution-tlp", + "3.2.1.6": "document-property-language", + "3.2.1.7": "document-property-notes", + "3.2.1.8": "document-property-publisher", + "3.2.1.8.1": "document-property-publisher-category", + "3.2.1.8.2": "document-property-publisher-contact-details", + "3.2.1.8.3": "document-property-publisher-issuing-authority", + "3.2.1.8.4": "document-property-publisher-name", + "3.2.1.8.5": "document-property-publisher-namespace", + "3.2.1.9": "document-property-references", + "3.2.1.10": "document-property-source-language", + "3.2.1.11": "document-property-title", + "3.2.1.12": "document-property-tracking", + "3.2.1.12.1": "document-property-tracking-aliases", + "3.2.1.12.2": "document-property-tracking-current-release-date", + "3.2.1.12.3": "document-property-tracking-generator", + "3.2.1.12.4": "document-property-tracking-id", + "3.2.1.12.5": "document-property-tracking-initial-release-date", + "3.2.1.12.6": "document-property-tracking-revision-history", + "3.2.1.12.7": "document-property-tracking-status", + "3.2.1.12.8": "document-property-tracking-version", + "3.2.2": "product-tree-property", + "3.2.2.1": "product-tree-property-branches", + "3.2.2.2": "product-tree-property-full-product-names", + "3.2.2.3": "product-tree-property-product-groups", + "3.2.2.4": "product-tree-property-relationships", + "3.2.3": "vulnerabilities-property", + "3.2.3.1": "vulnerabilities-property-acknowledgments", + "3.2.3.2": "vulnerabilities-property-cve", + "3.2.3.3": "vulnerabilities-property-cwe", + "3.2.3.4": "vulnerabilities-property-discovery-date", + "3.2.3.5": "vulnerabilities-property-flags", + "3.2.3.6": "vulnerabilities-property-ids", + "3.2.3.7": "vulnerabilities-property-involvements", + "3.2.3.8": "vulnerabilities-property-notes", + "3.2.3.9": "vulnerabilities-property-product-status", + "3.2.3.10": "vulnerabilities-property-references", + "3.2.3.11": "vulnerabilities-property-release-date", + "3.2.3.12": "vulnerabilities-property-remediations", + "3.2.3.12.1": "vulnerabilities-property-remediations-category", + "3.2.3.12.2": "vulnerabilities-property-remediations-date", + "3.2.3.12.3": "vulnerabilities-property-remediations-details", + "3.2.3.12.4": "vulnerabilities-property-remediations-entitlements", + "3.2.3.12.5": "vulnerabilities-property-remediations-group-ids", + "3.2.3.12.6": "vulnerabilities-property-remediations-product-ids", + "3.2.3.12.7": "vulnerabilities-property-remediations-restart-required", + "3.2.3.12.8": "vulnerabilities-property-remediations-url", + "3.2.3.13": "vulnerabilities-property-scores", + "3.2.3.14": "vulnerabilities-property-threats", + "3.2.3.15": "vulnerabilities-property-title", + "4": "profiles", + "4.1": "profile-1-csaf-base", + "4.2": "profile-2-security-incident-response", + "4.3": "profile-3-informational-advisory", + "4.4": "profile-4-security-advisory", + "4.5": "profile-5-vex", + "5": "additional-conventions", + "5.1": "filename", + "5.2": "separation-in-data-stream", + "5.3": "additional-conventions--sorting", + "6": "tests", + "6.1": "mandatory-tests", + "6.1.1": "missing-definition-of-product-id", + "6.1.2": "multiple-definition-of-product-id", + "6.1.3": "circular-definition-of-product-id", + "6.1.4": "missing-definition-of-product-group-id", + "6.1.5": "multiple-definition-of-product-group-id", + "6.1.6": "contradicting-product-status", + "6.1.7": "multiple-scores-with-same-version-per-product", + "6.1.8": "invalid-cvss", + "6.1.9": "invalid-cvss-computation", + "6.1.10": "inconsistent-cvss", + "6.1.11": "cwe", + "6.1.12": "language", + "6.1.13": "purl", + "6.1.14": "sorted-revision-history", + "6.1.15": "translator", + "6.1.16": "latest-document-version", + "6.1.17": "document-status-draft", + "6.1.18": "released-revision-history", + "6.1.19": "revision-history-entries-for-pre-release-versions", + "6.1.20": "non-draft-document-version", + "6.1.21": "missing-item-in-revision-history", + "6.1.22": "multiple-definition-in-revision-history", + "6.1.23": "multiple-use-of-same-cve", + "6.1.24": "multiple-definition-in-involvements", + "6.1.25": "multiple-use-of-same-hash-algorithm", + "6.1.26": "prohibited-document-category-name", + "6.1.27": "profile-tests", + "6.1.27.1": "document-notes", + "6.1.27.2": "document-references", + "6.1.27.3": "vulnerabilities-for-informational-advisory", + "6.1.27.4": "product-tree", + "6.1.27.5": "vulnerability-notes", + "6.1.27.6": "product-status", + "6.1.27.7": "vex-product-status", + "6.1.27.8": "vulnerability-id", + "6.1.27.9": "impact-statement", + "6.1.27.10": "action-statement", + "6.1.27.11": "vulnerabilities-for-security-advisory-or-vex", + "6.1.28": "translation", + "6.1.29": "remediation-without-product-reference", + "6.1.30": "mixed-integer-and-semantic-versioning", + "6.1.31": "version-range-in-product-version", + "6.1.32": "flag-without-product-reference", + "6.1.33": "multiple-flags-with-vex-justification-codes-per-product", + "6.2": "optional-tests", + "6.2.1": "unused-definition-of-product-id", + "6.2.2": "missing-remediation", + "6.2.3": "missing-score", + "6.2.4": "build-metadata-in-revision-history", + "6.2.5": "older-initial-release-date-than-revision-history", + "6.2.6": "older-current-release-date-than-revision-history", + "6.2.7": "missing-date-in-involvements", + "6.2.8": "use-of-md5-as-the-only-hash-algorithm", + "6.2.9": "use-of-sha-1-as-the-only-hash-algorithm", + "6.2.10": "missing-tlp-label", + "6.2.11": "missing-canonical-url", + "6.2.12": "missing-document-language", + "6.2.13": "optional-tests--sorting", + "6.2.14": "use-of-private-language", + "6.2.15": "use-of-default-language", + "6.2.16": "missing-product-identification-helper", + "6.2.17": "cve-in-field-ids", + "6.2.18": "product-version-range-without-vers", + "6.2.19": "cvss-for-fixed-products", + "6.2.20": "additional-properties", + "6.3": "informative-test", + "6.3.1": "use-of-cvss-v2-as-the-only-scoring-system", + "6.3.2": "use-of-cvss-v3-0", + "6.3.3": "missing-cve", + "6.3.4": "missing-cwe", + "6.3.5": "use-of-short-hash", + "6.3.6": "use-of-non-self-referencing-urls-failing-to-resolve", + "6.3.7": "use-of-self-referencing-urls-failing-to-resolve", + "6.3.8": "spell-check", + "6.3.9": "branch-categories", + "6.3.10": "usage-of-product-version-range", + "6.3.11": "usage-of-v-as-version-indicator", + "7": "distributing-csaf-documents", + "7.1": "requirements", + "7.1.1": "requirement-1-valid-csaf-document", + "7.1.2": "requirement-2-filename", + "7.1.3": "requirement-3-tls", + "7.1.4": "requirement-4-tlp-white", + "7.1.5": "requirement-5-tlp-amber-and-tlp-red", + "7.1.6": "requirement-6-no-redirects", + "7.1.7": "requirement-7-provider-metadata-json", + "7.1.8": "requirement-8-security-txt", + "7.1.9": "requirement-9-well-known-url-for-provider-metadata-json", + "7.1.10": "requirement-10-dns-path", + "7.1.11": "requirement-11-one-folder-per-year", + "7.1.12": "requirement-12-index-txt", + "7.1.13": "requirement-13-changes-csv", + "7.1.14": "requirement-14-directory-listings", + "7.1.15": "requirement-15-rolie-feed", + "7.1.16": "requirement-16-rolie-service-document", + "7.1.17": "requirement-17-rolie-category-document", + "7.1.18": "requirement-18-integrity", + "7.1.19": "requirement-19-signatures", + "7.1.20": "requirement-20-public-openpgp-key", + "7.1.21": "requirement-21-list-of-csaf-providers", + "7.1.22": "requirement-22-two-disjoint-issuing-parties", + "7.1.23": "requirement-23-mirror", + "7.2": "roles", + "7.2.1": "role-csaf-publisher", + "7.2.2": "role-csaf-provider", + "7.2.3": "role-csaf-trusted-provider", + "7.2.4": "role-csaf-lister", + "7.2.5": "role-csaf-aggregator", + "7.3": "retrieving-rules", + "7.3.1": "finding-provider-metadata.json", + "7.3.2": "retrieving-csaf-documents", + "8": "safety-security-and-data-protection-considerations", + "9": "conformance", + "9.1": "conformance-targets", + "9.1.1": "conformance-clause-1-csaf-document", + "9.1.2": "conformance-clause-2-csaf-producer", + "9.1.3": "conformance-clause-3-csaf-direct-producer", + "9.1.4": "conformance-clause-4-csaf-converter", + "9.1.5": "conformance-clause-5-cvrf-csaf-converter", + "9.1.6": "conformance-clause-6-csaf-content-management-system", + "9.1.7": "conformance-clause-7-csaf-post-processor", + "9.1.8": "conformance-clause-8-csaf-modifier", + "9.1.9": "conformance-clause-9-csaf-translator", + "9.1.10": "conformance-clause-10-csaf-consumer", + "9.1.11": "conformance-clause-11-csaf-viewer", + "9.1.12": "conformance-clause-12-csaf-management-system", + "9.1.13": "conformance-clause-13-csaf-asset-matching-system", + "9.1.14": "conformance-clause-14-csaf-basic-validator", + "9.1.15": "conformance-clause-15-csaf-extended-validator", + "9.1.16": "conformance-clause-16-csaf-full-validator", + "9.1.17": "conformance-clause-17-csaf-sbom-matching-system", + "Appendix A.": "acknowledgments", + "Appendix B.": "revision-history", + "Appendix C.": "guidance-on-the-size-of-csaf-documents", + "C.1": "file-size", + "C.2": "array-length", + "C.3": "string-length", + "C.4": "uri-length", + "C.5": "enum", + "C.6": "date" +} diff --git a/csaf_2.1/prose/edit/etc/section-label-to-display.json b/csaf_2.1/prose/edit/etc/section-label-to-display.json new file mode 100644 index 000000000..6b34e181e --- /dev/null +++ b/csaf_2.1/prose/edit/etc/section-label-to-display.json @@ -0,0 +1,257 @@ +{ + "acknowledgments": "Appendix A.", + "acknowledgments-type": "3.1.1", + "acknowledgments-type-example": "3.1.1.5", + "acknowledgments-type-names": "3.1.1.1", + "acknowledgments-type-organization": "3.1.1.2", + "acknowledgments-type-summary": "3.1.1.3", + "acknowledgments-type-urls": "3.1.1.4", + "action-statement": "6.1.27.10", + "additional-conventions": "5", + "additional-conventions--sorting": "5.3", + "additional-properties": "6.2.20", + "array-length": "C.2", + "branch-categories": "6.3.9", + "branches-type": "3.1.2", + "branches-type-branches": "3.1.2.1", + "branches-type-category": "3.1.2.2", + "branches-type-name": "3.1.2.3", + "branches-type-name-under-product-version": "3.1.2.3.1", + "branches-type-name-under-product-version-range": "3.1.2.3.2", + "branches-type-product": "3.1.2.4", + "build-metadata-in-revision-history": "6.2.4", + "circular-definition-of-product-id": "6.1.3", + "conformance": "9", + "conformance-clause-1-csaf-document": "9.1.1", + "conformance-clause-10-csaf-consumer": "9.1.10", + "conformance-clause-11-csaf-viewer": "9.1.11", + "conformance-clause-12-csaf-management-system": "9.1.12", + "conformance-clause-13-csaf-asset-matching-system": "9.1.13", + "conformance-clause-14-csaf-basic-validator": "9.1.14", + "conformance-clause-15-csaf-extended-validator": "9.1.15", + "conformance-clause-16-csaf-full-validator": "9.1.16", + "conformance-clause-17-csaf-sbom-matching-system": "9.1.17", + "conformance-clause-2-csaf-producer": "9.1.2", + "conformance-clause-3-csaf-direct-producer": "9.1.3", + "conformance-clause-4-csaf-converter": "9.1.4", + "conformance-clause-5-cvrf-csaf-converter": "9.1.5", + "conformance-clause-6-csaf-content-management-system": "9.1.6", + "conformance-clause-7-csaf-post-processor": "9.1.7", + "conformance-clause-8-csaf-modifier": "9.1.8", + "conformance-clause-9-csaf-translator": "9.1.9", + "conformance-targets": "9.1", + "construction-principles": "2.1", + "contradicting-product-status": "6.1.6", + "cve-in-field-ids": "6.2.17", + "cvss-for-fixed-products": "6.2.19", + "cwe": "6.1.11", + "date": "C.6", + "definitions": "3.1", + "design-considerations": "2", + "distributing-csaf-documents": "7", + "document-notes": "6.1.27.1", + "document-property": "3.2.1", + "document-property-acknowledgments": "3.2.1.1", + "document-property-aggregate-severity": "3.2.1.2", + "document-property-category": "3.2.1.3", + "document-property-csaf-version": "3.2.1.4", + "document-property-distribution": "3.2.1.5", + "document-property-distribution-text": "3.2.1.5.1", + "document-property-distribution-tlp": "3.2.1.5.2", + "document-property-language": "3.2.1.6", + "document-property-notes": "3.2.1.7", + "document-property-publisher": "3.2.1.8", + "document-property-publisher-category": "3.2.1.8.1", + "document-property-publisher-contact-details": "3.2.1.8.2", + "document-property-publisher-issuing-authority": "3.2.1.8.3", + "document-property-publisher-name": "3.2.1.8.4", + "document-property-publisher-namespace": "3.2.1.8.5", + "document-property-references": "3.2.1.9", + "document-property-source-language": "3.2.1.10", + "document-property-title": "3.2.1.11", + "document-property-tracking": "3.2.1.12", + "document-property-tracking-aliases": "3.2.1.12.1", + "document-property-tracking-current-release-date": "3.2.1.12.2", + "document-property-tracking-generator": "3.2.1.12.3", + "document-property-tracking-id": "3.2.1.12.4", + "document-property-tracking-initial-release-date": "3.2.1.12.5", + "document-property-tracking-revision-history": "3.2.1.12.6", + "document-property-tracking-status": "3.2.1.12.7", + "document-property-tracking-version": "3.2.1.12.8", + "document-references": "6.1.27.2", + "document-status-draft": "6.1.17", + "enum": "C.5", + "file-size": "C.1", + "filename": "5.1", + "finding-provider-metadata.json": "7.3.1", + "flag-without-product-reference": "6.1.32", + "full-product-name-type": "3.1.3", + "full-product-name-type-name": "3.1.3.1", + "full-product-name-type-product-id": "3.1.3.2", + "full-product-name-type-product-identification-helper": "3.1.3.3", + "full-product-name-type-product-identification-helper-cpe": "3.1.3.3.1", + "full-product-name-type-product-identification-helper-generic-uris": "3.1.3.3.8", + "full-product-name-type-product-identification-helper-hashes": "3.1.3.3.2", + "full-product-name-type-product-identification-helper-model-numbers": "3.1.3.3.3", + "full-product-name-type-product-identification-helper-purl": "3.1.3.3.4", + "full-product-name-type-product-identification-helper-sbom-urls": "3.1.3.3.5", + "full-product-name-type-product-identification-helper-serial-numbers": "3.1.3.3.6", + "full-product-name-type-product-identification-helper-skus": "3.1.3.3.7", + "guidance-on-the-size-of-csaf-documents": "Appendix C.", + "impact-statement": "6.1.27.9", + "inconsistent-cvss": "6.1.10", + "informative-references": "1.4", + "informative-test": "6.3", + "introduction": "1", + "invalid-cvss": "6.1.8", + "invalid-cvss-computation": "6.1.9", + "ipr-policy": "1.1", + "language": "6.1.12", + "language-type": "3.1.4", + "latest-document-version": "6.1.16", + "mandatory-tests": "6.1", + "missing-canonical-url": "6.2.11", + "missing-cve": "6.3.3", + "missing-cwe": "6.3.4", + "missing-date-in-involvements": "6.2.7", + "missing-definition-of-product-group-id": "6.1.4", + "missing-definition-of-product-id": "6.1.1", + "missing-document-language": "6.2.12", + "missing-item-in-revision-history": "6.1.21", + "missing-product-identification-helper": "6.2.16", + "missing-remediation": "6.2.2", + "missing-score": "6.2.3", + "missing-tlp-label": "6.2.10", + "mixed-integer-and-semantic-versioning": "6.1.30", + "multiple-definition-in-involvements": "6.1.24", + "multiple-definition-in-revision-history": "6.1.22", + "multiple-definition-of-product-group-id": "6.1.5", + "multiple-definition-of-product-id": "6.1.2", + "multiple-flags-with-vex-justification-codes-per-product": "6.1.33", + "multiple-scores-with-same-version-per-product": "6.1.7", + "multiple-use-of-same-cve": "6.1.23", + "multiple-use-of-same-hash-algorithm": "6.1.25", + "non-draft-document-version": "6.1.20", + "normative-references": "1.3", + "notes-type": "3.1.5", + "older-current-release-date-than-revision-history": "6.2.6", + "older-initial-release-date-than-revision-history": "6.2.5", + "optional-tests": "6.2", + "optional-tests--sorting": "6.2.13", + "product-group-id-type": "3.1.6", + "product-groups-type": "3.1.7", + "product-id-type": "3.1.8", + "product-status": "6.1.27.6", + "product-tree": "6.1.27.4", + "product-tree-property": "3.2.2", + "product-tree-property-branches": "3.2.2.1", + "product-tree-property-full-product-names": "3.2.2.2", + "product-tree-property-product-groups": "3.2.2.3", + "product-tree-property-relationships": "3.2.2.4", + "product-version-range-without-vers": "6.2.18", + "products-type": "3.1.9", + "profile-1-csaf-base": "4.1", + "profile-2-security-incident-response": "4.2", + "profile-3-informational-advisory": "4.3", + "profile-4-security-advisory": "4.4", + "profile-5-vex": "4.5", + "profile-tests": "6.1.27", + "profiles": "4", + "prohibited-document-category-name": "6.1.26", + "properties": "3.2", + "purl": "6.1.13", + "references-type": "3.1.10", + "released-revision-history": "6.1.18", + "remediation-without-product-reference": "6.1.29", + "requirement-1-valid-csaf-document": "7.1.1", + "requirement-10-dns-path": "7.1.10", + "requirement-11-one-folder-per-year": "7.1.11", + "requirement-12-index-txt": "7.1.12", + "requirement-13-changes-csv": "7.1.13", + "requirement-14-directory-listings": "7.1.14", + "requirement-15-rolie-feed": "7.1.15", + "requirement-16-rolie-service-document": "7.1.16", + "requirement-17-rolie-category-document": "7.1.17", + "requirement-18-integrity": "7.1.18", + "requirement-19-signatures": "7.1.19", + "requirement-2-filename": "7.1.2", + "requirement-20-public-openpgp-key": "7.1.20", + "requirement-21-list-of-csaf-providers": "7.1.21", + "requirement-22-two-disjoint-issuing-parties": "7.1.22", + "requirement-23-mirror": "7.1.23", + "requirement-3-tls": "7.1.3", + "requirement-4-tlp-white": "7.1.4", + "requirement-5-tlp-amber-and-tlp-red": "7.1.5", + "requirement-6-no-redirects": "7.1.6", + "requirement-7-provider-metadata-json": "7.1.7", + "requirement-8-security-txt": "7.1.8", + "requirement-9-well-known-url-for-provider-metadata-json": "7.1.9", + "requirements": "7.1", + "retrieving-csaf-documents": "7.3.2", + "retrieving-rules": "7.3", + "revision-history": "Appendix B.", + "revision-history-entries-for-pre-release-versions": "6.1.19", + "role-csaf-aggregator": "7.2.5", + "role-csaf-lister": "7.2.4", + "role-csaf-provider": "7.2.2", + "role-csaf-publisher": "7.2.1", + "role-csaf-trusted-provider": "7.2.3", + "roles": "7.2", + "safety-security-and-data-protection-considerations": "8", + "schema-elements": "3", + "separation-in-data-stream": "5.2", + "sorted-revision-history": "6.1.14", + "spell-check": "6.3.8", + "string-length": "C.3", + "terminology": "1.2", + "tests": "6", + "translation": "6.1.28", + "translator": "6.1.15", + "typographical-conventions": "1.5", + "unused-definition-of-product-id": "6.2.1", + "uri-length": "C.4", + "usage-of-product-version-range": "6.3.10", + "usage-of-v-as-version-indicator": "6.3.11", + "use-of-cvss-v2-as-the-only-scoring-system": "6.3.1", + "use-of-cvss-v3-0": "6.3.2", + "use-of-default-language": "6.2.15", + "use-of-md5-as-the-only-hash-algorithm": "6.2.8", + "use-of-non-self-referencing-urls-failing-to-resolve": "6.3.6", + "use-of-private-language": "6.2.14", + "use-of-self-referencing-urls-failing-to-resolve": "6.3.7", + "use-of-sha-1-as-the-only-hash-algorithm": "6.2.9", + "use-of-short-hash": "6.3.5", + "version-range-in-product-version": "6.1.31", + "version-type": "3.1.11", + "version-type-integer-versioning": "3.1.11.1", + "version-type-semantic-versioning": "3.1.11.2", + "vex-product-status": "6.1.27.7", + "vulnerabilities-for-informational-advisory": "6.1.27.3", + "vulnerabilities-for-security-advisory-or-vex": "6.1.27.11", + "vulnerabilities-property": "3.2.3", + "vulnerabilities-property-acknowledgments": "3.2.3.1", + "vulnerabilities-property-cve": "3.2.3.2", + "vulnerabilities-property-cwe": "3.2.3.3", + "vulnerabilities-property-discovery-date": "3.2.3.4", + "vulnerabilities-property-flags": "3.2.3.5", + "vulnerabilities-property-ids": "3.2.3.6", + "vulnerabilities-property-involvements": "3.2.3.7", + "vulnerabilities-property-notes": "3.2.3.8", + "vulnerabilities-property-product-status": "3.2.3.9", + "vulnerabilities-property-references": "3.2.3.10", + "vulnerabilities-property-release-date": "3.2.3.11", + "vulnerabilities-property-remediations": "3.2.3.12", + "vulnerabilities-property-remediations-category": "3.2.3.12.1", + "vulnerabilities-property-remediations-date": "3.2.3.12.2", + "vulnerabilities-property-remediations-details": "3.2.3.12.3", + "vulnerabilities-property-remediations-entitlements": "3.2.3.12.4", + "vulnerabilities-property-remediations-group-ids": "3.2.3.12.5", + "vulnerabilities-property-remediations-product-ids": "3.2.3.12.6", + "vulnerabilities-property-remediations-restart-required": "3.2.3.12.7", + "vulnerabilities-property-remediations-url": "3.2.3.12.8", + "vulnerabilities-property-scores": "3.2.3.13", + "vulnerabilities-property-threats": "3.2.3.14", + "vulnerabilities-property-title": "3.2.3.15", + "vulnerability-id": "6.1.27.8", + "vulnerability-notes": "6.1.27.5" +} diff --git a/csaf_2.1/prose/edit/src/acknowledgements.md b/csaf_2.1/prose/edit/src/acknowledgements.md index 97c4abbc4..5efbc52f7 100644 --- a/csaf_2.1/prose/edit/src/acknowledgements.md +++ b/csaf_2.1/prose/edit/src/acknowledgements.md @@ -6,7 +6,7 @@ toc: enumerate: Appendix A. --- --> -# Appendix A. Acknowledgments +# Acknowledgments The following individuals were members of the OASIS CSAF Technical Committee during the creation of this specification and their contributions are gratefully acknowledged: diff --git a/csaf_2.1/prose/edit/src/additional-conventions.md b/csaf_2.1/prose/edit/src/additional-conventions.md index be0577c44..9a0dbc098 100644 --- a/csaf_2.1/prose/edit/src/additional-conventions.md +++ b/csaf_2.1/prose/edit/src/additional-conventions.md @@ -1,8 +1,8 @@ -# 5 Additional Conventions +# Additional Conventions This section provides additional rules for handling CSAF documents. -## 5.1 Filename +## Filename The following rules MUST be applied to determine the filename for the CSAF document: @@ -34,11 +34,11 @@ The following rules MUST be applied to determine the filename for the CSAF docum rhba-2019_0024_invalid.json ``` -## 5.2 Separation in Data Stream +## Separation in Data Stream If multiple CSAF documents are transported via a data stream in a sequence without requests inbetween, they MUST be separated by the Record Separator in accordance with [RFC7464]. -## 5.3 Sorting +## Sorting{#additional-conventions--sorting} The keys within a CSAF document SHOULD be sorted alphabetically. diff --git a/csaf_2.1/prose/edit/src/conformance.md b/csaf_2.1/prose/edit/src/conformance.md index 223b8df03..fd1521f57 100644 --- a/csaf_2.1/prose/edit/src/conformance.md +++ b/csaf_2.1/prose/edit/src/conformance.md @@ -1,4 +1,4 @@ -# 9 Conformance +# Conformance In the only subsection of this section, the conformance targets and clauses are listed. The clauses, matching the targets one to one, are listed in separate sub-subsections of the targets listing subsection. @@ -17,7 +17,7 @@ Informative Comments: > * Clear baseline across the communities per this specification > * Additional per-community cooperative extensions which may flow back into future updates of this specification -## 9.1 Conformance Targets +## Conformance Targets This document defines requirements for the CSAF file format and for certain software components that interact with it. The entities ("conformance targets") for which this document defines requirements are: @@ -40,7 +40,7 @@ The entities ("conformance targets") for which this document defines requirement * **CSAF full validator**: A CSAF extended validator that additionally performs informative tests. * **CSAF SBOM matching system**: A program that connects to or is an SBOM database and is able to manage CSAF documents as required by CSAF management system as well as matching them to SBOM components of the SBOM database. -### 9.1.1 Conformance Clause 1: CSAF document +### Conformance Clause 1: CSAF document A text file or data stream satisfies the "CSAF document" conformance profile if it: @@ -48,14 +48,14 @@ A text file or data stream satisfies the "CSAF document" conformance profile if * satisfies at least one profile defined in section 4. * does not fail any mandatory test defined in section 6.1. -### 9.1.2 Conformance Clause 2: CSAF producer +### Conformance Clause 2: CSAF producer A program satisfies the "CSAF producer" conformance profile if the program: * produces output in the CSAF format, according to the conformance profile "CSAF document" . * satisfies those normative requirements in section 3 and 8 that are designated as applying to CSAF producers. -### 9.1.3 Conformance Clause 3: CSAF direct producer +### Conformance Clause 3: CSAF direct producer An analysis tool satisfies the "CSAF direct producer" conformance profile if the analysis tool: @@ -63,7 +63,7 @@ An analysis tool satisfies the "CSAF direct producer" conformance profile if the * additionally satisfies those normative requirements in section 3 that are designated as applying to "direct producers" or to "analysis tools". * does not emit any objects, properties, or values which, according to section 3, are intended to be produced only by converters. -### 9.1.4 Conformance Clause 4: CSAF converter +### Conformance Clause 4: CSAF converter A converter satisfies the “CSAF converter” conformance profile if the converter: @@ -71,7 +71,7 @@ A converter satisfies the “CSAF converter” conformance profile if the conver * additionally satisfies those normative requirements in section 3 that are designated as applying to converters. * does not emit any objects, properties, or values which, according to section 3, are intended to be produced only by direct producers. -### 9.1.5 Conformance Clause 5: CVRF CSAF converter +### Conformance Clause 5: CVRF CSAF converter A program satisfies the "CVRF CSAF converter" conformance profile if the program fulfills the following two groups of requirements: @@ -135,7 +135,7 @@ Secondly, the program fulfills the following for all items of: 4. Retrieve the CVSS version from a config value, which defaults to `3.0`. (As CSAF CVRF v1.2 predates CVSS v3.1.) The CVRF CSAF converter outputs a warning that this value was taken from the config. -### 9.1.6 Conformance Clause 6: CSAF content management system +### Conformance Clause 6: CSAF content management system A CSAF content management system satisfies the "CSAF content management system" conformance profile if the content management system: @@ -222,7 +222,7 @@ A CSAF content management system satisfies the "CSAF content management system" * `/document/tracking/version` with the value of `number` the latest `/document/tracking/revision_history[]` element * `/document/publisher` and children -### 9.1.7 Conformance Clause 7: CSAF post-processor +### Conformance Clause 7: CSAF post-processor A CSAF post-processor satisfies the "CSAF post-processor" conformance profile if the post-processor: @@ -230,7 +230,7 @@ A CSAF post-processor satisfies the "CSAF post-processor" conformance profile if * satisfies the "CSAF producer" conformance profile. * additionally satisfies those normative requirements in section 3 that are designated as applying to post-processors. -### 9.1.8 Conformance Clause 8: CSAF modifier +### Conformance Clause 8: CSAF modifier A program satisfies the "CSAF modifier" conformance profile if the program fulfills the two following groups of requirements: @@ -246,7 +246,7 @@ The resulting modified document: * does not have the same `/document/tracking/id` as the original document. The modified document can use a completely new `/document/tracking/id` or compute one by appending the original `/document/tracking/id` as a suffix after an ID from the naming scheme of the issuer of the modified version. It SHOULD NOT use the original `/document/tracking/id` as a prefix. * includes a reference to the original advisory as first element of the array `/document/references[]`. -### 9.1.9 Conformance Clause 9: CSAF translator +### Conformance Clause 9: CSAF translator A program satisfies the "CSAF translator" conformance profile if the program fulfills the two following groups of requirements: @@ -266,14 +266,14 @@ The resulting translated document: * includes a reference to the original advisory as first element of the array `/document/references[]`. * MAY contain translations for elements in arrays of `references_t` after the first element. However, it MUST keep the original URLs as references at the end. -### 9.1.10 Conformance Clause 10: CSAF consumer +### Conformance Clause 10: CSAF consumer A processor satisfies the "CSAF consumer" conformance profile if the processor: * reads CSAF documents and interprets them according to the semantics defined in section 3. * satisfies those normative requirements in section 3 and 8 that are designated as applying to CSAF consumers. -### 9.1.11 Conformance Clause 11: CSAF viewer +### Conformance Clause 11: CSAF viewer A viewer satisfies the "CSAF viewer" conformance profile if the viewer fulfills the two following groups of requirements: @@ -287,7 +287,7 @@ For each CVSS-Score in `/vulnerabilities[]/scores[]` the viewer: * preferably shows the `vector` if there is an inconsistency between the `vector` and any other sibling attribute. * SHOULD prefer the item of `scores[]` for each `product_id` which has the highest CVSS Base Score and newest CVSS version (in that order) if a `product_id` is listed in more than one item of `scores[]`. -### 9.1.12 Conformance Clause 12: CSAF management system +### Conformance Clause 12: CSAF management system A CSAF management system satisfies the "CSAF management system" conformance profile if the management system: @@ -307,7 +307,7 @@ A CSAF management system satisfies the "CSAF management system" conformance prof * identifies the latest version of CSAF documents with the same `/document/tracking/id`. * is able to show the difference between 2 versions of a CSAF document with the same `/document/tracking/id`. -### 9.1.13 Conformance Clause 13: CSAF asset matching system +### Conformance Clause 13: CSAF asset matching system A CSAF asset matching system satisfies the "CSAF asset matching system" conformance profile if the asset matching system: @@ -337,7 +337,7 @@ A CSAF asset matching system satisfies the "CSAF asset matching system" conforma * matching that CSAF document at all * marked with a given status -### 9.1.14 Conformance Clause 14: CSAF basic validator +### Conformance Clause 14: CSAF basic validator A program satisfies the "CSAF basic validator" conformance profile if the program: @@ -351,7 +351,7 @@ A CSAF basic validator MAY provide one or more additional functions: * Apply quick fixes as specified in the standard. * Apply additional quick fixes as implemented by the vendor. -### 9.1.15 Conformance Clause 15: CSAF extended validator +### Conformance Clause 15: CSAF extended validator A CSAF basic validator satisfies the "CSAF extended validator" conformance profile if the CSAF basic validator: @@ -360,7 +360,7 @@ A CSAF basic validator satisfies the "CSAF extended validator" conformance profi A CSAF extended validator MAY provide an additional function to only run one or more selected optional tests. -### 9.1.16 Conformance Clause 16: CSAF full validator +### Conformance Clause 16: CSAF full validator A CSAF extended validator satisfies the "CSAF full validator" conformance profile if the CSAF extended validator: @@ -369,7 +369,7 @@ A CSAF extended validator satisfies the "CSAF full validator" conformance profil A CSAF full validator MAY provide an additional function to only run one or more selected informative tests. -### 9.1.17 Conformance Clause 17: CSAF SBOM matching system +### Conformance Clause 17: CSAF SBOM matching system A CSAF SBOM matching system satisfies the "CSAF SBOM matching system" conformance profile if the SBOM matching system: diff --git a/csaf_2.1/prose/edit/src/design-considerations-00.md b/csaf_2.1/prose/edit/src/design-considerations-00.md index 48882ed79..162c851cc 100644 --- a/csaf_2.1/prose/edit/src/design-considerations-00.md +++ b/csaf_2.1/prose/edit/src/design-considerations-00.md @@ -1,4 +1,4 @@ -# 2 Design Considerations +# Design Considerations The Common Security Advisory Framework (CSAF) is a language to exchange Security Advisories formulated in JSON. diff --git a/csaf_2.1/prose/edit/src/design-considerations-01-construction-principles.md b/csaf_2.1/prose/edit/src/design-considerations-01-construction-principles.md index c54e30ace..0396545af 100644 --- a/csaf_2.1/prose/edit/src/design-considerations-01-construction-principles.md +++ b/csaf_2.1/prose/edit/src/design-considerations-01-construction-principles.md @@ -1,4 +1,4 @@ -## 2.1 Construction Principles +## Construction Principles A Security Advisory defined as a CSAF document is the result of complex orchestration of many players and distinct and partially difficult to play schemas. diff --git a/csaf_2.1/prose/edit/src/distributing.md b/csaf_2.1/prose/edit/src/distributing.md index 27ef26fec..63bd75194 100644 --- a/csaf_2.1/prose/edit/src/distributing.md +++ b/csaf_2.1/prose/edit/src/distributing.md @@ -1,24 +1,24 @@ -# 7 Distributing CSAF documents +# Distributing CSAF documents This section lists requirements and roles defined for distributing CSAF documents. The first subsection provides all requirements - the second one the roles. It is mandatory to fulfill the basic role "CSAF publisher". The last section provides specific rules for the process of retrieving CSAF documents. -## 7.1 Requirements +## Requirements The requirements in this subsection are consecutively numbered to be able to refer to them directly. The order does not give any hint about the importance. Not all requirements have to be fulfilled to conform to this specification - the sets of requirements per conformance clause are defined in section 7.2. -### 7.1.1 Requirement 1: Valid CSAF document +### Requirement 1: Valid CSAF document The document is a valid CSAF document (cf. Conformance clause 1). -### 7.1.2 Requirement 2: Filename +### Requirement 2: Filename The CSAF document has a filename according to the rules in section 5.1. -### 7.1.3 Requirement 3: TLS +### Requirement 3: TLS The CSAF document is per default retrievable from a website which uses TLS for encryption and server authenticity. The CSAF document MUST NOT be downloadable from a location which does not encrypt the transport when crossing organizational boundaries to maintain the chain of custody. -### 7.1.4 Requirement 4: TLP:WHITE +### Requirement 4: TLP:WHITE If the CSAF document is labeled TLP:WHITE, it MUST be freely accessible. @@ -26,19 +26,19 @@ This does not exclude that such a document is also available in an access protec > Reasoning: If an advisory is already in the media, an end user should not be forced to collect the pieces of information from a press release but be able to retrieve the CSAF document. -### 7.1.5 Requirement 5: TLP:AMBER and TLP:RED +### Requirement 5: TLP:AMBER and TLP:RED CSAF documents labeled TLP:AMBER or TLP:RED MUST be access protected. If they are provided via a web server this SHALL be done under a different path than for TLP:WHITE, TLP:GREEN and unlabeled CSAF documents. TLS client authentication, access tokens or any other automatable authentication method SHALL be used. An issuing party MAY agree with the recipients to use any kind of secured drop at the recipients' side to avoid putting them on their own website. However, it MUST be ensured that the documents are still access protected. -### 7.1.6 Requirement 6: No Redirects +### Requirement 6: No Redirects Redirects SHOULD NOT be used. If they are inevitable only HTTP Header redirects are allowed. > Reasoning: Clients should not parse the payload for navigation and some, as e.g. `curl`, do not follow any other kind of redirects. -### 7.1.7 Requirement 7: provider-metadata.json +### Requirement 7: provider-metadata.json The party MUST provide a valid `provider-metadata.json` according to the schema [CSAF provider metadata](https://docs.oasis-open.org/csaf/csaf/v2.0/provider_json_schema.json) for its own metadata. The `publisher` object SHOULD match the one used in the CSAF documents of the issuing party but can be set to whatever value a CSAF aggregator SHOULD display over any individual `publisher` values in the CSAF documents themselves. @@ -99,7 +99,7 @@ If a CSAF publisher (cf. section 7.2.1) does not provide the `provider-metadata. > This prevents that CSAF documents of a CSAF publisher which have been collected by one CSAF aggregator A are mirrored again on a second CSAF aggregator B. Such cascades are prone to outdated information. > If the first aggregator A collects the CSAF documents on best effort and B copies the files from A and announces that this is done weekly, one might assume that B's CSAF documents are more recent. However, that is not the case as B's information depends on A. -### 7.1.8 Requirement 8: security.txt +### Requirement 8: security.txt In the security.txt there MUST be at least one field `CSAF` which points to the `provider-metadata.json` (requirement 7). If this field indicates a web URI, then it MUST begin with "https://" (as per section 2.7.2 of [RFC7230]). See [SECURITY-TXT] for more details. @@ -116,7 +116,7 @@ CSAF: https://www.example.com/.well-known/csaf/provider-metadata.json It is possible to advertise more than one `provider-metadata.json` by adding multiple `CSAF` fields, e.g. in case of changes to the organizational structure through merges or acquisitions. However, this SHOULD NOT be done and removed as soon as possible. If one of the URLs fulfills requirement 9, this MUST be used as the first CSAF entry in the security.txt. -### 7.1.9 Requirement 9: Well-known URL for provider-metadata.json +### Requirement 9: Well-known URL for provider-metadata.json The URL path `/.well-known/csaf/provider-metadata.json` under the main domain of the issuing authority serves directly the `provider-metadata.json` according to requirement 7. The use of the scheme "HTTPS" is required. See [RFC8615] for more details. @@ -126,11 +126,11 @@ The URL path `/.well-known/csaf/provider-metadata.json` under the main domain of https://www.example.com/.well-known/csaf/provider-metadata.json ``` -### 7.1.10 Requirement 10: DNS path +### Requirement 10: DNS path The DNS record `csaf.data.security.domain.tld` SHALL resolve as a web server which serves directly the `provider-metadata.json` according to requirement 7. The use of the scheme "HTTPS" is required. -### 7.1.11 Requirement 11: One folder per year +### Requirement 11: One folder per year The CSAF documents MUST be located within folders named `` where `` is the year given in the value of `/document/tracking/initial_release_date`. @@ -141,7 +141,7 @@ The CSAF documents MUST be located within folders named `` where `` 2020 ``` -### 7.1.12 Requirement 12: index.txt +### Requirement 12: index.txt The index.txt file within MUST provide a list of all filenames of CSAF documents which are located in the sub-directories with their filenames. @@ -155,7 +155,7 @@ The index.txt file within MUST provide a list of all filenames of CSAF documents > This can be used to download all CSAF documents. -### 7.1.13 Requirement 13: changes.csv +### Requirement 13: changes.csv The file changes.csv MUST contain the filename as well as the value of `/document/tracking/current_release_date` for each CSAF document in the sub-directories without a heading; lines MUST be sorted by the `current_release_date` timestamp with the latest one first. @@ -168,11 +168,11 @@ The file changes.csv MUST contain the filename as well as the value of `/documen "2018/example_company_-_2018-yh2312.json","2019-03-01T06:01:00Z" ``` -### 7.1.14 Requirement 14: Directory listings +### Requirement 14: Directory listings Directory listing SHALL be enabled to support manual navigation. -### 7.1.15 Requirement 15: ROLIE feed +### Requirement 15: ROLIE feed Resource-Oriented Lightweight Information Exchange (ROLIE) is a standard to ease discovery of security content. ROLIE is built on top of the Atom Publishing Format and Protocol, with specific requirements that support publishing security content. All CSAF documents with the same TLP level MUST be listed in a single ROLIE feed. At least one of the feeds @@ -242,7 +242,7 @@ MUST exist. Each ROLIE feed document MUST be a JSON file that conforms with [RFC Any existing hash file (requirement 18) MUST be listed in the corresponding entry of the ROLIE feed as an item of the array `link` having the `rel` value of `hash`. Any existing signature file (requirement 19) MUST be listed in the corresponding entry of the ROLIE feed as an item of the array `link` having the `rel` value of `signature`. -### 7.1.16 Requirement 16: ROLIE service document +### Requirement 16: ROLIE service document The use and therefore the existence of ROLIE service document is optional. If it is used, each ROLIE service document MUST be a JSON file that conforms with [RFC8322] and lists the ROLIE feed documents. @@ -274,7 +274,7 @@ The use and therefore the existence of ROLIE service document is optional. If it } ``` -### 7.1.17 Requirement 17: ROLIE category document +### Requirement 17: ROLIE category document The use and therefore the existence of ROLIE category document is optional. If it is used, each ROLIE category document MUST be a JSON file that conforms with [RFC8322]. ROLIE categories SHOULD be used for to further dissect CSAF documents by one or more of the following criteria: @@ -334,7 +334,7 @@ The use and therefore the existence of ROLIE category document is optional. If i } ``` -### 7.1.18 Requirement 18: Integrity +### Requirement 18: Integrity All CSAF documents SHALL have at least one hash file computed with a secure cryptographic hash algorithm (e.g. SHA-512 or SHA-3) to ensure their integrity. The filename is constructed by appending the file extension which is given by the algorithm. @@ -358,7 +358,7 @@ ea6a209dba30a958a78d82309d6cdcc6929fcb81673b3dc4d6b16fac18b6ff38 example_compan If a ROLIE feed exists, each hash file MUST be listed in it as described in requirement 15. -### 7.1.19 Requirement 19: Signatures +### Requirement 19: Signatures All CSAF documents SHALL have at least one OpenPGP signature file which is provided under the same filename which is extended by the appropriate extension. See [RFC4880] for more details. @@ -371,7 +371,7 @@ File name of signature file: example_company_-_2019-yh3234.json.asc If a ROLIE feed exists, each signature file MUST be listed in it as described in requirement 15. -### 7.1.20 Requirement 20: Public OpenPGP Key +### Requirement 20: Public OpenPGP Key The public part of the OpenPGP key used to sign the CSAF documents MUST be available. It SHOULD also be available at a public key server. @@ -381,7 +381,7 @@ The OpenPGP key SHOULD have a strength that is considered secure. > Guidance on OpenPGP key strength can be retrieved from technical guidelines of competent authorities. -### 7.1.21 Requirement 21: List of CSAF providers +### Requirement 21: List of CSAF providers The file `aggregator.json` MUST be present and valid according to the JSON schema [CSAF aggregator](https://docs.oasis-open.org/csaf/csaf/v2.0/aggregator_json_schema.json). It MUST NOT be stored adjacent to a `provider-metadata.json`. @@ -435,11 +435,11 @@ The file `aggregator.json` SHOULD only list the latest version of the metadata o } ``` -### 7.1.22 Requirement 22: Two disjoint issuing parties +### Requirement 22: Two disjoint issuing parties The file `aggregator.json` (requirement 21) lists at least two disjoint CSAF providers (including CSAF trusted providers) or one CSAF publisher and one CSAF provider (including CSAF trusted provider). -### 7.1.23 Requirement 23: Mirror +### Requirement 23: Mirror The CSAF documents for each issuing party that is mirrored MUST be in a different folder. The folder name SHOULD be retrieved from the name of the issuing authority. This folders MUST be adjacent to the `aggregator.json` (requirement 21). Each such folder MUST at least: @@ -493,7 +493,7 @@ The CSAF documents for each issuing party that is mirrored MUST be in a differen } ``` -## 7.2 Roles +## Roles This subsection groups the requirements from the previous subsection into named sets which target the roles with the same name. This allows end users to request their suppliers to fulfill a certain set of requirements. A supplier can use roles for advertising and marketing. @@ -506,14 +506,14 @@ Issuing parties MUST indicate through the value `false` in `mirror_on_CSAF_aggre The values are independent. The combination of the value `false` in `list_on_CSAF_aggregators` and `true` in `mirror_on_CSAF_aggregators` implies that the issuing party does not want to be listed without having the CSAF documents mirrored. Therefore, a CSAF aggregator can list that issuing party if it mirrors the files. -### 7.2.1 Role: CSAF publisher +### Role: CSAF publisher A distributing party satisfies the "CSAF publisher" role if the party: * satisfies the requirements 1 to 4 in section 7.1. * distributes only CSAF documents on behalf of its own. -### 7.2.2 Role: CSAF provider +### Role: CSAF provider A CSAF publisher satisfies the "CSAF provider" role if the party fulfills the following three groups of requirements: @@ -532,14 +532,14 @@ Thirdly, the party: > If the party uses the ROLIE-based distribution, it MUST also satisfy requirements 15 to 17. If it uses the directory-based distribution, it MUST also satisfy requirements 11 to 14. -### 7.2.3 Role: CSAF trusted provider +### Role: CSAF trusted provider A CSAF provider satisfies the "CSAF trusted provider" role if the party: * satisfies the "CSAF provider" role profile. * additionally satisfies the requirements 18 to 20 in section 7.1. -### 7.2.4 Role: CSAF lister +### Role: CSAF lister A distributing party satisfies the "CSAF lister" role if the party: @@ -549,7 +549,7 @@ A distributing party satisfies the "CSAF lister" role if the party: > The purpose of this role is to provide a list of URLs where to find CSAF documents. It is not assumed that the list will be complete. -### 7.2.5 Role: CSAF aggregator +### Role: CSAF aggregator A distributing party satisfies the "CSAF aggregator" role if the party: @@ -568,13 +568,13 @@ Additionally, a CSAF aggregator MAY list one or more issuing parties that it doe > The purpose of this option is that a consumer can retrieve CSAF documents from a CSAF publisher as if this issuing party would be a CSAF trusted provider. To reach that goal, a CSAF aggregator collects the CSAF documents from the CSAF publisher and mirrors it. The collection process MAY be automated or manual. CSAF aggregators announce the collection interval through the field `update_interval` in the corresponding item of the CSAF publishers list (`csaf_publishers`) in their `aggregator.json`. > To minimize the implementation efforts and process overhead, a CSAF aggregator MAY upload the CSAF documents of a CSAF publisher into an internal instance of a CSAF provider software. Such construct is called "CSAF proxy provider" as it can be mirrored by the CSAF aggregator software. However, such a CSAF proxy provider MUST NOT be accessible from anyone else than the CSAF aggregator itself. Otherwise, that would violate the second rule of section 7.2.1. Therefore, it is recommended to expose the CSAF proxy provider only on localhost and allow the access only from the CSAF aggregator software. -## 7.3 Retrieving rules +## Retrieving rules The retrieving process executes in two phases: Finding the `provider-metadata.json` (requirement 7 in section 7.1) and retrieving CSAF documents. > A retrieving party SHOULD do the first phase every time. Based on the setup and use case of the retrieving party it MAY choose to do it less often, e.g. only when adding new or updating distributing parties. In that case, it SHOULD to check regularly whether new information is available. -### 7.3.1 Finding provider-metadata.json +### Finding provider-metadata.json **Direct locating**: The following process SHOULD be used to determine the location of a `provider-metadata.json` (requirement 7 in section 7.1) based on the main domain of the issuing party: @@ -589,7 +589,7 @@ The first two steps SHOULD be performed in all cases as the security.txt MAY adv **Indirect locating**: A retrieving party MAY choose to determine the location of a `provider-metadata.json` by retrieving its location from an `aggregator.json` (requirement 21 in section 7.1) of a CSAF lister or CSAF aggregator. -### 7.3.2 Retrieving CSAF documents +### Retrieving CSAF documents Given a `provider-metadata.json`, the following process SHOULD be used to retrieve CSAF documents: diff --git a/csaf_2.1/prose/edit/src/guidance-on-size.md b/csaf_2.1/prose/edit/src/guidance-on-size.md index a2700d73a..c1e3776c5 100644 --- a/csaf_2.1/prose/edit/src/guidance-on-size.md +++ b/csaf_2.1/prose/edit/src/guidance-on-size.md @@ -19,7 +19,7 @@ toc: enumerate: C.6 --- --> -# Appendix C. Guidance on the Size of CSAF Documents +# Guidance on the Size of CSAF Documents This appendix provides informative guidance on the size of CSAF documents. @@ -29,13 +29,13 @@ All _CSAF consumers_ SHOULD be able to process CSAF documents which comply with > If you come across a case where these limits are exceeded, please provide feedback to the TC. -## C.1 File size +## File size A CSAF document in the specified JSON format encoded in UTF-8 SHOULD conform to known size limits of current technologies parsing JSON content, e.g.: 15 MB. > At least one database technology in wide use for storing CSAF documents rejects insert attempts when the transformed BSON size exceeds 16 megabytes. The BSON format optimizes for accessibility and not size. So, small integers and small strings may incur more overhead in the BSON format than in JSON. In addition, the BSON format adds length information for the entries inside the document, which adds to the size when storing CSAF document content in a BSON format. -## C.2 Array length +## Array length An array SHOULD NOT have more than: @@ -118,7 +118,7 @@ An array SHOULD NOT have more than: * `/vulnerabilities[]/threats[]/group_ids` * `/vulnerabilities[]/threats[]/product_ids` -## C.3 String length +## String length A string SHOULD NOT have a length greater than: @@ -236,7 +236,7 @@ A string SHOULD NOT have a length greater than: * `/vulnerabilities[]/remediations[]/restart_required/details` * `/vulnerabilities[]/threats[]/details` -## C.4 URI length +## URI length A string with format `uri` SHOULD NOT have a length greater than 20000. This applies to: @@ -261,7 +261,7 @@ A string with format `uri` SHOULD NOT have a length greater than 20000. This app * `/vulnerabilities[]/references[]/url` * `/vulnerabilities[]/remediations[]/url` -## C.5 Enum +## Enum A string which is an enum has a fixed maximum length given by its longest value. @@ -328,7 +328,7 @@ It seems to be safe to assume that the length of each value is not greater than * `/vulnerabilities[]/scores[]/cvss_v3/environmentalSeverity` (8) * `/vulnerabilities[]/threats[]/category` (14) -## C.6 Date +## Date The maximum length of strings representing a temporal value is given by the format specifier. This applies to: diff --git a/csaf_2.1/prose/edit/src/introduction-00.md b/csaf_2.1/prose/edit/src/introduction-00.md index 69a5e8993..e10b99d01 100644 --- a/csaf_2.1/prose/edit/src/introduction-00.md +++ b/csaf_2.1/prose/edit/src/introduction-00.md @@ -1 +1 @@ -# 1 Introduction +# Introduction diff --git a/csaf_2.1/prose/edit/src/introduction-01-ipr-policy.md b/csaf_2.1/prose/edit/src/introduction-01-ipr-policy.md index b920ce620..4aabb198f 100644 --- a/csaf_2.1/prose/edit/src/introduction-01-ipr-policy.md +++ b/csaf_2.1/prose/edit/src/introduction-01-ipr-policy.md @@ -1,3 +1,3 @@ -## 1.1 IPR Policy +## IPR Policy This specification is provided under the [Non-Assertion](https://www.oasis-open.org/policies-guidelines/ipr/#Non-Assertion-Mode) Mode of the [OASIS IPR Policy](https://www.oasis-open.org/policies-guidelines/ipr/), the mode chosen when the Technical Committee was established. For information on whether any patents have been disclosed that may be essential to implementing this specification, and any offers of patent licensing terms, please refer to the Intellectual Property Rights section of the TC's web page ([https://www.oasis-open.org/committees/csaf/ipr.php](https://www.oasis-open.org/committees/csaf/ipr.php)). diff --git a/csaf_2.1/prose/edit/src/introduction-02-terminology.md b/csaf_2.1/prose/edit/src/introduction-02-terminology.md index cc586c363..681f9d9ac 100644 --- a/csaf_2.1/prose/edit/src/introduction-02-terminology.md +++ b/csaf_2.1/prose/edit/src/introduction-02-terminology.md @@ -1,4 +1,4 @@ -## 1.2 Terminology +## Terminology The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 [[RFC2119](#rfc2119)] and [[RFC8174](#rfc8174)] when, and only when, they appear in all capitals, as shown here. diff --git a/csaf_2.1/prose/edit/src/introduction-03-normative-references.md b/csaf_2.1/prose/edit/src/introduction-03-normative-references.md index 6d9d82a53..485ff4ab8 100644 --- a/csaf_2.1/prose/edit/src/introduction-03-normative-references.md +++ b/csaf_2.1/prose/edit/src/introduction-03-normative-references.md @@ -1,4 +1,4 @@ -## 1.3 Normative References +## Normative References JSON-Schema-Core : _JSON Schema: A Media Type for Describing JSON Documents_, draft-bhutton-json-schema-00, December 2020, https://datatracker.ietf.org/doc/html/draft-bhutton-json-schema-00. diff --git a/csaf_2.1/prose/edit/src/introduction-04-informative-references.md b/csaf_2.1/prose/edit/src/introduction-04-informative-references.md index 91e96834f..fa9e25f29 100644 --- a/csaf_2.1/prose/edit/src/introduction-04-informative-references.md +++ b/csaf_2.1/prose/edit/src/introduction-04-informative-references.md @@ -1,4 +1,4 @@ -## 1.4 Informative References +## Informative References CPE23-A : _Common Platform Enumeration: Applicability Language Specification Version 2.3 (NISTIR 7698)_, D. Waltermire, P. Cichonski, K. Scarfone, Editors, NIST Interagency Report 7698, August 2011, https://dx.doi.org/10.6028/NIST.IR.7698. diff --git a/csaf_2.1/prose/edit/src/introduction-05-typographical-conventions.md b/csaf_2.1/prose/edit/src/introduction-05-typographical-conventions.md index 05f87cb83..1f909d8a7 100644 --- a/csaf_2.1/prose/edit/src/introduction-05-typographical-conventions.md +++ b/csaf_2.1/prose/edit/src/introduction-05-typographical-conventions.md @@ -1,4 +1,4 @@ -## 1.5 Typographical Conventions +## Typographical Conventions Keywords defined by this specification use this `monospaced` font. diff --git a/csaf_2.1/prose/edit/src/profiles.md b/csaf_2.1/prose/edit/src/profiles.md index 2f576a36c..d699e233d 100644 --- a/csaf_2.1/prose/edit/src/profiles.md +++ b/csaf_2.1/prose/edit/src/profiles.md @@ -1,4 +1,4 @@ -# 4 Profiles +# Profiles CSAF documents do not have many required fields as they can be used for different purposes. To ensure a common understanding of which fields are required in a given use case the standard defines profiles. Each subsection describes such a profile by describing necessary content for that specific use case and providing insights into its purpose. The value of `/document/category` is used to identify a CSAF document's profile. The following rules apply: @@ -10,7 +10,7 @@ CSAF documents do not have many required fields as they can be used for differen 6. Local or private profiles MAY exist and tools MAY choose to support them. 7. If an official profile and a private profile exists, tools MUST validate against the official one from the standard. -## 4.1 Profile 1: CSAF Base +## Profile 1: CSAF Base This profile defines the default required fields for any CSAF document. Therefore, it is a "catch all" for CSAF documents that do not satisfy any other profile. Furthermore, it is the foundation all other profiles are build on. @@ -39,7 +39,7 @@ An issuing party might choose to set `/document/publisher/name` in front of a va > Both values `Example Company Security Advisory` and `Example Company security_advisory` in `/document/category` use the profile "CSAF Base". This is important to prepare forward compatibility as later versions of CSAF might add new profiles. Therefore, the values which can be used for the profile "CSAF Base" might change. -## 4.2 Profile 2: Security incident response +## Profile 2: Security incident response This profile SHOULD be used to provide a response to a security breach or incident. This MAY also be used to convey information about an incident that is unrelated to the issuing party's own products or infrastructure. @@ -55,7 +55,7 @@ A CSAF document SHALL fulfill the following requirements to satisfy the profile > The intended use for this field is to refer to one or more documents or websites which provides more details about the incident. * The value of `/document/category` SHALL be `csaf_security_incident_response`. -## 4.3 Profile 3: Informational Advisory +## Profile 3: Informational Advisory This profile SHOULD be used to provide information which are **not related to a vulnerability** but e.g. a misconfiguration. @@ -72,7 +72,7 @@ A CSAF document SHALL fulfill the following requirements to satisfy the profile If the element `/product_tree` exists, a user MUST assume that all products mentioned are affected. -## 4.4 Profile 4: Security Advisory +## Profile 4: Security Advisory This profile SHOULD be used to provide information which is related to vulnerabilities and corresponding remediations. @@ -88,7 +88,7 @@ A CSAF document SHALL fulfill the following requirements to satisfy the profile > Lists each product's status in regard to the vulnerability. * The value of `/document/category` SHALL be `csaf_security_advisory`. -## 4.5 Profile 5: VEX +## Profile 5: VEX This profile SHOULD be used to provide information of the "Vulnerability Exploitability eXchange". The main purpose of the VEX format is to state that and why a certain product is, or is not, affected by a vulnerability. See [VEX] for details. diff --git a/csaf_2.1/prose/edit/src/revision-history.md b/csaf_2.1/prose/edit/src/revision-history.md index e0a5af1d9..d84b761ff 100644 --- a/csaf_2.1/prose/edit/src/revision-history.md +++ b/csaf_2.1/prose/edit/src/revision-history.md @@ -6,7 +6,7 @@ toc: enumerate: Appendix B. --- --> -# Appendix B. Revision History +# Revision History | Revision | Date | Editor | Changes Made | |:-------------------------|:-----------|:--------------------------------|:--------------------------------------------------------------------------------------| diff --git a/csaf_2.1/prose/edit/src/safety-security-and-data-protection.md b/csaf_2.1/prose/edit/src/safety-security-and-data-protection.md index b35c9efdd..cb3756b85 100644 --- a/csaf_2.1/prose/edit/src/safety-security-and-data-protection.md +++ b/csaf_2.1/prose/edit/src/safety-security-and-data-protection.md @@ -1,4 +1,4 @@ -# 8 Safety, Security, and Data Protection Considerations +# Safety, Security, and Data Protection Considerations CSAF documents are based on JSON, thus the security considerations of [RFC8259] apply and are repeated here as service for the reader: >Generally, there are security issues with scripting languages. JSON is a subset of JavaScript but excludes assignment and invocation. diff --git a/csaf_2.1/prose/edit/src/schema-elements-00.md b/csaf_2.1/prose/edit/src/schema-elements-00.md index f6916ce66..5280d3a12 100644 --- a/csaf_2.1/prose/edit/src/schema-elements-00.md +++ b/csaf_2.1/prose/edit/src/schema-elements-00.md @@ -1,4 +1,4 @@ -# 3 Schema Elements +# Schema Elements The CSAF schema describes how to represent security advisory information as a JSON document. diff --git a/csaf_2.1/prose/edit/src/schema-elements-01-definitions.md b/csaf_2.1/prose/edit/src/schema-elements-01-definitions.md index bc19013f9..545752047 100644 --- a/csaf_2.1/prose/edit/src/schema-elements-01-definitions.md +++ b/csaf_2.1/prose/edit/src/schema-elements-01-definitions.md @@ -1,4 +1,4 @@ -## 3.1 Definitions +## Definitions The definitions (`$defs`) introduce the following domain specific types into the CSAF language: Acknowledgments (`acknowledgments_t`), Branches (`branches_t`), Full Product Name (`full_product_name_t`), Language (`lang_t`), Notes (`notes_t`), @@ -43,7 +43,7 @@ and Version (`version_t`). }, ``` -### 3.1.1 Acknowledgments Type +### Acknowledgments Type List of Acknowledgments (`acknowledgments_t`) type instances of value type `array` with 1 or more elements contain a list of `Acknowledgment` elements. @@ -76,7 +76,7 @@ The properties are: `names`, `organization`, `summary`, and `urls`. } ``` -#### 3.1.1.1 Acknowledgments Type - Names +#### Acknowledgments Type - Names List of acknowledged names (`names`) has value type `array` with 1 or more items holds the names of contributors being recognized. Every such item of value type `string` with 1 or more characters represents the name of the contributor and contains the name of a single contributor being recognized. @@ -88,7 +88,7 @@ Every such item of value type `string` with 1 or more characters represents the Johann Sebastian Bach ``` -#### 3.1.1.2 Acknowledgments Type - Organization +#### Acknowledgments Type - Organization The contributing organization (`organization`) has value type `string` with 1 or more characters and holds the name of the contributing organization being recognized. @@ -100,7 +100,7 @@ The contributing organization (`organization`) has value type `string` with 1 or Talos ``` -#### 3.1.1.3 Acknowledgments Type - Summary +#### Acknowledgments Type - Summary Summary of the acknowledgment (`summary`) of value type `string` with 1 or more characters SHOULD represent any contextual details the document producers wish to make known about the acknowledgment or acknowledged parties. @@ -110,13 +110,13 @@ Summary of the acknowledgment (`summary`) of value type `string` with 1 or more First analysis of Coordinated Multi-Stream Attack (CMSA) ``` -#### 3.1.1.4 Acknowledgments Type - URLs +#### Acknowledgments Type - URLs List of URLs (`urls`) of acknowledgment is a container (value type `array`) for 1 or more `string` of type URL that specifies a list of URLs or location of the reference to be acknowledged. Any URL of acknowledgment contains the URL or location of the reference to be acknowledged. Value type is string with format URI (`uri`). -#### 3.1.1.5 Acknowledgments Type - Example +#### Acknowledgments Type - Example *Example 4:* @@ -160,7 +160,7 @@ The example 4 above SHOULD lead to the following outcome in a human-readable adv > * BSI for assistance in coordination > * Antonio Vivaldi for influencing other composers -### 3.1.2 Branches Type +### Branches Type List of branches (`branches_t`) with value type `array` contains 1 or more branch elements as children of the current element. @@ -196,11 +196,11 @@ The properties `name` and `category` are mandatory. In addition, the object cont > `branches_t` supports building a hierarchical structure of products that allows to indicate the relationship of products to each other and enables grouping for simpler referencing. As an example, the structure MAY use the following levels: `vendor` -> `product_family` -> `product_name` -> `product_version`. > It is recommended to use the hierarchical structure of `vendor` -> `product_name` -> `product_version` whenever possible to support the identification and matching of products on the consumer side. -#### 3.1.2.1 Branches Type - Branches +#### Branches Type - Branches List of branches (`branches`) has the value type `branches_t`. -#### 3.1.2.2 Branches Type - Category +#### Branches Type - Category Category of the branch (`category`) of value type `string` and `enum` describes the characteristics of the labeled branch. Valid `enum` values are: @@ -246,7 +246,7 @@ The value `specification` indicates the specification such as a standard, best c The value `vendor` indicates the name of the vendor or manufacturer that makes the product. -#### 3.1.2.3 Branches Type - Name +#### Branches Type - Name Name of the branch (`name`) of value type `string` with 1 or more characters contains the canonical descriptor or 'friendly name' of the branch. @@ -265,7 +265,7 @@ Name of the branch (`name`) of value type `string` with 1 or more characters con A leading `v` or `V` in the value of `name` SHOULD only exist for the categories `product_version` or `product_version_range` if it is part of the product version as given by the vendor. -##### 3.1.2.3.1 Branches Type - Name under Product Version +##### Branches Type - Name under Product Version If adjacent property `category` has the value `product_version`, the value of `name` MUST NOT contain version ranges of any kind. @@ -292,7 +292,7 @@ If adjacent property `category` has the value `product_version`, the value of `n > All the examples above contain some kind of a version range and are therefore invalid under the category `product_version`. -##### 3.1.2.3.2 Branches Type - Name under Product Version Range +##### Branches Type - Name under Product Version Range If adjacent property `category` has the value `product_version_range`, the value of `name` MUST contain version ranges. The value of MUST obey to exactly one of the following options: @@ -329,11 +329,11 @@ If adjacent property `category` has the value `product_version_range`, the value >=8.1.5 ``` -#### 3.1.2.4 Branches Type - Product +#### Branches Type - Product Product (`product`) has the value type Full Product Name (`full_product_name_t`). -### 3.1.3 Full Product Name Type +### Full Product Name Type Full Product Name (`full_product_name_t`) with value type `object` specifies information about the product and assigns the product ID. The properties `name` and `product_id` are required. The property `product_identification_helper` is optional. @@ -355,7 +355,7 @@ The properties `name` and `product_id` are required. The property `product_ident }, ``` -#### 3.1.3.1 Full Product Name Type - Name +#### Full Product Name Type - Name Textual description of the product (`name`) has value type `string` with 1 or more characters. The value SHOULD be the product's full canonical name, including version number and other attributes, as it would be used in a human-friendly document. @@ -367,11 +367,11 @@ The value SHOULD be the product's full canonical name, including version number Microsoft Host Integration Server 2006 Service Pack 1 ``` -#### 3.1.3.2 Full Product Name Type - Product ID +#### Full Product Name Type - Product ID Product ID (`product_id`) holds a value of type Product ID (`product_id_t`). -#### 3.1.3.3 Full Product Name Type - Product Identification Helper +#### Full Product Name Type - Product Identification Helper Helper to identify the product (`product_identification_helper`) of value type `object` provides in its properties at least one method which aids in identifying the product in an asset database. Of the given eight properties `cpe`, `hashes`, `model_numbers`, `purl`, `sbom_urls`, `serial_numbers`, `skus`, and `x_generic_uris`, one is mandatory. @@ -407,7 +407,7 @@ Of the given eight properties `cpe`, `hashes`, `model_numbers`, `purl`, `sbom_ur } ``` -##### 3.1.3.3.1 Full Product Name Type - Product Identification Helper - CPE +##### Full Product Name Type - Product Identification Helper - CPE Common Platform Enumeration representation (`cpe`) of value type `string` of 5 or more characters with `pattern` (regular expression): @@ -417,7 +417,7 @@ Common Platform Enumeration representation (`cpe`) of value type `string` of 5 o The Common Platform Enumeration (CPE) attribute refers to a method for naming platforms external to this specification. See [CPE23-N] for details. -##### 3.1.3.3.2 Full Product Name Type - Product Identification Helper - Hashes +##### Full Product Name Type - Product Identification Helper - Hashes List of hashes (`hashes`) of value type `array` holding at least one item contains a list of cryptographic hashes usable to identify files. @@ -526,7 +526,7 @@ The filename representation (`filename`) of value type `string` with one or more If the value of the hash matches and the filename does not, a user SHOULD prefer the hash value. In such cases, the filename SHOULD be used as informational property. -##### 3.1.3.3.3 Full Product Name Type - Product Identification Helper - Model Numbers +##### Full Product Name Type - Product Identification Helper - Model Numbers The list of models (`model_numbers`) of value type `array` with 1 or more unique items contains a list of full or abbreviated (partial) model numbers. @@ -559,7 +559,7 @@ Two `*` MUST NOT follow each other. IC25T060ATCS05-0 ``` -##### 3.1.3.3.4 Full Product Name Type - Product Identification Helper - PURL +##### Full Product Name Type - Product Identification Helper - PURL The package URL (PURL) representation (`purl`) is a `string` of 7 or more characters with `pattern` (regular expression): @@ -572,7 +572,7 @@ The package URL (PURL) representation (`purl`) is a `string` of 7 or more charac This package URL (PURL) attribute refers to a method for reliably identifying and locating software packages external to this specification. See [PURL] for details. -##### 3.1.3.3.5 Full Product Name Type - Product Identification Helper - SBOM URLs +##### Full Product Name Type - Product Identification Helper - SBOM URLs The list of SBOM URLs (`sbom_urls`) of value type `array` with 1 or more items contains a list of URLs where SBOMs for this product can be retrieved. @@ -596,7 +596,7 @@ Any given SBOM URL of value type `string` with format `uri` contains a URL of on https://swinslow.net/spdx-examples/example4/main-bin-v2 ``` -##### 3.1.3.3.6 Full Product Name Type - Product Identification Helper - Serial Numbers +##### Full Product Name Type - Product Identification Helper - Serial Numbers The list of serial numbers (`serial_numbers`) of value type `array` with 1 or more unique items contains a list of full or abbreviated (partial) serial numbers. @@ -617,7 +617,7 @@ If a part of a serial number of the component to identify is given, it SHOULD be Characters which SHOULD NOT be matched MUST be replaced by either `?` (for a single character) or `*` (for zero or more characters). Two `*` MUST NOT follow each other. -##### 3.1.3.3.7 Full Product Name Type - Product Identification Helper - SKUs +##### Full Product Name Type - Product Identification Helper - SKUs The list of stock keeping units (`skus`) of value type `array` with 1 or more items contains a list of full or abbreviated (partial) stock keeping units. @@ -642,7 +642,7 @@ If a part of a stock keeping unit of the component to identify is given, it SHOU Characters which SHOULD NOT be matched MUST be replaced by either `?` (for a single character) or `*` (for zero or more characters). Two `*` MUST NOT follow each other. -##### 3.1.3.3.8 Full Product Name Type - Product Identification Helper - Generic URIs +##### Full Product Name Type - Product Identification Helper - Generic URIs List of generic URIs (`x_generic_uris`) of value type `array` with at least 1 item contains a list of identifiers which are either vendor-specific or derived from a standard not yet supported. @@ -696,7 +696,7 @@ The URI (`uri`) of value type `string` with format `uri` contains the identifier ] ``` -### 3.1.4 Language Type +### Language Type Language type (`lang_t`) has value type `string` with `pattern` (regular expression): @@ -720,7 +720,7 @@ See IETF language registry: [https://www.iana.org/assignments/language-subtag-re jp ``` -### 3.1.5 Notes Type +### Notes Type List of notes (`notes_t`) of value type `array` with 1 or more items of type `Note` contains notes which are specific to the current context. @@ -804,7 +804,7 @@ Title of note (`title`) of value type `string` with 1 or more characters provide Impact on safety systems ``` -### 3.1.6 Product Group ID Type +### Product Group ID Type The Product Group ID Type (`product_group_id_t`) of value type `string` with 1 or more characters is a reference token for product group instances. The value is a token required to identify a group of products so that it can be referred to from other parts in the document. @@ -826,7 +826,7 @@ There is no predefined or required format for the Product Group ID (`product_gro > Even though the standard does not require a specific format it is recommended to use different prefixes for the Product ID and the Product Group ID to support reading and parsing the document. -### 3.1.7 Product Groups Type +### Product Groups Type List of Product Group ID (`product_groups_t`) of value type `array` with 1 or more unique items (a `set`) of type Product Group ID (`product_group_id_t`) specifies a list of `product_group_ids` to give context to the parent item. @@ -839,7 +839,7 @@ List of Product Group ID (`product_groups_t`) of value type `array` with 1 or mo }, ``` -### 3.1.8 Product ID Type +### Product ID Type The Product ID Type (`product_id_t`) of value type `string` with 1 or more characters is a reference token for product instances. The value is a token required to identify a `full_product_name` so that it can be referred to from other parts in the document. There is no predefined or required format for the Product ID (`product_id`) as long as it uniquely identifies a product in the context of the current document. @@ -859,7 +859,7 @@ The value is a token required to identify a `full_product_name` so that it can b > Even though the standard does not require a specific format it is recommended to use different prefixes for the Product ID and the Product Group ID to support reading and parsing the document. -### 3.1.9 Products Type +### Products Type List of Product IDs (`products_t`) of value type `array` with 1 or more unique items (a `set`) of type Product ID (`product_id_t`) specifies a list of `product_ids` to give context to the parent item. @@ -872,7 +872,7 @@ List of Product IDs (`products_t`) of value type `array` with 1 or more unique i }, ``` -### 3.1.10 References Type +### References Type List of references (`references_t`) of value type `array` with 1 or more items of type Reference holds a list of Reference objects. @@ -922,7 +922,7 @@ Summary of the reference (`summary`) of value type `string` with 1 or more chara URL of reference (`url`) of value type `string` with format `uri` provides the URL for the reference. -### 3.1.11 Version Type +### Version Type The Version (`version_t`) type has value type `string` with `pattern` (regular expression): @@ -947,7 +947,7 @@ A CSAF document MUST use only one versioning system. 2.40.0+21AF26D3 ``` -#### 3.1.11.1 Version Type - Integer versioning +#### Version Type - Integer versioning Integer versioning increments for each version where the `/document/tracking/status` is `final` the version number by one. The regular expression for this type is: @@ -964,7 +964,7 @@ The following rules apply: 5. Build metadata is never included in the version. 6. Precedence MUST be calculate by integer comparison. -#### 3.1.11.2 Version Type - Semantic versioning +#### Version Type - Semantic versioning Semantic versioning derived the rules from [SemVer]. The regular expression for this type is: diff --git a/csaf_2.1/prose/edit/src/schema-elements-02-properties.md b/csaf_2.1/prose/edit/src/schema-elements-02-properties.md index 067dbe871..a67c30e09 100644 --- a/csaf_2.1/prose/edit/src/schema-elements-02-properties.md +++ b/csaf_2.1/prose/edit/src/schema-elements-02-properties.md @@ -1,8 +1,8 @@ -## 3.2 Properties +## Properties These final three subsections document the three properties of a CSAF document. The single mandatory property `document`, as well as the optional properties `product_tree` and `vulnerabilities` in that order. -### 3.2.1 Document Property +### Document Property Document level meta-data (`document`) of value type `object` with the 5 mandatory properties Category (`category`), CSAF Version (`csaf_version`), Publisher (`publisher`), Title (`title`), and Tracking (`tracking`) captures the meta-data about this document describing a particular set of security advisories. In addition, the `document` object MAY provide the 7 optional properties Acknowledgments (`acknowledgments`), Aggregate Severity (`aggregate_severity`), Distribution (`distribution`), Language (`lang`), Notes (`notes`), References (`references`), and Source Language (`source_lang`). @@ -51,7 +51,7 @@ In addition, the `document` object MAY provide the 7 optional properties Acknowl }, ``` -#### 3.2.1.1 Document Property - Acknowledgments +#### Document Property - Acknowledgments Document acknowledgments (`acknowledgments`) of value type Acknowledgments Type (`acknowledgments_t`) contains a list of acknowledgment elements associated with the whole document. @@ -61,7 +61,7 @@ Document acknowledgments (`acknowledgments`) of value type Acknowledgments Type }, ``` -#### 3.2.1.2 Document Property - Aggregate Severity +#### Document Property - Aggregate Severity Aggregate severity (`aggregate_severity`) of value type `object` with the mandatory property `text` and the optional property `namespace` is a vehicle that is provided by the document producer to convey the urgency and criticality with which the one or more vulnerabilities reported should be addressed. It is a document-level metric and applied to the document as a whole — not any specific vulnerability. The range of values in this field is defined according to the document producer's policies and procedures. @@ -91,7 +91,7 @@ The Text of aggregate severity (`text`) of value type `string` with 1 or more ch Moderate ``` -#### 3.2.1.3 Document Property - Category +#### Document Property - Category Document category (`category`) with value type `string` of 1 or more characters with `pattern` (regular expression): @@ -118,7 +118,7 @@ Document category defines a short canonical name, chosen by the document produce Example Company Security Notice ``` -#### 3.2.1.4 Document Property - CSAF Version +#### Document Property - CSAF Version CSAF version (`csaf_version`) of value type `string` and `enum` gives the version of the CSAF specification which the document was generated for. The single valid value for this `enum` is: @@ -127,7 +127,7 @@ The single valid value for this `enum` is: 2.0 ``` -#### 3.2.1.5 Document Property - Distribution +#### Document Property - Distribution Rules for sharing document (`distribution`) of value type `object` with at least 1 of the 2 properties Text (`text`) and Traffic Light Protocol (TLP) (`tlp`) describes any constraints on how this document might be shared. @@ -147,7 +147,7 @@ Rules for sharing document (`distribution`) of value type `object` with at least If both values are present, the TLP information SHOULD be preferred as this aids in automation. -##### 3.2.1.5.1 Document Property - Distribution - Text +##### Document Property - Distribution - Text The Textual description (`text`) of value type `string` with 1 or more characters provides a textual description of additional constraints. @@ -159,7 +159,7 @@ The Textual description (`text`) of value type `string` with 1 or more character Share only on a need-to-know-basis only. ``` -##### 3.2.1.5.2 Document Property - Distribution - TLP +##### Document Property - Distribution - TLP Traffic Light Protocol (TLP) (`tlp`) of value type `object` with the mandatory property Label (`label`) and the optional property URL (`url`) provides details about the TLP classification of the document. @@ -200,11 +200,11 @@ The URL of TLP version (`url`) with value type `string` with format `uri` provid https://www.bsi.bund.de/SharedDocs/Downloads/DE/BSI/Kritis/Merkblatt_TLP.pdf ``` -#### 3.2.1.6 Document Property - Language +#### Document Property - Language Document language (`lang`) of value type Language Type (`lang_t`) identifies the language used by this document, corresponding to IETF BCP 47 / RFC 5646. -#### 3.2.1.7 Document Property - Notes +#### Document Property - Notes Document notes (`notes`) of value type Notes Type (`notes_t`) holds notes associated with the whole document. @@ -214,7 +214,7 @@ Document notes (`notes`) of value type Notes Type (`notes_t`) holds notes associ }, ``` -#### 3.2.1.8 Document Property - Publisher +#### Document Property - Publisher Publisher (`publisher`) has value type `object` with the mandatory properties Category (`category`), Name (`name`) and Namespace (`namespace`) and provides information on the publishing entity. The 2 other optional properties are: `contact_details` and `issuing_authority`. @@ -242,7 +242,7 @@ The 2 other optional properties are: `contact_details` and `issuing_authority`. }, ``` -##### 3.2.1.8.1 Document Property - Publisher - Category +##### Document Property - Publisher - Category The Category of publisher (`category`) of value type `string` and `enum` provides information about the category of publisher releasing the document. The valid values are: @@ -268,7 +268,7 @@ The value `user` indicates anyone using a vendor’s product. The value `vendor` indicates developers or maintainers of information system products or services. This includes all authoritative product vendors, Product Security Incident Response Teams (PSIRTs), and product resellers and distributors, including authoritative vendor partners. -##### 3.2.1.8.2 Document Property - Publisher - Contact Details +##### Document Property - Publisher - Contact Details Contact details (`contact_details`) of value type `string` with 1 or more characters provides information on how to contact the publisher, possibly including details such as web sites, email addresses, phone numbers, and postal mail addresses. @@ -278,11 +278,11 @@ Contact details (`contact_details`) of value type `string` with 1 or more charac Example Company can be reached at contact_us@example.com, or via our website at https://www.example.com/contact. ``` -##### 3.2.1.8.3 Document Property - Publisher - Issuing Authority +##### Document Property - Publisher - Issuing Authority Issuing authority (`issuing_authority`) of value type `string` with 1 or more characters Provides information about the authority of the issuing party to release the document, in particular, the party's constituency and responsibilities or other obligations. -##### 3.2.1.8.4 Document Property - Publisher - Name +##### Document Property - Publisher - Name The Name of publisher (`name`) of value type `string` with 1 or more characters contains the name of the issuing party. @@ -294,7 +294,7 @@ The Name of publisher (`name`) of value type `string` with 1 or more characters Siemens ProductCERT ``` -##### 3.2.1.8.5 Document Property - Publisher - Namespace +##### Document Property - Publisher - Namespace The Namespace of publisher (`namespace`) of value type `string` with format `uri` contains a URL which is under control of the issuing party and can be used as a globally unique identifier for that issuing party. The URL SHALL be normalized. @@ -314,7 +314,7 @@ If an issuing party decides to change its Namespace it SHOULD reissue all CSAF d https://www.example.com ``` -#### 3.2.1.9 Document Property - References +#### Document Property - References Document references (`references`) of value type References Type (`references_t`) holds a list of references associated with the whole document. @@ -324,7 +324,7 @@ Document references (`references`) of value type References Type (`references_t` }, ``` -#### 3.2.1.10 Document Property - Source Language +#### Document Property - Source Language Source language (`source_lang`) of value type Language Type (`lang_t`) identifies if this copy of the document is a translation then the value of this property describes from which language this document was translated. @@ -332,7 +332,7 @@ The property MUST be present and set for any CSAF document with the value `trans > If an issuing party publishes a CSAF document with the same content in more than one language, one of these documents SHOULD be deemed the "original", the other ones SHOULD be considered translations from the "original". The issuing party can retain its original publisher information including the `category`. However, other rules defined in the conformance clause "CSAF translator" SHOULD be applied. -#### 3.2.1.11 Document Property - Title +#### Document Property - Title Title of this document (`title`) of value type `string` with 1 or more characters SHOULD be a canonical name for the document, and sufficiently unique to distinguish it from similar documents. @@ -343,7 +343,7 @@ Title of this document (`title`) of value type `string` with 1 or more character Example Company Cross-Site-Scripting Vulnerability in Example Generator ``` -#### 3.2.1.12 Document Property - Tracking +#### Document Property - Tracking Tracking (`tracking`) of value type `object` with the six mandatory properties: Current Release Date (`current_release_date`), Identifier (`id`), Initial Release Date (`initial_release_date`), Revision History (`revision_history`), Status (`status`), and Version (`version`) is a container designated to hold all management attributes necessary to track a CSAF document as a whole. The two optional additional properties are Aliases (`aliases`) and Generator (`generator`). @@ -380,7 +380,7 @@ The two optional additional properties are Aliases (`aliases`) and Generator (`g }, ``` -##### 3.2.1.12.1 Document Property - Tracking - Aliases +##### Document Property - Tracking - Aliases Aliases (`aliases`) of value type `array` with 1 or more unique items (a `set`) representing Alternate Names contains a list of alternate names for the same document. @@ -401,11 +401,11 @@ Every such Alternate Name of value type `string` with 1 or more characters speci CVE-2019-12345 ``` -##### 3.2.1.12.2 Document Property - Tracking - Current Release Date +##### Document Property - Tracking - Current Release Date Current release date (`current_release_date`) with value type `string` with format `date-time` holds the date when the current revision of this document was released. -##### 3.2.1.12.3 Document Property - Tracking - Generator +##### Document Property - Tracking - Generator Document Generator (`generator`) of value type `object` with mandatory property Engine (`engine`) and optional property Date (`date`) is a container to hold all elements related to the generation of the document. These items will reference when the document was actually created, including the date it was generated and the entity that generated it. @@ -464,7 +464,7 @@ Engine version (`version`) of value type `string` with 1 or more characters cont 2 ``` -##### 3.2.1.12.4 Document Property - Tracking - ID +##### Document Property - Tracking - ID Unique identifier for the document (`id`) of value type `string` with 1 or more characters with `pattern` (regular expression): @@ -491,11 +491,11 @@ Its value SHOULD be assigned and maintained by the original document issuing aut This value is also used to determine the filename for the CSAF document (cf. section 5.1). -##### 3.2.1.12.5 Document Property - Tracking - Initial Release Date +##### Document Property - Tracking - Initial Release Date Initial release date (`initial_release_date`) with value type `string` with format `date-time` holds the date when this document was first published. -##### 3.2.1.12.6 Document Property - Tracking - Revision History +##### Document Property - Tracking - Revision History The Revision History (`revision_history`) with value type `array` of 1 or more Revision History Entries holds one revision item for each version of the CSAF document, including the initial one. @@ -539,7 +539,7 @@ The Summary of the revision (`summary`) of value type `string` with 1 or more ch Each Revision item which has a `number` of `0` or `0.y.z` MUST be removed from the document if the document status is `final`. Versions of the document which are pre-release SHALL NOT have its own revision item. All changes MUST be tracked in the item for the next release version. Build metadata SHOULD NOT be included in the `number` of any revision item. -##### 3.2.1.12.7 Document Property - Tracking - Status +##### Document Property - Tracking - Status Document status (`status`) of value type `string` and `enum` defines the draft status of the document. The value MUST be one of the following: @@ -558,11 +558,11 @@ The value `interim` indicates, that the issuing party expects rapid updates. Thi > This is extremely useful for downstream vendors to constantly inform the end users about ongoing investigation. It can be used as an indication to pull the CSAF document more frequently. -##### 3.2.1.12.8 Document Property - Tracking - Version +##### Document Property - Tracking - Version Version has the value type Version (`version_t`). -### 3.2.2 Product Tree Property +### Product Tree Property Product Tree (`product_tree`) has value type `object` with 1 or more properties is a container for all fully qualified product names that can be referenced elsewhere in the document. The properties are Branches (`branches`), Full Product Names (`full_product_names`), Product Groups (`product_groups`), and Relationships (`relationships`). @@ -587,15 +587,15 @@ The properties are Branches (`branches`), Full Product Names (`full_product_name }, ``` -#### 3.2.2.1 Product Tree Property - Branches +#### Product Tree Property - Branches List of branches (`branches`) has the value type `branches_t`. -#### 3.2.2.2 Product Tree Property - Full Product Names +#### Product Tree Property - Full Product Names List of full product names (`full_product_names`) of value type `array` with 1 or more items of type `full_product_name_t` contains a list of full product names. -#### 3.2.2.3 Product Tree Property - Product Groups +#### Product Tree Property - Product Groups List of product groups (`product_groups`) of value type `array` with 1 or more items of value type `object` contains a list of product groups. @@ -637,7 +637,7 @@ Group ID (`group_id`) has value type Product Group ID (`product_group_id_t`). List of Product IDs (`product_ids`) of value type `array` with 2 or more unique items of value type Product ID (`product_id_t`) lists the product_ids of those products which known as one group in the document. -#### 3.2.2.4 Product Tree Property - Relationships +#### Product Tree Property - Relationships List of relationships (`relationships`) of value type `array` with 1 or more items contains a list of relationships. @@ -728,7 +728,7 @@ Relates to Product Reference (`relates_to_product_reference`) of value type Prod > The product `Cisco AnyConnect Secure Mobility Client 4.9.04053"` (Product ID: `CSAFPID-908070601`) and the product `Microsoft Windows` (Product ID: `CSAFPID-908070602`) form together a new product with the separate Product ID `CSAFPID-908070603`. The latter one can be used to refer to that combination in other parts of the CSAF document. In example 34, it might be the case that `Cisco AnyConnect Secure Mobility Client 4.9.04053"` is only vulnerable when installed on `Microsoft Windows`. -### 3.2.3 Vulnerabilities Property +### Vulnerabilities Property Vulnerabilities (`vulnerabilities`) of value type `array` with 1 or more objects representing vulnerabilities and providing 1 or more properties represents a list of all relevant vulnerability information items. @@ -794,7 +794,7 @@ Any vulnerability MAY provide the optional properties Acknowledgments (`acknowle } ``` -#### 3.2.3.1 Vulnerabilities Property - Acknowledgments +#### Vulnerabilities Property - Acknowledgments Vulnerability acknowledgments (`acknowledgments`) of value type Acknowledgments Type (`acknowledgments_t`) contains a list of acknowledgment elements associated with this vulnerability item. @@ -804,7 +804,7 @@ Vulnerability acknowledgments (`acknowledgments`) of value type Acknowledgments }, ``` -#### 3.2.3.2 Vulnerabilities Property - CVE +#### Vulnerabilities Property - CVE CVE (`cve`) of value type `string` with `pattern` (regular expression): @@ -814,7 +814,7 @@ CVE (`cve`) of value type `string` with `pattern` (regular expression): holds the MITRE standard Common Vulnerabilities and Exposures (CVE) tracking number for the vulnerability. -#### 3.2.3.3 Vulnerabilities Property - CWE +#### Vulnerabilities Property - CWE CWE (`cwe`) of value type `object` with the 2 mandatory properties Weakness ID (`id`) and Weakness Name (`name`) holds the MITRE standard Common Weakness Enumeration (CWE) for the weakness associated. For more information cf. [CWE]. @@ -858,11 +858,11 @@ The Weakness name (`name`) has value type `string` with 1 or more characters and Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting') ``` -#### 3.2.3.4 Vulnerabilities Property - Discovery Date +#### Vulnerabilities Property - Discovery Date Discovery date (`discovery_date`) of value type `string` with format `date-time` holds the date and time the vulnerability was originally discovered. -#### 3.2.3.5 Vulnerabilities Property - Flags +#### Vulnerabilities Property - Flags List of flags (`flags`) of value type `array` with 1 or more unique items (a set) of value type `object` contains a list of machine readable flags. @@ -926,7 +926,7 @@ The given values reflect the VEX not affected justifications. See [VEX-Justifica Product IDs (`product_ids`) are of value type Products (`products_t`) and contain a list of Products the current flag item applies to. -#### 3.2.3.6 Vulnerabilities Property - IDs +#### Vulnerabilities Property - IDs List of IDs (`ids`) of value type `array` with one or more unique ID items of value type `object` represents a list of unique labels or tracking IDs for the vulnerability (if such information exists). @@ -979,7 +979,7 @@ Text (`text`) of value type `string` with 1 or more characters is unique label o > > The ID MAY be a vendor-specific value but is not to be used to publish the CVE tracking numbers (MITRE standard Common Vulnerabilities and Exposures), as these are specified inside the dedicated CVE element. -#### 3.2.3.7 Vulnerabilities Property - Involvements +#### Vulnerabilities Property - Involvements List of involvements (`involvements`) of value type `array` with 1 or more items of value type `object` contains a list of involvements. @@ -1056,7 +1056,7 @@ The value `open` is the default status. It doesn’t indicate anything about the Summary of involvement (`summary`) of value type `string` with 1 or more characters contains additional context regarding what is going on. -#### 3.2.3.8 Vulnerabilities Property - Notes +#### Vulnerabilities Property - Notes Vulnerability notes (`notes`) of value type Notes Type (`notes_t`) holds notes associated with this vulnerability item. @@ -1066,7 +1066,7 @@ Vulnerability notes (`notes`) of value type Notes Type (`notes_t`) holds notes a }, ``` -#### 3.2.3.9 Vulnerabilities Property - Product Status +#### Vulnerabilities Property - Product Status Product status (`product_status`) of value type `object` with 1 or more properties contains different lists of product_ids which provide details on the status of the referenced product related to the current vulnerability. The eight defined properties are First affected (`first_affected`), First fixed (`first_fixed`), Fixed (`fixed`), Known affected (`known_affected`), Known not affected (`known_not_affected`), Last affected (`last_affected`), Recommended (`recommended`), and Under investigation (`under_investigation`) are all of value type Products (`products_t`). @@ -1124,7 +1124,7 @@ Recommended (`recommended`) of value type Products (`products_t`) represents tha Under investigation (`under_investigation`) of value type Products (`products_t`) represents that it is not known yet whether these versions are or are not affected by the vulnerability. However, it is still under investigation - the result will be provided in a later release of the document. -#### 3.2.3.10 Vulnerabilities Property - References +#### Vulnerabilities Property - References Vulnerability references (`references`) of value type References Type (`references_t`) holds a list of references associated with this vulnerability item. @@ -1134,11 +1134,11 @@ Vulnerability references (`references`) of value type References Type (`referenc }, ``` -#### 3.2.3.11 Vulnerabilities Property - Release Date +#### Vulnerabilities Property - Release Date Release date (`release_date`) with value type `string` of format `date-time` holds the date and time the vulnerability was originally released into the wild. -#### 3.2.3.12 Vulnerabilities Property - Remediations +#### Vulnerabilities Property - Remediations List of remediations (`remediations`) of value type `array` with 1 or more Remediation items of value type `object` contains a list of remediations. @@ -1184,7 +1184,7 @@ In addition, any Remediation MAY expose the six optional properties Date (`date` } ``` -##### 3.2.3.12.1 Vulnerabilities Property - Remediations - Category +##### Vulnerabilities Property - Remediations - Category Category of the remediation (`category`) of value type `string` and `enum` specifies the category which this remediation belongs to. Valid values are: @@ -1212,15 +1212,15 @@ The values `none_available` and `vendor_fix` are mutually exclusive per product. The value `no_fix_planned` indicates that there is no fix for the vulnerability and it is not planned to provide one at any time. This is often the case when a product has been orphaned, declared end-of-life, or otherwise deprecated. The text in field `details` SHOULD contain details about why there will be no fix issued. The values `no_fix_planned` and `vendor_fix` are mutually exclusive per product. -##### 3.2.3.12.2 Vulnerabilities Property - Remediations - Date +##### Vulnerabilities Property - Remediations - Date Date of the remediation (`date`) of value type `string` with format `date-time` contains the date from which the remediation is available. -##### 3.2.3.12.3 Vulnerabilities Property - Remediations - Details +##### Vulnerabilities Property - Remediations - Details Details of the remediation (`details`) of value type `string` with 1 or more characters contains a thorough human-readable discussion of the remediation. -##### 3.2.3.12.4 Vulnerabilities Property - Remediations - Entitlements +##### Vulnerabilities Property - Remediations - Entitlements List of entitlements (`entitlements`) of value type `array` with 1 or more items of type Entitlement of the remediation as `string` with 1 or more characters contains a list of entitlements. @@ -1235,15 +1235,15 @@ List of entitlements (`entitlements`) of value type `array` with 1 or more items Every Entitlement of the remediation contains any possible vendor-defined constraints for obtaining fixed software or hardware that fully resolves the vulnerability. -##### 3.2.3.12.5 Vulnerabilities Property - Remediations - Group IDs +##### Vulnerabilities Property - Remediations - Group IDs Group IDs (`group_ids`) are of value type Product Groups (`product_groups_t`) and contain a list of Product Groups the current remediation item applies to. -##### 3.2.3.12.6 Vulnerabilities Property - Remediations - Product IDs +##### Vulnerabilities Property - Remediations - Product IDs Product IDs (`product_ids`) are of value type Products (`products_t`) and contain a list of Products the current remediation item applies to. -##### 3.2.3.12.7 Vulnerabilities Property - Remediations - Restart Required +##### Vulnerabilities Property - Remediations - Restart Required Restart required by remediation (`restart_required`) of value type `object` with the 1 mandatory property Category (`category`) and the optional property Details (`details`) provides information on category of restart is required by this remediation to become effective. @@ -1290,11 +1290,11 @@ The values MUST be used as follows: Additional restart information (`details`) of value type `string` with 1 or more characters provides additional information for the restart. This can include details on procedures, scope or impact. -##### 3.2.3.12.8 Vulnerabilities Property - Remediations - URL +##### Vulnerabilities Property - Remediations - URL URL (`url`) of value type `string` with format `uri` contains the URL where to obtain the remediation. -#### 3.2.3.13 Vulnerabilities Property - Scores +#### Vulnerabilities Property - Scores List of scores (`scores`) of value type `array` with 1 or more items of type score holds a list of score objects for the current vulnerability. @@ -1331,7 +1331,7 @@ The property CVSS v3 (`cvss_v3`) holding a CVSS v3.x value abiding by one of the Product IDs (`products`) of value type `products_t` with 1 or more items indicates for which products the given scores apply. A score object SHOULD reflect the associated product's status (for example, a fixed product no longer contains a vulnerability and should have a CVSS score of 0, or simply no score listed; the known affected versions of that product can list the vulnerability score as it applies to them). -#### 3.2.3.14 Vulnerabilities Property - Threats +#### Vulnerabilities Property - Threats List of threats (`threats`) of value type `array` with 1 or more items of value type `object` contains information about a vulnerability that can change with time. @@ -1391,7 +1391,7 @@ Group IDs (`group_ids`) are of value type Product Groups (`product_groups_t`) an Product IDs (`product_ids`) are of value type Products (`products_t`) and contain a list of Products the current threat item applies to. -#### 3.2.3.15 Vulnerabilities Property - Title +#### Vulnerabilities Property - Title Title (`title`) has value type `string` with 1 or more characters and gives the document producer the ability to apply a canonical name or title to the vulnerability. diff --git a/csaf_2.1/prose/edit/src/tests-00.md b/csaf_2.1/prose/edit/src/tests-00.md index cef3c64ac..704a907bb 100644 --- a/csaf_2.1/prose/edit/src/tests-00.md +++ b/csaf_2.1/prose/edit/src/tests-00.md @@ -1,3 +1,3 @@ -# 6 Tests +# Tests The following three subsections list a number of tests which all will have a short description and an excerpt of an example which fails the test. diff --git a/csaf_2.1/prose/edit/src/tests-01-mandatory.md b/csaf_2.1/prose/edit/src/tests-01-mandatory.md index fda267a3f..e2bee28dd 100644 --- a/csaf_2.1/prose/edit/src/tests-01-mandatory.md +++ b/csaf_2.1/prose/edit/src/tests-01-mandatory.md @@ -1,8 +1,8 @@ -## 6.1 Mandatory Tests +## Mandatory Tests Mandatory tests MUST NOT fail at a valid CSAF document. A program MUST handle a test failure as an error. -### 6.1.1 Missing Definition of Product ID +### Missing Definition of Product ID For each element of type `/$defs/product_id_t` which is not inside a Full Product Name (type: `full_product_name_t`) and therefore reference an element within the `product_tree` it MUST be tested that the Full Product Name element with the matching `product_id` exists. The same applies for all items of elements of type `/$defs/products_t`. @@ -43,7 +43,7 @@ The relevant paths for this test are: > Neither `CSAFPID-9080700` nor `CSAFPID-9080701` were defined in the `product_tree`. -### 6.1.2 Multiple Definition of Product ID +### Multiple Definition of Product ID For each Product ID (type `/$defs/product_id_t`) in Full Product Name elements (type: `/$defs/full_product_name_t`) it MUST be tested that the `product_id` was not already defined within the same document. @@ -74,7 +74,7 @@ The relevant paths for this test are: > `CSAFPID-9080700` was defined twice. -### 6.1.3 Circular Definition of Product ID +### Circular Definition of Product ID For each new defined Product ID (type `/$defs/product_id_t`) in items of relationships (`/product_tree/relationships`) it MUST be tested that the `product_id` does not end up in a circle. @@ -112,7 +112,7 @@ The relevant path for this test is: > `CSAFPID-9080701` refers to itself - this is a circular definition. -### 6.1.4 Missing Definition of Product Group ID +### Missing Definition of Product Group ID For each element of type `/$defs/product_group_id_t` which is not inside a Product Group (`/product_tree/product_groups[]`) and therefore reference an element within the `product_tree` it MUST be tested that the Product Group element with the matching `group_id` exists. The same applies for all items of elements of type `/$defs/product_groups_t`. @@ -151,7 +151,7 @@ The relevant paths for this test are: > `CSAFGID-1020301` was not defined in the Product Tree. -### 6.1.5 Multiple Definition of Product Group ID +### Multiple Definition of Product Group ID For each Product Group ID (type `/$defs/product_group_id_t`) Product Group elements (`/product_tree/product_groups[]`) it MUST be tested that the `group_id` was not already defined within the same document. @@ -200,7 +200,7 @@ The relevant path for this test is: > `CSAFGID-1020300` was defined twice. -### 6.1.6 Contradicting Product Status +### Contradicting Product Status For each item in `/vulnerabilities` it MUST be tested that the same Product ID is not member of contradicting product status groups. The sets formed by the contradicting groups within one vulnerability item MUST be pairwise disjoint. @@ -262,7 +262,7 @@ Contradiction groups are: > `CSAFPID-9080700` is a member of the two contradicting groups "Affected" and "Not affected". -### 6.1.7 Multiple Scores with same Version per Product +### Multiple Scores with same Version per Product For each item in `/vulnerabilities` it MUST be tested that the same Product ID is not member of more than one CVSS-Vectors with the same version. @@ -315,7 +315,7 @@ The relevant path for this test is: > Two CVSS v3.1 scores are given for `CSAFPID-9080700`. -### 6.1.8 Invalid CVSS +### Invalid CVSS It MUST be tested that the given CVSS object is valid according to the referenced schema. @@ -340,7 +340,7 @@ The relevant paths for this test are: > A tool MAY add one or more of the missing properties `version`, `baseScore` and `baseSeverity` based on the values given in `vectorString` as quick fix. -### 6.1.9 Invalid CVSS computation +### Invalid CVSS computation It MUST be tested that the given CVSS object has the values computed correctly according to the definition. @@ -375,7 +375,7 @@ The relevant paths for this test are: > A tool MAY set the correct values as computed according to the specification as quick fix. -### 6.1.10 Inconsistent CVSS +### Inconsistent CVSS It MUST be tested that the given CVSS properties do not contradict the CVSS vector. @@ -409,7 +409,7 @@ The relevant paths for this test are: > A tool MAY overwrite contradicting values according to the `vectorString` as quick fix. -### 6.1.11 CWE +### CWE It MUST be tested that given CWE exists and is valid. @@ -430,7 +430,7 @@ The relevant path for this test is: > The `CWE-79` exists. However, its name is `Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')`. -### 6.1.12 Language +### Language For each element of type `/$defs/language_t` it MUST be tested that the language code is valid and exists. @@ -451,7 +451,7 @@ The relevant paths for this test are: > For any deprecated subtag, a tool MAY replace it with its preferred value as a quick fix. -### 6.1.13 PURL +### PURL It MUST be tested that given PURL is valid. @@ -481,7 +481,7 @@ The relevant paths for this test are: > Any valid purl has a name component. -### 6.1.14 Sorted Revision History +### Sorted Revision History It MUST be tested that the value of `number` of items of the revision history are sorted ascending when the items are sorted ascending by `date`. @@ -510,7 +510,7 @@ The relevant path for this test is: > The first item has a higher version number than the second. -### 6.1.15 Translator +### Translator It MUST be tested that `/document/source_lang` is present and set if the value `translator` is used for `/document/publisher/category`. @@ -537,7 +537,7 @@ The relevant path for this test is: > The required element `source_lang` is missing. -### 6.1.16 Latest Document Version +### Latest Document Version It MUST be tested that document version has the same value as the the `number` in the last item of Revision History when it is sorted ascending by `date`. Build metadata is ignored in the comparison. Any pre-release part is also ignored if the document status is `draft`. @@ -571,7 +571,7 @@ The relevant path for this test is: > The value of `number` of the last item after sorting is `2`. However, the document version is `1`. -### 6.1.17 Document Status Draft +### Document Status Draft It MUST be tested that document status is `draft` if the document version is `0` or `0.y.z` or contains the pre-release part. @@ -593,7 +593,7 @@ The relevant path for this test is: > The `/document/tracking/version` is `0.9.5` but the document status is `final`. -### 6.1.18 Released Revision History +### Released Revision History It MUST be tested that no item of the revision history has a `number` of `0` or `0.y.z` when the document status is `final` or `interim`. @@ -627,7 +627,7 @@ The relevant path for this test is: > The document status is `final` but the revision history includes an item which has `0` as value for `number`. -### 6.1.19 Revision History Entries for Pre-release Versions +### Revision History Entries for Pre-release Versions It MUST be tested that no item of the revision history has a `number` which includes pre-release information. @@ -656,7 +656,7 @@ The relevant path for this test is: > The revision history contains an item which has a `number` that indicates that this is pre-release. -### 6.1.20 Non-draft Document Version +### Non-draft Document Version It MUST be tested that document version does not contain a pre-release part if the document status is `final` or `interim`. @@ -678,7 +678,7 @@ The relevant path for this test is: > The document status is `interim` but the document version contains the pre-release part `-alpha`. -### 6.1.21 Missing Item in Revision History +### Missing Item in Revision History It MUST be tested that items of the revision history do not omit a version number when the items are sorted ascending by `date`. In the case of semantic versioning, this applies only to the Major version. It MUST also be tested that the first item in such a sorted list has either the version number 0 or 1 in the case of integer versioning or a Major version of 0 or 1 in the case of semantic versioning. @@ -707,7 +707,7 @@ The relevant path for this test is: > The item for version `2` is missing. -### 6.1.22 Multiple Definition in Revision History +### Multiple Definition in Revision History It MUST be tested that items of the revision history do not contain the same version number. @@ -736,7 +736,7 @@ The relevant path for this test is: > The revision history contains two items with the version number `1`. -### 6.1.23 Multiple Use of Same CVE +### Multiple Use of Same CVE It MUST be tested that a CVE is not used in multiple vulnerability items. @@ -761,7 +761,7 @@ The relevant path for this test is: > The vulnerabilities array contains two items with the same CVE identifier `CVE-2017-0145`. -### 6.1.24 Multiple Definition in Involvements +### Multiple Definition in Involvements It MUST be tested that items of the list of involvements do not contain the same `party` regardless of its `status` more than once at any `date`. @@ -795,7 +795,7 @@ The relevant path for this test is: > The list of involvements contains two items with the same tuple `party` and `date`. -### 6.1.25 Multiple Use of Same Hash Algorithm +### Multiple Use of Same Hash Algorithm It MUST be tested that the same hash algorithm is not used multiple times in one item of hashes. @@ -839,7 +839,7 @@ The relevant paths for this test are: > The hash algorithm `sha256` is used two times in one item of hashes. -### 6.1.26 Prohibited Document Category Name +### Prohibited Document Category Name It MUST be tested that the document category is not equal to the (case insensitive) name (without the prefix `csaf_`) or value of any other profile than "CSAF Base". Any occurrences of dash, whitespace, and underscore characters are removed from the values on both sides before the match. Also the value MUST NOT start with the reserved prefix `csaf_` except if the value is `csaf_base`. @@ -882,13 +882,13 @@ The relevant path for this test is: > The value `Security_Incident_Response` is the name of a profile where the space was replaced with underscores. -### 6.1.27 Profile Tests +### Profile Tests This subsubsection structures the tests for the profiles. Not all tests apply for all profiles. Tests SHOULD be skipped if the document category does not match the one given in the test. Each of the following tests SHOULD be treated as they where listed similar to the other tests. > An application MAY group these tests by profiles when providing the additional function to only run one or more selected tests. This results in one virtual test per profile. -#### 6.1.27.1 Document Notes +#### Document Notes It MUST be tested that at least one item in `/document/notes` exists which has a `category` of `description`, `details`, `general` or `summary`. @@ -919,7 +919,7 @@ The relevant path for this test is: > The document notes do not contain an item which has a `category` of `description`, `details`, `general` or `summary`. -#### 6.1.27.2 Document References +#### Document References It MUST be tested that at least one item in `/document/references` exists that has links to an `external` source. @@ -950,7 +950,7 @@ The relevant path for this test is: > The document references do not contain any item which has the category `external`. -#### 6.1.27.3 Vulnerabilities +#### Vulnerabilities{#vulnerabilities-for-informational-advisory} It MUST be tested that the element `/vulnerabilities` does not exist. @@ -980,7 +980,7 @@ The relevant path for this test is: > A tool MAY change the `/document/category` to `csaf_base` as a quick fix. -#### 6.1.27.4 Product Tree +#### Product Tree It MUST be tested that the element `/product_tree` exists. @@ -1012,7 +1012,7 @@ The relevant path for this test is: > The element `/product_tree` does not exist. -#### 6.1.27.5 Vulnerability Notes +#### Vulnerability Notes For each item in `/vulnerabilities` it MUST be tested that the element `notes` exists. @@ -1041,7 +1041,7 @@ The relevant path for this test is: > The vulnerability item has no `notes` element. -#### 6.1.27.6 Product Status +#### Product Status For each item in `/vulnerabilities` it MUST be tested that the element `product_status` exists. @@ -1069,7 +1069,7 @@ The relevant path for this test is: > The vulnerability item has no `product_status` element. -#### 6.1.27.7 VEX Product Status +#### VEX Product Status For each item in `/vulnerabilities` it MUST be tested that at least one of the elements `fixed`, `known_affected`, `known_not_affected`, or `under_investigation` is present in `product_status`. @@ -1103,7 +1103,7 @@ The relevant paths for this test are: > None of the elements `fixed`, `known_affected`, `known_not_affected`, or `under_investigation` is present in `product_status`. -#### 6.1.27.8 Vulnerability ID +#### Vulnerability ID For each item in `/vulnerabilities` it MUST be tested that at least one of the elements `cve` or `ids` is present. @@ -1132,7 +1132,7 @@ The relevant paths for this test are: > None of the elements `cve` or `ids` is present. -#### 6.1.27.9 Impact Statement +#### Impact Statement For each item in `/vulnerabilities[]/product_status/known_not_affected` it MUST be tested that a corresponding impact statement exist in `/vulnerabilities[]/flags` or `/vulnerabilities[]/threats`. For the latter one, the `category` value for such a statement MUST be `impact`. @@ -1204,7 +1204,7 @@ The relevant path for this test is: > > Note: The impact statement for `CSAFPID-9080700` and `CSAFPID-9080701` is given through `CSAFGID-0001`. -#### 6.1.27.10 Action Statement +#### Action Statement For each item in `/vulnerabilities[]/product_status/known_affected` it MUST be tested that a corresponding action statement exist in `/vulnerabilities[]/remediations`. @@ -1276,7 +1276,7 @@ The relevant path for this test is: > > Note: The action statement for `CSAFPID-9080700` and `CSAFPID-9080701` is given through `CSAFGID-0001`. -#### 6.1.27.11 Vulnerabilities +#### Vulnerabilities{#vulnerabilities-for-security-advisory-or-vex} It MUST be tested that the element `/vulnerabilities` exists. @@ -1308,7 +1308,7 @@ The relevant path for this test is: > The element `/vulnerabilities` does not exist. -### 6.1.28 Translation +### Translation It MUST be tested that the given source language and document language are not the same. @@ -1337,7 +1337,7 @@ The relevant path for this test is: > A tool MAY remove the source language as quick fix. -### 6.1.29 Remediation without Product Reference +### Remediation without Product Reference For each item in `/vulnerabilities[]/remediations` it MUST be tested that it includes at least one of the elements `group_ids` or `product_ids`. @@ -1362,7 +1362,7 @@ The relevant path for this test is: > A tool MAY add all products of the affected group of this vulnerability to the remediation as quick fix. -### 6.1.30 Mixed Integer and Semantic Versioning +### Mixed Integer and Semantic Versioning It MUST be tested that all elements of type `/$defs/version_t` follow either integer versioning or semantic versioning homogeneously within the same document. @@ -1399,7 +1399,7 @@ The relevant paths for this test are: > A tool MAY assign all items their corresponding value according to integer versioning as a quick fix. In such case, the old `number` SHOULD be stored in `legacy_version`. -### 6.1.31 Version Range in Product Version +### Version Range in Product Version For each element of type `/$defs/branches_t` with `category` of `product_version` it MUST be tested that the value of `name` does not contain a version range. @@ -1439,7 +1439,7 @@ The relevant paths for this test are: > The version range `prior to 4.2` is given for the branch category `product_version`. -### 6.1.32 Flag without Product Reference +### Flag without Product Reference For each item in `/vulnerabilities[]/flags` it MUST be tested that it includes at least one of the elements `group_ids` or `product_ids`. @@ -1461,7 +1461,7 @@ The relevant path for this test is: > The given flag does not specify to which products it should be applied. -### 6.1.33 Multiple Flags with VEX Justification Codes per Product +### Multiple Flags with VEX Justification Codes per Product For each item in `/vulnerabilities[]` it MUST be tested that a Product is not member of more than one Flag item with a VEX justification code (see section 3.2.3.5). This takes indirect relations through Product Groups into account. diff --git a/csaf_2.1/prose/edit/src/tests-02-optional.md b/csaf_2.1/prose/edit/src/tests-02-optional.md index 00a25b154..9aec7f3e1 100644 --- a/csaf_2.1/prose/edit/src/tests-02-optional.md +++ b/csaf_2.1/prose/edit/src/tests-02-optional.md @@ -1,8 +1,8 @@ -## 6.2 Optional Tests +## Optional Tests Optional tests SHOULD NOT fail at a valid CSAF document without a good reason. Failing such a test does not make the CSAF document invalid. These tests may include information about features which are still supported but expected to be deprecated in a future version of CSAF. A program MUST handle a test failure as a warning. -### 6.2.1 Unused Definition of Product ID +### Unused Definition of Product ID For each Product ID (type `/$defs/product_id_t`) in Full Product Name elements (type: `/$defs/full_product_name_t`) it MUST be tested that the `product_id` is referenced somewhere within the same document. @@ -33,7 +33,7 @@ The relevant paths for this test are: > A tool MAY remove the unused definition as quick fix. However, such quick fix shall not be applied if the test was skipped. -### 6.2.2 Missing Remediation +### Missing Remediation For each Product ID (type `/$defs/product_id_t`) in the Product Status groups Affected and Under investigation it MUST be tested that a remediation exists. @@ -72,7 +72,7 @@ The relevant paths for this test are: > `CSAFPID-9080700` has in Product Status `last_affected` but there is no remediation object for this Product ID. -### 6.2.3 Missing Score +### Missing Score For each Product ID (type `/$defs/product_id_t`) in the Product Status groups Affected it MUST be tested that a score object exists which covers this product. @@ -108,7 +108,7 @@ The relevant paths for this test are: > `CSAFPID-9080700` has in Product Status `first_affected` but there is no score object which covers this Product ID. -### 6.2.4 Build Metadata in Revision History +### Build Metadata in Revision History For each item in revision history it MUST be tested that `number` does not include build metadata. @@ -132,7 +132,7 @@ The relevant path for this test is: > The revision history contains an item which has a `number` that includes the build metadata `+exp.sha.ac00785`. -### 6.2.5 Older Initial Release Date than Revision History +### Older Initial Release Date than Revision History It MUST be tested that the Initial Release Date is not older than the `date` of the oldest item in Revision History. @@ -166,7 +166,7 @@ The relevant path for this test is: > The initial release date `2021-04-22T10:00:00.000Z` is older than `2021-05-06T10:00:00.000Z` which is the `date` of the oldest item in Revision History. -### 6.2.6 Older Current Release Date than Revision History +### Older Current Release Date than Revision History It MUST be tested that the Current Release Date is not older than the `date` of the newest item in Revision History. @@ -200,7 +200,7 @@ The relevant path for this test is: > The current release date `2021-05-06T10:00:00.000Z` is older than `2021-05-23T1100:00.000Z` which is the `date` of the newest item in Revision History. -### 6.2.7 Missing Date in Involvements +### Missing Date in Involvements For each item in the list of involvements it MUST be tested that it includes the property `date`. @@ -227,7 +227,7 @@ The relevant path for this test is: > The list of involvements contains an item which does not contain the property `date`. -### 6.2.8 Use of MD5 as the only Hash Algorithm +### Use of MD5 as the only Hash Algorithm It MUST be tested that the hash algorithm `md5` is not the only one present. @@ -269,7 +269,7 @@ The relevant paths for this test are: > The hash algorithm `md5` is used in one item of hashes without being accompanied by a second hash algorithm. -### 6.2.9 Use of SHA-1 as the only Hash Algorithm +### Use of SHA-1 as the only Hash Algorithm It MUST be tested that the hash algorithm `sha1` is not the only one present. @@ -311,7 +311,7 @@ The relevant paths for this test are: > The hash algorithm `sha1` is used in one item of hashes without being accompanied by a second hash algorithm. -### 6.2.10 Missing TLP label +### Missing TLP label It MUST be tested that `/document/distribution/tlp/label` is present and valid. @@ -333,7 +333,7 @@ The relevant path for this test is: > The CSAF document has no TLP label. -### 6.2.11 Missing Canonical URL +### Missing Canonical URL It MUST be tested that the CSAF document has a canonical URL. @@ -374,7 +374,7 @@ The relevant path for this test is: > The only element where the `category` is `self` has a URL that does not fulfill the requirement of a valid filename for a CSAF document. -### 6.2.12 Missing Document Language +### Missing Document Language It MUST be tested that the document language is present and set. @@ -399,7 +399,7 @@ The relevant path for this test is: > The document language is not defined. -### 6.2.13 Sorting +### Sorting{#optional-tests--sorting} It MUST be tested that all keys in a CSAF document are sorted alphabetically. @@ -423,7 +423,7 @@ The relevant path for this test is: > A tool MAY sort the keys as a quick fix. -### 6.2.14 Use of Private Language +### Use of Private Language For each element of type `/$defs/language_t` it MUST be tested that the language code does not contain subtags reserved for private use. @@ -444,7 +444,7 @@ The relevant paths for this test are: > A tool MAY remove such subtag as a quick fix. -### 6.2.15 Use of Default Language +### Use of Default Language For each element of type `/$defs/language_t` it MUST be tested that the language code is not `i-default`. @@ -465,7 +465,7 @@ The relevant paths for this test are: > A tool MAY remove such element as a quick fix. -### 6.2.16 Missing Product Identification Helper +### Missing Product Identification Helper For each element of type `/$defs/full_product_name_t` it MUST be tested that it includes the property `product_identification_helper`. @@ -490,7 +490,7 @@ The relevant paths for this test are: > The product `CSAFPID-9080700` does not provide any Product Identification Helper at all. -### 6.2.17 CVE in field IDs +### CVE in field IDs For each item in `/vulnerabilities[]/ids` it MUST be tested that it is not a CVE ID. @@ -517,7 +517,7 @@ The relevant paths for this test are: > A tool MAY set such element as value for the `cve` property as a quick fix, if that didn't exist before. Alternatively, it MAY remove such element as a quick fix. -### 6.2.18 Product Version Range without vers +### Product Version Range without vers For each element of type `/$defs/branches_t` with `category` of `product_version_range` it MUST be tested that the value of `name` conforms the vers specification. @@ -547,7 +547,7 @@ The relevant paths for this test are: > The version range `>4.2` is a valid vsl but not valid according to the vers specification. -### 6.2.19 CVSS for Fixed Products +### CVSS for Fixed Products For each item the fixed products group (`first_fixed` and `fixed`) it MUST be tested that a CVSS applying to this product has an environmental score of `0`. The test SHALL pass if none of the Product IDs listed within product status `fixed` or `first_fixed` is found in `products` of any item of the `scores` element. @@ -597,7 +597,7 @@ The relevant path for this test is: > A tool MAY set the properties `modifiedIntegrityImpact`, `modifiedAvailabilityImpact`, `modifiedConfidentialityImpact` accordingly and compute the `environmentalScore` as quick fix. -### 6.2.20 Additional Properties +### Additional Properties It MUST be tested that there is no additional property in the CSAF document that was not defined in the CSAF JSON schema. diff --git a/csaf_2.1/prose/edit/src/tests-03-informative.md b/csaf_2.1/prose/edit/src/tests-03-informative.md index c8d97e58e..3e561fa0b 100644 --- a/csaf_2.1/prose/edit/src/tests-03-informative.md +++ b/csaf_2.1/prose/edit/src/tests-03-informative.md @@ -1,8 +1,8 @@ -## 6.3 Informative Test +## Informative Test Informative tests provide insights in common mistakes and bad practices. They MAY fail at a valid CSAF document. It is up to the issuing party to decide whether this was an intended behavior and can be ignore or should be treated. These tests MAY include information about recommended usage. A program MUST handle a test failure as a information. -### 6.3.1 Use of CVSS v2 as the only Scoring System +### Use of CVSS v2 as the only Scoring System For each item in the list of scores which contains the `cvss_v2` object it MUST be tested that is not the only scoring item present. The test SHALL pass if a second scoring object is available. @@ -47,7 +47,7 @@ Recommendation: It is recommended to (also) use the CVSS v3.1. -### 6.3.2 Use of CVSS v3.0 +### Use of CVSS v3.0 For each item in the list of scores which contains the `cvss_v3` object it MUST be tested that CVSS v3.0 is not used. @@ -77,7 +77,7 @@ It is recommended to upgrade to CVSS v3.1. > A tool MAY upgrade to CVSS v3.1 as quick fix. However, if such quick fix is supported the tool SHALL also recompute the `baseScore` and `baseSeverity`. The same applies for `temporalScore` and `temporalSeverity` respectively `environmentalScore` and `environmentalSeverity` if the necessary fields for computing their value are present and set. -### 6.3.3 Missing CVE +### Missing CVE It MUST be tested that the CVE number is given. @@ -103,7 +103,7 @@ Recommendation: It is recommended to provide a CVE number to support the users efforts to find more details about a vulnerability and potentially track it through multiple advisories. If no CVE exists for that vulnerability, it is recommended to get one assigned. -### 6.3.4 Missing CWE +### Missing CWE It MUST be tested that the CWE is given. @@ -126,7 +126,7 @@ The relevant path for this test is: > The CWE number is not given. -### 6.3.5 Use of Short Hash +### Use of Short Hash It MUST be tested that the length of the hash value is not shorter than 64 characters. @@ -166,7 +166,7 @@ The relevant paths for this test are: > The length of the hash value is only 32 characters long. -### 6.3.6 Use of non-self referencing URLs Failing to Resolve +### Use of non-self referencing URLs Failing to Resolve For each URL which is not in the category `self` it MUST be tested that it resolves with a HTTP status code from the 2xx (Successful) or 3xx (Redirection) class. @@ -210,7 +210,7 @@ The relevant paths for this test are: > The `category` is not set and therefore treated as its default value `external`. A request to that URL does not resolve with a status code from the 2xx (Successful) or 3xx (Redirection) class. -### 6.3.7 Use of self referencing URLs Failing to Resolve +### Use of self referencing URLs Failing to Resolve For each item in an array of type `references_t` with the category `self` it MUST be tested that the URL referenced resolves with a HTTP status code less than 400. @@ -237,7 +237,7 @@ The relevant paths for this test are: > The `category` is `self` and a request to that URL does not resolve with a status code from the 2xx (Successful) or 3xx (Redirection) class. -### 6.3.8 Spell check +### Spell check If the document language is given it MUST be tested that a spell check for the given language does not find any mistakes. The test SHALL be skipped if not document language is set. It SHALL fail it the given language is not supported. The value of `/document/category` SHOULD NOT be tested if the CSAF document does not use the profile "CSAF Base". @@ -300,7 +300,7 @@ The relevant paths for this test are: > There is a spelling mistake in `Secruity`. -### 6.3.9 Branch Categories +### Branch Categories For each element of type `/$defs/full_product_name_t` in `/product_tree/branches` it MUST be tested that ancestor nodes along the path exist which use the following branch categories `vendor` -> `product_name` -> `product_version` in that order starting with the Product tree node. @@ -341,7 +341,7 @@ The relevant paths for this test are: > The product `CSAFPID-9080700` does not have any ancestor with the branch category `product_version`. -### 6.3.10 Usage of Product Version Range +### Usage of Product Version Range For each element of type `/$defs/branches_t` it MUST be tested that the `category` is not `product_version_range`. @@ -361,7 +361,7 @@ The relevant paths for this test are: > The category `product_version_range` was used. -### 6.3.11 Usage of V as Version Indicator +### Usage of V as Version Indicator For each element of type `/$defs/branches_t` with `category` of `product_version` it MUST be tested that the value of `name` does not start with `v` or `V` before the version. From 92efb86490bc758e3e7ef72347c9dc677c407c62 Mon Sep 17 00:00:00 2001 From: Stefan Hagen Date: Mon, 14 Aug 2023 14:18:01 +0200 Subject: [PATCH 09/74] documentary: added a volatile generator and a share folder - the volatile script for generating the user facing GFM+gh_cosmetics delivery item from the sources (bin/volatile.py) is documented and passes the usual quality controls: + mypy bin/volatile.py (for type verification) + ruff --ignore E501 bin/volatile.py (for general linting) + black -S -l120 bin/volatile.py (single quotes preferred and 120 chars or less long lines format) + vale --config etc/vale.ini bin/volatile.py (developer documentation spell check) - added a share folder with documentation to share the current state of generated GFM+gh_cosmetics format, the user facing delivery item as a single file and as built from current sources within the edit folder - this generated file is not intended to mimic the incoming 'elephant', but instead to enable feedback on the usefulness for end-users reading the current draft of the spec (offering extended navigation capabilities). Signed-off-by: Stefan Hagen --- csaf_2.1/prose/edit/bin/volatile.py | 449 ++ csaf_2.1/prose/share/README.md | 7 + csaf_2.1/prose/share/csaf-v2.1-draft.md | 7435 +++++++++++++++++++++++ 3 files changed, 7891 insertions(+) create mode 100755 csaf_2.1/prose/edit/bin/volatile.py create mode 100644 csaf_2.1/prose/share/README.md create mode 100644 csaf_2.1/prose/share/csaf-v2.1-draft.md diff --git a/csaf_2.1/prose/edit/bin/volatile.py b/csaf_2.1/prose/edit/bin/volatile.py new file mode 100755 index 000000000..74e6a7b2d --- /dev/null +++ b/csaf_2.1/prose/edit/bin/volatile.py @@ -0,0 +1,449 @@ +#! /usr/bin/env python +"""Volatile script file for prototyping that may take on different behaviors in time. + +This one off script is a constant place to document the early stages of tools for processing the editable +sources and build the delivery items. + +Currently impersonating phase zero concatenate and map from the initial sources to the GFM+gh_cosmetics file. +""" +import json +import pathlib +import re +import os +import sys +from typing import Union + +import yaml + +ENCODING = 'utf-8' +NL = '\n' +CB_END = '}' +COLON = ':' +FULL_STOP = '.' +HASH = '#' +PARA = '§' +SEMI = ';' +SPACE = ' ' +TM = '™' + +# Optionally dump the look-up tables (LUT)s for section display and label: +DUMP_LUT = bool(os.getenv('DUMP_LUT', '')) + +# Configuration and runtime parameter candidates: +BINDER_AT = pathlib.Path('etc') / 'bind.txt' +SOURCE_AT = pathlib.Path('src') +BUILD_AT = pathlib.Path('build') +SECTION_DISPLAY_TO_LABEL_AT = pathlib.Path('etc') / 'section-display-to-label.json' +SECTION_LABEL_TO_DISPLAY_AT = pathlib.Path('etc') / 'section-label-to-display.json' + +# Parsers and magical literals: +IS_CITE_REF = 'cite' +CITE_REF_DETECT = re.compile(r'\\\[\[(?Pcite)\]\(#(?P