zap.go 973 B

1234567891011121314151617181920212223242526272829303132
  1. package core
  2. import (
  3. "fmt"
  4. "github.com/flipped-aurora/gin-vue-admin/server/core/internal"
  5. "github.com/flipped-aurora/gin-vue-admin/server/global"
  6. "github.com/flipped-aurora/gin-vue-admin/server/utils"
  7. "go.uber.org/zap"
  8. "go.uber.org/zap/zapcore"
  9. "os"
  10. )
  11. // Zap 获取 zap.Logger
  12. // Author [SliverHorn](https://github.com/SliverHorn)
  13. func Zap() (logger *zap.Logger) {
  14. if ok, _ := utils.PathExists(global.GVA_CONFIG.Zap.Director); !ok { // 判断是否有Director文件夹
  15. fmt.Printf("create %v directory\n", global.GVA_CONFIG.Zap.Director)
  16. _ = os.Mkdir(global.GVA_CONFIG.Zap.Director, os.ModePerm)
  17. }
  18. levels := global.GVA_CONFIG.Zap.Levels()
  19. length := len(levels)
  20. cores := make([]zapcore.Core, 0, length)
  21. for i := 0; i < length; i++ {
  22. core := internal.NewZapCore(levels[i])
  23. cores = append(cores, core)
  24. }
  25. logger = zap.New(zapcore.NewTee(cores...))
  26. if global.GVA_CONFIG.Zap.ShowLine {
  27. logger = logger.WithOptions(zap.AddCaller())
  28. }
  29. return logger
  30. }