api/database: add the layer name that add each feature in getLayer
This commit is contained in:
parent
6b23520710
commit
6d2eedf121
@ -63,6 +63,7 @@ func LayerFromDatabaseModel(dbLayer database.Layer, withFeatures, withVulnerabil
|
|||||||
Name: dbFeatureVersion.Feature.Name,
|
Name: dbFeatureVersion.Feature.Name,
|
||||||
Namespace: dbFeatureVersion.Feature.Namespace.Name,
|
Namespace: dbFeatureVersion.Feature.Namespace.Name,
|
||||||
Version: dbFeatureVersion.Version.String(),
|
Version: dbFeatureVersion.Version.String(),
|
||||||
|
AddedBy: dbFeatureVersion.AddedBy.Name,
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, dbVuln := range dbFeatureVersion.AffectedBy {
|
for _, dbVuln := range dbFeatureVersion.AffectedBy {
|
||||||
@ -148,6 +149,7 @@ type Feature struct {
|
|||||||
Namespace string `json:"Namespace,omitempty"`
|
Namespace string `json:"Namespace,omitempty"`
|
||||||
Version string `json:"Version,omitempty"`
|
Version string `json:"Version,omitempty"`
|
||||||
Vulnerabilities []Vulnerability `json:"Vulnerabilities,omitempty"`
|
Vulnerabilities []Vulnerability `json:"Vulnerabilities,omitempty"`
|
||||||
|
AddedBy string `json:"AddedBy,omitempty"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func FeatureFromDatabaseModel(dbFeatureVersion database.FeatureVersion) Feature {
|
func FeatureFromDatabaseModel(dbFeatureVersion database.FeatureVersion) Feature {
|
||||||
@ -160,6 +162,7 @@ func FeatureFromDatabaseModel(dbFeatureVersion database.FeatureVersion) Feature
|
|||||||
Name: dbFeatureVersion.Feature.Name,
|
Name: dbFeatureVersion.Feature.Name,
|
||||||
Namespace: dbFeatureVersion.Feature.Namespace.Name,
|
Namespace: dbFeatureVersion.Feature.Namespace.Name,
|
||||||
Version: versionStr,
|
Version: versionStr,
|
||||||
|
AddedBy: dbFeatureVersion.AddedBy.Name,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -56,6 +56,9 @@ type FeatureVersion struct {
|
|||||||
Feature Feature
|
Feature Feature
|
||||||
Version types.Version
|
Version types.Version
|
||||||
AffectedBy []Vulnerability
|
AffectedBy []Vulnerability
|
||||||
|
|
||||||
|
// For output purposes. Only make sense when the feature version is in the context of an image.
|
||||||
|
AddedBy Layer
|
||||||
}
|
}
|
||||||
|
|
||||||
type Vulnerability struct {
|
type Vulnerability struct {
|
||||||
|
@ -109,7 +109,8 @@ func (pgSQL *pgSQL) getLayerFeatureVersions(layerID int) ([]database.FeatureVers
|
|||||||
|
|
||||||
err = rows.Scan(&featureVersion.ID, &modification, &featureVersion.Feature.Namespace.ID,
|
err = rows.Scan(&featureVersion.ID, &modification, &featureVersion.Feature.Namespace.ID,
|
||||||
&featureVersion.Feature.Namespace.Name, &featureVersion.Feature.ID,
|
&featureVersion.Feature.Namespace.Name, &featureVersion.Feature.ID,
|
||||||
&featureVersion.Feature.Name, &featureVersion.ID, &featureVersion.Version)
|
&featureVersion.Feature.Name, &featureVersion.ID, &featureVersion.Version,
|
||||||
|
&featureVersion.AddedBy.ID, &featureVersion.AddedBy.Name)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return featureVersions, handleError("s_layer_featureversion.Scan()", err)
|
return featureVersions, handleError("s_layer_featureversion.Scan()", err)
|
||||||
}
|
}
|
||||||
|
@ -86,20 +86,20 @@ func init() {
|
|||||||
WHERE l.name = $1;`
|
WHERE l.name = $1;`
|
||||||
|
|
||||||
queries["s_layer_featureversion"] = `
|
queries["s_layer_featureversion"] = `
|
||||||
WITH RECURSIVE layer_tree(id, parent_id, depth, path, cycle) AS(
|
WITH RECURSIVE layer_tree(id, name, parent_id, depth, path, cycle) AS(
|
||||||
SELECT l.id, l.parent_id, 1, ARRAY[l.id], false
|
SELECT l.id, l.name, l.parent_id, 1, ARRAY[l.id], false
|
||||||
FROM Layer l
|
FROM Layer l
|
||||||
WHERE l.id = $1
|
WHERE l.id = $1
|
||||||
UNION ALL
|
UNION ALL
|
||||||
SELECT l.id, l.parent_id, lt.depth + 1, path || l.id, l.id = ANY(path)
|
SELECT l.id, l.name, l.parent_id, lt.depth + 1, path || l.id, l.id = ANY(path)
|
||||||
FROM Layer l, layer_tree lt
|
FROM Layer l, layer_tree lt
|
||||||
WHERE l.id = lt.parent_id
|
WHERE l.id = lt.parent_id
|
||||||
)
|
)
|
||||||
SELECT ldf.featureversion_id, ldf.modification, fn.id, fn.name, f.id, f.name, fv.id, fv.version
|
SELECT ldf.featureversion_id, ldf.modification, fn.id, fn.name, f.id, f.name, fv.id, fv.version, ltree.id, ltree.name
|
||||||
FROM Layer_diff_FeatureVersion ldf
|
FROM Layer_diff_FeatureVersion ldf
|
||||||
JOIN (
|
JOIN (
|
||||||
SELECT row_number() over (ORDER BY depth DESC), id FROM layer_tree
|
SELECT row_number() over (ORDER BY depth DESC), id, name FROM layer_tree
|
||||||
) AS ltree (ordering, id) ON ldf.layer_id = ltree.id, FeatureVersion fv, Feature f, Namespace fn
|
) AS ltree (ordering, id, name) ON ldf.layer_id = ltree.id, FeatureVersion fv, Feature f, Namespace fn
|
||||||
WHERE ldf.featureversion_id = fv.id AND fv.feature_id = f.id AND f.namespace_id = fn.id
|
WHERE ldf.featureversion_id = fv.id AND fv.feature_id = f.id AND f.namespace_id = fn.id
|
||||||
ORDER BY ltree.ordering`
|
ORDER BY ltree.ordering`
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user