Files
trivy/analyzer/library/npm/npm.go
Teppei Fukuda 6fd4c8951f feat: support config (fanal#166)
Co-authored-by: aprp <doelaudi@gmail.com>
Co-authored-by: rahul2393 <rahulyadavsep92@gmail.com>
2021-05-19 08:05:14 +03:00

46 lines
1.1 KiB
Go

package npm
import (
"os"
"path/filepath"
"golang.org/x/xerrors"
"github.com/aquasecurity/fanal/analyzer"
"github.com/aquasecurity/fanal/analyzer/library"
"github.com/aquasecurity/fanal/types"
"github.com/aquasecurity/fanal/utils"
"github.com/aquasecurity/go-dep-parser/pkg/npm"
)
func init() {
analyzer.RegisterAnalyzer(&npmLibraryAnalyzer{})
}
const version = 1
var requiredFiles = []string{"package-lock.json"}
type npmLibraryAnalyzer struct{}
func (a npmLibraryAnalyzer) Analyze(target analyzer.AnalysisTarget) (*analyzer.AnalysisResult, error) {
res, err := library.Analyze(types.Npm, target.FilePath, target.Content, npm.Parse)
if err != nil {
return nil, xerrors.Errorf("unable to parse package-lock.json: %w", err)
}
return res, nil
}
func (a npmLibraryAnalyzer) Required(filePath string, _ os.FileInfo) bool {
fileName := filepath.Base(filePath)
return utils.StringInSlice(fileName, requiredFiles)
}
func (a npmLibraryAnalyzer) Type() analyzer.Type {
return analyzer.TypeNpm
}
func (a npmLibraryAnalyzer) Version() int {
return version
}