-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreader.go
83 lines (78 loc) · 2.27 KB
/
reader.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
package kafka
import (
"context"
"crypto/tls"
"github.com/segmentio/kafka-go"
"github.com/segmentio/kafka-go/sasl/scram"
"time"
)
type Reader struct {
Reader *kafka.Reader
LogError func(ctx context.Context, msg string)
AckOnConsume bool
Key string
}
func NewReader(reader *kafka.Reader, logError func(ctx context.Context, msg string), ackOnConsume bool, key string) (*Reader, error) {
return &Reader{Reader: reader, LogError: logError, AckOnConsume: ackOnConsume, Key: key}, nil
}
func NewReaderByConfig(c ReaderConfig, logError func(ctx context.Context, msg string), ackOnConsume bool) (*Reader, error) {
if c.Client.Timeout <= 0 {
c.Client.Timeout = 30
}
dialer := GetDialer(c.Client.Username, c.Client.Password, scram.SHA512, &kafka.Dialer{
Timeout: time.Duration(c.Client.Timeout) * time.Second,
DualStack: true,
TLS: &tls.Config{},
})
reader := NewKafkaReader(c, dialer)
return NewReader(reader, logError, ackOnConsume, c.Key)
}
func (c *Reader) Read(ctx context.Context, handle func(context.Context, []byte, map[string]string)) {
for {
msg, err := c.Reader.FetchMessage(ctx)
if err != nil {
c.LogError(ctx, "Error when read: "+err.Error())
} else {
attributes := HeaderToMap(msg.Headers)
if len(c.Key) > 0 && msg.Key != nil {
ctx = context.WithValue(ctx, c.Key, string(msg.Key))
}
if c.AckOnConsume {
c.Reader.CommitMessages(ctx, msg)
}
handle(ctx, msg.Value, attributes)
}
}
}
func (c *Reader) ReadValue(ctx context.Context, handle func(context.Context, []byte)) {
for {
msg, err := c.Reader.FetchMessage(ctx)
if err != nil {
c.LogError(ctx, "Error when read: "+err.Error())
} else {
if len(c.Key) > 0 && msg.Key != nil {
ctx = context.WithValue(ctx, c.Key, string(msg.Key))
}
if c.AckOnConsume {
c.Reader.CommitMessages(ctx, msg)
}
handle(ctx, msg.Value)
}
}
}
func (c *Reader) ReadMessage(ctx context.Context, handle func(context.Context, kafka.Message)) {
for {
msg, err := c.Reader.FetchMessage(ctx)
if err != nil {
c.LogError(ctx, "Error when read: "+err.Error())
} else {
if len(c.Key) > 0 && msg.Key != nil {
ctx = context.WithValue(ctx, c.Key, string(msg.Key))
}
if c.AckOnConsume {
c.Reader.CommitMessages(ctx, msg)
}
handle(ctx, msg)
}
}
}