1
0
mirror of https://github.com/rancher/os.git synced 2025-09-08 18:20:32 +00:00

Services as compose format

This commit is contained in:
Darren Shepherd
2015-04-15 23:16:23 -07:00
parent 61b5525d5b
commit be8fa8e5b7
6 changed files with 101 additions and 47 deletions

View File

@@ -6,7 +6,6 @@ import (
"github.com/codegangsta/cli"
"github.com/rancherio/os/config"
"github.com/rancherio/os/util"
)
func serviceSubCommands() []cli.Command {
@@ -37,21 +36,16 @@ func disable(c *cli.Context) {
}
for _, service := range c.Args() {
filtered := make([]string, 0, len(c.Args()))
for _, existing := range cfg.EnabledServices {
if existing != service {
filtered = append(filtered, existing)
}
if _, ok := cfg.Services[service]; !ok {
continue
}
if len(filtered) != len(c.Args()) {
cfg.EnabledServices = filtered
changed = true
}
cfg.Services[service] = false
changed = true
}
if changed {
if err = cfg.Set("enabled_services", cfg.EnabledServices); err != nil {
if err = cfg.Set("services", cfg.Services); err != nil {
log.Fatal(err)
}
}
@@ -65,14 +59,14 @@ func enable(c *cli.Context) {
}
for _, service := range c.Args() {
if !util.Contains(cfg.EnabledServices, service) {
cfg.EnabledServices = append(cfg.EnabledServices, service)
if val, ok := cfg.Services[service]; !ok || !val {
cfg.Services[service] = true
changed = true
}
}
if changed {
if err = cfg.Set("enabled_services", cfg.EnabledServices); err != nil {
if err = cfg.Set("services", cfg.Services); err != nil {
log.Fatal(err)
}
}
@@ -84,22 +78,11 @@ func list(c *cli.Context) {
log.Fatal(err)
}
enabled := map[string]bool{}
for _, service := range cfg.EnabledServices {
enabled[service] = true
}
for service, _ := range cfg.Services {
if _, ok := enabled[service]; ok {
delete(enabled, service)
for service, enabled := range cfg.Services {
if enabled {
fmt.Printf("enabled %s\n", service)
} else {
fmt.Printf("disabled %s\n", service)
}
}
for service, _ := range enabled {
fmt.Printf("enabled %s\n", service)
}
}