/
section.go
44 lines (40 loc) · 1.09 KB
/
section.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
package tyber
import (
"context"
"go.uber.org/zap"
)
func Section(ctx context.Context, logger *zap.Logger, name string) (context.Context, bool, func(error, string, ...StepMutator)) {
ctx, newTrace := ContextWithTraceID(ctx)
if newTrace {
LogTraceStart(ctx, logger, name)
} else {
LogStep(ctx, logger, name)
}
return ctx, newTrace, func(err error, rename string, muts ...StepMutator) {
if err != nil {
errorName := "Error while " + name
if rename != "" {
errorName = rename
}
if newTrace {
_ = LogFatalError(ctx, logger, errorName, err, muts...)
} else {
_ = LogError(ctx, logger, errorName, err, muts...)
}
} else {
successName := name + " succeeded"
if rename != "" {
successName = rename
}
if newTrace {
LogTraceEnd(ctx, logger, successName, muts...)
} else {
LogStep(ctx, logger, successName, muts...)
}
}
}
}
func SimpleSection(ctx context.Context, logger *zap.Logger, name string) func(error, ...StepMutator) {
_, _, end := Section(ctx, logger, name)
return func(err error, muts ...StepMutator) { end(err, "", muts...) }
}