forked from toolshed/abra
		
	fix: pass sample env when loading recipe
Closes coop-cloud/organising#176.
This commit is contained in:
		| @ -3,18 +3,20 @@ package compose | |||||||
| import ( | import ( | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"io/ioutil" | 	"io/ioutil" | ||||||
|  | 	"path" | ||||||
| 	"path/filepath" | 	"path/filepath" | ||||||
| 	"strings" | 	"strings" | ||||||
|  |  | ||||||
| 	"coopcloud.tech/abra/pkg/client/stack" | 	"coopcloud.tech/abra/pkg/client/stack" | ||||||
| 	loader "coopcloud.tech/abra/pkg/client/stack" | 	loader "coopcloud.tech/abra/pkg/client/stack" | ||||||
|  | 	"coopcloud.tech/abra/pkg/config" | ||||||
| 	composetypes "github.com/docker/cli/cli/compose/types" | 	composetypes "github.com/docker/cli/cli/compose/types" | ||||||
| 	"github.com/docker/distribution/reference" | 	"github.com/docker/distribution/reference" | ||||||
| 	"github.com/sirupsen/logrus" | 	"github.com/sirupsen/logrus" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| // UpdateTag updates an image tag in-place on file system local compose files. | // UpdateTag updates an image tag in-place on file system local compose files. | ||||||
| func UpdateTag(pattern, image, tag string) error { | func UpdateTag(pattern, image, tag, recipeName string) error { | ||||||
| 	composeFiles, err := filepath.Glob(pattern) | 	composeFiles, err := filepath.Glob(pattern) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| @ -24,8 +26,14 @@ func UpdateTag(pattern, image, tag string) error { | |||||||
|  |  | ||||||
| 	for _, composeFile := range composeFiles { | 	for _, composeFile := range composeFiles { | ||||||
| 		opts := stack.Deploy{Composefiles: []string{composeFile}} | 		opts := stack.Deploy{Composefiles: []string{composeFile}} | ||||||
| 		emptyEnv := make(map[string]string) |  | ||||||
| 		compose, err := loader.LoadComposefile(opts, emptyEnv) | 		envSamplePath := path.Join(config.ABRA_DIR, "apps", recipeName, ".env.sample") | ||||||
|  | 		sampleEnv, err := config.ReadEnv(envSamplePath) | ||||||
|  | 		if err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		compose, err := loader.LoadComposefile(opts, sampleEnv) | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			return err | 			return err | ||||||
| 		} | 		} | ||||||
| @ -74,7 +82,7 @@ func UpdateTag(pattern, image, tag string) error { | |||||||
| } | } | ||||||
|  |  | ||||||
| // UpdateLabel updates a label in-place on file system local compose files. | // UpdateLabel updates a label in-place on file system local compose files. | ||||||
| func UpdateLabel(pattern, serviceName, label string) error { | func UpdateLabel(pattern, serviceName, label, recipeName string) error { | ||||||
| 	composeFiles, err := filepath.Glob(pattern) | 	composeFiles, err := filepath.Glob(pattern) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| @ -84,8 +92,14 @@ func UpdateLabel(pattern, serviceName, label string) error { | |||||||
|  |  | ||||||
| 	for _, composeFile := range composeFiles { | 	for _, composeFile := range composeFiles { | ||||||
| 		opts := stack.Deploy{Composefiles: []string{composeFile}} | 		opts := stack.Deploy{Composefiles: []string{composeFile}} | ||||||
| 		emptyEnv := make(map[string]string) |  | ||||||
| 		compose, err := loader.LoadComposefile(opts, emptyEnv) | 		envSamplePath := path.Join(config.ABRA_DIR, "apps", recipeName, ".env.sample") | ||||||
|  | 		sampleEnv, err := config.ReadEnv(envSamplePath) | ||||||
|  | 		if err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		compose, err := loader.LoadComposefile(opts, sampleEnv) | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			return err | 			return err | ||||||
| 		} | 		} | ||||||
|  | |||||||
| @ -26,7 +26,7 @@ type Recipe struct { | |||||||
| // UpdateLabel updates a recipe label | // UpdateLabel updates a recipe label | ||||||
| func (r Recipe) UpdateLabel(serviceName, label string) error { | func (r Recipe) UpdateLabel(serviceName, label string) error { | ||||||
| 	pattern := fmt.Sprintf("%s/%s/compose**yml", config.APPS_DIR, r.Name) | 	pattern := fmt.Sprintf("%s/%s/compose**yml", config.APPS_DIR, r.Name) | ||||||
| 	if err := compose.UpdateLabel(pattern, serviceName, label); err != nil { | 	if err := compose.UpdateLabel(pattern, serviceName, label, r.Name); err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	return nil | 	return nil | ||||||
| @ -35,7 +35,7 @@ func (r Recipe) UpdateLabel(serviceName, label string) error { | |||||||
| // UpdateTag updates a recipe tag | // UpdateTag updates a recipe tag | ||||||
| func (r Recipe) UpdateTag(image, tag string) error { | func (r Recipe) UpdateTag(image, tag string) error { | ||||||
| 	pattern := fmt.Sprintf("%s/%s/compose**yml", config.APPS_DIR, r.Name) | 	pattern := fmt.Sprintf("%s/%s/compose**yml", config.APPS_DIR, r.Name) | ||||||
| 	if err := compose.UpdateTag(pattern, image, tag); err != nil { | 	if err := compose.UpdateTag(pattern, image, tag, r.Name); err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	return nil | 	return nil | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user