45 lines
994 B
Go
45 lines
994 B
Go
package mq
|
|
|
|
import (
|
|
"encoding/json"
|
|
"mongo.games.com/game/dbproxy/svc"
|
|
"mongo.games.com/game/model"
|
|
"mongo.games.com/game/mq"
|
|
"mongo.games.com/goserver/core/broker"
|
|
"mongo.games.com/goserver/core/broker/rabbitmq"
|
|
"mongo.games.com/goserver/core/logger"
|
|
)
|
|
|
|
func init() {
|
|
mq.RegisterSubscriber(model.GameDetailedLogCollName, func(e broker.Event) (err error) {
|
|
msg := e.Message()
|
|
if msg != nil {
|
|
defer func() {
|
|
if err != nil {
|
|
mq.BackUp(e, err)
|
|
}
|
|
|
|
e.Ack()
|
|
|
|
recover()
|
|
}()
|
|
|
|
var log model.GameDetailedLog
|
|
err = json.Unmarshal(msg.Body, &log)
|
|
if err != nil {
|
|
return
|
|
}
|
|
logger.Logger.Tracef("mq receive GameDetailedLog:%v", log)
|
|
c := svc.GameDetailedLogsCollection(log.Platform)
|
|
if c != nil {
|
|
err = c.Insert(log)
|
|
if err != nil {
|
|
logger.Logger.Tracef("c.Insert(log) err:%v", err.Error())
|
|
}
|
|
}
|
|
return
|
|
}
|
|
return nil
|
|
}, broker.Queue(model.GameDetailedLogCollName), broker.DisableAutoAck(), rabbitmq.DurableQueue())
|
|
}
|