Make source of vulnerability data configurable

This commit is contained in:
Tobias Furuholm 2017-08-31 09:17:12 +02:00
parent 44b9701c94
commit db60b5fb22
9 changed files with 43 additions and 5 deletions

View File

@ -61,6 +61,7 @@ func DefaultConfig() Config {
Updater: &clair.UpdaterConfig{
EnabledUpdaters: vulnsrc.ListUpdaters(),
Interval: 1 * time.Hour,
SourceURLs: make(map[string]string),
},
Worker: &clair.WorkerConfig{
EnabledDetectors: featurens.ListDetectors(),

View File

@ -124,6 +124,8 @@ func configClairVersion(config *Config) {
}
clair.EnabledUpdaters = strutil.CompareStringListsInBoth(config.Updater.EnabledUpdaters, updaters)
clair.SourceURLs = config.Updater.SourceURLs
}
// Boot starts Clair instance with the provided config.

View File

@ -34,8 +34,9 @@ import (
"github.com/coreos/clair/pkg/commonerr"
)
var secdbGitURL = "https://git.alpinelinux.org/cgit/alpine-secdb"
const (
secdbGitURL = "https://git.alpinelinux.org/cgit/alpine-secdb"
updaterFlag = "alpine-secdbUpdater"
nvdURLPrefix = "https://cve.mitre.org/cgi-bin/cvename.cgi?name="
)
@ -115,6 +116,10 @@ func (u *updater) Clean() {
}
}
func (u *updater) SetSourceUrl(sourceURL string) {
secdbGitURL = sourceURL
}
type lsFilter int
const (

View File

@ -34,8 +34,9 @@ import (
"github.com/coreos/clair/pkg/commonerr"
)
var url = "https://security-tracker.debian.org/tracker/data/json"
const (
url = "https://security-tracker.debian.org/tracker/data/json"
cveURLPrefix = "https://security-tracker.debian.org/tracker"
updaterFlag = "debianUpdater"
)
@ -101,6 +102,10 @@ func (u *updater) Update(datastore database.Datastore) (resp vulnsrc.UpdateRespo
func (u *updater) Clean() {}
func (u *updater) SetSourceUrl(sourceURL string) {
url = sourceURL
}
func buildResponse(jsonReader io.Reader, latestKnownHash string) (resp vulnsrc.UpdateResponse, err error) {
hash := latestKnownHash

View File

@ -50,6 +50,9 @@ type Updater interface {
// Clean deletes any allocated resources.
// It is invoked when Clair stops.
Clean()
// Sets the source of vulnerability data to be used by the updater
SetSourceUrl(string)
}
// RegisterUpdater makes an Updater available by the provided name.

View File

@ -36,9 +36,10 @@ import (
"github.com/coreos/clair/pkg/commonerr"
)
var ovalURI = "https://linux.oracle.com/oval/"
const (
firstOracle5ELSA = 20070057
ovalURI = "https://linux.oracle.com/oval/"
elsaFilePrefix = "com.oracle.elsa-"
updaterFlag = "oracleUpdater"
)
@ -202,6 +203,10 @@ func largest(list []int) (largest int) {
func (u *updater) Clean() {}
func (u *updater) SetSourceUrl(sourceURL string) {
ovalURI = sourceURL
}
func parseELSA(ovalReader io.Reader) (vulnerabilities []database.VulnerabilityWithAffected, err error) {
// Decode the XML.
var ov oval

View File

@ -35,12 +35,13 @@ import (
"github.com/coreos/clair/pkg/commonerr"
)
var ovalURI = "https://www.redhat.com/security/data/oval/"
const (
// Before this RHSA, it deals only with RHEL <= 4.
firstRHEL5RHSA = 20070044
firstConsideredRHEL = 5
ovalURI = "https://www.redhat.com/security/data/oval/"
rhsaFilePrefix = "com.redhat.rhsa-"
updaterFlag = "rhelUpdater"
)
@ -169,6 +170,10 @@ func (u *updater) Update(datastore database.Datastore) (resp vulnsrc.UpdateRespo
func (u *updater) Clean() {}
func (u *updater) SetSourceUrl(sourceURL string) {
ovalURI = sourceURL
}
func parseRHSA(ovalReader io.Reader) (vulnerabilities []database.VulnerabilityWithAffected, err error) {
// Decode the XML.
var ov oval

View File

@ -37,9 +37,10 @@ import (
"github.com/coreos/clair/pkg/commonerr"
)
var trackerRepository = "https://launchpad.net/ubuntu-cve-tracker"
const (
trackerURI = "https://launchpad.net/ubuntu-cve-tracker"
trackerRepository = "https://launchpad.net/ubuntu-cve-tracker"
updaterFlag = "ubuntuUpdater"
cveURL = "http://people.ubuntu.com/~ubuntu-security/cve/%s"
)
@ -175,6 +176,10 @@ func (u *updater) Clean() {
os.RemoveAll(u.repositoryLocalPath)
}
func (u *updater) SetSourceUrl(sourceURL string) {
trackerRepository = sourceURL
}
func (u *updater) pullRepository() (err error) {
// Determine whether we should branch or pull.
if _, pathExists := os.Stat(u.repositoryLocalPath); u.repositoryLocalPath == "" || os.IsNotExist(pathExists) {

View File

@ -57,6 +57,9 @@ var (
// EnabledUpdaters contains all updaters to be used for update.
EnabledUpdaters []string
// SourceURLs contains any modified vulnerability data sources
SourceURLs map[string]string
)
func init() {
@ -69,6 +72,7 @@ func init() {
type UpdaterConfig struct {
EnabledUpdaters []string
Interval time.Duration
SourceURLs map[string]string
}
type vulnerabilityChange struct {
@ -276,6 +280,9 @@ func fetch(datastore database.Datastore) (bool, []database.VulnerabilityWithAffe
continue
}
numUpdaters++
if url, ok := SourceURLs[n]; ok {
u.SetSourceUrl(url)
}
go func(name string, u vulnsrc.Updater) {
response, err := u.Update(datastore)
if err != nil {