mirror of
https://github.com/anchore/syft.git
synced 2025-11-17 16:33:21 +01:00
* add initial secrets cataloger Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * update ETUI elements with new catalogers (file metadata, digests, and secrets) Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * update secrets cataloger to read full contents into memory for searching Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * quick prototype of parallelization secret regex search Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * quick prototype with single aggregated regex Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * quick prototype for secret search line-by-line Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * quick prototype hybrid secrets search Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * add secrets cataloger with line strategy Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * adjust verbiage towards SearchResults instead of Secrets + add tests Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * update json schema with secrets cataloger results Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * address PR comments Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * update readme with secrets config options Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * ensure file catalogers call AllLocations once Signed-off-by: Alex Goodman <alex.goodman@anchore.com>
33 lines
817 B
Go
33 lines
817 B
Go
package poweruser
|
|
|
|
import (
|
|
"sort"
|
|
|
|
"github.com/anchore/syft/syft/file"
|
|
"github.com/anchore/syft/syft/source"
|
|
)
|
|
|
|
type JSONSecrets struct {
|
|
Location source.Location `json:"location"`
|
|
Secrets []file.SearchResult `json:"secrets"`
|
|
}
|
|
|
|
func NewJSONSecrets(data map[source.Location][]file.SearchResult) []JSONSecrets {
|
|
results := make([]JSONSecrets, 0)
|
|
for location, secrets := range data {
|
|
results = append(results, JSONSecrets{
|
|
Location: location,
|
|
Secrets: secrets,
|
|
})
|
|
}
|
|
|
|
// sort by real path then virtual path to ensure the result is stable across multiple runs
|
|
sort.SliceStable(results, func(i, j int) bool {
|
|
if results[i].Location.RealPath != results[j].Location.RealPath {
|
|
return results[i].Location.VirtualPath < results[j].Location.VirtualPath
|
|
}
|
|
return false
|
|
})
|
|
return results
|
|
}
|