特权每日邮件
This commit is contained in:
parent
758d91b356
commit
cccc4821f0
@ -238,6 +238,8 @@ type (
|
|||||||
// 续费特权卡
|
// 续费特权卡
|
||||||
RenewPrivilegeCard(session IUserSession, cId string) (res []*pb.UserAssets, code pb.ErrorCode)
|
RenewPrivilegeCard(session IUserSession, cId string) (res []*pb.UserAssets, code pb.ErrorCode)
|
||||||
// 检查特权
|
// 检查特权
|
||||||
CheckPrivilege(session IUserSession)
|
CheckPrivilege(session IUserSession, cId string) (privilege *pb.DBPrivilege)
|
||||||
|
// 查询玩家当前所有特权 返回特权id
|
||||||
|
QueryPrivilege(session IUserSession) (privilegeID []int32)
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
@ -3,11 +3,13 @@ package privilege
|
|||||||
import (
|
import (
|
||||||
"go_dreamfactory/comm"
|
"go_dreamfactory/comm"
|
||||||
"go_dreamfactory/lego/core"
|
"go_dreamfactory/lego/core"
|
||||||
|
"go_dreamfactory/lego/sys/event"
|
||||||
"go_dreamfactory/modules"
|
"go_dreamfactory/modules"
|
||||||
"go_dreamfactory/pb"
|
"go_dreamfactory/pb"
|
||||||
"go_dreamfactory/sys/configure"
|
"go_dreamfactory/sys/configure"
|
||||||
cfg "go_dreamfactory/sys/configure/structs"
|
cfg "go_dreamfactory/sys/configure/structs"
|
||||||
"go_dreamfactory/sys/db"
|
"go_dreamfactory/sys/db"
|
||||||
|
"go_dreamfactory/utils"
|
||||||
|
|
||||||
"go.mongodb.org/mongo-driver/bson/primitive"
|
"go.mongodb.org/mongo-driver/bson/primitive"
|
||||||
)
|
)
|
||||||
@ -22,6 +24,8 @@ type Privilege struct {
|
|||||||
api_comp *apiComp
|
api_comp *apiComp
|
||||||
configure *configureComp
|
configure *configureComp
|
||||||
modelPrivilege *ModelPrivilege
|
modelPrivilege *ModelPrivilege
|
||||||
|
mail comm.Imail
|
||||||
|
service core.IService
|
||||||
}
|
}
|
||||||
|
|
||||||
//模块名
|
//模块名
|
||||||
@ -43,6 +47,17 @@ func (this *Privilege) OnInstallComp() {
|
|||||||
this.configure = this.RegisterComp(new(configureComp)).(*configureComp)
|
this.configure = this.RegisterComp(new(configureComp)).(*configureComp)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (this *Privilege) Start() (err error) {
|
||||||
|
var module core.IModule
|
||||||
|
if module, err = this.service.GetModule(comm.ModuleMail); err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
this.mail = module.(comm.Imail)
|
||||||
|
err = this.ModuleBase.Start()
|
||||||
|
event.RegisterGO(comm.EventUserOffline, this.EventUserOffline)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
//Event------------------------------------------------------------------------------------------------------------
|
//Event------------------------------------------------------------------------------------------------------------
|
||||||
func (this *Privilege) EventUserOffline(session comm.IUserSession) {
|
func (this *Privilege) EventUserOffline(session comm.IUserSession) {
|
||||||
this.modelPrivilege.DelByUId(session.GetUserId(), db.SetDBMgoLog(false))
|
this.modelPrivilege.DelByUId(session.GetUserId(), db.SetDBMgoLog(false))
|
||||||
@ -127,7 +142,7 @@ func (this *Privilege) RenewPrivilegeCard(session comm.IUserSession, cId string)
|
|||||||
atn := &pb.UserAssets{
|
atn := &pb.UserAssets{
|
||||||
A: "vip",
|
A: "vip",
|
||||||
T: "",
|
T: "",
|
||||||
N: 1,
|
N: 1, // 暂时只支持一次续费一次
|
||||||
}
|
}
|
||||||
list, err := this.modelPrivilege.getPrivilegeList(session.GetUserId())
|
list, err := this.modelPrivilege.getPrivilegeList(session.GetUserId())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -169,18 +184,94 @@ func (this *Privilege) RenewPrivilegeCard(session comm.IUserSession, cId string)
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// 清除到期的特权
|
// 查询特权特权
|
||||||
func (this *Privilege) CheckPrivilege(session comm.IUserSession) {
|
func (this *Privilege) CheckPrivilege(session comm.IUserSession, cId string) (privilege *pb.DBPrivilege) {
|
||||||
list, err := this.modelPrivilege.getPrivilegeList(session.GetUserId())
|
list, err := this.modelPrivilege.getPrivilegeList(session.GetUserId())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
for _, v := range list {
|
for _, v := range list {
|
||||||
if v.ETime > configure.Now().Unix() {
|
if v.CId == cId {
|
||||||
|
if v.ETime < configure.Now().Unix() { // 判断当前特权是否过期
|
||||||
|
if err := this.modelPrivilege.DelListlds(session.GetUserId(), v.Id); err != nil {
|
||||||
|
this.Errorf("delete privilege failed:%v", err)
|
||||||
|
}
|
||||||
|
privilege = nil
|
||||||
|
return
|
||||||
|
}
|
||||||
|
privilege = v
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// 查询特权信息,把过期的特权清除掉
|
||||||
|
func (this *Privilege) QueryPrivilege(session comm.IUserSession) (privilegeID []int32) {
|
||||||
|
list, err := this.modelPrivilege.getPrivilegeList(session.GetUserId())
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
for _, v := range list {
|
||||||
|
if v.ETime < configure.Now().Unix() { // 判断当前特权是否过期
|
||||||
if err := this.modelPrivilege.DelListlds(session.GetUserId(), v.Id); err != nil {
|
if err := this.modelPrivilege.DelListlds(session.GetUserId(), v.Id); err != nil {
|
||||||
this.Errorf("delete privilege failed:%v", err)
|
this.Errorf("delete privilege failed:%v", err)
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
|
||||||
|
privilegeID = append(privilegeID, v.PrivilegeID...)
|
||||||
|
// 检查 每日奖励是否发放
|
||||||
|
if !utils.IsToday(v.RewardTime) {
|
||||||
|
v.RewardTime = configure.Now().Unix()
|
||||||
|
if err = this.modelPrivilege.Change(session.GetUserId(), map[string]interface{}{
|
||||||
|
"rewardTime": v.RewardTime,
|
||||||
|
}); err != nil {
|
||||||
|
this.Errorf("err:%v", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
// 检查离上次领奖过去几天
|
||||||
|
dt := configure.Now().Unix() - utils.GetZeroTime(v.RewardTime)
|
||||||
|
count := dt / (24 * 3600)
|
||||||
|
this.SendDailyMail(session, v.Id, int32(count+1))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (this *Privilege) SendDailyMail(session comm.IUserSession, cId string, count int32) {
|
||||||
|
conf, err := this.configure.GetPrivilegeCard(cId)
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
var (
|
||||||
|
res []*pb.UserAssets
|
||||||
|
)
|
||||||
|
for _, v := range conf.DayReward {
|
||||||
|
res = append(res, &pb.UserAssets{
|
||||||
|
A: v.A,
|
||||||
|
T: v.T,
|
||||||
|
N: v.N,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// 构建一个每日奖励邮件对象
|
||||||
|
mail := &pb.DBMailData{
|
||||||
|
ObjId: "",
|
||||||
|
Uid: session.GetUserId(),
|
||||||
|
Title: "",
|
||||||
|
Contex: "",
|
||||||
|
CreateTime: uint64(configure.Now().Unix()),
|
||||||
|
DueTime: uint64(configure.Now().Unix() + 30*24*3600),
|
||||||
|
Check: false,
|
||||||
|
Reward: false,
|
||||||
|
Items: res,
|
||||||
|
Cid: "",
|
||||||
|
Param: []string{},
|
||||||
|
}
|
||||||
|
for i := 0; i < int(count); i++ {
|
||||||
|
mail.ObjId = primitive.NewObjectID().Hex()
|
||||||
|
this.mail.CreateNewMail(session, mail)
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
@ -146,6 +146,8 @@ func (this *apiComp) Login(session comm.IUserSession, req *pb.UserLoginReq) (cod
|
|||||||
this.module.modelSign.checkResetSignData(session)
|
this.module.modelSign.checkResetSignData(session)
|
||||||
|
|
||||||
this.Sign(session, &pb.UserSignReq{})
|
this.Sign(session, &pb.UserSignReq{})
|
||||||
|
// 检查特权 并发送每日邮件
|
||||||
|
this.module.ModulePrivilege.QueryPrivilege(session)
|
||||||
//推送登录公告
|
//推送登录公告
|
||||||
this.chat.SendSysChatToUser(session, comm.UserLoginNotice, 0)
|
this.chat.SendSysChatToUser(session, comm.UserLoginNotice, 0)
|
||||||
mail := &pb.DBMailData{
|
mail := &pb.DBMailData{
|
||||||
|
Loading…
Reference in New Issue
Block a user