Documentation ¶
Index ¶
- func CreateTempFile(filePath string) bool
- func CreateTimestamp() int64
- func DeleteTempFile(filePath string) (bool, error)
- func DirIsEmpty(path string) (bool, error)
- func DownloadAndExtractZip(zipURL string, destination string) error
- func DownloadFile(URL, destination string) error
- func DownloadFromRepoURL(repoURL string, destination string) error
- func DownloadFromTarGzURL(URL string, destination string) error
- func DownloadFromURLThenExtract(URL string, destination string) error
- func GetZipURL(owner, repo, branch string) (string, error)
- func IsTarGzURL(URL string) bool
- func OnAddTemplateRepo(extensions []Extension, url string, repos []TemplateRepo)
- func OnDeleteTemplateRepo(extensions []Extension, url string, repos []TemplateRepo)
- func PathExists(path string) bool
- func PrettyPrintJSON(i interface{})
- func RemoveDuplicateEntries(inputArr []string) []string
- func ReplaceInFiles(projectPath string, oldStr string, newStr string) error
- func RunCommand(projectPath string, command ExtensionCommand, params map[string]string) error
- func UnTar(pathToTarFile, destination string) error
- func UnZip(filePath, destination string) error
- func WaitForService(url string, successStatusCode int, maxRetries int) error
- type Extension
- type ExtensionCommand
- type ExtensionConfig
- type HTTPClient
- type TemplateRepo
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func CreateTempFile ¶
CreateTempFile in the same directory as the binary for docker compose
func DeleteTempFile ¶
DeleteTempFile once the the Codewind environment has been created
func DirIsEmpty ¶
DirIsEmpty returns true if the directory at the given path if empty
func DownloadAndExtractZip ¶
DownloadAndExtractZip downloads a zip file from a URL and extracts it to a destination
func DownloadFile ¶
DownloadFile from URL to file destination
func DownloadFromRepoURL ¶
DownloadFromRepoURL downloads a repo from a URL to a destination
func DownloadFromTarGzURL ¶
DownloadFromTarGzURL downloads a tar.gz file from a URL and extracts it to a destination
func DownloadFromURLThenExtract ¶
DownloadFromURLThenExtract downloads files from a URL to a destination, extracting them if necessary
func IsTarGzURL ¶
IsTarGzURL returns whether the provided URL is a tar.gz file
func OnAddTemplateRepo ¶
func OnAddTemplateRepo(extensions []Extension, url string, repos []TemplateRepo)
OnAddTemplateRepo runs any extension command associated with a repo add
func OnDeleteTemplateRepo ¶
func OnDeleteTemplateRepo(extensions []Extension, url string, repos []TemplateRepo)
OnDeleteTemplateRepo runs any extension command associated with a repo delete
func PathExists ¶
PathExists returns whether a path exists on the local file system.
func PrettyPrintJSON ¶
func PrettyPrintJSON(i interface{})
PrettyPrintJSON : Format JSON output for display
func RemoveDuplicateEntries ¶
RemoveDuplicateEntries elements
func ReplaceInFiles ¶
ReplaceInFiles the placeholder string "[PROJ_NAME_PLACEHOLDER]" with a generated name based on the project directory
func RunCommand ¶
func RunCommand(projectPath string, command ExtensionCommand, params map[string]string) error
RunCommand runs a command defined by an extension
Types ¶
type Extension ¶
type Extension struct { ProjectType string `json:"projectType"` Detection string `json:"detection"` Commands []ExtensionCommand `json:"commands"` Config ExtensionConfig `json:"config"` }
Extension represents a project extension defined by codewind.yaml
type ExtensionCommand ¶
type ExtensionCommand struct { Name string `json:"name"` Command string `json:"command"` Args []string `json:"args"` }
ExtensionCommand represents a command defined by a project extension
type ExtensionConfig ¶
type ExtensionConfig struct {
Style string `json:"style"`
}
ExtensionConfig represents a project extension's config element
type HTTPClient ¶
HTTPClient : An net HTTP Client to simplify testing
type TemplateRepo ¶
type TemplateRepo struct { Description string `json:"description"` URL string `json:"url"` Name string `json:"name"` ID string `json:"id"` Enabled bool `json:"enabled"` Protected bool `json:"protected"` ProjectStyles []string `json:"projectStyles"` }
TemplateRepo represents a template repository.