diff options
author | Lunny Xiao <xiaolunwen@gmail.com> | 2017-02-20 16:11:13 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-02-20 16:11:13 +0800 |
commit | 04fdeb9d8d4dc3cf296d8354ee29f1d053154a54 (patch) | |
tree | a0510e09bd7d5f91520fd101ad478cf3c8e2a623 /modules/setting | |
parent | d4b752def9d46995720526c1757456948df2a790 (diff) | |
download | gitea-04fdeb9d8d4dc3cf296d8354ee29f1d053154a54.tar.gz gitea-04fdeb9d8d4dc3cf296d8354ee29f1d053154a54.zip |
Make Xorm log configurable (#174)
* make xorm log configable
* bug fixed for other sub commands except web
* rebase and fix xorm log
* bug fix for TrimSpace
Diffstat (limited to 'modules/setting')
-rw-r--r-- | modules/setting/setting.go | 91 |
1 files changed, 87 insertions, 4 deletions
diff --git a/modules/setting/setting.go b/modules/setting/setting.go index bbccb44eab..e69cfaa320 100644 --- a/modules/setting/setting.go +++ b/modules/setting/setting.go @@ -30,6 +30,7 @@ import ( _ "github.com/go-macaron/cache/redis" "github.com/go-macaron/session" _ "github.com/go-macaron/session/redis" // redis plugin for store session + "github.com/go-xorm/core" ini "gopkg.in/ini.v1" "strk.kbt.io/projects/go/libravatar" ) @@ -944,18 +945,18 @@ func newLogService() { LogConfigs = make([]string, len(LogModes)) useConsole := false - for _, mode := range LogModes { - if mode == "console" { + for i := 0; i < len(LogModes); i++ { + LogModes[i] = strings.TrimSpace(LogModes[i]) + if LogModes[i] == "console" { useConsole = true } } + if !useConsole { log.DelLogger("console") } for i, mode := range LogModes { - mode = strings.TrimSpace(mode) - sec, err := Cfg.GetSection("log." + mode) if err != nil { @@ -1014,6 +1015,87 @@ func newLogService() { } } +// NewXORMLogService initializes xorm logger service +func NewXORMLogService(disableConsole bool) { + logModes := strings.Split(Cfg.Section("log").Key("MODE").MustString("console"), ",") + var logConfigs string + for _, mode := range logModes { + mode = strings.TrimSpace(mode) + + if disableConsole && mode == "console" { + continue + } + sec, err := Cfg.GetSection("log." + mode) + if err != nil { + log.Fatal(4, "Unknown log mode: %s", mode) + } + + validLevels := []string{"Trace", "Debug", "Info", "Warn", "Error", "Critical"} + // Log level. + levelName := Cfg.Section("log."+mode).Key("LEVEL").In( + Cfg.Section("log").Key("LEVEL").In("Trace", validLevels), + validLevels) + level, ok := logLevels[levelName] + if !ok { + log.Fatal(4, "Unknown log level: %s", levelName) + } + + // Generate log configuration. + switch mode { + case "console": + logConfigs = fmt.Sprintf(`{"level":%s}`, level) + case "file": + logPath := sec.Key("FILE_NAME").MustString(path.Join(LogRootPath, "xorm.log")) + if err = os.MkdirAll(path.Dir(logPath), os.ModePerm); err != nil { + panic(err.Error()) + } + logPath = filepath.Join(filepath.Dir(logPath), "xorm.log") + + logConfigs = 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<<uint(sec.Key("MAX_SIZE_SHIFT").MustInt(28)), + sec.Key("DAILY_ROTATE").MustBool(true), + sec.Key("MAX_DAYS").MustInt(7)) + case "conn": + logConfigs = fmt.Sprintf(`{"level":%s,"reconnectOnMsg":%v,"reconnect":%v,"net":"%s","addr":"%s"}`, level, + sec.Key("RECONNECT_ON_MSG").MustBool(), + sec.Key("RECONNECT").MustBool(), + sec.Key("PROTOCOL").In("tcp", []string{"tcp", "unix", "udp"}), + sec.Key("ADDR").MustString(":7020")) + case "smtp": + logConfigs = fmt.Sprintf(`{"level":%s,"username":"%s","password":"%s","host":"%s","sendTos":"%s","subject":"%s"}`, level, + sec.Key("USER").MustString("example@example.com"), + sec.Key("PASSWD").MustString("******"), + sec.Key("HOST").MustString("127.0.0.1:25"), + sec.Key("RECEIVERS").MustString("[]"), + sec.Key("SUBJECT").MustString("Diagnostic message from serve")) + case "database": + logConfigs = fmt.Sprintf(`{"level":%s,"driver":"%s","conn":"%s"}`, level, + sec.Key("DRIVER").String(), + sec.Key("CONN").String()) + } + + log.NewXORMLogger(Cfg.Section("log").Key("BUFFER_LEN").MustInt64(10000), mode, logConfigs) + log.Info("XORM Log Mode: %s(%s)", strings.Title(mode), levelName) + + var lvl core.LogLevel + switch levelName { + case "Trace", "Debug": + lvl = core.LOG_DEBUG + case "Info": + lvl = core.LOG_INFO + case "Warn": + lvl = core.LOG_WARNING + case "Error", "Critical": + lvl = core.LOG_ERR + } + log.XORMLogger.SetLevel(lvl) + } +} + func newCacheService() { CacheAdapter = Cfg.Section("cache").Key("ADAPTER").In("memory", []string{"memory", "redis", "memcache"}) switch CacheAdapter { @@ -1140,6 +1222,7 @@ func newWebhookService() { func NewServices() { newService() newLogService() + NewXORMLogService(false) newCacheService() newSessionService() newMailService() |