about summary refs log tree commit diff
path: root/context/context.go
diff options
context:
space:
mode:
authorVincent Ambo <tazjin@gmail.com>2017-06-22T13·52+0200
committerVincent Ambo <tazjin@gmail.com>2017-07-03T12·27+0200
commit3728d0ae2eb957c8ba4251ee0f562c4941163816 (patch)
tree11e1960127024569d3ee77b8ed24039acda6ff13 /context/context.go
parente2f7cf6258f469ae9b69d0b5cce57b397c08c36d (diff)
refactor context: Extract loadJsonOrYaml to util package
The logic to deserialise a structure from *either* JSON or YAML is reused several
times and can be easily extracted, which this commit does.
Diffstat (limited to 'context/context.go')
-rw-r--r--context/context.go32
1 files changed, 3 insertions, 29 deletions
diff --git a/context/context.go b/context/context.go
index ad3d00693b95..0dde5905561d 100644
--- a/context/context.go
+++ b/context/context.go
@@ -1,13 +1,8 @@
 package context
 
 import (
-	"encoding/json"
-	"fmt"
-	"io/ioutil"
 	"path"
-	"strings"
 
-	"github.com/ghodss/yaml"
 	"github.com/polydawn/meep"
 	"github.com/tazjin/kontemplate/util"
 )
@@ -35,27 +30,8 @@ type ContextLoadingError struct {
 
 // Attempt to load and deserialise a Context from the specified file.
 func LoadContextFromFile(filename string) (*Context, error) {
-	file, err := ioutil.ReadFile(filename)
-
-	if err != nil {
-		return nil, meep.New(
-			&ContextLoadingError{Filename: filename},
-			meep.Cause(err),
-		)
-	}
-
 	var c Context
-
-	if strings.HasSuffix(filename, "json") {
-		err = json.Unmarshal(file, &c)
-	} else if strings.HasSuffix(filename, "yaml") || strings.HasSuffix(filename, "yml") {
-		err = yaml.Unmarshal(file, &c)
-	} else {
-		return nil, meep.New(
-			&ContextLoadingError{Filename: filename},
-			meep.Cause(fmt.Errorf("File format not supported. Must be JSON or YAML.")),
-		)
-	}
+	err := util.LoadJsonOrYaml(filename, &c)
 
 	if err != nil {
 		return nil, meep.New(
@@ -112,16 +88,14 @@ func loadDefaultValues(rs *ResourceSet, c *Context) *map[string]interface{} {
 	var defaultVars map[string]interface{}
 
 	// Attempt to load YAML values
-	y, err := ioutil.ReadFile(path.Join(c.BaseDir, rs.Name, "default.yaml"))
+	err := util.LoadJsonOrYaml(path.Join(c.BaseDir, rs.Name, "default.yaml"), &defaultVars)
 	if err == nil {
-		yaml.Unmarshal(y, &defaultVars)
 		return util.Merge(&defaultVars, &rs.Values)
 	}
 
 	// Attempt to load JSON values
-	j, err := ioutil.ReadFile(path.Join(c.BaseDir, rs.Name, "default.json"))
+	err = util.LoadJsonOrYaml(path.Join(c.BaseDir, rs.Name, "default.json"), &defaultVars)
 	if err == nil {
-		json.Unmarshal(j, &defaultVars)
 		return util.Merge(&defaultVars, &rs.Values)
 	}