image

package
v1.14.16-dcf8320c8c4e Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 12, 2024 License: Apache-2.0 Imports: 53 Imported by: 2

Documentation

Index

Constants

View Source
const (

	// OcDefaultTries is the number of times to execute the oc command on failures.
	OcDefaultTries = 5
	// OcDefaultRetryDelay is the time between retries.
	OcDefaultRetryDelay = time.Second * 5
)

Variables

View Source
var (

	// DefaultCoreOSStreamGetter uses the pinned metadata.
	DefaultCoreOSStreamGetter = rhcos.FetchCoreOSBuild
)

Functions

func GetConfigImageFiles added in v0.9.153

func GetConfigImageFiles() []string

GetConfigImageFiles returns the list of files or file paths to be included in the config-image.

func RetrieveRendezvousIP

func RetrieveRendezvousIP(agentConfig *agent.Config, hosts []agent.Host, nmStateConfigs []*v1beta1.NMStateConfig) (string, error)

RetrieveRendezvousIP Returns the Rendezvous IP from either AgentConfig or NMStateConfig

Types

type AgentArtifacts added in v0.9.153

type AgentArtifacts struct {
	CPUArch              string
	RendezvousIP         string
	TmpPath              string
	IgnitionByte         []byte
	Kargs                string
	ISOPath              string
	BootArtifactsBaseURL string
}

AgentArtifacts is an asset that generates all the artifacts that could be used for a subsequent generation of an ISO image or PXE files, starting from the content of the rhcos image enriched with agent specific files.

func (*AgentArtifacts) Dependencies added in v0.9.153

func (a *AgentArtifacts) Dependencies() []asset.Asset

Dependencies returns the assets on which the AgentArtifacts asset depends.

func (*AgentArtifacts) Generate added in v0.9.153

func (a *AgentArtifacts) Generate(_ context.Context, dependencies asset.Parents) error

Generate generates the configurations for the agent ISO image and PXE assets.

func (*AgentArtifacts) Name added in v0.9.153

func (a *AgentArtifacts) Name() string

Name returns the human-friendly name of the asset.

type AgentImage

type AgentImage struct {
	// contains filtered or unexported fields
}

AgentImage is an asset that generates the bootable image used to install clusters.

func (*AgentImage) Dependencies

func (a *AgentImage) Dependencies() []asset.Asset

Dependencies returns the assets on which the Bootstrap asset depends.

func (*AgentImage) Files

func (a *AgentImage) Files() []*asset.File

Files returns the files generated by the asset.

func (*AgentImage) Generate

func (a *AgentImage) Generate(ctx context.Context, dependencies asset.Parents) error

Generate generates the image file for to ISO asset.

func (*AgentImage) Load

func (a *AgentImage) Load(f asset.FileFetcher) (bool, error)

Load returns the ISO from disk.

func (*AgentImage) Name

func (a *AgentImage) Name() string

Name returns the human-friendly name of the asset.

func (*AgentImage) PersistToFile

func (a *AgentImage) PersistToFile(directory string) error

PersistToFile writes the iso image in the assets folder

type AgentPXEFiles

type AgentPXEFiles struct {
	// contains filtered or unexported fields
}

AgentPXEFiles is an asset that generates the bootable image used to install clusters.

func (*AgentPXEFiles) Dependencies

func (a *AgentPXEFiles) Dependencies() []asset.Asset

Dependencies returns the assets on which the AgentPXEFiles asset depends.

func (*AgentPXEFiles) Files

func (a *AgentPXEFiles) Files() []*asset.File

Files returns the files generated by the asset.

func (*AgentPXEFiles) Generate

func (a *AgentPXEFiles) Generate(_ context.Context, dependencies asset.Parents) error

Generate generates the image files for PXE asset.

func (*AgentPXEFiles) Load

func (a *AgentPXEFiles) Load(f asset.FileFetcher) (bool, error)

Load returns the PXE image from disk.

func (*AgentPXEFiles) Name

func (a *AgentPXEFiles) Name() string

Name returns the human-friendly name of the asset.

func (*AgentPXEFiles) PersistToFile

func (a *AgentPXEFiles) PersistToFile(directory string) error

PersistToFile writes the PXE assets in the assets folder named pxe.

type BaseIso

type BaseIso struct {
	File *asset.File
	// contains filtered or unexported fields
}

BaseIso generates the base ISO file for the image

func (*BaseIso) Dependencies

func (i *BaseIso) Dependencies() []asset.Asset

Dependencies returns dependencies used by the asset.

func (*BaseIso) Files

func (i *BaseIso) Files() []*asset.File

Files returns the files generated by the asset.

func (*BaseIso) Generate

func (i *BaseIso) Generate(ctx context.Context, dependencies asset.Parents) error

Generate the baseIso

func (*BaseIso) Load

func (i *BaseIso) Load(f asset.FileFetcher) (bool, error)

