-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlogger.go
65 lines (55 loc) · 1.42 KB
/
logger.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
package portapps
import (
"fmt"
"os"
"os/signal"
"time"
"github.com/ilya1st/rotatewriter"
"github.com/portapps/portapps/v3/pkg/utl"
"github.com/rs/zerolog"
"github.com/rs/zerolog/log"
"github.com/rs/zerolog/pkgerrors"
"golang.org/x/sys/windows"
)
// InitLogger configures logger
func (app *App) InitLogger() error {
dialogHook := zerolog.HookFunc(func(e *zerolog.Event, level zerolog.Level, msg string) {
if level == zerolog.FatalLevel {
app.ErrorBox(msg)
}
})
if app.config.Common.DisableLog {
log.Logger = zerolog.New(zerolog.Nop()).With().Logger().Hook(dialogHook)
return nil
}
var err error
zerolog.ErrorStackMarshaler = pkgerrors.MarshalStack
logfolder := utl.CreateFolder(utl.PathJoin(app.RootPath, "log"))
logfile := utl.PathJoin(logfolder, fmt.Sprintf("%s.log", app.ID))
app.logfile, err = os.OpenFile(logfile, os.O_WRONLY|os.O_CREATE|os.O_APPEND, 0o644)
if err != nil {
return err
}
rwriter, err := rotatewriter.NewRotateWriter(logfile, 5)
if err != nil {
return err
}
sighupChan := make(chan os.Signal, 1)
signal.Notify(sighupChan, windows.SIGHUP)
go func() {
for {
_, ok := <-sighupChan
if !ok {
return
}
rwriter.Rotate(nil)
}
}()
log.Logger = zerolog.New(zerolog.ConsoleWriter{
Out: rwriter,
TimeFormat: time.RFC1123,
NoColor: true,
}).With().Caller().Timestamp().Logger().Hook(dialogHook)
zerolog.SetGlobalLevel(zerolog.DebugLevel)
return nil
}