package svc import ( "errors" "net/rpc" "time" "github.com/globalsign/mgo" "github.com/globalsign/mgo/bson" "mongo.games.com/game/dbproxy/mongo" "mongo.games.com/game/model" "mongo.games.com/goserver/core/logger" ) var ( MatchLogDBErr = errors.New("log_matchlog db open failed.") ) func MatchLogCollection(plt string) *mongo.Collection { s := mongo.MgoSessionMgrSington.GetPltMgoSession(plt, model.MatchLogDBName) if s != nil { c, first := s.DB().C(model.MatchLogCollName) if first { c.EnsureIndex(mgo.Index{Key: []string{"gamefreeid"}, Background: true, Sparse: true}) c.EnsureIndex(mgo.Index{Key: []string{"matchid"}, Background: true, Sparse: true}) c.EnsureIndex(mgo.Index{Key: []string{"starttime"}, Background: true, Sparse: true}) c.EnsureIndex(mgo.Index{Key: []string{"endtime"}, Background: true, Sparse: true}) } return c } return nil } func InsertMatchLogs(logs ...*model.MatchLog) (err error) { clog := MatchLogCollection(logs[0].Platform) if clog == nil { return } switch len(logs) { case 0: return errors.New("no data") case 1: err = clog.Insert(logs[0]) default: docs := make([]interface{}, 0, len(logs)) for _, log := range logs { docs = append(docs, log) } err = clog.Insert(docs...) } if err != nil { logger.Logger.Warn("InsertMatchLogs error:", err) return } return } func RemoveMatchLogs(plt string, ts time.Time) (*mgo.ChangeInfo, error) { return MatchLogCollection(plt).RemoveAll(bson.M{"endtime": bson.M{"$lt": ts}}) } type MatchLogSvc struct { } func (svc *MatchLogSvc) InsertMatchLogs(args []*model.MatchLog, ret *bool) (err error) { err = InsertMatchLogs(args...) if err == nil { *ret = true } return } func (svc *MatchLogSvc) RemoveMatchLogs(args *model.RemoveMatchLogsArgs, ret **mgo.ChangeInfo) (err error) { *ret, err = RemoveMatchLogs(args.Plt, args.Ts) return } func init() { rpc.Register(new(MatchLogSvc)) }