utils

package
v2.2.1 Latest Latest
Warning

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

Go to latest
Published: Oct 2, 2024 License: Apache-2.0 Imports: 32 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func BootedFrom

func BootedFrom(runner types.Runner, label string) bool

BootedFrom will check if we are booting from the given label

func CalcFileChecksum

func CalcFileChecksum(fs types.FS, fileName string) (string, error)

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

func ConcatFiles(fs types.FS, sources []string, target string) (err error)

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

func CopyFile(fs types.FS, source string, target string) error

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

func CreateDirStructure(fs types.FS, target string) error

CreateDirStructure creates essentials directories under the root tree that might not be present within a container image (/dev, /run, etc.)

func CreateRAWFile

func CreateRAWFile(fs types.FS, filename string, size uint) error

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 DirSize

func DirSize(fs types.FS, path string, excludes ...string) (int64, error)

DirSize returns the accumulated size of all files in folder. Result in bytes

func DirSizeMB

func DirSizeMB(fs types.FS, path string, excludes ...string) (uint, error)

DirSizeMB returns the accumulated size of all files in folder. Result in Megabytes

func Exists

func Exists(fs types.FS, path string, noFollow ...bool) (bool, error)

Check if a file or directory exists. noFollow flag determines to not follow symlinks to check files existance.

func FindFile

func FindFile(vfs types.FS, rootDir string, patterns ...string) (string, error)

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

func FindFiles(vfs types.FS, rootDir string, pattern string) ([]string, error)

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

func FindInitrd(fs types.FS, rootDir string) (string, error)

FindInitrd finds for initrd files inside a given root tree path. It assumes initrd files match certain patterns

func FindKernel

func FindKernel(fs types.FS, rootDir string) (string, string, error)

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

func FindKernelInitrd(fs types.FS, rootDir string) (kernel string, initrd string, err error)

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

func GetDeviceByLabel(runner types.Runner, label string, attempts int) (string, error)

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

func GetPartitionFS(partition string) (string, error)

GetPartitionFS gets the FS of a partition given

func GetSource

func GetSource(config types.Config, source string, destination string) error

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 IsDir

func IsDir(fs types.FS, path string) (bool, error)

IsDir check if the path is a dir

func IsHTTPURI

func IsHTTPURI(uri string) (bool, error)

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

func IsLocalURI(uri string) (bool, error)

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

func LoadEnvFile(fs types.FS, file string) (map[string]string, error)

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 MkdirAll

func MkdirAll(fs types.FS, name string, mode os.FileMode) (err error)

MkdirAll directory and all parents if not existing

func PreAppendRoot added in v2.2.1

func PreAppendRoot(root string, paths ...string) []string

PreAppendRoot simply adds the given root as a prefix to the given paths

func RawDiskToFixedVhd

func RawDiskToFixedVhd(diskFile *os.File)

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 Reboot

func Reboot(runner types.Runner, delay time.Duration) error

Reboot reboots the system after the given delay (in seconds) time passed.

func RemoveAll added in v2.1.0

func RemoveAll(fs types.FS, path string) error

RemoveAll removes the specified path. It silently drop NotExists errors.

func ResolveLink(vfs types.FS, path string, rootDir string, depth int) (string, error)

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 RunStage

func RunStage(cfg *types.Config, stage string, strict bool, cloudInitPaths ...string) error

RunStage will run yip

func Shutdown

func Shutdown(runner types.Runner, delay time.Duration) error

Shutdown halts the system after the given delay (in seconds) time passed.

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 TempDir

func TempDir(fs types.FS, dir, prefix string) (name string, err error)

TempDir creates a temp file in the virtual fs Took from afero.FS code and adapted

func TempFile

func TempFile(fs types.FS, dir, pattern string) (f *os.File, err error)

TempFile creates a temp file in the virtual fs Took from afero.FS code and adapted

func ValidContainerReference

func ValidContainerReference(ref string) bool

ValidContainerReferece returns true if the given string matches a container registry reference, false otherwise

func ValidTaggedContainerReference

func ValidTaggedContainerReference(ref string) bool

ValidTaggedContainerReferece returns true if the given string matches a container registry reference including a tag, false otherwise.

func WalkDirFs

func WalkDirFs(fs types.FS, root string, fn fs.WalkDirFunc) error

WalkDirFs is the same as filepath.WalkDir but accepts a types.Fs so it can be run on any types.Fs type

func WriteEnvFile

func WriteEnvFile(fs types.FS, envs map[string]string, filename string) error

WriteEnvFile will write the given environment file with the given key/values

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 NewChroot

func NewChroot(path string, config *types.Config) *Chroot

func (*Chroot) Close

func (c *Chroot) Close() error

Close will unmount all active mounts created in Prepare on reverse order

func (*Chroot) Prepare

func (c *Chroot) Prepare() error

Prepare will mount the defaultMounts as bind mounts, to be ready when we run chroot

func (*Chroot) Run

func (c *Chroot) Run(command string, args ...string) (out []byte, err error)

Run executes a command inside a chroot

func (*Chroot) RunCallback

func (c *Chroot) RunCallback(callback func() error) (err error)

RunCallback runs the given callback in a chroot environment

func (*Chroot) SetExtraMounts

func (c *Chroot) SetExtraMounts(extraMounts map[string]string)

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 CleanFunc

type CleanFunc func() error

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.

func (CleanJob) Run

func (cj CleanJob) Run() error

Run executes the defined job

func (CleanJob) Type

func (cj CleanJob) Type() int

Type returns the CleanJob type

type CleanStack

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

Stack is a basic LIFO stack that resizes as needed.

func NewCleanStack

func NewCleanStack() *CleanStack

NewCleanStack returns a new stack.

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.
}

Jump to

Keyboard shortcuts

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