From c504d2ed0e409ebc1a579259c8f8c80a3ba6e1a6 Mon Sep 17 00:00:00 2001 From: Jimmy Zelinskie Date: Thu, 4 Feb 2016 16:49:38 -0500 Subject: [PATCH] api: add FeatureFromDatabaseModel This also handles replacing the DB identifier for a maximum version with the string "None". --- api/v1/models.go | 31 +++++++++++++++++++++++-------- 1 file changed, 23 insertions(+), 8 deletions(-) diff --git a/api/v1/models.go b/api/v1/models.go index 664d1945..e87c7ca7 100644 --- a/api/v1/models.go +++ b/api/v1/models.go @@ -129,11 +129,7 @@ func VulnerabilityFromDatabaseModel(dbVuln database.Vulnerability, withFixedIn b if withFixedIn { for _, dbFeatureVersion := range dbVuln.FixedIn { - vuln.FixedIn = append(vuln.FixedIn, Feature{ - Name: dbFeatureVersion.Feature.Name, - Namespace: dbFeatureVersion.Feature.Namespace.Name, - Version: dbFeatureVersion.Version.String(), - }) + vuln.FixedIn = append(vuln.FixedIn, FeatureFromDatabaseModel(dbFeatureVersion)) } } @@ -147,10 +143,29 @@ type Feature struct { Vulnerabilities []Vulnerability `json:"Vulnerabilities,omitempty"` } +func FeatureFromDatabaseModel(dbFeatureVersion database.FeatureVersion) Feature { + versionStr := dbFeatureVersion.Version.String() + if versionStr == types.MaxVersion.String() { + versionStr = "None" + } + + return Feature{ + Name: dbFeatureVersion.Feature.Name, + Namespace: dbFeatureVersion.Feature.Namespace.Name, + Version: versionStr, + } +} + func (f Feature) DatabaseModel() (database.FeatureVersion, error) { - version, err := types.NewVersion(f.Version) - if err != nil { - return database.FeatureVersion{}, err + var version types.Version + if f.Version == "None" { + version = types.MaxVersion + } else { + var err error + version, err = types.NewVersion(f.Version) + if err != nil { + return database.FeatureVersion{}, err + } } return database.FeatureVersion{