-
-
Notifications
You must be signed in to change notification settings - Fork 180
Expand file tree
/
Copy pathkafka.go
More file actions
40 lines (33 loc) · 1.18 KB
/
kafka.go
File metadata and controls
40 lines (33 loc) · 1.18 KB
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
package main
import (
cmdinternal "github.com/MarioCarrion/todo-api/cmd/internal"
"github.com/MarioCarrion/todo-api/internal"
"github.com/MarioCarrion/todo-api/internal/envvar"
"github.com/MarioCarrion/todo-api/internal/kafka"
"github.com/MarioCarrion/todo-api/internal/service"
)
// KafkaMessageBroker represents Kafka as a Message Broker.
type KafkaMessageBroker struct {
producer *cmdinternal.KafkaProducer
publisher service.TaskMessageBrokerPublisher
}
// NewMessageBrokerPublisher initializes a new Kafka Broker.
func NewMessageBrokerPublisher(conf *envvar.Configuration) (MessageBrokerPublisher, error) { //nolint: ireturn
producer, err := cmdinternal.NewKafkaProducer(conf)
if err != nil {
return nil, internal.WrapErrorf(err, internal.ErrorCodeUnknown, "internal.NewKafkaProducer")
}
return &KafkaMessageBroker{
producer: producer,
publisher: kafka.NewTask(producer.Producer, producer.Topic),
}, nil
}
// Publisher returns the Kafka broker.
func (m *KafkaMessageBroker) Publisher() service.TaskMessageBrokerPublisher { //nolint: ireturn
return m.publisher
}
// Close closes the broker.
func (m *KafkaMessageBroker) Close() error {
m.producer.Producer.Close()
return nil
}