diff --git a/SOURCES/openscap-1.3.7-PR-1891-xmlfilecontent.patch b/SOURCES/openscap-1.3.7-PR-1891-xmlfilecontent.patch new file mode 100644 index 0000000..caa356b --- /dev/null +++ b/SOURCES/openscap-1.3.7-PR-1891-xmlfilecontent.patch @@ -0,0 +1,132 @@ +From 9c2052febe494ca5fe8e3fef7996fd2c2c736785 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Jan=20=C4=8Cern=C3=BD?= +Date: Wed, 2 Nov 2022 09:04:25 +0100 +Subject: [PATCH] Don't emit items if XPath doesn't match + +This commit fixes the behavior of the xmlfilecontent probe in situation +when the XPath query in xmlfilecontent_object doesn't match any node in +the given XML file and the query returns an empty node set. Currently, +in this situation, we emit an item in which we add an empty value_of +element. However, this value_of element has its datatype attribute set +to an empty string, which is invalid according to the OVAL schema. When +we try to make the OVAL results valid, we face the problem that it isn't +clear what should be the value of the datatype attribute for empty +elements. But as we can realize the XPath doesn't match anything means +that the requested object doesn't exist on the system, so a better +behavior would be to not produce a xmlfilecontent54_item. That is +consistent with eg. situation when a regular expression matched nothing +in textfilecontent54_object. This commit therefore stops the item +generation in this situation. + +This commit also extends the existing test to cover the situation +of XPath queries for nonexistent element and nonexistent attribute. + +Fixes: #1890, rhbz#2138884, rhbz#2139060 +--- + .../probes/independent/xmlfilecontent_probe.c | 5 +-- + .../test_xmlfilecontent_probe.sh | 6 +++ + .../test_xmlfilecontent_probe.xml | 38 +++++++++++++++++++ + 3 files changed, 46 insertions(+), 3 deletions(-) + +diff --git a/src/OVAL/probes/independent/xmlfilecontent_probe.c b/src/OVAL/probes/independent/xmlfilecontent_probe.c +index 6c70b359ba..5d56afa0d4 100644 +--- a/src/OVAL/probes/independent/xmlfilecontent_probe.c ++++ b/src/OVAL/probes/independent/xmlfilecontent_probe.c +@@ -296,10 +296,9 @@ static int process_file(const char *prefix, const char *path, const char *filena + + node_cnt = nodes->nodeNr; + dD("node_cnt: %d.", node_cnt); +- if (node_cnt == 0) { +- probe_item_setstatus(item, SYSCHAR_STATUS_DOES_NOT_EXIST); +- probe_item_ent_add(item, "value_of", NULL, NULL); +- probe_itement_setstatus(item, "value_of", 1, SYSCHAR_STATUS_DOES_NOT_EXIST); ++ if (node_cnt <= 0) { ++ ret = -5; ++ goto cleanup; + } else { + node_tab = nodes->nodeTab; + for (i = 0; i < node_cnt; ++i) { +diff --git a/tests/probes/xmlfilecontent/test_xmlfilecontent_probe.sh b/tests/probes/xmlfilecontent/test_xmlfilecontent_probe.sh +index e3c56a8606..68138dad75 100755 +--- a/tests/probes/xmlfilecontent/test_xmlfilecontent_probe.sh ++++ b/tests/probes/xmlfilecontent/test_xmlfilecontent_probe.sh +@@ -6,9 +6,15 @@ set -e -o pipefail + cp $srcdir/example.xml /tmp/ + result=$(mktemp) + $OSCAP oval eval --results $result $srcdir/test_xmlfilecontent_probe.xml ++# Even if OSCAP_FULL_VALIDATION is set, an invalid OVAL result doesn't cause ++# the "oscap oval eval" to return a non-zero value, so let's run validation ++# as a separate command ++$OSCAP oval validate "$result" + assert_exists 1 '/oval_results/results/system/definitions/definition[@definition_id="oval:x:def:1" and @result="true"]' + assert_exists 1 '/oval_results/results/system/definitions/definition[@definition_id="oval:x:def:2" and @result="true"]' + assert_exists 1 '/oval_results/results/system/definitions/definition[@definition_id="oval:x:def:3" and @result="true"]' + assert_exists 1 '/oval_results/results/system/definitions/definition[@definition_id="oval:x:def:4" and @result="true"]' + assert_exists 1 '/oval_results/results/system/definitions/definition[@definition_id="oval:x:def:5" and @result="true"]' ++assert_exists 1 '/oval_results/results/system/definitions/definition[@definition_id="oval:x:def:6" and @result="true"]' ++assert_exists 1 '/oval_results/results/system/definitions/definition[@definition_id="oval:x:def:7" and @result="true"]' + rm -f $result +\ No newline at end of file +diff --git a/tests/probes/xmlfilecontent/test_xmlfilecontent_probe.xml b/tests/probes/xmlfilecontent/test_xmlfilecontent_probe.xml +index 3350df0c49..0a9708d4b6 100644 +--- a/tests/probes/xmlfilecontent/test_xmlfilecontent_probe.xml ++++ b/tests/probes/xmlfilecontent/test_xmlfilecontent_probe.xml +@@ -66,6 +66,30 @@ + + + ++ ++ ++ A simple test OVAL for xmlfilecontent test - check nonexisting attribute ++ x ++ ++ x ++ ++ ++ ++ ++ ++ ++ ++ ++ A simple test OVAL for xmlfilecontent test - check nonexisting element ++ x ++ ++ x ++ ++ ++ ++ ++ ++ + + + +@@ -89,6 +113,12 @@ + + + ++ ++ ++ ++ ++ ++ + + + +@@ -112,6 +142,14 @@ + /tmp/example.xml + //*[@regid="mycoyote.com"]/@name + ++ ++ /tmp/example.xml ++ /SoftwareIdentity/@thisattributedoesnotexist ++ ++ ++ /tmp/example.xml ++ /SoftwareIdentity/thiselementdoesnotexist ++ + + + diff --git a/SPECS/openscap.spec b/SPECS/openscap.spec index dc3ff46..a1f089b 100644 --- a/SPECS/openscap.spec +++ b/SPECS/openscap.spec @@ -1,6 +1,6 @@ Name: openscap Version: 1.3.6 -Release: 4%{?dist} +Release: 5%{?dist} Epoch: 1 Summary: Set of open source libraries enabling integration of the SCAP line of standards License: LGPLv2+ @@ -14,6 +14,7 @@ Patch5: openscap-1.3.7-PR-1861-failed-to-check-available-memory.patch Patch6: openscap-1.3.7-PR-1874-unit-test-read-common-sizet.patch Patch7: openscap-1.3.7-PR-1875-reset-errno-strtol.patch Patch8: openscap-1.3.7-PR-1876-disable-oscap-remediate.patch +Patch9: openscap-1.3.7-PR-1891-xmlfilecontent.patch BuildRequires: make BuildRequires: cmake >= 2.6 BuildRequires: gcc @@ -208,6 +209,9 @@ pathfix.py -i %{__python3} -p -n $RPM_BUILD_ROOT%{_bindir}/scap-as-rpm * Wed Mar 15 2023 MSVSphere Packaging Team - 1.3.6-4 - Rebuilt for MSVSphere 9.1. +* Mon Jan 30 2023 Jan Černý - 1:1.3.6-5 +- Don't emit xmlfilecontent items if XPath doesn't match (rhbz#2165580) + * Thu Jul 21 2022 Jan Černý - 1:1.3.6-4 - Fix potential invalid scan results in OpenSCAP (rhbz#2109485) - Remove oscap-remediate service (rhbz#2111358)