* change: never refer to ChangeLog
* change raspberry pi os use debian oval at report
* change do not use r.Family
* change gost do not use r.Family
* change use r.Family because family has a large impact
* change replace MaineK00n/goval-dictionary@raspberrypi-oval
* note Raspbian Scan Policy
* add Raspbian Changelog support policy
* change grep Package for Raspbian at fast-scan mode
* add changelog preprocessing for Raspbian
* add take note of TODO
* change Changelog fetch part to function
* change error handling
* change solve one TODO
* change make ChangelogDir once
* add comment
* fix oval support Amazon Linux :refs #824
* change to useScannedCves from ovalSupproted
* change confidence for Raspbian
* change skip package for raspbian in OVAL DB
* change separate raspbian implementation from util
* change error, log format
* change print format
* change log format(delete newline)
* change support changelog.(Debian.)gz
* Revert "change support changelog.(Debian.)gz"
This reverts commit 2265a72c67.
* change test chnage.(Debian.)gz
* change support raspbian package(*raspberry*)
* change error format
* fix regexp pattern
* fix typo
* fix changelog cache
* change rename function name
* add TestParseChangelog
* change changelog lenient match for raspbian
* fix test case
* change clog dir support symbolic link, clog save dir name append suffix
* change remove more package for raspberry pi
* fix error handling
* change module update
* change refactoring around identifying raspbian package
* update go module
* update scan image
* update scan image
* change clarify scan mode
* change raspiPackNamePattern and add test case
		
	
		
			
				
	
	
		
			189 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			189 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package gost
 | 
						|
 | 
						|
import (
 | 
						|
	"encoding/json"
 | 
						|
 | 
						|
	"github.com/future-architect/vuls/config"
 | 
						|
	"github.com/future-architect/vuls/models"
 | 
						|
	"github.com/future-architect/vuls/util"
 | 
						|
	"github.com/knqyf263/gost/db"
 | 
						|
	gostmodels "github.com/knqyf263/gost/models"
 | 
						|
)
 | 
						|
 | 
						|
// Debian is Gost client for Debian GNU/Linux
 | 
						|
type Debian struct {
 | 
						|
	Base
 | 
						|
}
 | 
						|
 | 
						|
type packCves struct {
 | 
						|
	packName  string
 | 
						|
	isSrcPack bool
 | 
						|
	cves      []models.CveContent
 | 
						|
}
 | 
						|
 | 
						|
func (deb Debian) Supported(major string) bool {
 | 
						|
	_, ok := map[string]string{
 | 
						|
		"8":  "jessie",
 | 
						|
		"9":  "stretch",
 | 
						|
		"10": "buster",
 | 
						|
	}[major]
 | 
						|
	return ok
 | 
						|
}
 | 
						|
 | 
						|
// DetectUnfixed fills cve information that has in Gost
 | 
						|
