mirror of
https://github.com/SagerNet/sing-box.git
synced 2025-01-09 17:39:43 +00:00
111 lines
2.3 KiB
Go
111 lines
2.3 KiB
Go
|
package log
|
||
|
|
||
|
import (
|
||
|
"io"
|
||
|
"os"
|
||
|
"time"
|
||
|
|
||
|
C "github.com/sagernet/sing-box/constant"
|
||
|
"github.com/sagernet/sing-box/option"
|
||
|
"github.com/sagernet/sing/common"
|
||
|
E "github.com/sagernet/sing/common/exceptions"
|
||
|
)
|
||
|
|
||
|
type factoryWithFile struct {
|
||
|
Factory
|
||
|
file *os.File
|
||
|
}
|
||
|
|
||
|
func (f *factoryWithFile) Close() error {
|
||
|
return common.Close(
|
||
|
f.Factory,
|
||
|
common.PtrOrNil(f.file),
|
||
|
)
|
||
|
}
|
||
|
|
||
|
type observableFactoryWithFile struct {
|
||
|
ObservableFactory
|
||
|
file *os.File
|
||
|
}
|
||
|
|
||
|
func (f *observableFactoryWithFile) Close() error {
|
||
|
return common.Close(
|
||
|
f.ObservableFactory,
|
||
|
common.PtrOrNil(f.file),
|
||
|
)
|
||
|
}
|
||
|
|
||
|
type Options struct {
|
||
|
Options option.LogOptions
|
||
|
Observable bool
|
||
|
DefaultWriter io.Writer
|
||
|
BaseTime time.Time
|
||
|
PlatformWriter io.Writer
|
||
|
}
|
||
|
|
||
|
func New(options Options) (Factory, error) {
|
||
|
logOptions := options.Options
|
||
|
|
||
|
if logOptions.Disabled {
|
||
|
return NewNOPFactory(), nil
|
||
|
}
|
||
|
|
||
|
var logFile *os.File
|
||
|
var logWriter io.Writer
|
||
|
|
||
|
switch logOptions.Output {
|
||
|
case "":
|
||
|
logWriter = options.DefaultWriter
|
||
|
if logWriter == nil {
|
||
|
logWriter = os.Stderr
|
||
|
}
|
||
|
case "stderr":
|
||
|
logWriter = os.Stderr
|
||
|
case "stdout":
|
||
|
logWriter = os.Stdout
|
||
|
default:
|
||
|
var err error
|
||
|
logFile, err = os.OpenFile(C.BasePath(logOptions.Output), os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0o644)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
logWriter = logFile
|
||
|
}
|
||
|
logFormatter := Formatter{
|
||
|
BaseTime: options.BaseTime,
|
||
|
DisableColors: logOptions.DisableColor || logFile != nil,
|
||
|
DisableTimestamp: !logOptions.Timestamp && logFile != nil,
|
||
|
FullTimestamp: logOptions.Timestamp,
|
||
|
TimestampFormat: "-0700 2006-01-02 15:04:05",
|
||
|
}
|
||
|
var factory Factory
|
||
|
if options.Observable {
|
||
|
factory = NewObservableFactory(logFormatter, logWriter, options.PlatformWriter)
|
||
|
} else {
|
||
|
factory = NewFactory(logFormatter, logWriter, options.PlatformWriter)
|
||
|
}
|
||
|
if logOptions.Level != "" {
|
||
|
logLevel, err := ParseLevel(logOptions.Level)
|
||
|
if err != nil {
|
||
|
return nil, E.Cause(err, "parse log level")
|
||
|
}
|
||
|
factory.SetLevel(logLevel)
|
||
|
} else {
|
||
|
factory.SetLevel(LevelTrace)
|
||
|
}
|
||
|
if logFile != nil {
|
||
|
if options.Observable {
|
||
|
factory = &observableFactoryWithFile{
|
||
|
ObservableFactory: factory.(ObservableFactory),
|
||
|
file: logFile,
|
||
|
}
|
||
|
} else {
|
||
|
factory = &factoryWithFile{
|
||
|
Factory: factory,
|
||
|
file: logFile,
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
return factory, nil
|
||
|
}
|