log.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. package log
  2. //go:generate go run $GOPATH/src/v2ray.com/core/common/errors/errorgen/main.go -pkg log -path App,Log
  3. import (
  4. "context"
  5. "sync"
  6. "v2ray.com/core/common"
  7. "v2ray.com/core/common/log"
  8. )
  9. // Instance is an app.Application that handles logs.
  10. type Instance struct {
  11. sync.RWMutex
  12. config *Config
  13. accessLogger log.Handler
  14. errorLogger log.Handler
  15. active bool
  16. }
  17. // New creates a new log.Instance based on the given config.
  18. func New(ctx context.Context, config *Config) (*Instance, error) {
  19. g := &Instance{
  20. config: config,
  21. active: true,
  22. }
  23. if err := g.initAccessLogger(); err != nil {
  24. return nil, newError("failed to initialize access logger").Base(err).AtWarning()
  25. }
  26. if err := g.initErrorLogger(); err != nil {
  27. return nil, newError("failed to initialize error logger").Base(err).AtWarning()
  28. }
  29. log.RegisterHandler(g)
  30. return g, nil
  31. }
  32. // Interface implements app.Application.Interface().
  33. func (*Instance) Interface() interface{} {
  34. return (*Instance)(nil)
  35. }
  36. func (g *Instance) initAccessLogger() error {
  37. switch g.config.AccessLogType {
  38. case LogType_File:
  39. creator, err := log.CreateFileLogWriter(g.config.AccessLogPath)
  40. if err != nil {
  41. return err
  42. }
  43. g.accessLogger = log.NewLogger(creator)
  44. case LogType_Console:
  45. g.accessLogger = log.NewLogger(log.CreateStdoutLogWriter())
  46. default:
  47. }
  48. return nil
  49. }
  50. func (g *Instance) initErrorLogger() error {
  51. switch g.config.ErrorLogType {
  52. case LogType_File:
  53. creator, err := log.CreateFileLogWriter(g.config.ErrorLogPath)
  54. if err != nil {
  55. return err
  56. }
  57. g.errorLogger = log.NewLogger(creator)
  58. case LogType_Console:
  59. g.errorLogger = log.NewLogger(log.CreateStdoutLogWriter())
  60. default:
  61. }
  62. return nil
  63. }
  64. // Start implements app.Application.Start().
  65. func (g *Instance) Start() error {
  66. g.Lock()
  67. defer g.Unlock()
  68. g.active = true
  69. return nil
  70. }
  71. func (g *Instance) isActive() bool {
  72. g.RLock()
  73. defer g.RUnlock()
  74. return g.active
  75. }
  76. // Handle implements log.Handler.
  77. func (g *Instance) Handle(msg log.Message) {
  78. if !g.isActive() {
  79. return
  80. }
  81. switch msg := msg.(type) {
  82. case *log.AccessMessage:
  83. if g.accessLogger != nil {
  84. g.accessLogger.Handle(msg)
  85. }
  86. case *log.GeneralMessage:
  87. if g.errorLogger != nil && msg.Severity <= g.config.ErrorLogLevel {
  88. g.errorLogger.Handle(msg)
  89. }
  90. default:
  91. // Swallow
  92. }
  93. }
  94. // Close implement app.Application.Close().
  95. func (g *Instance) Close() {
  96. g.Lock()
  97. defer g.Unlock()
  98. g.active = false
  99. }
  100. func init() {
  101. common.Must(common.RegisterConfig((*Config)(nil), func(ctx context.Context, config interface{}) (interface{}, error) {
  102. return New(ctx, config.(*Config))
  103. }))
  104. }