func (deb Debian) DetectUnfixed(driver db.DB, r *models.ScanResult, _ bool) (nCVEs int, err error) {
 | 
						|
	if !deb.Supported(major(r.Release)) {
 | 
						|
		// only logging
 | 
						|
		util.Log.Warnf("Debian %s is not supported yet", r.Release)
 | 
						|
		return 0, nil
 | 
						|
	}
 | 
						|
 | 
						|
	linuxImage := "linux-image-" + r.RunningKernel.Release
 | 
						|
	// Add linux and set the version of running kernel to search OVAL.
 | 
						|
	if r.Container.ContainerID == "" {
 | 
						|
		newVer := ""
 | 
						|
		if p, ok := r.Packages[linuxImage]; ok {
 | 
						|
			newVer = p.NewVersion
 | 
						|
		}
 | 
						|
		r.Packages["linux"] = models.Package{
 | 
						|
			Name:       "linux",
 | 
						|
			Version:    r.RunningKernel.Version,
 | 
						|
			NewVersion: newVer,
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	// Debian Security Tracker does not support Package for Raspbian, so skip it.
 | 
						|
	var scanResult models.ScanResult
 | 
						|
	if r.Family != config.Raspbian {
 | 
						|
		scanResult = *r
 | 
						|
	} else {
 | 
						|
		scanResult = r.RemoveRaspbianPackFromResult()
 | 
						|
	}
 | 
						|
 | 
						|
	packCvesList := []packCves{}
 | 
						|
	if config.Conf.Gost.IsFetchViaHTTP() {
 | 
						|
		url, _ := util.URLPathJoin(config.Conf.Gost.URL, "debian", major(scanResult.Release), "pkgs")
 | 
						|
		responses, err := getAllUnfixedCvesViaHTTP(r, url)
 | 
						|
		if err != nil {
 | 
						|
			return 0, err
 | 
						|
		}
 | 
						|
 | 
						|
		for _, res := range responses {
 | 
						|
			debCves := map[string]gostmodels.DebianCVE{}
 | 
						|
			if err := json.Unmarshal([]byte(res.json), &debCves); err != nil {
 | 
						|
				return 0, err
 | 
						|
			}
 | 
						|
			cves := []models.CveContent{}
 | 
						|
			for _, debcve := range debCves {
 | 
						|
				cves = append(cves, *deb.ConvertToModel(&debcve))
 | 
						|
			}
 | 
						|
			packCvesList = append(packCvesList, packCves{
 | 
						|
				packName:  res.request.packName,
 | 
						|
				isSrcPack: res.request.isSrcPack,
 | 
						|
				cves:      cves,
 | 
						|
			})
 | 
						|
		}
 | 
						|
	} else {
 | 
						|
		if driver == nil {
 | 
						|
			return 0, nil
 | 
						|
		}
 | 
						|
		for _, pack := range scanResult.Packages {
 | 
						|
			cveDebs := driver.GetUnfixedCvesDebian(major(scanResult.Release), pack.Name)
 | 
						|
			cves := []models.CveContent{}
 | 
						|
			for _, cveDeb := range cveDebs {
 | 
						|
				cves = append(cves, *deb.ConvertToModel(&cveDeb))
 | 
						|
			}
 | 
						|
			packCvesList = append(packCvesList, packCves{
 | 
						|
				packName:  pack.Name,
 | 
						|
				isSrcPack: false,
 | 
						|
				cves:      cves,
 | 
						|
			})
 | 
						|
		}
 | 
						|
 | 
						|
		// SrcPack
 | 
						|
		for _, pack := range scanResult.SrcPackages {
 | 
						|
			cveDebs := driver.GetUnfixedCvesDebian(major(scanResult.Release), pack.Name)
 | 
						|
			cves := []models.CveContent{}
 | 
						|
			for _, cveDeb := range cveDebs {
 | 
						|
				cves = append(cves, *deb.ConvertToModel(&cveDeb))
 | 
						|
			}
 | 
						|
			packCvesList = append(packCvesList, packCves{
 | 
						|
				packName:  pack.Name,
 | 
						|
				isSrcPack: true,
 | 
						|
				cves:      cves,
 | 
						|
			})
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	delete(r.Packages, "linux")
 | 
						|
 | 
						|
	for _, p := range packCvesList {
 | 
						|
		for _, cve := range p.cves {
 | 
						|
			v, ok := r.ScannedCves[cve.CveID]
 | 
						|
			if ok {
 | 
						|
				if v.CveContents == nil {
 | 
						|
					v.CveContents = models.NewCveContents(cve)
 | 
						|
				} else {
 | 
						|
					v.CveContents[models.DebianSecurityTracker] = cve
 | 
						|
				}
 | 
						|
			} else {
 | 
						|
				v = models.VulnInfo{
 | 
						|
					CveID:       cve.CveID,
 | 
						|
					CveContents: models.NewCveContents(cve),
 | 
						|
					Confidences: models.Confidences{models.DebianSecurityTrackerMatch},
 | 
						|
				}
 | 
						|
				nCVEs++
 | 
						|
			}
 | 
						|
 | 
						|
			names := []string{}
 | 
						|
			if p.isSrcPack {
 | 
						|
				if srcPack, ok := r.SrcPackages[p.packName]; ok {
 | 
						|
					for _, binName := range srcPack.BinaryNames {
 | 
						|
						if _, ok := r.Packages[binName]; ok {
 | 
						|
							names = append(names, binName)
 | 
						|
						}
 | 
						|
					}
 | 
						|
				}
 | 
						|
			} else {
 | 
						|
				if p.packName == "linux" {
 | 
						|
					names = append(names, linuxImage)
 | 
						|
				} else {
 | 
						|
					names = append(names, p.packName)
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			for _, name := range names {
 | 
						|
				v.AffectedPackages = v.AffectedPackages.Store(models.PackageFixStatus{
 | 
						|
					Name:        name,
 | 
						|
					FixState:    "open",
 | 
						|
					NotFixedYet: true,
 | 
						|
				})
 | 
						|
			}
 | 
						|
			r.ScannedCves[cve.CveID] = v
 | 
						|
		}
 | 
						|
	}
 | 
						|
	return nCVEs, nil
 | 
						|
}
 | 
						|
 | 
						|
// ConvertToModel converts gost model to vuls model
 | 
						|
func (deb Debian) ConvertToModel(cve *gostmodels.DebianCVE) *models.CveContent {
 | 
						|
	severity := ""
 | 
						|
	for _, p := range cve.Package {
 | 
						|
		for _, r := range p.Release {
 | 
						|
			severity = r.Urgency
 | 
						|
			break
 | 
						|
		}
 | 
						|
	}
 | 
						|
	return &models.CveContent{
 | 
						|
		Type:          models.DebianSecurityTracker,
 | 
						|
		CveID:         cve.CveID,
 | 
						|
		Summary:       cve.Description,
 | 
						|
		Cvss2Severity: severity,
 | 
						|
		Cvss3Severity: severity,
 | 
						|
		SourceLink:    "https://security-tracker.debian.org/tracker/" + cve.CveID,
 | 
						|
		Optional: map[string]string{
 | 
						|
			"attack range": cve.Scope,
 | 
						|
		},
 | 
						|
	}
 | 
						|
}
 |