wormhole-explorer/parser/consumer/consumer.go

48 lines
1.1 KiB
Go

package consumer
import (
"context"
"github.com/wormhole-foundation/wormhole-explorer/parser/processor"
"github.com/wormhole-foundation/wormhole-explorer/parser/queue"
"go.uber.org/zap"
)
// Consumer consumer struct definition.
type Consumer struct {
consume queue.VAAConsumeFunc
process processor.ProcessorFunc
logger *zap.Logger
}
// New creates a new vaa consumer.
func New(consume queue.VAAConsumeFunc, process processor.ProcessorFunc, logger *zap.Logger) *Consumer {
return &Consumer{consume: consume, process: process, logger: logger}
}
// Start consumes messages from VAA queue, parse and store those messages in a repository.
func (c *Consumer) Start(ctx context.Context) {
go func() {
for msg := range c.consume(ctx) {
event := msg.Data()
// check id message is expired.
if msg.IsExpired() {
c.logger.Warn("Message with vaa expired", zap.String("id", event.ID))
msg.Failed()
continue
}
_, err := c.process(ctx, event.Vaa)
if err != nil {
c.logger.Error("Error processing parsed vaa",
zap.String("id", event.ID),
zap.Error(err))
msg.Failed()
continue
}
msg.Done()
}
}()
}