Create config file when it's missing

This commit is contained in:
Arturo Filastò 2018-06-25 17:49:17 +02:00
parent a6b95f50c9
commit 78cf8d6ca2
3 changed files with 35 additions and 16 deletions

View File

@ -3,7 +3,6 @@ package config
import ( import (
"encoding/json" "encoding/json"
"io/ioutil" "io/ioutil"
"path/filepath"
"sync" "sync"
"github.com/ooni/probe-cli/utils" "github.com/ooni/probe-cli/utils"
@ -14,7 +13,7 @@ import (
func ReadConfig(path string) (*Config, error) { func ReadConfig(path string) (*Config, error) {
b, err := ioutil.ReadFile(path) b, err := ioutil.ReadFile(path)
if err != nil { if err != nil {
return nil, errors.Wrap(err, "reading file") return nil, err
} }
c, err := ParseConfig(b) c, err := ParseConfig(b)
@ -93,7 +92,7 @@ func (c *Config) Default() error {
return err return err
} }
c.path = filepath.Join(home, "config.json") c.path = utils.ConfigPath(home)
return nil return nil
} }

41
ooni.go
View File

@ -4,11 +4,11 @@ import (
"io/ioutil" "io/ioutil"
"os" "os"
"path" "path"
"path/filepath"
"github.com/apex/log" "github.com/apex/log"
"github.com/jmoiron/sqlx" "github.com/jmoiron/sqlx"
"github.com/ooni/probe-cli/config" "github.com/ooni/probe-cli/config"
"github.com/ooni/probe-cli/internal/bindata"
"github.com/ooni/probe-cli/internal/database" "github.com/ooni/probe-cli/internal/database"
"github.com/ooni/probe-cli/internal/legacy" "github.com/ooni/probe-cli/internal/legacy"
"github.com/ooni/probe-cli/internal/onboard" "github.com/ooni/probe-cli/internal/onboard"
@ -100,7 +100,7 @@ func (c *Context) Init() error {
c.Config, err = config.ReadConfig(c.configPath) c.Config, err = config.ReadConfig(c.configPath)
} else { } else {
log.Debug("Reading default config file") log.Debug("Reading default config file")
c.Config, err = ReadDefaultConfigPaths(c.Home) c.Config, err = InitDefaultConfig(c.Home)
} }
if err != nil { if err != nil {
return err return err
@ -144,21 +144,36 @@ func MaybeInitializeHome(home string) error {
return nil return nil
} }
// ReadDefaultConfigPaths from common locations. // InitDefaultConfig reads the config from common locations or creates it if
func ReadDefaultConfigPaths(home string) (*config.Config, error) { // missing.
var paths = []string{ func InitDefaultConfig(home string) (*config.Config, error) {
filepath.Join(home, "config.json"), var (
} err error
for _, path := range paths { c *config.Config
if _, err := os.Stat(path); err == nil { configPath = utils.ConfigPath(home)
c, err := config.ReadConfig(path) )
c, err = config.ReadConfig(configPath)
if err != nil {
if os.IsNotExist(err) {
log.Debugf("writing default config to %s", configPath)
var data []byte
data, err = bindata.Asset("data/default-config.json")
if err != nil { if err != nil {
return nil, err return nil, err
} }
return c, nil err = ioutil.WriteFile(
configPath,
data,
0644,
)
if err != nil {
return nil, err
}
return InitDefaultConfig(home)
} }
return nil, err
} }
// Run from the default config return c, nil
return config.ReadConfig(paths[0])
} }

View File

@ -20,6 +20,11 @@ func RequiredDirs(home string) []string {
return requiredDirs return requiredDirs
} }
// ConfigPath returns the default path to the config file
func ConfigPath(home string) string {
return filepath.Join(home, "config.json")
}
// GeoIPDir returns the geoip data dir for the given OONI Home // GeoIPDir returns the geoip data dir for the given OONI Home
func GeoIPDir(home string) string { func GeoIPDir(home string) string {
return filepath.Join(home, "geoip") return filepath.Join(home, "geoip")