go_dreamfactory/modules/timer/caravanrank.go
2023-05-23 17:02:08 +08:00

120 lines
3.3 KiB
Go

package timer
import (
"context"
"go_dreamfactory/comm"
"go_dreamfactory/lego/base"
"go_dreamfactory/lego/core"
"go_dreamfactory/lego/core/cbase"
"go_dreamfactory/lego/sys/log"
"go_dreamfactory/lego/sys/timewheel"
"go_dreamfactory/modules"
"go_dreamfactory/pb"
"go_dreamfactory/sys/configure"
cfg "go_dreamfactory/sys/configure/structs"
"time"
)
// 此组件废弃
type CaravanRank struct {
cbase.ModuleBase
modules.MCompModel
service base.IRPCXService
module *Timer
}
const (
game_global = "game_global.json" //全局配置表
)
//组件初始化接口
func (this *CaravanRank) Init(service core.IService, module core.IModule, comp core.IModuleComp, options core.IModuleOptions) (err error) {
this.TableName = comm.TableCaravan
this.MCompModel.Init(service, module, comp, options)
this.module = module.(*Timer)
this.service = service.(base.IRPCXService)
err = this.LoadConfigure(game_global, cfg.NewGameGlobal)
return
}
func (this *CaravanRank) LoadConfigure(name string, fn interface{}) (err error) {
return configure.RegisterConfigure(name, fn, nil)
}
//读取配置数据
func (this *CaravanRank) GetConfigure(name string) (v interface{}, err error) {
return configure.GetConfigure(name)
}
//全局配置
func (this *CaravanRank) GetGlobalConf() *cfg.GameGlobalData {
var (
configure *cfg.GameGlobal
ok bool
)
if v, err := this.GetConfigure(game_global); err != nil {
log.Errorf("get global conf err:%v", err)
return nil
} else {
if configure, ok = v.(*cfg.GameGlobal); !ok {
log.Errorf("%T no is *cfg.Game_global", v)
return nil
}
}
return configure.GetDataList()[0] // 返回对象信息
}
func (this *CaravanRank) Start() (err error) {
err = this.MCompModel.Start()
opentime := this.service.GetOpentime().Unix()
this.module.Debugf("%d", opentime)
//cron.AddFunc("30 10 1 * * ?", this.TimerSeason)
this.module.Debugf("--%d", time.Now().Unix())
seasonTime := this.GetGlobalConf().BusinessRewardday
if configure.Now().Unix() < opentime { // 开服时间是未来可能存在问题
return
}
subTime := int32(configure.Now().Unix() - opentime)
if subTime < seasonTime {
timewheel.Add(time.Second*time.Duration(subTime), this.TimerSeason, nil)
} else {
s := configure.Now().Unix() - (configure.Now().Unix()-opentime)%int64(subTime) + int64(seasonTime)
timewheel.Add(time.Second*time.Duration(s), this.TimerSeason, nil)
}
return
}
func (this *CaravanRank) TimerSeason(task *timewheel.Task, args ...interface{}) {
this.module.Debugf("==%d", time.Now().Unix())
if _, err := this.service.RpcGo(context.Background(),
comm.Service_Worker,
string(comm.Rpc_ModuleCaravanSettlement),
pb.EmptyReq{},
nil,
); err != nil {
this.module.Errorln(err)
}
// if _data, err := this.DB.Find(comm.TableUser, bson.M{"merchantmoney": bson.M{"$gt": 0}}); err == nil {
// for _data.Next(context.TODO()) {
// temp := &pb.DBUser{}
// if err = _data.Decode(temp); err == nil {
// }
// }
// }
// sTime := time.Now()
// Query := bson.M{}
// Query["merchantmoney"] = 0
// _, err := this.DB.UpdateMany(core.SqlTable(comm.TableUser), bson.M{}, bson.M{"$set": Query}, options.MergeUpdateOptions().SetUpsert(true)) //, new(options.UpdateOptions).SetUpsert(true)
// if err != nil {
// this.module.Errorf("UpdateMany error: %v", err)
// }
// this.module.Debugf("sub time:%d", time.Now().Local().Sub(sTime).Milliseconds())
}