forked from DataDog/datadog-agent
-
Notifications
You must be signed in to change notification settings - Fork 1
/
stats.go
78 lines (61 loc) · 2.05 KB
/
stats.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
// Unless explicitly stated otherwise all files in this repository are licensed
// under the Apache License Version 2.0.
// This product includes software developed at Datadog (https://www.datadoghq.com/).
// Copyright 2016-present Datadog, Inc.
package collector
import (
"sync"
"github.com/DataDog/datadog-agent/pkg/collector/check"
)
// collectorErrors holds the error objects
type collectorErrors struct {
loader map[string]map[string]string // check Name -> loader -> error
run map[check.ID]string // check ID -> error
m sync.RWMutex
}
// newCollectorErrors returns an instance holding autoconfig errors stats
func newCollectorErrors() *collectorErrors {
return &collectorErrors{
loader: make(map[string]map[string]string),
run: make(map[check.ID]string),
}
}
// setLoaderError will safely set the error for that check and loader to the LoaderErrorStats
func (ce *collectorErrors) setLoaderError(checkName string, loaderName string, err string) {
_, found := ce.loader[checkName]
if !found {
ce.loader[checkName] = make(map[string]string)
}
ce.loader[checkName][loaderName] = err
}
// removeLoaderErrors removes the errors for a check (usually when successfully loaded)
func (ce *collectorErrors) removeLoaderErrors(checkName string) {
delete(ce.loader, checkName)
}
// GetLoaderErrors will safely get the errors regarding loaders
func (ce *collectorErrors) getLoaderErrors() map[string]map[string]string {
ce.m.RLock()
defer ce.m.RUnlock()
errorsCopy := make(map[string]map[string]string)
for check, loaderErrors := range ce.loader {
errorsCopy[check] = make(map[string]string)
for loader, loaderError := range loaderErrors {
errorsCopy[check][loader] = loaderError
}
}
return errorsCopy
}
func (ce *collectorErrors) setRunError(checkID check.ID, err string) {
ce.m.Lock()
defer ce.m.Unlock()
ce.run[checkID] = err
}
func (ce *collectorErrors) getRunErrors() map[check.ID]string {
ce.m.RLock()
defer ce.m.RUnlock()
runCopy := make(map[check.ID]string)
for k, v := range ce.run {
runCopy[k] = v
}
return runCopy
}