Documentation ¶
Index ¶
- func BootedFrom(runner types.Runner, label string) bool
- func CalcFileChecksum(fs types.FS, fileName string) (string, error)
- func ChrootedCallback(cfg *types.Config, path string, bindMounts map[string]string, ...) error
- func ConcatFiles(fs types.FS, sources []string, target string) (err error)
- func CopyFile(fs types.FS, source string, target string) error
- func CosignVerify(fs types.FS, runner types.Runner, image string, publicKey string, debug bool) (string, error)
- func CreateDirStructure(fs types.FS, target string) error
- func CreateRAWFile(fs types.FS, filename string, size uint) error
- func CreateSquashFS(runner types.Runner, logger types.Logger, source string, destination string, ...) error
- func DirSize(fs types.FS, path string, excludes ...string) (int64, error)
- func DirSizeMB(fs types.FS, path string, excludes ...string) (uint, error)
- func Exists(fs types.FS, path string, noFollow ...bool) (bool, error)
- func FindFile(vfs types.FS, rootDir string, patterns ...string) (string, error)
- func FindFiles(vfs types.FS, rootDir string, pattern string) ([]string, error)
- func FindInitrd(fs types.FS, rootDir string) (string, error)
- func FindKernel(fs types.FS, rootDir string) (string, string, error)
- func FindKernelInitrd(fs types.FS, rootDir string) (kernel string, initrd string, err error)
- func GetAllPartitions() (types.PartitionList, error)
- func GetDeviceByLabel(runner types.Runner, label string, attempts int) (string, error)
- func GetFullDeviceByLabel(runner types.Runner, label string, attempts int) (*types.Partition, error)
- func GetPartitionFS(partition string) (string, error)
- func GetSource(config types.Config, source string, destination string) error
- func IsDir(fs types.FS, path string) (bool, error)
- func IsHTTPURI(uri string) (bool, error)
- func IsLocalURI(uri string) (bool, error)
- func LoadEnvFile(fs types.FS, file string) (map[string]string, error)
- func MirrorData(log types.Logger, runner types.Runner, fs types.FS, source string, ...) error
- func MkdirAll(fs types.FS, name string, mode os.FileMode) (err error)
- func PreAppendRoot(root string, paths ...string) []string
- func RawDiskToFixedVhd(diskFile *os.File)
- func Reboot(runner types.Runner, delay time.Duration) error
- func RemoveAll(fs types.FS, path string) error
- func ResolveLink(vfs types.FS, path string, rootDir string, depth int) (string, error)
- func RunStage(cfg *types.Config, stage string, strict bool, cloudInitPaths ...string) error
- func Shutdown(runner types.Runner, delay time.Duration) error
- func SyncData(log types.Logger, runner types.Runner, fs types.FS, source string, ...) error
- func TempDir(fs types.FS, dir, prefix string) (name string, err error)
- func TempFile(fs types.FS, dir, pattern string) (f *os.File, err error)
- func ValidContainerReference(ref string) bool
- func ValidTaggedContainerReference(ref string) bool
- func WalkDirFs(fs types.FS, root string, fn fs.WalkDirFunc) error
- func WriteEnvFile(fs types.FS, envs map[string]string, filename string) error
- type Chroot
- type CleanFunc
- type CleanJob
- type CleanStack
- type VHDHeader
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func BootedFrom ¶
BootedFrom will check if we are booting from the given label
func CalcFileChecksum ¶
CalcFileChecksum opens the given file and returns the sha256 checksum of it.
func ChrootedCallback ¶
func ChrootedCallback(cfg *types.Config, path string, bindMounts map[string]string, callback func() error) error
ChrootedCallback runs the given callback in a chroot environment
func ConcatFiles ¶
ConcatFiles Copies source files to target file using Fs interface. Source files are concatenated into target file in the given order. If target is a directory source is copied into that directory using 1st source name file. The result keeps the file mode of the 1st source.
func CopyFile ¶
CopyFile Copies source file to target file using Fs interface. If target is directory source is copied into that directory using source name file. File mode is preserved
func CosignVerify ¶
func CosignVerify(fs types.FS, runner types.Runner, image string, publicKey string, debug bool) (string, error)
CosignVerify runs a cosign validation for the give image and given public key. If no key is provided then it attempts a keyless validation (experimental feature).
func CreateDirStructure ¶
CreateDirStructure creates essentials directories under the root tree that might not be present within a container image (/dev, /run, etc.)
func CreateRAWFile ¶
CreateRAWFile creates raw file of the given size in MB
func CreateSquashFS ¶
func CreateSquashFS(runner types.Runner, logger types.Logger, source string, destination string, options []string) error
CreateSquashFS creates a squash file at destination from a source, with options TODO: Check validity of source maybe?
func Exists ¶
Check if a file or directory exists. noFollow flag determines to not follow symlinks to check files existance.
func FindFile ¶
FindFile attempts to find a file from a list of patterns on top of a given root path. Returns first match if any and returns error otherwise.
func FindFiles ¶ added in v2.1.1
FindFiles attempts to find files from a given pattern on top of a root path. Returns empty list if no files are found.
func FindInitrd ¶
FindInitrd finds for initrd files inside a given root tree path. It assumes initrd files match certain patterns
func FindKernel ¶
FindKernel finds for kernel files inside a given root tree path. Returns kernel file and version. It assumes kernel files match certain patterns
func FindKernelInitrd ¶
FindKernelInitrd finds for kernel and intird files inside a given root tree path. It assumes kernel and initrd files match certain patterns. This is a comodity method of a combination of FindKernel and FindInitrd.
func GetAllPartitions ¶
func GetAllPartitions() (types.PartitionList, error)
GetAllPartitions returns all partitions in the system for all disks
func GetDeviceByLabel ¶
GetDeviceByLabel will try to return the device that matches the given label. attempts value sets the number of attempts to find the device, it waits a second between attempts.
func GetFullDeviceByLabel ¶
func GetFullDeviceByLabel(runner types.Runner, label string, attempts int) (*types.Partition, error)
GetFullDeviceByLabel works like GetDeviceByLabel, but it will try to get as much info as possible from the existing partition and return a types.Partition object
func GetPartitionFS ¶
GetPartitionFS gets the FS of a partition given
func GetSource ¶
GetSource copies given source to destination, if source is a local path it simply copies files, if source is a remote URL it tries to download URL to destination.
func IsHTTPURI ¶
IsHTTPURI returns true if the uri has "http" or "https" scheme, returns false otherwise. Error is not nil only if the url can't be parsed.
func IsLocalURI ¶
IsLocalURI returns true if the uri has "file" scheme or no scheme and URI is not prefixed with a domain (container registry style). Returns false otherwise. Error is not nil only if the url can't be parsed.
func LoadEnvFile ¶
LoadEnvFile will try to parse the file given and return a map with the key/values
func MirrorData ¶
func MirrorData(log types.Logger, runner types.Runner, fs types.FS, source string, target string, excludes ...string) error
MirrorData rsync's source folder contents to a target folder content, in contrast, to SyncData this method includes the --delete flag which forces the deletion of files in target that are missing in source.
func PreAppendRoot ¶ added in v2.2.1
PreAppendRoot simply adds the given root as a prefix to the given paths
func RawDiskToFixedVhd ¶
RawDiskToFixedVhd will write the proper header to a given os.File to convert it from a simple raw disk to a Fixed VHD RawDiskToFixedVhd makes no effort into opening/closing/checking if the file exists
func RemoveAll ¶ added in v2.1.0
RemoveAll removes the specified path. It silently drop NotExists errors.
func ResolveLink ¶
ResolveLink attempts to resolve a symlink, if any. Returns the original given path if not a symlink or if it can't be resolved.
func SyncData ¶
func SyncData(log types.Logger, runner types.Runner, fs types.FS, source string, target string, excludes ...string) error
SyncData rsync's source folder contents to a target folder content, both are expected to exist before hand.
func ValidContainerReference ¶
ValidContainerReferece returns true if the given string matches a container registry reference, false otherwise
func ValidTaggedContainerReference ¶
ValidTaggedContainerReferece returns true if the given string matches a container registry reference including a tag, false otherwise.
Types ¶
type Chroot ¶
type Chroot struct {
// contains filtered or unexported fields
}
Chroot represents the struct that will allow us to run commands inside a given chroot
func (*Chroot) Prepare ¶
Prepare will mount the defaultMounts as bind mounts, to be ready when we run chroot
func (*Chroot) RunCallback ¶
RunCallback runs the given callback in a chroot environment
func (*Chroot) SetExtraMounts ¶
Sets additional bind mounts for the chroot enviornment. They are represented in a map where the key is the path outside the chroot and the value is the path inside the chroot.
type CleanJob ¶
type CleanJob struct {
// contains filtered or unexported fields
}
CleanJob represents a clean task. In can be of three different types. ErrorOnly type is a clean job only executed on error, successOnly type is executed only on sucess and always is always executed regardless the error value.
type CleanStack ¶
type CleanStack struct {
// contains filtered or unexported fields
}
Stack is a basic LIFO stack that resizes as needed.
func (*CleanStack) Cleanup ¶
func (clean *CleanStack) Cleanup(err error) error
Cleanup runs the whole cleanup stack. In case of error it runs all jobs and returns the first error occurrence.
func (*CleanStack) Pop ¶
func (clean *CleanStack) Pop() *CleanJob
Pop removes and returns a node from the stack in last to first order.
func (*CleanStack) Push ¶
func (clean *CleanStack) Push(cFunc CleanFunc)
Push adds a node to the stack that will be always executed
func (*CleanStack) PushErrorOnly ¶
func (clean *CleanStack) PushErrorOnly(cFunc CleanFunc)
PushErrorOnly adds an error only node to the stack
func (*CleanStack) PushSuccessOnly ¶
func (clean *CleanStack) PushSuccessOnly(cFunc CleanFunc)
PushSuccessOnly adds a success only node to the stack
type VHDHeader ¶
type VHDHeader struct { Cookie [8]byte // Cookies are used to uniquely identify the original creator of the hard disk image Features [4]byte // This is a bit field used to indicate specific feature support. // Can be 0x00000000 (no features), 0x00000001 (Temporary, candidate for deletion on shutdown) or 0x00000002 (Reserved) FileFormatVersion [4]byte // Divided into a major/minor version and matches the version of the specification used in creating the file. DataOffset [8]byte // For fixed disks, this field should be set to 0xFFFFFFFF. Timestamp [4]byte // Sstores the creation time of a hard disk image. This is the number of seconds since January 1, 2000 12:00:00 AM in UTC/GMT. CreatorApplication [4]byte // Used to document which application created the hard disk. CreatorVersion [4]byte // This field holds the major/minor version of the application that created the hard disk image. CreatorHostOS [4]byte // This field stores the type of host operating system this disk image is created on. OriginalSize [8]byte // This field stores the size of the hard disk in bytes, from the perspective of the virtual machine, at creation time. Info only CurrentSize [8]byte // This field stores the current size of the hard disk, in bytes, from the perspective of the virtual machine. DiskGeometry [4]byte // This field stores the cylinder, heads, and sectors per track value for the hard disk. DiskType [4]byte // Fixed = 2, Dynamic = 3, Differencing = 4 Checksum [4]byte // This field holds a basic checksum of the hard disk footer. It is just a one’s complement of the sum of all the bytes in the footer without the checksum field. UniqueID [16]byte // This is a 128-bit universally unique identifier (UUID). SavedState [1]byte // This field holds a one-byte flag that describes whether the system is in saved state. If the hard disk is in the saved state the value is set to 1 Reserved [427]byte // This field contains zeroes. }