From 6e75095daa07629ba17164037f51cc5fb6509f45 Mon Sep 17 00:00:00 2001 From: erroneousboat Date: Sat, 18 May 2019 13:01:01 +0200 Subject: [PATCH] Create default config file when not present Fixes #165 --- config/config.go | 23 ++++++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) diff --git a/config/config.go b/config/config.go index aa378d0..316cfdc 100644 --- a/config/config.go +++ b/config/config.go @@ -4,6 +4,7 @@ import ( "encoding/json" "errors" "fmt" + "io/ioutil" "os" "github.com/erroneousboat/termui" @@ -31,9 +32,14 @@ type keyMapping map[string]string func NewConfig(filepath string) (*Config, error) { cfg := getDefaultConfig() + // Open config file, and when none is found or present create + // a default empty one, at the filepath location file, err := os.Open(filepath) if err != nil { - return &cfg, fmt.Errorf("couldn't find the slack-term config file: %v", err) + file, err = CreateConfigFile(filepath) + if err != nil { + return &cfg, fmt.Errorf("couldn't open the slack-term config file: %v", err) + } } if err := json.NewDecoder(file).Decode(&cfg); err != nil { @@ -65,6 +71,21 @@ func NewConfig(filepath string) (*Config, error) { return &cfg, nil } +func CreateConfigFile(filepath string) (*os.File, error) { + payload := "{\"slack_token\": \"\"}" + err := ioutil.WriteFile(filepath, []byte(payload), 0755) + if err != nil { + return nil, err + } + + file, err := os.Open(filepath) + if err != nil { + return nil, err + } + + return file, nil +} + func getDefaultConfig() Config { return Config{ SidebarWidth: 1,