For now all it does is represent the name of the runner and what requirements it has of the build pipeline. Move some package definitions from the runner package set to where it belongs.
61 lines
1.6 KiB
Go
61 lines
1.6 KiB
Go
package manifest
|
|
|
|
import (
|
|
"github.com/osbuild/osbuild-composer/internal/osbuild2"
|
|
)
|
|
|
|
// An OCIContainerPipeline represents an OCI container, containing a filesystem
|
|
// tree created by another Pipeline.
|
|
type OCIContainerPipeline struct {
|
|
BasePipeline
|
|
Cmd []string
|
|
ExposedPorts []string
|
|
|
|
treePipeline *BasePipeline
|
|
architecture string
|
|
filename string
|
|
}
|
|
|
|
func NewOCIContainerPipeline(m *Manifest,
|
|
buildPipeline *BuildPipeline,
|
|
treePipeline *BasePipeline,
|
|
architecture,
|
|
filename string) *OCIContainerPipeline {
|
|
p := &OCIContainerPipeline{
|
|
BasePipeline: NewBasePipeline(m, "container", buildPipeline),
|
|
treePipeline: treePipeline,
|
|
architecture: architecture,
|
|
filename: filename,
|
|
}
|
|
if treePipeline.build.BasePipeline.manifest != m {
|
|
panic("tree pipeline from different manifest")
|
|
}
|
|
buildPipeline.addDependent(p)
|
|
m.addPipeline(p)
|
|
return p
|
|
}
|
|
|
|
func (p *OCIContainerPipeline) serialize() osbuild2.Pipeline {
|
|
pipeline := p.BasePipeline.serialize()
|
|
|
|
options := &osbuild2.OCIArchiveStageOptions{
|
|
Architecture: p.architecture,
|
|
Filename: p.filename,
|
|
Config: &osbuild2.OCIArchiveConfig{
|
|
Cmd: p.Cmd,
|
|
ExposedPorts: p.ExposedPorts,
|
|
},
|
|
}
|
|
baseInput := new(osbuild2.OCIArchiveStageInput)
|
|
baseInput.Type = "org.osbuild.tree"
|
|
baseInput.Origin = "org.osbuild.pipeline"
|
|
baseInput.References = []string{"name:" + p.treePipeline.Name()}
|
|
inputs := &osbuild2.OCIArchiveStageInputs{Base: baseInput}
|
|
pipeline.AddStage(osbuild2.NewOCIArchiveStage(options, inputs))
|
|
|
|
return pipeline
|
|
}
|
|
|
|
func (p *OCIContainerPipeline) getBuildPackages() []string {
|
|
return []string{"tar"}
|
|
}
|