updater: Add vulnsrc affected feature type
Each vulnerability source has a specific type of feature that it affects We assume the following: * Alpine: Binary Package * Debian: Source Package * Ubuntu: Source Package * Oracle OVAL: Binary Package * RHEL OVAL: Binary Package
This commit is contained in:
parent
00fadfc3e3
commit
2236b0a5c9
@ -37,6 +37,9 @@ const (
|
|||||||
secdbGitURL = "https://github.com/alpinelinux/alpine-secdb"
|
secdbGitURL = "https://github.com/alpinelinux/alpine-secdb"
|
||||||
updaterFlag = "alpine-secdbUpdater"
|
updaterFlag = "alpine-secdbUpdater"
|
||||||
nvdURLPrefix = "https://cve.mitre.org/cgi-bin/cvename.cgi?name="
|
nvdURLPrefix = "https://cve.mitre.org/cgi-bin/cvename.cgi?name="
|
||||||
|
// affected type indicates if the affected feature hint is for binary or
|
||||||
|
// source package.
|
||||||
|
affectedType = database.AffectBinaryPackage
|
||||||
)
|
)
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
@ -226,6 +229,7 @@ func parseYAML(r io.Reader) (vulns []database.VulnerabilityWithAffected, err err
|
|||||||
}
|
}
|
||||||
vuln.Affected = []database.AffectedFeature{
|
vuln.Affected = []database.AffectedFeature{
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
FeatureName: pkg.Name,
|
FeatureName: pkg.Name,
|
||||||
AffectedVersion: version,
|
AffectedVersion: version,
|
||||||
FixedInVersion: fixedInVersion,
|
FixedInVersion: fixedInVersion,
|
||||||
|
@ -38,6 +38,7 @@ const (
|
|||||||
url = "https://security-tracker.debian.org/tracker/data/json"
|
url = "https://security-tracker.debian.org/tracker/data/json"
|
||||||
cveURLPrefix = "https://security-tracker.debian.org/tracker"
|
cveURLPrefix = "https://security-tracker.debian.org/tracker"
|
||||||
updaterFlag = "debianUpdater"
|
updaterFlag = "debianUpdater"
|
||||||
|
affectedType = database.AffectSourcePackage
|
||||||
)
|
)
|
||||||
|
|
||||||
type jsonData map[string]map[string]jsonVuln
|
type jsonData map[string]map[string]jsonVuln
|
||||||
@ -227,6 +228,7 @@ func parseDebianJSON(data *jsonData) (vulnerabilities []database.VulnerabilityWi
|
|||||||
|
|
||||||
// Create and add the feature version.
|
// Create and add the feature version.
|
||||||
pkg := database.AffectedFeature{
|
pkg := database.AffectedFeature{
|
||||||
|
AffectedType: affectedType,
|
||||||
FeatureName: pkgName,
|
FeatureName: pkgName,
|
||||||
AffectedVersion: version,
|
AffectedVersion: version,
|
||||||
FixedInVersion: fixedInVersion,
|
FixedInVersion: fixedInVersion,
|
||||||
|
@ -41,6 +41,7 @@ func TestDebianParser(t *testing.T) {
|
|||||||
|
|
||||||
expectedFeatures := []database.AffectedFeature{
|
expectedFeatures := []database.AffectedFeature{
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "debian:8",
|
Name: "debian:8",
|
||||||
VersionFormat: dpkg.ParserName,
|
VersionFormat: dpkg.ParserName,
|
||||||
@ -49,6 +50,7 @@ func TestDebianParser(t *testing.T) {
|
|||||||
AffectedVersion: versionfmt.MaxVersion,
|
AffectedVersion: versionfmt.MaxVersion,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "debian:unstable",
|
Name: "debian:unstable",
|
||||||
VersionFormat: dpkg.ParserName,
|
VersionFormat: dpkg.ParserName,
|
||||||
@ -69,6 +71,7 @@ func TestDebianParser(t *testing.T) {
|
|||||||
|
|
||||||
expectedFeatures := []database.AffectedFeature{
|
expectedFeatures := []database.AffectedFeature{
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "debian:8",
|
Name: "debian:8",
|
||||||
VersionFormat: dpkg.ParserName,
|
VersionFormat: dpkg.ParserName,
|
||||||
@ -78,6 +81,7 @@ func TestDebianParser(t *testing.T) {
|
|||||||
AffectedVersion: "0.7.0",
|
AffectedVersion: "0.7.0",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "debian:unstable",
|
Name: "debian:unstable",
|
||||||
VersionFormat: dpkg.ParserName,
|
VersionFormat: dpkg.ParserName,
|
||||||
@ -87,6 +91,7 @@ func TestDebianParser(t *testing.T) {
|
|||||||
AffectedVersion: "0.7.0",
|
AffectedVersion: "0.7.0",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "debian:8",
|
Name: "debian:8",
|
||||||
VersionFormat: dpkg.ParserName,
|
VersionFormat: dpkg.ParserName,
|
||||||
|
@ -41,6 +41,7 @@ const (
|
|||||||
ovalURI = "https://linux.oracle.com/oval/"
|
ovalURI = "https://linux.oracle.com/oval/"
|
||||||
elsaFilePrefix = "com.oracle.elsa-"
|
elsaFilePrefix = "com.oracle.elsa-"
|
||||||
updaterFlag = "oracleUpdater"
|
updaterFlag = "oracleUpdater"
|
||||||
|
affectedType = database.AffectBinaryPackage
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -345,6 +346,7 @@ func toFeatures(criteria criteria) []database.AffectedFeature {
|
|||||||
} else if strings.Contains(c.Comment, " is earlier than ") {
|
} else if strings.Contains(c.Comment, " is earlier than ") {
|
||||||
const prefixLen = len(" is earlier than ")
|
const prefixLen = len(" is earlier than ")
|
||||||
featureVersion.FeatureName = strings.TrimSpace(c.Comment[:strings.Index(c.Comment, " is earlier than ")])
|
featureVersion.FeatureName = strings.TrimSpace(c.Comment[:strings.Index(c.Comment, " is earlier than ")])
|
||||||
|
featureVersion.AffectedType = affectedType
|
||||||
version := c.Comment[strings.Index(c.Comment, " is earlier than ")+prefixLen:]
|
version := c.Comment[strings.Index(c.Comment, " is earlier than ")+prefixLen:]
|
||||||
err := versionfmt.Valid(rpm.ParserName, version)
|
err := versionfmt.Valid(rpm.ParserName, version)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -42,6 +42,7 @@ func TestOracleParser(t *testing.T) {
|
|||||||
|
|
||||||
expectedFeatures := []database.AffectedFeature{
|
expectedFeatures := []database.AffectedFeature{
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "oracle:7",
|
Name: "oracle:7",
|
||||||
VersionFormat: rpm.ParserName,
|
VersionFormat: rpm.ParserName,
|
||||||
@ -51,6 +52,7 @@ func TestOracleParser(t *testing.T) {
|
|||||||
AffectedVersion: "0:3.1.1-7.el7_1",
|
AffectedVersion: "0:3.1.1-7.el7_1",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "oracle:7",
|
Name: "oracle:7",
|
||||||
VersionFormat: rpm.ParserName,
|
VersionFormat: rpm.ParserName,
|
||||||
@ -60,6 +62,7 @@ func TestOracleParser(t *testing.T) {
|
|||||||
AffectedVersion: "0:3.1.1-7.el7_1",
|
AffectedVersion: "0:3.1.1-7.el7_1",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "oracle:7",
|
Name: "oracle:7",
|
||||||
VersionFormat: rpm.ParserName,
|
VersionFormat: rpm.ParserName,
|
||||||
@ -86,6 +89,7 @@ func TestOracleParser(t *testing.T) {
|
|||||||
assert.Equal(t, ` [38.1.0-1.0.1.el7_1] - Add firefox-oracle-default-prefs.js and remove the corresponding Red Hat file [38.1.0-1] - Update to 38.1.0 ESR [38.0.1-2] - Fixed rhbz#1222807 by removing preun section `, vulnerabilities[0].Description)
|
assert.Equal(t, ` [38.1.0-1.0.1.el7_1] - Add firefox-oracle-default-prefs.js and remove the corresponding Red Hat file [38.1.0-1] - Update to 38.1.0 ESR [38.0.1-2] - Fixed rhbz#1222807 by removing preun section `, vulnerabilities[0].Description)
|
||||||
expectedFeatures := []database.AffectedFeature{
|
expectedFeatures := []database.AffectedFeature{
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "oracle:6",
|
Name: "oracle:6",
|
||||||
VersionFormat: rpm.ParserName,
|
VersionFormat: rpm.ParserName,
|
||||||
@ -95,6 +99,7 @@ func TestOracleParser(t *testing.T) {
|
|||||||
AffectedVersion: "0:38.1.0-1.0.1.el6_6",
|
AffectedVersion: "0:38.1.0-1.0.1.el6_6",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "oracle:7",
|
Name: "oracle:7",
|
||||||
VersionFormat: rpm.ParserName,
|
VersionFormat: rpm.ParserName,
|
||||||
|
@ -43,6 +43,7 @@ const (
|
|||||||
ovalURI = "https://www.redhat.com/security/data/oval/"
|
ovalURI = "https://www.redhat.com/security/data/oval/"
|
||||||
rhsaFilePrefix = "com.redhat.rhsa-"
|
rhsaFilePrefix = "com.redhat.rhsa-"
|
||||||
updaterFlag = "rhelUpdater"
|
updaterFlag = "rhelUpdater"
|
||||||
|
affectedType = database.AffectBinaryPackage
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -341,6 +342,7 @@ func toFeatures(criteria criteria) []database.AffectedFeature {
|
|||||||
} else if strings.Contains(c.Comment, " is earlier than ") {
|
} else if strings.Contains(c.Comment, " is earlier than ") {
|
||||||
const prefixLen = len(" is earlier than ")
|
const prefixLen = len(" is earlier than ")
|
||||||
featureVersion.FeatureName = strings.TrimSpace(c.Comment[:strings.Index(c.Comment, " is earlier than ")])
|
featureVersion.FeatureName = strings.TrimSpace(c.Comment[:strings.Index(c.Comment, " is earlier than ")])
|
||||||
|
featureVersion.AffectedType = affectedType
|
||||||
version := c.Comment[strings.Index(c.Comment, " is earlier than ")+prefixLen:]
|
version := c.Comment[strings.Index(c.Comment, " is earlier than ")+prefixLen:]
|
||||||
err := versionfmt.Valid(rpm.ParserName, version)
|
err := versionfmt.Valid(rpm.ParserName, version)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -46,6 +46,7 @@ func TestRHELParserMultipleCVE(t *testing.T) {
|
|||||||
database.MediumSeverity, database.MediumSeverity}
|
database.MediumSeverity, database.MediumSeverity}
|
||||||
expectedFeatures := []database.AffectedFeature{
|
expectedFeatures := []database.AffectedFeature{
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "centos:6",
|
Name: "centos:6",
|
||||||
VersionFormat: rpm.ParserName,
|
VersionFormat: rpm.ParserName,
|
||||||
@ -55,6 +56,7 @@ func TestRHELParserMultipleCVE(t *testing.T) {
|
|||||||
AffectedVersion: "0:38.1.0-1.el6_6",
|
AffectedVersion: "0:38.1.0-1.el6_6",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "centos:7",
|
Name: "centos:7",
|
||||||
VersionFormat: rpm.ParserName,
|
VersionFormat: rpm.ParserName,
|
||||||
@ -94,6 +96,7 @@ func TestRHELParserOneCVE(t *testing.T) {
|
|||||||
|
|
||||||
expectedFeatures := []database.AffectedFeature{
|
expectedFeatures := []database.AffectedFeature{
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "centos:7",
|
Name: "centos:7",
|
||||||
VersionFormat: rpm.ParserName,
|
VersionFormat: rpm.ParserName,
|
||||||
@ -103,6 +106,7 @@ func TestRHELParserOneCVE(t *testing.T) {
|
|||||||
FixedInVersion: "0:3.1.1-7.el7_1",
|
FixedInVersion: "0:3.1.1-7.el7_1",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "centos:7",
|
Name: "centos:7",
|
||||||
VersionFormat: rpm.ParserName,
|
VersionFormat: rpm.ParserName,
|
||||||
@ -112,6 +116,7 @@ func TestRHELParserOneCVE(t *testing.T) {
|
|||||||
FixedInVersion: "0:3.1.1-7.el7_1",
|
FixedInVersion: "0:3.1.1-7.el7_1",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "centos:7",
|
Name: "centos:7",
|
||||||
VersionFormat: rpm.ParserName,
|
VersionFormat: rpm.ParserName,
|
||||||
|
@ -35,9 +35,10 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
trackerURI = "https://git.launchpad.net/ubuntu-cve-tracker"
|
trackerURI = "https://git.launchpad.net/ubuntu-cve-tracker"
|
||||||
updaterFlag = "ubuntuUpdater"
|
updaterFlag = "ubuntuUpdater"
|
||||||
cveURL = "http://people.ubuntu.com/~ubuntu-security/cve/%s"
|
cveURL = "http://people.ubuntu.com/~ubuntu-security/cve/%s"
|
||||||
|
affectedType = database.AffectSourcePackage
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -334,6 +335,7 @@ func parseUbuntuCVE(fileContent io.Reader) (vulnerability database.Vulnerability
|
|||||||
|
|
||||||
// Create and add the new package.
|
// Create and add the new package.
|
||||||
featureVersion := database.AffectedFeature{
|
featureVersion := database.AffectedFeature{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: releaseName,
|
Name: releaseName,
|
||||||
VersionFormat: dpkg.ParserName,
|
VersionFormat: dpkg.ParserName,
|
||||||
|
@ -46,6 +46,7 @@ func TestUbuntuParser(t *testing.T) {
|
|||||||
|
|
||||||
expectedFeatures := []database.AffectedFeature{
|
expectedFeatures := []database.AffectedFeature{
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "ubuntu:14.04",
|
Name: "ubuntu:14.04",
|
||||||
VersionFormat: dpkg.ParserName,
|
VersionFormat: dpkg.ParserName,
|
||||||
@ -54,6 +55,7 @@ func TestUbuntuParser(t *testing.T) {
|
|||||||
AffectedVersion: versionfmt.MaxVersion,
|
AffectedVersion: versionfmt.MaxVersion,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "ubuntu:15.04",
|
Name: "ubuntu:15.04",
|
||||||
VersionFormat: dpkg.ParserName,
|
VersionFormat: dpkg.ParserName,
|
||||||
@ -63,6 +65,7 @@ func TestUbuntuParser(t *testing.T) {
|
|||||||
AffectedVersion: "0.4-3",
|
AffectedVersion: "0.4-3",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
AffectedType: affectedType,
|
||||||
Namespace: database.Namespace{
|
Namespace: database.Namespace{
|
||||||
Name: "ubuntu:15.10",
|
Name: "ubuntu:15.10",
|
||||||
VersionFormat: dpkg.ParserName,
|
VersionFormat: dpkg.ParserName,
|
||||||
|
@ -425,7 +425,7 @@ func doVulnerabilitiesNamespacing(vulnerabilities []database.VulnerabilityWithAf
|
|||||||
|
|
||||||
for _, fv := range namespacedFeatures {
|
for _, fv := range namespacedFeatures {
|
||||||
// validate vulnerabilities, throw out the invalid vulnerabilities
|
// validate vulnerabilities, throw out the invalid vulnerabilities
|
||||||
if fv.AffectedVersion == "" || fv.FeatureName == "" || fv.Namespace.Name == "" || fv.Namespace.VersionFormat == "" {
|
if fv.AffectedType == "" || fv.AffectedVersion == "" || fv.FeatureName == "" || fv.Namespace.Name == "" || fv.Namespace.VersionFormat == "" {
|
||||||
log.WithFields(log.Fields{
|
log.WithFields(log.Fields{
|
||||||
"Name": fv.FeatureName,
|
"Name": fv.FeatureName,
|
||||||
"Affected Version": fv.AffectedVersion,
|
"Affected Version": fv.AffectedVersion,
|
||||||
|
@ -183,6 +183,7 @@ func newmockUpdaterDatastore() *mockUpdaterDatastore {
|
|||||||
|
|
||||||
func TestDoVulnerabilitiesNamespacing(t *testing.T) {
|
func TestDoVulnerabilitiesNamespacing(t *testing.T) {
|
||||||
fv1 := database.AffectedFeature{
|
fv1 := database.AffectedFeature{
|
||||||
|
AffectedType: database.AffectSourcePackage,
|
||||||
Namespace: database.Namespace{Name: "Namespace1"},
|
Namespace: database.Namespace{Name: "Namespace1"},
|
||||||
FeatureName: "Feature1",
|
FeatureName: "Feature1",
|
||||||
FixedInVersion: "0.1",
|
FixedInVersion: "0.1",
|
||||||
@ -190,6 +191,7 @@ func TestDoVulnerabilitiesNamespacing(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fv2 := database.AffectedFeature{
|
fv2 := database.AffectedFeature{
|
||||||
|
AffectedType: database.AffectSourcePackage,
|
||||||
Namespace: database.Namespace{Name: "Namespace2"},
|
Namespace: database.Namespace{Name: "Namespace2"},
|
||||||
FeatureName: "Feature1",
|
FeatureName: "Feature1",
|
||||||
FixedInVersion: "0.2",
|
FixedInVersion: "0.2",
|
||||||
@ -197,7 +199,7 @@ func TestDoVulnerabilitiesNamespacing(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fv3 := database.AffectedFeature{
|
fv3 := database.AffectedFeature{
|
||||||
|
AffectedType: database.AffectSourcePackage,
|
||||||
Namespace: database.Namespace{Name: "Namespace2"},
|
Namespace: database.Namespace{Name: "Namespace2"},
|
||||||
FeatureName: "Feature2",
|
FeatureName: "Feature2",
|
||||||
FixedInVersion: "0.3",
|
FixedInVersion: "0.3",
|
||||||
@ -235,8 +237,9 @@ func TestCreatVulnerabilityNotification(t *testing.T) {
|
|||||||
VersionFormat: vf1,
|
VersionFormat: vf1,
|
||||||
}
|
}
|
||||||
af1 := database.AffectedFeature{
|
af1 := database.AffectedFeature{
|
||||||
Namespace: ns1,
|
AffectedType: database.AffectSourcePackage,
|
||||||
FeatureName: "feature 1",
|
Namespace: ns1,
|
||||||
|
FeatureName: "feature 1",
|
||||||
}
|
}
|
||||||
|
|
||||||
v1 := database.VulnerabilityWithAffected{
|
v1 := database.VulnerabilityWithAffected{
|
||||||
|
Loading…
Reference in New Issue
Block a user