-
Notifications
You must be signed in to change notification settings - Fork 4.8k
/
Copy pathfactory.go
89 lines (76 loc) · 1.75 KB
/
factory.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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
package logger
import (
"errors"
"path"
"github.com/goharbor/harbor/src/jobservice/logger/backend"
)
// Factory creates a new logger based on the settings.
type Factory func(options ...OptionItem) (Interface, error)
// FileFactory is factory of file logger
func FileFactory(options ...OptionItem) (Interface, error) {
var (
level, baseDir, fileName string
depth int
)
for _, op := range options {
switch op.Field() {
case "level":
level = op.String()
case "base_dir":
baseDir = op.String()
case "filename":
fileName = op.String()
case "depth":
depth = op.Int()
default:
}
}
if len(baseDir) == 0 {
return nil, errors.New("missing base dir option of the file logger")
}
if len(fileName) == 0 {
return nil, errors.New("missing file name option of the file logger")
}
return backend.NewFileLogger(level, path.Join(baseDir, fileName), depth)
}
// StdFactory is factory of std output logger.
func StdFactory(options ...OptionItem) (Interface, error) {
var (
level, output string
depth int
)
for _, op := range options {
switch op.Field() {
case "level":
level = op.String()
case "output":
output = op.String()
case "depth":
depth = op.Int()
default:
}
}
return backend.NewStdOutputLogger(level, output, depth), nil
}
// DBFactory is factory of file logger
func DBFactory(options ...OptionItem) (Interface, error) {
var (
level, key string
depth int
)
for _, op := range options {
switch op.Field() {
case "level":
level = op.String()
case "key":
key = op.String()
case "depth":
depth = op.Int()
default:
}
}
if len(key) == 0 {
return nil, errors.New("missing key option of the db logger")
}
return backend.NewDBLogger(key, level, depth)
}