Bump the required osbuild version to v93 (due to the systemd units change). Pin the new osbuild version in Schutzfile. Update repo snapshots in Schutzfile due to osbuild v93 depending on new selinux-policy build.
116 lines
3.8 KiB
Go
116 lines
3.8 KiB
Go
package image
|
|
|
|
import (
|
|
"fmt"
|
|
"math/rand"
|
|
|
|
"github.com/osbuild/images/internal/common"
|
|
"github.com/osbuild/images/internal/environment"
|
|
"github.com/osbuild/images/internal/workload"
|
|
"github.com/osbuild/images/pkg/artifact"
|
|
"github.com/osbuild/images/pkg/disk"
|
|
"github.com/osbuild/images/pkg/manifest"
|
|
"github.com/osbuild/images/pkg/osbuild"
|
|
"github.com/osbuild/images/pkg/platform"
|
|
"github.com/osbuild/images/pkg/rpmmd"
|
|
"github.com/osbuild/images/pkg/runner"
|
|
)
|
|
|
|
type DiskImage struct {
|
|
Base
|
|
Platform platform.Platform
|
|
PartitionTable *disk.PartitionTable
|
|
OSCustomizations manifest.OSCustomizations
|
|
Environment environment.Environment
|
|
Workload workload.Workload
|
|
Filename string
|
|
Compression string
|
|
ForceSize *bool
|
|
PartTool osbuild.PartTool
|
|
|
|
NoBLS bool
|
|
OSProduct string
|
|
OSVersion string
|
|
OSNick string
|
|
}
|
|
|
|
func NewDiskImage() *DiskImage {
|
|
return &DiskImage{
|
|
Base: NewBase("disk"),
|
|
PartTool: osbuild.PTSfdisk,
|
|
}
|
|
}
|
|
|
|
func (img *DiskImage) InstantiateManifest(m *manifest.Manifest,
|
|
repos []rpmmd.RepoConfig,
|
|
runner runner.Runner,
|
|
rng *rand.Rand) (*artifact.Artifact, error) {
|
|
buildPipeline := manifest.NewBuild(m, runner, repos)
|
|
buildPipeline.Checkpoint()
|
|
|
|
osPipeline := manifest.NewOS(m, buildPipeline, img.Platform, repos)
|
|
osPipeline.PartitionTable = img.PartitionTable
|
|
osPipeline.OSCustomizations = img.OSCustomizations
|
|
osPipeline.Environment = img.Environment
|
|
osPipeline.Workload = img.Workload
|
|
osPipeline.NoBLS = img.NoBLS
|
|
osPipeline.OSProduct = img.OSProduct
|
|
osPipeline.OSVersion = img.OSVersion
|
|
osPipeline.OSNick = img.OSNick
|
|
|
|
rawImagePipeline := manifest.NewRawImage(buildPipeline, osPipeline)
|
|
rawImagePipeline.PartTool = img.PartTool
|
|
|
|
var imagePipeline manifest.FilePipeline
|
|
switch img.Platform.GetImageFormat() {
|
|
case platform.FORMAT_RAW:
|
|
imagePipeline = rawImagePipeline
|
|
case platform.FORMAT_QCOW2:
|
|
qcow2Pipeline := manifest.NewQCOW2(buildPipeline, rawImagePipeline)
|
|
qcow2Pipeline.Compat = img.Platform.GetQCOW2Compat()
|
|
imagePipeline = qcow2Pipeline
|
|
case platform.FORMAT_VHD:
|
|
vpcPipeline := manifest.NewVPC(buildPipeline, rawImagePipeline)
|
|
vpcPipeline.ForceSize = img.ForceSize
|
|
imagePipeline = vpcPipeline
|
|
case platform.FORMAT_VMDK:
|
|
imagePipeline = manifest.NewVMDK(buildPipeline, rawImagePipeline)
|
|
case platform.FORMAT_OVA:
|
|
vmdkPipeline := manifest.NewVMDK(buildPipeline, rawImagePipeline)
|
|
ovfPipeline := manifest.NewOVF(buildPipeline, vmdkPipeline)
|
|
tarPipeline := manifest.NewTar(buildPipeline, ovfPipeline, "archive")
|
|
tarPipeline.Format = osbuild.TarArchiveFormatUstar
|
|
tarPipeline.RootNode = osbuild.TarRootNodeOmit
|
|
tarPipeline.SetFilename(img.Filename)
|
|
imagePipeline = tarPipeline
|
|
case platform.FORMAT_GCE:
|
|
// NOTE(akoutsou): temporary workaround; filename required for GCP
|
|
// TODO: define internal raw filename on image type
|
|
rawImagePipeline.SetFilename("disk.raw")
|
|
tarPipeline := manifest.NewTar(buildPipeline, rawImagePipeline, "archive")
|
|
tarPipeline.Format = osbuild.TarArchiveFormatOldgnu
|
|
tarPipeline.RootNode = osbuild.TarRootNodeOmit
|
|
// these are required to successfully import the image to GCP
|
|
tarPipeline.ACLs = common.ToPtr(false)
|
|
tarPipeline.SELinux = common.ToPtr(false)
|
|
tarPipeline.Xattrs = common.ToPtr(false)
|
|
tarPipeline.SetFilename(img.Filename) // filename extension will determine compression
|
|
imagePipeline = tarPipeline
|
|
default:
|
|
panic("invalid image format for image kind")
|
|
}
|
|
|
|
switch img.Compression {
|
|
case "xz":
|
|
xzPipeline := manifest.NewXZ(buildPipeline, imagePipeline)
|
|
xzPipeline.SetFilename(img.Filename)
|
|
return xzPipeline.Export(), nil
|
|
case "":
|
|
// don't compress, but make sure the pipeline's filename is set
|
|
imagePipeline.SetFilename(img.Filename)
|
|
return imagePipeline.Export(), nil
|
|
default:
|
|
// panic on unknown strings
|
|
panic(fmt.Sprintf("unsupported compression type %q", img.Compression))
|
|
}
|
|
}
|