package port import ( "gitea.dwysokinski.me/twhelp/corev3/internal/app" "gitea.dwysokinski.me/twhelp/corev3/internal/domain" "gitea.dwysokinski.me/twhelp/corev3/internal/watermillmsg" "github.com/ThreeDotsLabs/watermill" "github.com/ThreeDotsLabs/watermill/message" ) type ServerWatermillConsumer struct { svc *app.ServerService subscriber message.Subscriber logger watermill.LoggerAdapter marshaler watermillmsg.Marshaler cmdSyncTopic string } func NewServerWatermillConsumer( svc *app.ServerService, subscriber message.Subscriber, logger watermill.LoggerAdapter, marshaler watermillmsg.Marshaler, cmdSyncTopic string, ) *ServerWatermillConsumer { return &ServerWatermillConsumer{ svc: svc, subscriber: subscriber, logger: logger, marshaler: marshaler, cmdSyncTopic: cmdSyncTopic, } } func (c *ServerWatermillConsumer) Register(router *message.Router) { router.AddNoPublisherHandler("ServerConsumer.sync", c.cmdSyncTopic, c.subscriber, c.sync) } func (c *ServerWatermillConsumer) sync(msg *message.Message) error { var rawPayload watermillmsg.SyncServersCmdPayload if err := c.marshaler.Unmarshal(msg, &rawPayload); err != nil { c.logger.Error("couldn't unmarshal payload", err, watermill.LogFields{ "handler": message.HandlerNameFromCtx(msg.Context()), }) return nil } payload, err := domain.NewSyncServersCmdPayloadWithStringURL(rawPayload.VersionCode, rawPayload.URL) if err != nil { c.logger.Error("couldn't construct domain.SyncServersCmdPayload", err, watermill.LogFields{ "handler": message.HandlerNameFromCtx(msg.Context()), }) return nil } return c.svc.Sync(msg.Context(), payload) }