This repository was archived by the owner on Apr 5, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathscripting.go
61 lines (58 loc) · 1.73 KB
/
scripting.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
package metrics
import (
"github.com/ydb-platform/ydb-go-sdk/v3/trace"
"github.com/ydb-platform/ydb-go-sdk-metrics/internal/labels"
"github.com/ydb-platform/ydb-go-sdk-metrics/internal/scope"
"github.com/ydb-platform/ydb-go-sdk-metrics/internal/scope/config"
"github.com/ydb-platform/ydb-go-sdk-metrics/registry"
)
func Scripting(c registry.Config) (t trace.Scripting) {
if c.Details()&trace.ScriptingEvents == 0 {
return t
}
c = c.WithSystem("scripting")
execute := scope.New(c, "execute", config.New())
explain := scope.New(c, "explain", config.New())
streamExecute := scope.New(c.WithSystem("stream"), "execute", config.New(), labels.TagStage)
t.OnExecute = func(info trace.ScriptingExecuteStartInfo) func(trace.ScriptingExecuteDoneInfo) {
start := execute.Start()
return func(info trace.ScriptingExecuteDoneInfo) {
start.Sync(info.Error)
}
}
t.OnExplain = func(info trace.ScriptingExplainStartInfo) func(trace.ScriptingExplainDoneInfo) {
start := explain.Start()
return func(info trace.ScriptingExplainDoneInfo) {
start.Sync(info.Error)
}
}
t.OnStreamExecute = func(
info trace.ScriptingStreamExecuteStartInfo,
) func(
trace.ScriptingStreamExecuteIntermediateInfo,
) func(
trace.ScriptingStreamExecuteDoneInfo,
) {
start := streamExecute.Start(labels.Label{
Tag: labels.TagStage,
Value: "init",
})
return func(
info trace.ScriptingStreamExecuteIntermediateInfo,
) func(
trace.ScriptingStreamExecuteDoneInfo,
) {
start.Sync(info.Error, labels.Label{
Tag: labels.TagStage,
Value: "intermediate",
})
return func(info trace.ScriptingStreamExecuteDoneInfo) {
start.Sync(info.Error, labels.Label{
Tag: labels.TagStage,
Value: "finish",
})
}
}
}
return t
}