Skip to content

Commit

Permalink
chore: return both failures when failed to retrieve an image with a s…
Browse files Browse the repository at this point in the history
…cheme (anchore#1801)

Signed-off-by: Idan Frimark <idanf@cisco.com>
  • Loading branch information
FrimIdan committed May 23, 2023
1 parent 5f7c791 commit a55b1ef
Showing 1 changed file with 16 additions and 2 deletions.
18 changes: 16 additions & 2 deletions syft/source/source.go
Original file line number Diff line number Diff line change
Expand Up @@ -216,13 +216,27 @@ func getImageWithRetryStrategy(in Input, registryOptions *image.RegistryOptions)
// We need to determine the image source again, such that this determination
// doesn't take scheme parsing into account.
in.ImageSource = image.DetermineDefaultImagePullSource(in.UserInput)
img, err = stereoscope.GetImageFromSource(ctx, in.UserInput, in.ImageSource, opts...)
img, userInputErr := stereoscope.GetImageFromSource(ctx, in.UserInput, in.ImageSource, opts...)
cleanup = func() {
if err := img.Cleanup(); err != nil {
log.Warnf("unable to cleanup image=%q: %w", in.UserInput, err)
}
}
return img, cleanup, err
if userInputErr != nil {
// Image retrieval failed on both tries, we will want to return both errors.
return nil, nil, fmt.Errorf(
"scheme %q specified; "+
"image retrieval using scheme parsing (%s) was unsuccessful: %v; "+
"image retrieval without scheme parsing (%s) was unsuccessful: %v",
scheme,
in.Location,
err,
in.UserInput,
userInputErr,
)
}

return img, cleanup, nil
}

func generateDirectorySource(fs afero.Fs, in Input) (*Source, func(), error) {
Expand Down

0 comments on commit a55b1ef

Please sign in to comment.