From 7178dcad35c4e24e008d067d1b6b03ef993cf80a Mon Sep 17 00:00:00 2001 From: Torkel Odegaard Date: Sun, 19 Apr 2015 09:14:50 +0200 Subject: [PATCH] Windows: Fixed runtime issue with file logging config that casued errors on startup --- pkg/setting/setting.go | 78 +++++++++++++++++++++++++----------------- 1 file changed, 46 insertions(+), 32 deletions(-) diff --git a/pkg/setting/setting.go b/pkg/setting/setting.go index 0d5389ebc4f..d0c5bc717c1 100644 --- a/pkg/setting/setting.go +++ b/pkg/setting/setting.go @@ -9,6 +9,7 @@ import ( "net/url" "os" "path" + "encoding/json" "path/filepath" "regexp" "runtime" @@ -18,6 +19,7 @@ import ( "gopkg.in/ini.v1" "github.com/grafana/grafana/pkg/log" + "github.com/grafana/grafana/pkg/util" ) type Scheme string @@ -404,13 +406,13 @@ func readSessionConfig() { } } -var logLevels = map[string]string{ - "Trace": "0", - "Debug": "1", - "Info": "2", - "Warn": "3", - "Error": "4", - "Critical": "5", +var logLevels = map[string]int{ + "Trace": 0, + "Debug": 1, + "Info": 2, + "Warn": 3, + "Error": 4, + "Critical": 5, } func initLogging(args *CommandLineArgs) { @@ -434,40 +436,52 @@ func initLogging(args *CommandLineArgs) { log.Fatal(4, "Unknown log level: %s", levelName) } + var logCfg util.DynMap + // Generate log configuration. switch mode { case "console": - LogConfigs[i] = fmt.Sprintf(`{"level":%s}`, level) + logCfg = util.DynMap{"level": level} case "file": - logPath := sec.Key("file_name").MustString(path.Join(LogsPath, "grafana.log")) - os.MkdirAll(path.Dir(logPath), os.ModePerm) - LogConfigs[i] = fmt.Sprintf( - `{"level":%s,"filename":"%s","rotate":%v,"maxlines":%d,"maxsize":%d,"daily":%v,"maxdays":%d}`, level, - logPath, - sec.Key("log_rotate").MustBool(true), - sec.Key("max_lines").MustInt(1000000), - 1<