1
0
mirror of https://github.com/v2fly/v2ray-core.git synced 2024-06-26 09:25:23 +00:00
v2fly/app/log/log.go

119 lines
2.6 KiB
Go
Raw Normal View History

package log
2017-12-03 00:04:57 +00:00
//go:generate go run $GOPATH/src/v2ray.com/core/common/errors/errorgen/main.go -pkg log -path App,Log
2017-04-08 23:43:25 +00:00
import (
2017-02-01 20:35:40 +00:00
"context"
2017-12-19 20:28:12 +00:00
"sync"
2017-02-01 20:35:40 +00:00
"v2ray.com/core/app/log/internal"
"v2ray.com/core/common"
2017-12-10 22:33:23 +00:00
"v2ray.com/core/common/log"
)
2017-12-19 23:09:52 +00:00
// Instance is an app.Application that handles logs.
2017-12-19 20:28:12 +00:00
type Instance struct {
sync.RWMutex
config *Config
accessLogger internal.LogWriter
errorLogger internal.LogWriter
}
2017-12-19 23:09:52 +00:00
// New creates a new log.Instance based on the given config.
2017-12-19 20:28:12 +00:00
func New(ctx context.Context, config *Config) (*Instance, error) {
return &Instance{
config: config,
}, nil
}
2017-12-19 23:09:52 +00:00
// Interface implements app.Application.Interface().
2017-12-19 20:28:12 +00:00
func (*Instance) Interface() interface{} {
return (*Instance)(nil)
}
2017-12-19 20:28:12 +00:00
func (g *Instance) initAccessLogger() error {
switch g.config.AccessLogType {
case LogType_File:
logger, err := internal.NewFileLogWriter(g.config.AccessLogPath)
if err != nil {
return err
}
g.accessLogger = logger
case LogType_Console:
g.accessLogger = internal.NewStdOutLogWriter()
default:
2015-12-05 20:10:14 +00:00
}
return nil
}
2017-12-19 20:28:12 +00:00
func (g *Instance) initErrorLogger() error {
switch g.config.ErrorLogType {
case LogType_File:
logger, err := internal.NewFileLogWriter(g.config.ErrorLogPath)
if err != nil {
return err
}
g.errorLogger = logger
case LogType_Console:
g.errorLogger = internal.NewStdOutLogWriter()
2017-04-06 13:13:09 +00:00
default:
}
2017-12-19 20:28:12 +00:00
return nil
2017-04-06 13:13:09 +00:00
}
2017-12-19 23:09:52 +00:00
// Start implements app.Application.Start().
2017-12-19 20:28:12 +00:00
func (g *Instance) Start() error {
if err := g.initAccessLogger(); err != nil {
return newError("failed to initialize access logger").Base(err).AtWarning()
2017-07-25 21:12:45 +00:00
}
2017-12-19 20:28:12 +00:00
if err := g.initErrorLogger(); err != nil {
return newError("failed to initialize error logger").Base(err).AtWarning()
}
2017-12-19 21:02:52 +00:00
log.RegisterHandler(g)
2017-12-19 20:28:12 +00:00
return nil
2017-02-01 20:35:40 +00:00
}
2017-12-19 23:09:52 +00:00
// Handle implements log.Handler.
2017-12-19 20:28:12 +00:00
func (g *Instance) Handle(msg log.Message) {
switch msg := msg.(type) {
case *log.AccessMessage:
g.RLock()
defer g.RUnlock()
if g.accessLogger != nil {
g.accessLogger.Log(msg)
2017-02-01 20:35:40 +00:00
}
2017-12-19 20:28:12 +00:00
case *log.GeneralMessage:
if msg.Severity.SevererThan(g.config.ErrorLogLevel) {
g.RLock()
defer g.RUnlock()
if g.errorLogger != nil {
g.errorLogger.Log(msg)
2017-02-01 20:35:40 +00:00
}
}
2017-12-19 20:28:12 +00:00
default:
// Swallow
2017-02-01 20:35:40 +00:00
}
}
2017-12-19 23:09:52 +00:00
// Close implement app.Application.Close().
2017-12-19 20:28:12 +00:00
func (g *Instance) Close() {
g.Lock()
defer g.Unlock()
2017-12-19 23:09:52 +00:00
if g.accessLogger != nil {
g.accessLogger.Close()
g.accessLogger = nil
}
2017-12-19 20:28:12 +00:00
2017-12-19 23:09:52 +00:00
if g.errorLogger != nil {
g.errorLogger.Close()
g.errorLogger = nil
}
2016-07-10 21:11:42 +00:00
}
2017-02-01 20:35:40 +00:00
func init() {
common.Must(common.RegisterConfig((*Config)(nil), func(ctx context.Context, config interface{}) (interface{}, error) {
return New(ctx, config.(*Config))
}))
}