forked from rancher/rancher
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpasswordgetter.go
71 lines (59 loc) · 2.72 KB
/
passwordgetter.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
package passwordgetter
import (
"strings"
passwordutil "github.com/rancher/rancher/pkg/api/store/password"
v1 "github.com/rancher/types/apis/core/v1"
mgmtv3 "github.com/rancher/types/apis/management.cattle.io/v3"
)
const (
passwordSecretPrefix = "cattle-global-data:"
)
func NewPasswordGetter(secrets v1.SecretInterface) *PasswordGetter {
return &PasswordGetter{
secrets: secrets,
}
}
type PasswordGetter struct {
secrets v1.SecretInterface
}
func (p *PasswordGetter) GetPasswordFromSecret(loggingTarget *mgmtv3.LoggingTargets) (err error) {
if loggingTarget.ElasticsearchConfig != nil && loggingTarget.ElasticsearchConfig.AuthPassword != "" && strings.HasPrefix(loggingTarget.ElasticsearchConfig.AuthPassword, passwordSecretPrefix) {
if loggingTarget.ElasticsearchConfig.AuthPassword, err = passwordutil.GetValueForPasswordField(loggingTarget.ElasticsearchConfig.AuthPassword, p.secrets); err != nil {
return
}
}
if loggingTarget.SplunkConfig != nil && loggingTarget.SplunkConfig.Token != "" && strings.HasPrefix(loggingTarget.SplunkConfig.Token, passwordSecretPrefix) {
if loggingTarget.SplunkConfig.Token, err = passwordutil.GetValueForPasswordField(loggingTarget.SplunkConfig.Token, p.secrets); err != nil {
return
}
}
if loggingTarget.KafkaConfig != nil && loggingTarget.KafkaConfig.SaslPassword != "" && strings.HasPrefix(loggingTarget.KafkaConfig.SaslPassword, passwordSecretPrefix) {
if loggingTarget.KafkaConfig.SaslPassword, err = passwordutil.GetValueForPasswordField(loggingTarget.KafkaConfig.SaslPassword, p.secrets); err != nil {
return
}
}
if loggingTarget.SyslogConfig != nil && loggingTarget.SyslogConfig.Token != "" && strings.HasPrefix(loggingTarget.SyslogConfig.Token, passwordSecretPrefix) {
if loggingTarget.SyslogConfig.Token, err = passwordutil.GetValueForPasswordField(loggingTarget.SyslogConfig.Token, p.secrets); err != nil {
return
}
}
if loggingTarget.FluentForwarderConfig != nil && len(loggingTarget.FluentForwarderConfig.FluentServers) != 0 {
var newFluentdServers []mgmtv3.FluentServer
for _, server := range loggingTarget.FluentForwarderConfig.FluentServers {
newServer := server
if server.SharedKey != "" && strings.HasPrefix(server.SharedKey, passwordSecretPrefix) {
if newServer.SharedKey, err = passwordutil.GetValueForPasswordField(server.SharedKey, p.secrets); err != nil {
return
}
}
if server.Password != "" && strings.HasPrefix(server.Password, passwordSecretPrefix) {
if newServer.Password, err = passwordutil.GetValueForPasswordField(server.Password, p.secrets); err != nil {
return
}
}
newFluentdServers = append(newFluentdServers, newServer)
}
loggingTarget.FluentForwarderConfig.FluentServers = newFluentdServers
}
return
}