From ac96d296843b86353749ee3f991aca917e02fe81 Mon Sep 17 00:00:00 2001 From: Philip Laine Date: Tue, 23 Jul 2024 13:14:40 +0200 Subject: [PATCH] refactor: add error handling to view SBOM files Signed-off-by: Philip Laine --- src/internal/packager/sbom/tools.go | 43 ++++++++++++++++------------- src/pkg/packager/creator/normal.go | 5 +++- src/pkg/packager/inspect.go | 5 +++- 3 files changed, 32 insertions(+), 21 deletions(-) diff --git a/src/internal/packager/sbom/tools.go b/src/internal/packager/sbom/tools.go index 60aa998958..972b709906 100644 --- a/src/internal/packager/sbom/tools.go +++ b/src/internal/packager/sbom/tools.go @@ -14,26 +14,31 @@ import ( ) // ViewSBOMFiles opens a browser to view the SBOM files and pauses for user input. -func ViewSBOMFiles(directory string) { - sbomViewFiles, _ := filepath.Glob(filepath.Join(directory, "sbom-viewer-*")) - - if len(sbomViewFiles) > 0 { - link := sbomViewFiles[0] - msg := fmt.Sprintf("This package has %d images with software bill-of-materials (SBOM) included. If your browser did not open automatically you can copy and paste this file location into your browser address bar to view them: %s\n\n", len(sbomViewFiles), link) - message.Note(msg) - - if err := exec.LaunchURL(link); err != nil { - message.Debug(err) - } +func ViewSBOMFiles(directory string) error { + sbomViewFiles, err := filepath.Glob(filepath.Join(directory, "sbom-viewer-*")) + if err != nil { + return err + } - // Use survey.Input to hang until user input - var value string - prompt := &survey.Input{ - Message: "Hit the 'enter' key when you are done viewing the SBOM files", - Default: "", - } - _ = survey.AskOne(prompt, &value) - } else { + if len(sbomViewFiles) == 0 { message.Note("There were no images with software bill-of-materials (SBOM) included.") + return nil + } + + link := sbomViewFiles[0] + msg := fmt.Sprintf("This package has %d images with software bill-of-materials (SBOM) included. If your browser did not open automatically you can copy and paste this file location into your browser address bar to view them: %s\n\n", len(sbomViewFiles), link) + message.Note(msg) + if err := exec.LaunchURL(link); err != nil { + return err + } + var value string + prompt := &survey.Input{ + Message: "Hit the 'enter' key when you are done viewing the SBOM files", + Default: "", + } + err = survey.AskOne(prompt, &value) + if err != nil { + return err } + return nil } diff --git a/src/pkg/packager/creator/normal.go b/src/pkg/packager/creator/normal.go index 3b34b7e846..52baa708e4 100644 --- a/src/pkg/packager/creator/normal.go +++ b/src/pkg/packager/creator/normal.go @@ -321,7 +321,10 @@ func (pc *PackageCreator) Output(ctx context.Context, dst *layout.PackagePaths, } if pc.createOpts.ViewSBOM { - sbom.ViewSBOMFiles(sbomDir) + err := sbom.ViewSBOMFiles(sbomDir) + if err != nil { + return err + } } } return nil diff --git a/src/pkg/packager/inspect.go b/src/pkg/packager/inspect.go index bfa29d860b..88b1de88d8 100644 --- a/src/pkg/packager/inspect.go +++ b/src/pkg/packager/inspect.go @@ -47,7 +47,10 @@ func (p *Packager) Inspect(ctx context.Context) (err error) { } if p.cfg.InspectOpts.ViewSBOM { - sbom.ViewSBOMFiles(sbomDir) + err := sbom.ViewSBOMFiles(sbomDir) + if err != nil { + return err + } } return nil