utils

package
v1.4.0 Latest Latest
Warning

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

Go to latest
Published: Sep 19, 2018 License: Apache-2.0 Imports: 27 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func BindFlags added in v1.1.0

func BindFlags(flags *pflag.FlagSet) clientcmd.ClientConfig

BindFlags applies standard Go flags and the flags used by kubeclient to the specified FlagSet.

func CallInNetNSWithSysfsRemounted added in v1.1.2

func CallInNetNSWithSysfsRemounted(innerNS ns.NetNS, toCall func(ns.NetNS) error) error

CallInNetNSWithSysfsRemounted enters particular netns, adds new sysfs mount on top of /sys, calls "toCall" callback in this netns removing temporary mount on /sys at the end.

func GenIsoImage

func GenIsoImage(isoPath string, volumeID string, srcDir string) error

GenIsoImage generates an ISO 9660 filesystem image containing files from srcDir. It uses specified volumeID as the volume id.

func GetBoolFromString added in v0.9.0

func GetBoolFromString(str string) bool

GetBoolFromString returns false if str is an empty string or is equal to one of: "0", "f" or "false". Case doesnt't matter anythging else is true

func GetFsStatsForPath added in v1.2.0

func GetFsStatsForPath(path string) (uint64, uint64, error)

GetFsStatsForPath returns the info about inode usage and space usage (in bytes) for the filesystem that contains the provided path.

func GetK8sClientConfig added in v0.9.0

func GetK8sClientConfig(host string) (*rest.Config, error)

GetK8sClientConfig returns config that is needed to access k8s

func GetK8sClientset added in v0.9.0

func GetK8sClientset(config *rest.Config) (*kubernetes.Clientset, error)

GetK8sClientset returns clientset for standard k8s APIs

func Merge added in v0.9.0

func Merge(base, override interface{}) interface{}

Merge will take two data sets and merge them together - returning a new data set

func NewUUID added in v1.0.0

func NewUUID() string

NewUUID returns a new uuid4 as a string

func NewUUID5 added in v1.0.0

func NewUUID5(nsUUID, s string) string

NewUUID5 returns a new uuid5 as a string

func ReadJSON added in v1.0.0

func ReadJSON(filename string, v interface{}) error

ReadJSON converts data from file specified by `filename` to provided as `v` interface.

func ToJSON added in v1.4.0

func ToJSON(o interface{}) string

ToJSON converts the specified object to indented JSON. It panics in case if the object connot be converted.

func ToJSONUnindented added in v1.4.0

func ToJSONUnindented(o interface{}) string

ToJSONUnindented converts the specified object to unindented JSON. It panics in case if the object connot be converted.

func WaitForProcess added in v0.9.0

func WaitForProcess(procFile string) (int, error)

WaitForProcess waits for the following conditions to be true at the same time:

  • the specified procFile is readable and contains two numeric values separated by space, PID and start time in jiffies (field 22 in /proc/PID/stat, starting from 1)
  • the process with the PID read from procFile exists and has start time equal to the start time read from procFile

This avoids possible problems with stale procFile that could happen if only PID was stored there. The command can be used in shell script to generate the "procfile" for the current shell: /bin/sh -c 'echo "$$ `cut -d" " -f22 /proc/$$/stat`"'

func WaitLoop

func WaitLoop(test func() (bool, error), retryPeriod time.Duration, timeout time.Duration, clock clockwork.Clock) error

WaitLoop executes test func in loop until it returns error, true, or the timeout elapses. clock argument denotes a clock object to use for waiting. When clock is nil, WaitLoop uses clockwork.NewRealClock()

func WriteFiles

func WriteFiles(targetDir string, content map[string][]byte) error

WriteFiles writes the files specified as a map under `targetDir`. The keys of the map are subpaths and values are file contents. WriteFiles automatically creates any non-existing directories mentioned in subpaths.

func WriteJSON added in v1.0.0

func WriteJSON(filename string, v interface{}, perm os.FileMode) error

WriteJSON saves under specified `filename` data provided in `v` interface setting file mode according to `perm` value.

Types

type Command added in v1.4.0

type Command interface {
	// Output runs the command and returns its standard output.
	// If stdin is non-nil, it's passed to the command's standed
	// input. Any returned error will usually be of type
	// *ExitError with ExitError.Stderr containing the stderr
	// output of the command.
	Run(stdin []byte) ([]byte, error)
}

Command represents an external command being prepared or run.

type Commander added in v1.4.0

type Commander interface {
	// Command returns an isntance of Command to execute the named
	// program with the given arguments.
	Command(name string, arg ...string) Command
}

Commander is used to run external commands.

var DefaultCommander Commander = &defaultCommander{}

DefaultCommander is an implementation of Commander that runs the commands using exec.Command.

type Mounter added in v1.4.0

type Mounter interface {
	// Mount mounts the specified source under the target path.
	// For bind mounts, bind must be true.
	Mount(source string, target string, fstype string, bind bool) error
	// Unmount unmounts the specified target directory. If detach
	// is true, MNT_DETACH option is used (disconnect the
	// filesystem for the new accesses even if it's busy).
	Unmount(target string, detach bool) error
}

Mounter defines mount/unmount interface

var NullMounter Mounter = &nullMounter{}

NullMounter is a mounter that's used for testing and does nothing instead of mounting/unmounting.

func NewMounter added in v1.4.0

func NewMounter() Mounter

NewMounter creates linux mounter struct

type ShellTemplate added in v1.4.0

type ShellTemplate struct {
	*template.Template
}

ShellTemplate denotes a simple template used to generate shell commands. It adds 'shellquote' function to go-template that can be used to quote string values for the shell.

func NewShellTemplate added in v1.4.0

func NewShellTemplate(text string) *ShellTemplate

NewShellTemplate returns a new shell template using the specified text. It panics if the template doesn't compile.

func (*ShellTemplate) ExecuteToString added in v1.4.0

func (t *ShellTemplate) ExecuteToString(data interface{}) (string, error)

ExecuteToString executes the template using the specified data and returns the result as a string.

func (*ShellTemplate) MustExecuteToString added in v1.4.0

func (t *ShellTemplate) MustExecuteToString(data interface{}) string

MustExecuteToString executes the template using the specified data and returns the result as a string. It panics upon an error

type VFInfo added in v1.1.2

type VFInfo struct {
	// ID contains VF number
	ID int
	// Mac contains hardware mac address
	Mac string
	// VLanID contains vlan id
	VLanID int
	// SpoofChecking holds status of spoof checking
	SpoofChecking bool
	// LinkState holds state of link (nil means auto)
	LinkState *bool
}

VFInfo contains information about particular VF

func ParseIPLinkOutput added in v1.1.2

func ParseIPLinkOutput(data []byte) ([]VFInfo, error)

ParseIPLinkOutput takes output of `ip link show somelink` and parses it to list of VFInfo structures

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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