Files
open-im-server/internal/cron_task/cron_task.go
T

102 lines
3.4 KiB
Go
Raw Normal View History

2022-08-09 16:38:33 +08:00
package cronTask
import (
2022-08-10 15:14:51 +08:00
"Open_IM/pkg/common/config"
2022-08-09 16:38:33 +08:00
"Open_IM/pkg/common/constant"
"Open_IM/pkg/common/db/mysql_model/im_mysql_model"
2022-08-09 18:48:11 +08:00
rocksCache "Open_IM/pkg/common/db/rocks_cache"
2022-08-09 16:38:33 +08:00
"Open_IM/pkg/common/log"
"Open_IM/pkg/utils"
2022-08-10 12:02:50 +08:00
"fmt"
2022-08-10 12:09:28 +08:00
"time"
2022-12-26 10:25:42 +08:00
"github.com/robfig/cron/v3"
2022-08-09 16:38:33 +08:00
)
const cronTaskOperationID = "cronTaskOperationID-"
2022-11-24 19:17:29 +08:00
func StartCronTask(userID, workingGroupID string) {
2022-08-12 18:37:51 +08:00
log.NewPrivateLog("cron")
2022-11-02 11:40:55 +08:00
log.NewInfo(utils.OperationIDGenerator(), "start cron task", "cron config", config.Config.Mongo.ChatRecordsClearTime)
fmt.Println("cron config", config.Config.Mongo.ChatRecordsClearTime)
2022-11-24 19:17:29 +08:00
if userID != "" {
2022-08-09 16:38:33 +08:00
operationID := getCronTaskOperationID()
2022-11-24 19:17:29 +08:00
StartClearMsg(operationID, []string{userID})
}
if workingGroupID != "" {
operationID := getCronTaskOperationID()
StartClearWorkingGroupMsg(operationID, []string{workingGroupID})
}
if userID != "" || workingGroupID != "" {
fmt.Println("clear msg finished")
return
}
c := cron.New()
2022-11-29 18:08:47 +08:00
_, err := c.AddFunc(config.Config.Mongo.ChatRecordsClearTime, ClearAll)
2022-08-09 16:38:33 +08:00
if err != nil {
2022-11-01 16:54:23 +08:00
fmt.Println("start cron failed", err.Error(), config.Config.Mongo.ChatRecordsClearTime)
2022-08-09 16:38:33 +08:00
panic(err)
}
c.Start()
2022-08-10 12:08:28 +08:00
fmt.Println("start cron task success")
2022-08-10 12:09:28 +08:00
for {
2022-11-01 16:54:23 +08:00
time.Sleep(10 * time.Second)
2022-08-10 12:09:28 +08:00
}
2022-08-09 16:38:33 +08:00
}
func getCronTaskOperationID() string {
return cronTaskOperationID + utils.OperationIDGenerator()
}
2022-11-24 19:17:29 +08:00
func ClearAll() {
operationID := getCronTaskOperationID()
log.NewInfo(operationID, "====================== start del cron task ======================")
var err error
userIDList, err := im_mysql_model.SelectAllUserID()
if err == nil {
StartClearMsg(operationID, userIDList)
} else {
log.NewError(operationID, utils.GetSelfFuncName(), err.Error())
}
2022-12-26 10:25:42 +08:00
2022-11-24 19:17:29 +08:00
// working group msg clear
workingGroupIDList, err := im_mysql_model.GetGroupIDListByGroupType(constant.WorkingGroup)
if err == nil {
StartClearWorkingGroupMsg(operationID, workingGroupIDList)
} else {
log.NewError(operationID, utils.GetSelfFuncName(), err.Error())
}
log.NewInfo(operationID, "====================== start del cron finished ======================")
}
func StartClearMsg(operationID string, userIDList []string) {
log.NewDebug(operationID, utils.GetSelfFuncName(), "userIDList: ", userIDList)
for _, userID := range userIDList {
if err := DeleteMongoMsgAndResetRedisSeq(operationID, userID); err != nil {
log.NewError(operationID, utils.GetSelfFuncName(), err.Error(), userID)
}
if err := checkMaxSeqWithMongo(operationID, userID, constant.WriteDiffusion); err != nil {
log.NewError(operationID, utils.GetSelfFuncName(), userID, err)
}
}
}
func StartClearWorkingGroupMsg(operationID string, workingGroupIDList []string) {
log.NewDebug(operationID, utils.GetSelfFuncName(), "workingGroupIDList: ", workingGroupIDList)
for _, groupID := range workingGroupIDList {
userIDList, err := rocksCache.GetGroupMemberIDListFromCache(groupID)
if err != nil {
log.NewError(operationID, utils.GetSelfFuncName(), err.Error(), groupID)
continue
}
log.NewDebug(operationID, utils.GetSelfFuncName(), "groupID:", groupID, "workingGroupIDList:", userIDList)
if err := ResetUserGroupMinSeq(operationID, groupID, userIDList); err != nil {
log.NewError(operationID, utils.GetSelfFuncName(), err.Error(), groupID, userIDList)
}
if err := checkMaxSeqWithMongo(operationID, groupID, constant.ReadDiffusion); err != nil {
log.NewError(operationID, utils.GetSelfFuncName(), groupID, err)
}
}
}