natsio/jetstream_pubsub.go

66 lines
1.7 KiB
Go
Raw Normal View History

2021-12-02 03:29:52 +00:00
package natsio
import (
"errors"
"fmt"
"github.com/nats-io/nats.go"
)
// Publish ...
func (js JetStream) Publish(stream, subject string, payload []byte) error {
channel := combineStreamAndSubjectName(stream, subject)
_, err := js.instance.PublishAsync(channel, payload)
if err != nil {
2022-03-18 03:06:11 +00:00
msg := fmt.Sprintf("[NATS JETSTREAM] - publish message to subject #%s error: %s", channel, err.Error())
2021-12-02 03:29:52 +00:00
return errors.New(msg)
}
return nil
}
// Subscribe ...
func (js JetStream) Subscribe(stream, subject string, cb nats.MsgHandler) (*nats.Subscription, error) {
channel := combineStreamAndSubjectName(stream, subject)
sub, err := js.instance.Subscribe(channel, cb)
if err != nil {
msg := fmt.Sprintf("[NATS JETSTREAM] - subscribe subject %s error: %s", channel, err.Error())
return nil, errors.New(msg)
}
return sub, nil
}
2022-03-18 03:06:11 +00:00
// PullSubscribe ...
//
// Example:
//
2022-03-18 03:27:40 +00:00
// js := natsio.GetJetStream()
//
2022-03-18 04:19:01 +00:00
// sub, err := js.PullSubscribe("A_SUBJECT", "A_SUBJECT", "A_CONSUMER")
2022-03-18 03:06:11 +00:00
//
// for {
// messages, err := sub.Fetch(10)
// // process each messages
// }
//
2022-03-18 04:19:01 +00:00
func (js JetStream) PullSubscribe(stream, subject, consumer string) (*nats.Subscription, error) {
2022-03-18 04:03:15 +00:00
channel := combineStreamAndSubjectName(stream, subject)
2022-03-18 03:49:07 +00:00
// Check if consumer existed
2022-03-18 04:19:01 +00:00
con, err := js.GetConsumerInfo(stream, consumer)
if con == nil || err != nil {
msg := fmt.Sprintf("[NATS JETSTREAM] - pull subscribe consumer %s not existed in stream %s", consumer, stream)
return nil, errors.New(msg)
2022-03-18 03:55:13 +00:00
}
2022-03-18 03:49:07 +00:00
2022-03-18 04:19:01 +00:00
// Pull
sub, err := js.instance.PullSubscribe(channel, consumer)
2022-03-18 03:06:11 +00:00
if err != nil {
2022-03-18 04:19:01 +00:00
msg := fmt.Sprintf("[NATS JETSTREAM] - pull subscribe subject #%s - consumer #%s error: %s", channel, consumer, err.Error())
2022-03-18 03:06:11 +00:00
return nil, errors.New(msg)
}
return sub, nil
}