Remove all the internal package that are now in the github.com/osbuild/images package and vendor it. A new function in internal/blueprint/ converts from an osbuild-composer blueprint to an images blueprint. This is necessary for keeping the blueprint implementation in both packages. In the future, the images package will change the blueprint (and most likely rename it) and it will only be part of the osbuild-composer internals and interface. The Convert() function will be responsible for converting the blueprint into the new configuration object.
64 lines
1.8 KiB
Go
64 lines
1.8 KiB
Go
package main
|
|
|
|
import (
|
|
"math/rand"
|
|
|
|
"github.com/osbuild/images/pkg/artifact"
|
|
"github.com/osbuild/images/pkg/manifest"
|
|
"github.com/osbuild/images/pkg/platform"
|
|
"github.com/osbuild/images/pkg/rpmmd"
|
|
"github.com/osbuild/images/pkg/runner"
|
|
)
|
|
|
|
// MyContainer contains the arguments passed in as a JSON blob.
|
|
// You can replace them with whatever you want to use to
|
|
// configure your image. In the current example they are
|
|
// unused.
|
|
type MyContainer struct {
|
|
MyOption string `json:"my_option"`
|
|
}
|
|
|
|
// Name returns the name of the image type, used to select what kind
|
|
// of image to build.
|
|
func (img *MyContainer) Name() string {
|
|
return "my-container"
|
|
}
|
|
|
|
// init registeres this image type
|
|
func init() {
|
|
AddImageType(&MyContainer{})
|
|
}
|
|
|
|
// Build your manifest by attaching pipelines to it
|
|
//
|
|
// @m is the manifest you are constructing
|
|
// @options are what was passed in on the commandline
|
|
// @repos are the default repositories for the host OS/arch
|
|
// @runner is needed by any build pipelines
|
|
//
|
|
// Return nil when you are done, or an error if something
|
|
// went wrong. Your manifest will be streamed to osbuild
|
|
// for building.
|
|
func (img *MyContainer) InstantiateManifest(m *manifest.Manifest,
|
|
repos []rpmmd.RepoConfig,
|
|
runner runner.Runner,
|
|
rng *rand.Rand) (*artifact.Artifact, error) {
|
|
// Let's create a simple OCI container!
|
|
|
|
// configure a build pipeline
|
|
build := manifest.NewBuild(m, runner, repos)
|
|
build.Checkpoint()
|
|
|
|
// create a minimal non-bootable OS tree
|
|
os := manifest.NewOS(m, build, &platform.X86{}, repos)
|
|
os.ExtraBasePackages = []string{"@core"}
|
|
os.OSCustomizations.Language = "en_US.UTF-8"
|
|
os.OSCustomizations.Hostname = "my-host"
|
|
os.OSCustomizations.Timezone = "UTC"
|
|
|
|
// create an OCI container containing the OS tree created above
|
|
container := manifest.NewOCIContainer(m, build, os)
|
|
artifact := container.Export()
|
|
|
|
return artifact, nil
|
|
}
|