From a2a97c1e2e5e367c6d757fc28209301b2f4017c3 Mon Sep 17 00:00:00 2001 From: AtomicFS Date: Mon, 30 Dec 2024 15:00:08 +0100 Subject: [PATCH] fix(action): add coreboot blobs into GetSources - with this patch, changes to any blob will also trigger a rebuild Signed-off-by: AtomicFS --- action/recipes/coreboot.go | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) diff --git a/action/recipes/coreboot.go b/action/recipes/coreboot.go index 4d711cd5..33404a55 100644 --- a/action/recipes/coreboot.go +++ b/action/recipes/coreboot.go @@ -129,6 +129,41 @@ func (opts CorebootOpts) GetArtifacts() *[]container.Artifacts { return opts.CommonOpts.GetArtifacts() } +// GetSources returns slice of paths to all sources which are used for build +func (opts CorebootOpts) GetSources() []string { + sources := opts.CommonOpts.GetSources() + + // Add blobs to list of sources + blobs, err := corebootProcessBlobs(opts.Blobs) + if err != nil { + slog.Error( + "Failed to process all blobs", + slog.Any("error", err), + ) + return nil + } + + pwd, err := os.Getwd() + if err != nil { + slog.Error( + "Could not get working directory", + slog.String("suggestion", logging.ThisShouldNotHappenMessage), + slog.Any("error", err), + ) + return nil + } + for blob := range blobs { + // Path to local file on host + src := filepath.Join( + pwd, + blobs[blob].Path, + ) + sources = append(sources, src) + } + + return sources +} + // corebootProcessBlobs is used to figure out blobs from provided data func corebootProcessBlobs(opts CorebootBlobs) ([]BlobDef, error) { blobMap := map[string]BlobDef{