forked from Elara6331/itd
Compare commits
No commits in common. "aaaaaa" and "master" have entirely different histories.
33
config.go
33
config.go
@ -1,7 +1,6 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"strings"
|
"strings"
|
||||||
@ -17,8 +16,6 @@ import (
|
|||||||
var cfgDir string
|
var cfgDir string
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
etcPath := "/etc/itd.toml";
|
|
||||||
|
|
||||||
// Set up logger
|
// Set up logger
|
||||||
log.Logger = log.Output(zerolog.ConsoleWriter{Out: os.Stderr})
|
log.Logger = log.Output(zerolog.ConsoleWriter{Out: os.Stderr})
|
||||||
|
|
||||||
@ -54,9 +51,15 @@ func init() {
|
|||||||
// Set config defaults
|
// Set config defaults
|
||||||
setCfgDefaults()
|
setCfgDefaults()
|
||||||
|
|
||||||
// Load and watch config files
|
// Load config files
|
||||||
loadAndwatchCfgFile(etcPath)
|
etcProvider := file.Provider("/etc/itd.toml")
|
||||||
loadAndwatchCfgFile(cfgPath)
|
cfgProvider := file.Provider(cfgPath)
|
||||||
|
k.Load(etcProvider, toml.Parser())
|
||||||
|
k.Load(cfgProvider, toml.Parser())
|
||||||
|
|
||||||
|
// Watch configs for changes
|
||||||
|
cfgWatch(etcProvider)
|
||||||
|
cfgWatch(cfgProvider)
|
||||||
|
|
||||||
// Load envireonment variables
|
// Load envireonment variables
|
||||||
k.Load(env.Provider("ITD_", "_", func(s string) string {
|
k.Load(env.Provider("ITD_", "_", func(s string) string {
|
||||||
@ -64,31 +67,17 @@ func init() {
|
|||||||
}), nil)
|
}), nil)
|
||||||
}
|
}
|
||||||
|
|
||||||
func loadAndwatchCfgFile(filename string) {
|
func cfgWatch(provider *file.File) {
|
||||||
provider := file.Provider(filename)
|
|
||||||
|
|
||||||
loadCfg(provider)
|
|
||||||
|
|
||||||
// Watch for changes and reload when detected
|
// Watch for changes and reload when detected
|
||||||
provider.Watch(func(_ interface{}, err error) {
|
provider.Watch(func(_ interface{}, err error) {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
loadCfg(provider)
|
k.Load(provider, toml.Parser())
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func loadCfg(provider *file.File) {
|
|
||||||
fmt.Println("%#v\n", provider) // &file.File{path:"/etc/itd.toml"}
|
|
||||||
filename := ""
|
|
||||||
filename = provider.path // provider.path undefined (type *file.File has no field or method path)
|
|
||||||
filename = (*provider).path // (*provider).path undefined (type file.File has no field or method path)
|
|
||||||
if cfgError := k.Load(provider, toml.Parser()); cfgError != nil {
|
|
||||||
log.Warn().Msg(fmt.Sprintf("Error while trying to read %s: %s\n", filename, cfgError.Error()))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func setCfgDefaults() {
|
func setCfgDefaults() {
|
||||||
k.Load(confmap.Provider(map[string]interface{}{
|
k.Load(confmap.Provider(map[string]interface{}{
|
||||||
"bluetooth.adapter": "hci0",
|
"bluetooth.adapter": "hci0",
|
||||||
|
Loading…
Reference in New Issue
Block a user