forked from kubemq-io/kubemq-sources
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathoptions.go
89 lines (82 loc) · 2.28 KB
/
options.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 kafka
import (
"fmt"
"strings"
kafka "github.com/Shopify/sarama"
"github.com/kubemq-io/kubemq-sources/config"
)
type options struct {
brokers []string
topics []string
consumerGroup string
saslUsername string
saslPassword string
saslMechanism string
securityProtocol string
cacert string
clientCert string
clientKey string
insecure bool
dynamicMapping bool
}
func parseOptions(cfg config.Spec) (options, error) {
m := options{}
var err error
m.consumerGroup, err = cfg.Properties.MustParseString("consumer_group")
if err != nil {
return m, err
}
m.brokers, err = cfg.Properties.MustParseStringList("brokers")
if err != nil {
return m, err
}
m.topics, err = cfg.Properties.MustParseStringList("topics")
if err != nil {
return m, err
}
m.saslUsername = cfg.Properties.ParseString("sasl_username", "")
m.saslPassword = cfg.Properties.ParseString("sasl_password", "")
m.saslMechanism = cfg.Properties.ParseString("sasl_mechanism", "")
m.consumerGroup = cfg.Properties.ParseString("consumer_group", "")
m.cacert = cfg.Properties.ParseString("ca_cert", "")
m.clientCert = cfg.Properties.ParseString("client_certificate", "")
m.clientKey = cfg.Properties.ParseString("client_key", "")
m.insecure = cfg.Properties.ParseBool("insecure", false)
m.dynamicMapping, err = cfg.Properties.MustParseBool("dynamic_mapping")
if err != nil {
return options{}, fmt.Errorf("error parsing dynamic_mapping, %w", err)
}
return m, nil
}
func (m *options) parseASLMechanism() kafka.SASLMechanism {
switch strings.ToLower(m.saslMechanism) {
case "plain":
return kafka.SASLTypePlaintext
case "scram-sha-256":
return kafka.SASLTypeSCRAMSHA256
case "scram-sha-512":
return kafka.SASLTypeSCRAMSHA512
case "gssapi", "gss-api", "gss_api":
return kafka.SASLTypeGSSAPI
case "oauth", "0auth bearer":
return kafka.SASLTypeOAuth
case "external", "ext":
return kafka.SASLExtKeyAuth
default:
return kafka.SASLTypePlaintext
}
}
func (m *options) parseSecurityProtocol() (bool, bool) {
switch strings.ToLower(m.securityProtocol) {
case "plaintext":
return false, false
case "ssl":
return true, false
case "sasl_plaintext":
return false, true
case "sasl_ssl":
return true, true
default:
return false, false
}
}