forked from redpanda-data/connect
-
Notifications
You must be signed in to change notification settings - Fork 0
/
nats_jetstream.go
34 lines (31 loc) · 1.15 KB
/
nats_jetstream.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
package input
import (
"github.com/dafanshu/benthos/v3/internal/impl/nats/auth"
"github.com/dafanshu/benthos/v3/lib/util/tls"
"github.com/nats-io/nats.go"
)
// NATSJetStreamConfig contains configuration fields for the NATS Jetstream
// input type.
type NATSJetStreamConfig struct {
URLs []string `json:"urls" yaml:"urls"`
Subject string `json:"subject" yaml:"subject"`
Queue string `json:"queue" yaml:"queue"`
Durable string `json:"durable" yaml:"durable"`
Deliver string `json:"deliver" yaml:"deliver"`
AckWait string `json:"ack_wait" yaml:"ack_wait"`
MaxAckPending int `json:"max_ack_pending" yaml:"max_ack_pending"`
TLS tls.Config `json:"tls" yaml:"tls"`
Auth auth.Config `json:"auth" yaml:"auth"`
}
// NewNATSJetStreamConfig creates a new NATSJetstreamConfig with default values.
func NewNATSJetStreamConfig() NATSJetStreamConfig {
return NATSJetStreamConfig{
URLs: []string{nats.DefaultURL},
Subject: "",
AckWait: "30s",
MaxAckPending: 1024,
Deliver: "all",
TLS: tls.NewConfig(),
Auth: auth.New(),
}
}