From 1709a76e62ac4ec48c28041e476939613b5c344a Mon Sep 17 00:00:00 2001 From: Sanne Raymaekers Date: Tue, 6 Feb 2024 14:05:27 +0100 Subject: [PATCH] disk(ova): ovf descriptor must be the first file in the ova RHEL-22199 --- pkg/image/disk.go | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/pkg/image/disk.go b/pkg/image/disk.go index 79dca30050..8b7adafe72 100644 --- a/pkg/image/disk.go +++ b/pkg/image/disk.go @@ -3,6 +3,8 @@ package image import ( "fmt" "math/rand" + "path/filepath" + "strings" "github.com/osbuild/images/internal/common" "github.com/osbuild/images/internal/environment" @@ -87,8 +89,14 @@ func (img *DiskImage) InstantiateManifest(m *manifest.Manifest, ovfPipeline := manifest.NewOVF(buildPipeline, vmdkPipeline) tarPipeline := manifest.NewTar(buildPipeline, ovfPipeline, "archive") tarPipeline.Format = osbuild.TarArchiveFormatUstar - tarPipeline.RootNode = osbuild.TarRootNodeOmit tarPipeline.SetFilename(img.Filename) + extLess := strings.TrimSuffix(img.Filename, filepath.Ext(img.Filename)) + // The .ovf descriptor needs to be the first file in the archive + tarPipeline.Paths = []string{ + fmt.Sprintf("%s.ovf", extLess), + fmt.Sprintf("%s.mf", extLess), + fmt.Sprintf("%s.vmdk", extLess), + } imagePipeline = tarPipeline case platform.FORMAT_GCE: // NOTE(akoutsou): temporary workaround; filename required for GCP