assign stream name to config

This commit is contained in:
Nam Huynh 2022-12-04 22:10:05 +07:00
parent a94138e574
commit b3519790e2
6 changed files with 40 additions and 35 deletions

View File

@ -18,6 +18,9 @@ type Config struct {
// RequestTimeout // RequestTimeout
RequestTimeout time.Duration RequestTimeout time.Duration
// Stream name
StreamName string
} }
// TLSConfig ... // TLSConfig ...

View File

@ -8,27 +8,27 @@ import (
) )
// GetConsumerInfo ... // GetConsumerInfo ...
func (js JetStream) GetConsumerInfo(stream, name string) (*nats.ConsumerInfo, error) { func (js JetStream) GetConsumerInfo(name string) (*nats.ConsumerInfo, error) {
return js.instance.ConsumerInfo(stream, name) return js.instance.ConsumerInfo(js.streamName, name)
} }
// AddConsumer ... // AddConsumer ...
func (js JetStream) AddConsumer(stream, name, filterSubject string) error { func (js JetStream) AddConsumer(name, filterSubject string) error {
// Get consumer first, return if existed // Get consumer first, return if existed
consumer, _ := js.GetConsumerInfo(stream, name) consumer, _ := js.GetConsumerInfo(name)
if consumer != nil { if consumer != nil {
return nil return nil
} }
// Add // Add
_, err := js.instance.AddConsumer(stream, &nats.ConsumerConfig{ _, err := js.instance.AddConsumer(js.streamName, &nats.ConsumerConfig{
Durable: name, Durable: name,
AckPolicy: nats.AckExplicitPolicy, AckPolicy: nats.AckExplicitPolicy,
FilterSubject: filterSubject, FilterSubject: filterSubject,
}) })
if err != nil { if err != nil {
msg := fmt.Sprintf("[NATS JETSTREAM] - add consumer %s for stream #%s error: %s", name, stream, err.Error()) msg := fmt.Sprintf("[NATS JETSTREAM] - add consumer %s for stream #%s error: %s", name, js.streamName, err.Error())
return errors.New(msg) return errors.New(msg)
} }
return nil return nil

View File

@ -8,8 +8,8 @@ import (
) )
// Publish ... // Publish ...
func (js JetStream) Publish(stream, subject string, payload []byte) error { func (js JetStream) Publish(subject string, payload []byte) error {
channel := combineStreamAndSubjectName(stream, subject) channel := combineStreamAndSubjectName(js.streamName, subject)
_, err := js.instance.PublishAsync(channel, payload) _, err := js.instance.PublishAsync(channel, payload)
if err != nil { if err != nil {
@ -20,8 +20,8 @@ func (js JetStream) Publish(stream, subject string, payload []byte) error {
} }
// Subscribe ... // Subscribe ...
func (js JetStream) Subscribe(stream, subject string, cb nats.MsgHandler) (*nats.Subscription, error) { func (js JetStream) Subscribe(subject string, cb nats.MsgHandler) (*nats.Subscription, error) {
channel := combineStreamAndSubjectName(stream, subject) channel := combineStreamAndSubjectName(js.streamName, subject)
sub, err := js.instance.Subscribe(channel, cb) sub, err := js.instance.Subscribe(channel, cb)
if err != nil { if err != nil {
@ -39,18 +39,17 @@ func (js JetStream) Subscribe(stream, subject string, cb nats.MsgHandler) (*nats
// //
// sub, err := js.PullSubscribe("A_SUBJECT", "A_SUBJECT", "A_CONSUMER") // sub, err := js.PullSubscribe("A_SUBJECT", "A_SUBJECT", "A_CONSUMER")
// //
// for { // for {
// messages, err := sub.Fetch(10) // messages, err := sub.Fetch(10)
// // process each messages // // process each messages
// } // }
// func (js JetStream) PullSubscribe(subject, consumer string) (*nats.Subscription, error) {
func (js JetStream) PullSubscribe(stream, subject, consumer string) (*nats.Subscription, error) { channel := combineStreamAndSubjectName(js.streamName, subject)
channel := combineStreamAndSubjectName(stream, subject)
// Check if consumer existed // Check if consumer existed
con, err := js.GetConsumerInfo(stream, consumer) con, err := js.GetConsumerInfo(consumer)
if con == nil || err != nil { if con == nil || err != nil {
msg := fmt.Sprintf("[NATS JETSTREAM] - pull subscribe consumer %s not existed in stream %s", consumer, stream) msg := fmt.Sprintf("[NATS JETSTREAM] - pull subscribe consumer %s not existed in stream %s", consumer, js.streamName)
return nil, errors.New(msg) return nil, errors.New(msg)
} }

View File

@ -8,8 +8,8 @@ import (
) )
// QueueSubscribe ... // QueueSubscribe ...
func (js JetStream) QueueSubscribe(stream, subject, queueName string, cb nats.MsgHandler) error { func (js JetStream) QueueSubscribe(subject, queueName string, cb nats.MsgHandler) error {
channel := combineStreamAndSubjectName(stream, subject) channel := combineStreamAndSubjectName(js.streamName, subject)
_, err := js.instance.QueueSubscribe(channel, queueName, cb) _, err := js.instance.QueueSubscribe(channel, queueName, cb)
if err != nil { if err != nil {

View File

@ -21,21 +21,21 @@ func generateStreamConfig(stream string, subjects []string) *nats.StreamConfig {
} }
// GetStreamInfo ... // GetStreamInfo ...
func (js JetStream) GetStreamInfo(name string) (*nats.StreamInfo, error) { func (js JetStream) GetStreamInfo() (*nats.StreamInfo, error) {
return js.instance.StreamInfo(name) return js.instance.StreamInfo(js.streamName)
} }
// AddStream add new stream, with default config // AddStream add new stream, with default config
// Due to subject must have a unique name, subject name will be combined with stream name // Due to subject must have a unique name, subject name will be combined with stream name
// E.g: stream name is "DEMO", subject name is "Subject-1", so final name in NATS will be: DEMO.Subject-1 // E.g: stream name is "DEMO", subject name is "Subject-1", so final name in NATS will be: DEMO.Subject-1
func (js JetStream) AddStream(name string, subjects []string) error { func (js JetStream) AddStream(subjects []string) error {
// Get info about the stream // Get info about the stream
stream, _ := js.GetStreamInfo(name) stream, _ := js.GetStreamInfo()
// If stream not found, create new // If stream not found, create new
if stream == nil { if stream == nil {
subjectNames := generateSubjectNames(name, subjects) subjectNames := generateSubjectNames(js.streamName, subjects)
_, err := js.instance.AddStream(generateStreamConfig(name, subjectNames)) _, err := js.instance.AddStream(generateStreamConfig(js.streamName, subjectNames))
if err != nil { if err != nil {
msg := fmt.Sprintf("[NATS JETSTREAM] - add stream error: %s", err.Error()) msg := fmt.Sprintf("[NATS JETSTREAM] - add stream error: %s", err.Error())
return errors.New(msg) return errors.New(msg)
@ -46,8 +46,8 @@ func (js JetStream) AddStream(name string, subjects []string) error {
} }
// DeleteStream ... // DeleteStream ...
func (js JetStream) DeleteStream(name string) error { func (js JetStream) DeleteStream() error {
if err := js.instance.DeleteStream(name); err != nil { if err := js.instance.DeleteStream(js.streamName); err != nil {
msg := fmt.Sprintf("[NATS JETSTREAM] - delete stream error: %s", err.Error()) msg := fmt.Sprintf("[NATS JETSTREAM] - delete stream error: %s", err.Error())
return errors.New(msg) return errors.New(msg)
} }
@ -55,19 +55,19 @@ func (js JetStream) DeleteStream(name string) error {
} }
// AddStreamSubjects ... // AddStreamSubjects ...
func (js JetStream) AddStreamSubjects(name string, subjects []string) error { func (js JetStream) AddStreamSubjects(subjects []string) error {
// Get info about the stream // Get info about the stream
stream, _ := js.GetStreamInfo(name) stream, _ := js.GetStreamInfo()
if stream == nil { if stream == nil {
msg := fmt.Sprintf("[NATS JETSTREAM] - error when adding stream %s subjects: stream not found", name) msg := fmt.Sprintf("[NATS JETSTREAM] - error when adding stream %s subjects: stream not found", js.streamName)
return errors.New(msg) return errors.New(msg)
} }
// Merge current and new subjects // Merge current and new subjects
subjectNames := generateSubjectNames(name, subjects) subjectNames := generateSubjectNames(js.streamName, subjects)
newSubjects := mergeAndUniqueArrayStrings(subjectNames, stream.Config.Subjects) newSubjects := mergeAndUniqueArrayStrings(subjectNames, stream.Config.Subjects)
_, err := js.instance.UpdateStream(generateStreamConfig(name, newSubjects)) _, err := js.instance.UpdateStream(generateStreamConfig(js.streamName, newSubjects))
if err != nil { if err != nil {
msg := fmt.Sprintf("[NATS JETSTREAM] - add stream error: %s", err.Error()) msg := fmt.Sprintf("[NATS JETSTREAM] - add stream error: %s", err.Error())
return errors.New(msg) return errors.New(msg)

View File

@ -3,6 +3,7 @@ package natsio
import ( import (
"errors" "errors"
"fmt" "fmt"
"github.com/nats-io/nats.go" "github.com/nats-io/nats.go"
) )
@ -14,7 +15,8 @@ type Server struct {
// JetStream ... // JetStream ...
type JetStream struct { type JetStream struct {
instance nats.JetStreamContext instance nats.JetStreamContext
streamName string
} }
var ( var (
@ -61,6 +63,7 @@ func Connect(cfg Config) error {
return errors.New(msg) return errors.New(msg)
} }
natsJetStream.instance = js natsJetStream.instance = js
natsJetStream.streamName = cfg.StreamName
return nil return nil
} }