Load returns the cached baseIso

func (*BaseIso) Name

func (i *BaseIso) Name() string

Name returns the human-friendly name of the asset.

type Config

type Config struct {
	MaxTries   uint
	RetryDelay time.Duration
}

Config is used to set up the retries for extracting the base ISO.

type CoreOSBuildFetcher added in v0.90.0

type CoreOSBuildFetcher func(ctx context.Context) (*stream.Stream, error)

CoreOSBuildFetcher will be to used to switch the source of the coreos metadata.

type CpioArchive

type CpioArchive struct {
	// contains filtered or unexported fields
}

CpioArchive simplifies the creation of a compressed cpio archive.

func NewCpioArchive

func NewCpioArchive() *CpioArchive

NewCpioArchive creates a new CpioArchive instance.

func (*CpioArchive) Save

func (ca *CpioArchive) Save(archivePath string) error

Save the content of the current archive on the disk.

func (*CpioArchive) SaveBuffer

func (ca *CpioArchive) SaveBuffer() ([]byte, error)

SaveBuffer saves the content of the current archive and returns the buffer content.

func (*CpioArchive) StoreBytes

func (ca *CpioArchive) StoreBytes(filename string, content []byte, mode int) error

StoreBytes appends to the current archive the given content using the specified filename.

func (*CpioArchive) StoreFile

func (ca *CpioArchive) StoreFile(filename string, dstPath string) error

StoreFile appends to the current archive the specified file.

func (*CpioArchive) StorePath

func (ca *CpioArchive) StorePath(path string) error

StorePath adds a new path in the archive.

type Ignition

type Ignition struct {
	Config       *igntypes.Config
	CPUArch      string
	RendezvousIP string
}

Ignition is an asset that generates the agent installer ignition file.

func (*Ignition) Dependencies

func (a *Ignition) Dependencies() []asset.Asset

Dependencies returns the assets on which the Ignition asset depends.

func (*Ignition) Generate

func (a *Ignition) Generate(_ context.Context, dependencies asset.Parents) error

Generate generates the agent installer ignition.

func (*Ignition) Name

func (a *Ignition) Name() string

Name returns the human-friendly name of the asset.

type Kargs added in v0.9.153

type Kargs struct {
	// contains filtered or unexported fields
}

Kargs is an Asset that generates the additional kernel args.

func (*Kargs) Dependencies added in v0.9.153

func (a *Kargs) Dependencies() []asset.Asset

Dependencies returns the assets on which the Kargs asset depends.

func (*Kargs) Generate added in v0.9.153

func (a *Kargs) Generate(_ context.Context, dependencies asset.Parents) error

Generate generates the kernel args configurations for the agent ISO image and PXE assets.

func (*Kargs) KernelCmdLine added in v0.9.153

func (a *Kargs) KernelCmdLine() string

KernelCmdLine returns the data to be appended to the kernel arguments.

func (*Kargs) Name added in v0.9.153

func (a *Kargs) Name() string

Name returns the human-friendly name of the asset.

type Release

type Release interface {
	GetBaseIso(architecture string) (string, error)
	GetBaseIsoVersion(architecture string) (string, error)
	ExtractFile(image string, filename string, architecture string) ([]string, error)
}

Release is the interface to use the oc command to the get image info.

func NewRelease

func NewRelease(config Config, releaseImage string, pullSecret string, mirrorConfig []mirror.RegistriesConfig, streamGetter CoreOSBuildFetcher) Release

NewRelease is used to set up the executor to run oc commands.

type UnconfiguredIgnition added in v0.9.153

type UnconfiguredIgnition struct {
	Config  *igntypes.Config
	CPUArch string
	File    *asset.File
}

UnconfiguredIgnition is an asset that generates the agent installer unconfigured ignition file which excludes any cluster configuration.

func (*UnconfiguredIgnition) Dependencies added in v0.9.153

func (a *UnconfiguredIgnition) Dependencies() []asset.Asset

Dependencies returns the assets on which the UnconfiguredIgnition asset depends.

func (*UnconfiguredIgnition) Files added in v0.9.153

func (a *UnconfiguredIgnition) Files() []*asset.File

Files returns the files generated by the asset.

func (*UnconfiguredIgnition) Generate added in v0.9.153

func (a *UnconfiguredIgnition) Generate(_ context.Context, dependencies asset.Parents) error

Generate generates the agent installer unconfigured ignition.

func (*UnconfiguredIgnition) Load added in v0.9.153

Load returns the UnconfiguredIgnition from disk.

func (*UnconfiguredIgnition) Name added in v0.9.153

func (a *UnconfiguredIgnition) Name() string

Name returns the human-friendly name of the asset.

func (*UnconfiguredIgnition) PersistToFile added in v0.9.153

func (a *UnconfiguredIgnition) PersistToFile(directory string) error

PersistToFile writes the unconfigured ignition in the assets folder.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL