46 lines
942 B
Go
46 lines
942 B
Go
package brokers
|
|
|
|
import (
|
|
"context"
|
|
"encoding/json"
|
|
"gitea.pena/SQuiz/amocrm/internal/models"
|
|
"github.com/twmb/franz-go/pkg/kgo"
|
|
"go.uber.org/zap"
|
|
)
|
|
|
|
type ProducerDeps struct {
|
|
KafkaClient *kgo.Client
|
|
Logger *zap.Logger
|
|
}
|
|
|
|
type Producer struct {
|
|
kafkaClient *kgo.Client
|
|
logger *zap.Logger
|
|
}
|
|
|
|
func NewProducer(deps ProducerDeps) *Producer {
|
|
return &Producer{
|
|
logger: deps.Logger,
|
|
kafkaClient: deps.KafkaClient,
|
|
}
|
|
}
|
|
|
|
func (p *Producer) ToKafkaUpdate(ctx context.Context, message models.KafkaMessage) error {
|
|
bytes, err := json.Marshal(message)
|
|
if err != nil {
|
|
p.logger.Error("error marshal message to kafka", zap.Error(err))
|
|
return err
|
|
}
|
|
|
|
responses := p.kafkaClient.ProduceSync(ctx, &kgo.Record{Value: bytes})
|
|
for _, response := range responses {
|
|
if response.Err != nil {
|
|
p.logger.Error("failed to send message on update kafka", zap.Error(response.Err))
|
|
return response.Err
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
}
|