Documentation ¶
Index ¶
- Constants
- func AddFileToIgnoreFile(gitIgnoreFile, filename string) error
- func CheckKubeConfigExist() bool
- func CheckOutputFlag(outputFlag string) bool
- func CheckPathExists(path string) bool
- func ConvertGitSSHRemoteToHTTPS(remote string) string
- func ConvertKeyValueStringToMap(params []string) map[string]string
- func ConvertLabelsToSelector(labels map[string]string) string
- func CopyFile(srcPath string, dstPath string, info os.FileInfo) error
- func DeletePath(path string) error
- func DisplayLog(followLog bool, rd io.ReadCloser, compName string) (err error)
- func DownloadFile(params DownloadParams) error
- func DownloadFileInMemory(url string) ([]byte, error)
- func DownloadFileWithCache(params DownloadParams, cacheFor int) error
- func ExtractComponentType(namespacedVersionedComponentType string) string
- func FilterIgnores(filesChanged, filesDeleted, absIgnoreRules []string) (filesChangedFiltered, filesDeletedFiltered []string)
- func GenFileURL(location string, os ...string) string
- func GenerateRandomString(n int) string
- func GetAbsGlobExps(directory string, globExps []string) []string
- func GetAbsPath(path string) (string, error)
- func GetAndExtractZip(zipURL string, destination string, pathToUnzip string) error
- func GetContainerPortsFromStrings(ports []string) ([]corev1.ContainerPort, error)
- func GetDNS1123Name(str string) string
- func GetHostWithPort(inputURL string) (string, error)
- func GetIgnoreRulesFromDirectory(directory string) ([]string, error)
- func GetRandomName(prefix string, prefixMaxLen int, existList []string, retries int) (string, error)
- func GetRemoteFilesMarkedForDeletion(delSrcRelPaths []string, remoteFolder string) []string
- func GetSortedKeys(mapping map[string]string) []string
- func GetSplitValuesFromStr(inputStr string) []string
- func HTTPGetFreePort() (int, error)
- func HTTPGetRequest(request HTTPRequestParams, cacheFor int) ([]byte, error)
- func In(arr []string, value string) bool
- func IsEmpty(name string) (bool, error)
- func IsGlobExpMatch(strToMatch string, globExps []string) (bool, error)
- func IsValidProjectDir(path string, devfilePath string) error
- func NamespaceOpenShiftObject(componentName string, applicationName string) (string, error)
- func OpenBrowser(url string) error
- func ParseComponentImageName(imageName string) (string, string, string, string)
- func PathEqual(firstPath string, secondPath string) bool
- func ReadFilePath(u *url.URL, os string) string
- func RemoveDuplicates(s []string) []string
- func RemoveRelativePathFromFiles(files []string, path string) ([]string, error)
- func SliceDifference(s1 []string, s2 []string) []string
- func TruncateString(str string, maxLen int) string
- func Unzip(src, dest, pathToUnzip string) ([]string, error)
- func ValidateFile(filePath string) error
- func ValidateK8sResourceName(key string, value string) error
- func ValidateURL(sourceURL string) error
- type DownloadParams
- type HTTPRequestParams
- type ResourceRequirementInfo
Constants ¶
const ( HTTPRequestTimeout = 30 * time.Second // HTTPRequestTimeout configures timeout of all HTTP requests ResponseHeaderTimeout = 30 * time.Second // ResponseHeaderTimeout is the timeout to retrieve the server's response headers ModeReadWriteFile = 0600 // default Permission for a file CredentialPrefix = "odo-" // CredentialPrefix is the prefix of the credential that uses to access secure registry )
const WIN = "windows"
WIN represent the windows OS
Variables ¶
This section is empty.
Functions ¶
func AddFileToIgnoreFile ¶
AddFileToIgnoreFile adds a file to the gitignore file. It only does that if the file doesn't exist
func CheckKubeConfigExist ¶
func CheckKubeConfigExist() bool
CheckKubeConfigExist checks for existence of kubeconfig
func CheckOutputFlag ¶
CheckOutputFlag returns true if specified output format is supported
func CheckPathExists ¶
CheckPathExists checks if a path exists or not
func ConvertGitSSHRemoteToHTTPS ¶
Converts Git ssh remote to https
func ConvertKeyValueStringToMap ¶
ConvertKeyValueStringToMap converts String Slice of Parameters to a Map[String]string Each value of the slice is expected to be in the key=value format Values that do not conform to this "spec", will be ignored
func ConvertLabelsToSelector ¶
ConvertLabelsToSelector converts the given labels to selector
func DeletePath ¶
DeletePath deletes a file/directory if it exists and doesn't throw error if it doesn't exist
func DisplayLog ¶
func DisplayLog(followLog bool, rd io.ReadCloser, compName string) (err error)
DisplayLog displays logs to user stdout with some color formatting
func DownloadFile ¶
func DownloadFile(params DownloadParams) error
DownloadFile downloads the file to the filepath given URL and token (if applicable)
func DownloadFileInMemory ¶
DownloadFileInMemory uses the url to download the file and return bytes
func DownloadFileWithCache ¶
func DownloadFileWithCache(params DownloadParams, cacheFor int) error
DownloadFileWithCache downloads the file to the filepath given URL and token (if applicable) cacheFor determines how long the response should be cached (in minutes), 0 for no caching
func ExtractComponentType ¶
ExtractComponentType returns only component type part from passed component type(default unqualified, fully qualified, versioned, etc...and their combinations) for use as component name Possible types of parameters: 1. "myproject/python:3.5" -- Return python 2. "python:3.5" -- Return python 3. nodejs -- Return nodejs
func FilterIgnores ¶
func FilterIgnores(filesChanged, filesDeleted, absIgnoreRules []string) (filesChangedFiltered, filesDeletedFiltered []string)
FilterIgnores applies the glob rules on the filesChanged and filesDeleted and filters them returns the filtered results which match any of the glob rules
func GenFileURL ¶
GenFileURL Converts file path on windows to /C:/path/to/file to work in URL
func GenerateRandomString ¶
GenerateRandomString generates a random string of lower case characters of the given size
func GetAbsGlobExps ¶
GetAbsGlobExps converts the relative glob expressions into absolute glob expressions returns the absolute glob expressions
func GetAbsPath ¶
GetAbsPath returns absolute path from passed file path resolving even ~ to user home dir and any other such symbols that are only shell expanded can also be handled here
func GetAndExtractZip ¶
GetAndExtractZip downloads a zip file from a URL with a http prefix or takes an absolute path prefixed with file:// and extracts it to a destination. pathToUnzip specifies the path within the zip folder to extract
func GetContainerPortsFromStrings ¶
func GetContainerPortsFromStrings(ports []string) ([]corev1.ContainerPort, error)
GetContainerPortsFromStrings generates ContainerPort values from the array of string port values ports is the array containing the string port values
func GetDNS1123Name ¶
GetDNS1123Name Converts passed string into DNS-1123 string
func GetHostWithPort ¶
GetHostWithPort parses provided url and returns string formated as host:port even if port was not specifically specified in the origin url. If port is not specified, standart port corresponding to url schema is provided. example: for url https://example.com function will return "example.com:443"
for url https://example.com:8443 function will return "example:8443"
func GetIgnoreRulesFromDirectory ¶
GetIgnoreRulesFromDirectory reads the .odoignore file, if present, and reads the rules from it if the .odoignore file is not found, then .gitignore is searched for the rules if both are not found, return empty array directory is the name of the directory to look into for either of the files rules is the array of rules (in string form)
func GetRandomName ¶
func GetRandomName(prefix string, prefixMaxLen int, existList []string, retries int) (string, error)
GetRandomName returns a randomly generated name which can be used for naming odo and/or openshift entities prefix: Desired prefix part of the name prefixMaxLen: Desired maximum length of prefix part of random name; if -1 is passed, no limit on length will be enforced existList: List to verify that the returned name does not already exist retries: number of retries to try generating a unique name Returns:
- randomname: is prefix-suffix, where: prefix: string passed as prefix or fetched current directory of length same as the passed prefixMaxLen suffix: 4 char random string
- error: if requested number of retries also failed to generate unique name
func GetRemoteFilesMarkedForDeletion ¶
GetRemoteFilesMarkedForDeletion returns the list of remote files marked for deletion
func GetSortedKeys ¶
GetSortedKeys retrieves the alphabetically-sorted keys of the specified map
func GetSplitValuesFromStr ¶
GetSplitValuesFromStr returns a slice containing the split string, using ',' as a separator
func HTTPGetFreePort ¶
HTTPGetFreePort gets a free port from the system
func HTTPGetRequest ¶
func HTTPGetRequest(request HTTPRequestParams, cacheFor int) ([]byte, error)
HTTPGetRequest gets resource contents given URL and token (if applicable) cacheFor determines how long the response should be cached (in minutes), 0 for no caching
func IsEmpty ¶
IsEmpty checks to see if a directory is empty shamelessly taken from: https://stackoverflow.com/questions/30697324/how-to-check-if-directory-on-path-is-empty this helps detect any edge cases where an empty directory is copied over
func IsGlobExpMatch ¶
IsGlobExpMatch compiles strToMatch against each of the passed globExps Parameters: strToMatch : a string for matching against the rules globExps : a list of glob patterns to match strToMatch with Returns: true if there is any match else false the error (if any) Notes: Source as well as glob expression to match is changed to forward slashes due to supporting Windows as well as support with the "github.com/gobwas/glob" library that we use.
func IsValidProjectDir ¶
IsValidProjectDir checks that the folder to download the project from devfile is either empty or only contains the devfile used.
func NamespaceOpenShiftObject ¶
NamespaceOpenShiftObject hyphenates applicationName and componentName
func OpenBrowser ¶
OpenBrowser opens the URL within the users default browser
func ParseComponentImageName ¶
ParseComponentImageName returns 1. image name 2. component type i.e, builder image name 3. component name default value is component type else the user requested component name 4. component version which is by default latest else version passed with builder image name
func ReadFilePath ¶
ReadFilePath Reads file path form URL file:///C:/path/to/file to C:\path\to\file
func RemoveDuplicates ¶
RemoveDuplicates goes through a string slice and removes all duplicates. Reference: https://siongui.github.io/2018/04/14/go-remove-duplicates-from-slice-or-array/
func RemoveRelativePathFromFiles ¶
RemoveRelativePathFromFiles removes a specified path from a list of files
func SliceDifference ¶
SliceDifference returns the values of s2 that do not exist in s1
func TruncateString ¶
TruncateString truncates passed string to given length Note: if -1 is passed, the original string is returned
func Unzip ¶
Unzip will decompress a zip archive, moving specified files and folders within the zip file (parameter 1) to an output directory (parameter 2) Source: https://golangcode.com/unzip-files-in-go/ pathToUnzip (parameter 3) is the path within the zip folder to extract
func ValidateK8sResourceName ¶
ValidateK8sResourceName sanitizes kubernetes resource name with the following requirements: - Contain at most 63 characters - Contain only lowercase alphanumeric characters or ‘-’ - Start with an alphanumeric character - End with an alphanumeric character - Must not contain all numeric values
Types ¶
type DownloadParams ¶
type DownloadParams struct { Request HTTPRequestParams Filepath string }
DownloadParams holds parameters of forming file download request
type HTTPRequestParams ¶
HTTPRequestParams holds parameters of forming http request
type ResourceRequirementInfo ¶
type ResourceRequirementInfo struct { ResourceType corev1.ResourceName MinQty resource.Quantity MaxQty resource.Quantity }
ResourceRequirementInfo holds resource quantity before transformation into its appropriate form in container spec
func FetchResourceQuantity ¶
func FetchResourceQuantity(resourceType corev1.ResourceName, min string, max string, request string) (*ResourceRequirementInfo, error)
FetchResourceQuantity takes passed min, max and requested resource quantities and returns min and max resource requests