Skip to content

Commit

Permalink
Merge pull request #57 from james-nesbitt/initmergeyaml
Browse files Browse the repository at this point in the history
merge remoteyaml and yaml operations
  • Loading branch information
james-nesbitt committed Dec 8, 2015
2 parents d364a44 + 10202ce commit 27db8fa
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 33 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -287,7 +287,7 @@ The syntax for using your own local yaml file:

or remote yaml

$/> coach init remoteyaml https://raw.githubusercontent.com/james-nesbitt/coach/master/templates/demo/drupal8/.coach/coachinit.yml
$/> coach init yaml https://raw.githubusercontent.com/james-nesbitt/coach/master/templates/demo/drupal8/.coach/coachinit.yml

Take a look at the existing demos for the syntax:

Expand Down
64 changes: 32 additions & 32 deletions operation_init.go
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ func (operation *Operation_Init) Flags(flags []string) {

switch handler {
case "demo":
operation.handler = "remoteyaml"
operation.handler = "yaml"
if len(remainingFlags)>0 {
operation.source = remainingFlags[0]
remainingFlags = remainingFlags[1:]
Expand Down Expand Up @@ -155,6 +155,10 @@ EXAMPLES:
$/> coach init demo lamp_scaling
$/> coach init demo complete
creates a really full and noisy example of a project
YAML base inits
There is is a YAML file syntax that can be used to define an init,
Expand All @@ -167,7 +171,7 @@ and keep it on the internet, either in a repo, or a gist or even a pastebin.
Then you can create a new project using :
$/> coach init remoteyaml http://path.to.my/yaml.yml
$/> coach init yaml http://path.to.my/yaml.yml
(note that the path has to be a full body yml file)
`)
Expand Down Expand Up @@ -217,10 +221,11 @@ func (operation *Operation_Init) Run() {
ok = operation.Init_User_Run(operation.source, &tasks)
case "git":
ok = operation.Init_Git_Run(operation.source, &tasks)
case "remoteyaml":
// deprecated as "yaml" now handles remote files as wells
fallthrough
case "yaml":
ok = operation.Init_Yaml_Run(operation.source, &tasks)
case "remoteyaml":
ok = operation.Init_RemoteYaml_Run(operation.source, &tasks)
case "default":
ok = operation.Init_Default_Run(operation.source, &tasks)
default:
Expand Down Expand Up @@ -308,46 +313,41 @@ func (operation *Operation_Init) Init_Git_Run(source string, tasks *InitTasks) b
// Get tasks from remote YAML corresponding to a remote yaml file
func (operation *Operation_Init) Init_Yaml_Run(path string, tasks *InitTasks) bool {

// read the config file
yamlSourceBytes, err := ioutil.ReadFile(path)
if err!=nil {
operation.log.Error("Could not read the YAML file ["+path+"]: "+err.Error())
return false
}
if len(yamlSourceBytes)==0 {
operation.log.Error("Yaml file ["+path+"] was empty")
return false
}

tasks.AddMessage("Initializing using YAML Source ["+path+"] to local project folder")
var yamlSourceBytes []byte
var err error

// get tasks from yaml
tasks.AddTasksFromYaml(yamlSourceBytes)
if strings.Contains(path, "://") {

// Add some message items
tasks.AddFile(".coach/CREATEDFROM.md", "THIS PROJECT WAS CREATED A COACH YAML INSTALLER :"+path)
resp, err := http.Get(path)
if err != nil {
operation.log.Error("Could not retrieve remote yaml init instructions ["+path+"] : "+err.Error())
return false
}
defer resp.Body.Close()
yamlSourceBytes, err = ioutil.ReadAll(resp.Body)

return true
}
} else {

// Get tasks from remote YAML corresponding to a remote yaml file
func (operation *Operation_Init) Init_RemoteYaml_Run(url string, tasks *InitTasks) bool {
// read the config file
yamlSourceBytes, err = ioutil.ReadFile(path)
if err!=nil {
operation.log.Error("Could not read the local YAML file ["+path+"]: "+err.Error())
return false
}
if len(yamlSourceBytes)==0 {
operation.log.Error("Yaml file ["+path+"] was empty")
return false
}

resp, err := http.Get(url)
if err != nil {
operation.log.Error("Could not retrieve remote yaml init instructions ["+url+"] : "+err.Error())
return false
}
defer resp.Body.Close()
yamlSourceBytes, err := ioutil.ReadAll(resp.Body)

tasks.AddMessage("Initializing using Remote YAML Source ["+url+"] to local project folder")
tasks.AddMessage("Initializing using YAML Source ["+path+"] to local project folder")

// get tasks from yaml
tasks.AddTasksFromYaml(yamlSourceBytes)

// Add some message items
tasks.AddFile(".coach/CREATEDFROM.md", "THIS PROJECT WAS CREATED A COACH YAML INSTALLER :"+url)
tasks.AddFile(".coach/CREATEDFROM.md", "THIS PROJECT WAS CREATED A COACH YAML INSTALLER :"+path)

return true
}

0 comments on commit 27db8fa

Please sign in to comment.