1
0

log.go 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. // Copyright 2016 fatedier, fatedier@gmail.com
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package log
  15. import (
  16. "os"
  17. "github.com/fatedier/golib/log"
  18. )
  19. var Logger *log.Logger
  20. func init() {
  21. Logger = log.New(
  22. log.WithCaller(true),
  23. log.AddCallerSkip(1),
  24. log.WithLevel(log.InfoLevel),
  25. )
  26. }
  27. func InitLogger(logPath string, levelStr string, maxDays int, disableLogColor bool) {
  28. options := []log.Option{}
  29. if logPath == "console" {
  30. if !disableLogColor {
  31. options = append(options,
  32. log.WithOutput(log.NewConsoleWriter(log.ConsoleConfig{
  33. Colorful: true,
  34. }, os.Stdout)),
  35. )
  36. }
  37. } else {
  38. writer := log.NewRotateFileWriter(log.RotateFileConfig{
  39. FileName: logPath,
  40. Mode: log.RotateFileModeDaily,
  41. MaxDays: maxDays,
  42. })
  43. writer.Init()
  44. options = append(options, log.WithOutput(writer))
  45. }
  46. level, err := log.ParseLevel(levelStr)
  47. if err != nil {
  48. level = log.InfoLevel
  49. }
  50. options = append(options, log.WithLevel(level))
  51. Logger = Logger.WithOptions(options...)
  52. }
  53. func Errorf(format string, v ...interface{}) {
  54. Logger.Errorf(format, v...)
  55. }
  56. func Warnf(format string, v ...interface{}) {
  57. Logger.Warnf(format, v...)
  58. }
  59. func Infof(format string, v ...interface{}) {
  60. Logger.Infof(format, v...)
  61. }
  62. func Debugf(format string, v ...interface{}) {
  63. Logger.Debugf(format, v...)
  64. }
  65. func Tracef(format string, v ...interface{}) {
  66. Logger.Tracef(format, v...)
  67. }