Adding new types and adapting copies of all the old types to match the
new Manifest schema:
New types:
- Stages
- org.osbuild.ostree.init
- org.osbuild.ostree.pull
- org.osbuild.ostree.preptree (replaces org.osbuild.rpm-ostree)
- org.osbuild.curl
- Converted from assemblers
The concept of a Build and Assembler stage in gone now. Instead they
are regular Stages like any other.
- org.osbuild.oci-archive
- org.osbuild.ostree.commit
- Sources
- org.osbuild.curl
- org.osbuild.ostree
- Inputs
- org.osbuild.files
- org.osbuild.ostree
Types with changes:
- Stages
- org.osbuild.rpm:
- New input structure for defining packages
- New options
Basically copies:
- The rest simply rename the `Name` field to `Type`
Decoding types with interface fields:
Types that contain interfaces with multiple implementations implement
their own UnmarshalJSON method. In these cases, we use a JSON decoder
with the `DisallowUnknownFields` option to catch errors during the
deserialization while trying to determine which implementation matches
the data.
Copied tests for copied types are adapted accordingly.
18 lines
378 B
Go
18 lines
378 B
Go
package osbuild2
|
|
|
|
// Inputs for individual files
|
|
|
|
// Provides all the files, named via their content hash, specified
|
|
// via `references` in a new directory.
|
|
type FilesInput struct {
|
|
inputCommon
|
|
}
|
|
|
|
func (FilesInput) isInput() {}
|
|
|
|
func NewFilesInput() *FilesInput {
|
|
input := new(FilesInput)
|
|
input.Type = "org.osbuild.files"
|
|
input.Origin = "org.osbuild.source"
|
|
return input
|
|
}
|