Skip to content
This repository has been archived by the owner on Dec 21, 2019. It is now read-only.

Commit

Permalink
refactor context: Extract loadJsonOrYaml to util package
Browse files Browse the repository at this point in the history
The logic to deserialise a structure from *either* JSON or YAML is reused several
times and can be easily extracted, which this commit does.
  • Loading branch information
tazjin committed Jul 3, 2017
1 parent e2f7cf6 commit 3728d0a
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 29 deletions.
32 changes: 3 additions & 29 deletions context/context.go
Original file line number Diff line number Diff line change
@@ -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"
)
Expand Down Expand Up @@ -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(
Expand Down Expand Up @@ -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)
}

Expand Down
27 changes: 27 additions & 0 deletions util/util.go
Original file line number Diff line number Diff line change
@@ -1,5 +1,14 @@
package util

import (
"encoding/json"
"fmt"
"io/ioutil"
"strings"

"github.com/ghodss/yaml"
)

// Merges two maps together. Values from the second map override values in the first map.
// The returned map is new if anything was changed.
func Merge(in1 *map[string]interface{}, in2 *map[string]interface{}) *map[string]interface{} {
Expand All @@ -22,3 +31,21 @@ func Merge(in1 *map[string]interface{}, in2 *map[string]interface{}) *map[string

return &new
}

// Loads either a YAML or JSON file from the specified path and deserialises it into the provided interface.
func LoadJsonOrYaml(filename string, addr interface{}) error {
file, err := ioutil.ReadFile(filename)
if err != nil {
return err
}

if strings.HasSuffix(filename, "json") {
err = json.Unmarshal(file, addr)
} else if strings.HasSuffix(filename, "yaml") || strings.HasSuffix(filename, "yml") {
err = yaml.Unmarshal(file, addr)
} else {
return fmt.Errorf("File format not supported. Must be JSON or YAML.")
}

return nil
}

0 comments on commit 3728d0a

Please sign in to comment.