Skip to content

Commit

Permalink
perf(helm): load in-memory files
Browse files Browse the repository at this point in the history
  • Loading branch information
nikpivkin committed Mar 25, 2024
1 parent 7c409fd commit b528f68
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 39 deletions.
61 changes: 26 additions & 35 deletions pkg/iac/scanners/helm/parser/parser.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@ import (
"fmt"
"io"
"io/fs"
"os"
"path/filepath"
"regexp"
"sort"
Expand Down Expand Up @@ -192,17 +191,7 @@ func (p *Parser) extractChartName(chartPath string) error {
}

func (p *Parser) RenderedChartFiles() ([]ChartFile, error) {

tempDir, err := os.MkdirTemp(os.TempDir(), "defsec")
if err != nil {
return nil, err
}

if err := p.writeBuildFiles(tempDir); err != nil {
return nil, err
}

workingChart, err := loadChart(tempDir)
workingChart, err := p.loadChart()
if err != nil {
return nil, err
}
Expand Down Expand Up @@ -246,19 +235,39 @@ func (p *Parser) getRelease(chrt *chart.Chart) (*release.Release, error) {
return r, nil
}

func loadChart(tempFs string) (*chart.Chart, error) {
loadedChart, err := loader.Load(tempFs)
func (p *Parser) loadChart() (*chart.Chart, error) {

var files []*loader.BufferedFile

rootPath := p.rootPath + string(filepath.Separator)

for _, filePath := range p.filepaths {
b, err := fs.ReadFile(p.workingFS, filePath)
if err != nil {
return nil, err
}

filePath = strings.TrimPrefix(filePath, rootPath)
filePath = filepath.ToSlash(filePath)

files = append(files, &loader.BufferedFile{
Name: filePath,
Data: b,
})
}

c, err := loader.LoadFiles(files)
if err != nil {
return nil, err
}

if req := loadedChart.Metadata.Dependencies; req != nil {
if err := action.CheckDependencies(loadedChart, req); err != nil {
if req := c.Metadata.Dependencies; req != nil {
if err := action.CheckDependencies(c, req); err != nil {
return nil, err
}
}

return loadedChart, nil
return c, nil
}

func (*Parser) getRenderedManifests(manifestsKeys []string, splitManifests map[string]string) []ChartFile {
Expand Down Expand Up @@ -290,24 +299,6 @@ func getManifestPath(manifest string) string {
return manifestFilePathParts[0]
}

func (p *Parser) writeBuildFiles(tempFs string) error {
for _, path := range p.filepaths {
content, err := fs.ReadFile(p.workingFS, path)
if err != nil {
return err
}
workingPath := strings.TrimPrefix(path, p.rootPath)
workingPath = filepath.Join(tempFs, workingPath)
if err := os.MkdirAll(filepath.Dir(workingPath), os.ModePerm); err != nil {
return err
}
if err := os.WriteFile(workingPath, content, os.ModePerm); err != nil {
return err
}
}
return nil
}

func (p *Parser) required(path string, workingFS fs.FS) bool {
if p.skipRequired {
return true
Expand Down
5 changes: 1 addition & 4 deletions pkg/iac/scanners/helm/test/parser_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,11 +32,8 @@ func Test_helm_parser(t *testing.T) {
for _, test := range tests {
t.Run(test.testName, func(t *testing.T) {
chartName := test.chartName

t.Logf("Running test: %s", test.testName)

helmParser := parser.New(chartName)
err := helmParser.ParseFS(context.TODO(), os.DirFS(filepath.Join("testdata", chartName)), ".")
err := helmParser.ParseFS(context.TODO(), os.DirFS("testdata"), chartName)
require.NoError(t, err)
manifests, err := helmParser.RenderedChartFiles()
require.NoError(t, err)
Expand Down

0 comments on commit b528f68

Please sign in to comment.