Mainly to include: - distro/rhel9: Make /boot 600 MiB big on RHEL 9.3+ - fedora: exclude sdubby - Minimal image builds Signed-off-by: Ondřej Budai <ondrej@budai.cz>
123 lines
4.1 KiB
Go
123 lines
4.1 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
|
|
|
|
// InstallWeakDeps enables installation of weak dependencies for packages
|
|
// that are statically defined for the payload pipeline of the image.
|
|
InstallWeakDeps *bool
|
|
}
|
|
|
|
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
|
|
if img.InstallWeakDeps != nil {
|
|
osPipeline.InstallWeakDeps = *img.InstallWeakDeps
|
|
}
|
|
|
|
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))
|
|
}
|
|
}
|