log.go 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. package conf
  2. import (
  3. "strings"
  4. "github.com/xtls/xray-core/app/log"
  5. clog "github.com/xtls/xray-core/common/log"
  6. )
  7. func DefaultLogConfig() *log.Config {
  8. return &log.Config{
  9. AccessLogType: log.LogType_None,
  10. ErrorLogType: log.LogType_Console,
  11. ErrorLogLevel: clog.Severity_Warning,
  12. }
  13. }
  14. type LogConfig struct {
  15. AccessLog string `json:"access"`
  16. ErrorLog string `json:"error"`
  17. LogLevel string `json:"loglevel"`
  18. DNSLog bool `json:"dnsLog"`
  19. MaskAddress string `json:"maskAddress"`
  20. }
  21. func (v *LogConfig) Build() *log.Config {
  22. if v == nil {
  23. return nil
  24. }
  25. config := &log.Config{
  26. ErrorLogType: log.LogType_Console,
  27. AccessLogType: log.LogType_Console,
  28. EnableDnsLog: v.DNSLog,
  29. }
  30. if v.AccessLog == "none" {
  31. config.AccessLogType = log.LogType_None
  32. } else if len(v.AccessLog) > 0 {
  33. config.AccessLogPath = v.AccessLog
  34. config.AccessLogType = log.LogType_File
  35. }
  36. if v.ErrorLog == "none" {
  37. config.ErrorLogType = log.LogType_None
  38. } else if len(v.ErrorLog) > 0 {
  39. config.ErrorLogPath = v.ErrorLog
  40. config.ErrorLogType = log.LogType_File
  41. }
  42. level := strings.ToLower(v.LogLevel)
  43. switch level {
  44. case "debug":
  45. config.ErrorLogLevel = clog.Severity_Debug
  46. case "info":
  47. config.ErrorLogLevel = clog.Severity_Info
  48. case "error":
  49. config.ErrorLogLevel = clog.Severity_Error
  50. case "none":
  51. config.ErrorLogType = log.LogType_None
  52. config.AccessLogType = log.LogType_None
  53. default:
  54. config.ErrorLogLevel = clog.Severity_Warning
  55. }
  56. config.MaskAddress = v.MaskAddress
  57. return config
  58. }