anniversary.go 1.68 KB
Newer Older
hujiebin's avatar
hujiebin committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
package cp_cron

import (
	"encoding/json"
	"git.hilo.cn/hilo-common/domain"
	"git.hilo.cn/hilo-common/resource/config"
	"github.com/robfig/cron"
	"hilo-user/domain/model/cp_m"
	"hilo-user/domain/model/user_m"
)

// 纪念日
type CpAnniversaryNoticeMsg struct {
	Identifier string `json:"identifier"`
	Content    string `json:"content"`
hujiebin's avatar
hujiebin committed
16
	Timestamp  int64  `json:"timestamp"`
hujiebin's avatar
hujiebin committed
17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32
}

func CpAnniversaryNotice() {
	c := cron.New()
	// 1小时操作一次
	spec := "0 0 */1 * * ?"
	if !config.AppIsRelease() {
		// 测服1分钟
		spec = "0 * * * * ?"
	}
	_ = c.AddFunc(spec, func() {
		var model = domain.CreateModelNil()
		anniversary := cp_m.GetNeedRemindCpAnniversary(model)
		for _, v := range anniversary {
			var userIds []uint64
			userIds = append(userIds, v.UserId1, v.UserId2)
hujiebin's avatar
hujiebin committed
33
			users, err := user_m.GetUsersByIds(model, userIds)
hujiebin's avatar
hujiebin committed
34 35 36 37 38 39 40
			if err != nil || len(users) < 2 {
				model.Log.Errorf("GetUserMapByIds fail:%v", err)
				continue
			}
			data, _ := json.Marshal(CpAnniversaryNoticeMsg{
				Identifier: "CpAnniversaryNotice",
				Content:    v.Content,
hujiebin's avatar
hujiebin committed
41
				Timestamp:  v.Timestamp,
hujiebin's avatar
hujiebin committed
42
			})
43 44 45 46 47 48 49
			println(data) // todo 小助手
			//if err := tencentyun.BatchSendCustomMsg(model, 1, users[0].ExternalId, []string{users[1].ExternalId}, string(data), "cp纪念日"); err != nil {
			//	model.Log.Errorf("BatchSendCustomMsg fail:%v", err)
			//}
			//if err := tencentyun.BatchSendCustomMsg(model, 1, users[1].ExternalId, []string{users[0].ExternalId}, string(data), "cp纪念日"); err != nil {
			//	model.Log.Errorf("BatchSendCustomMsg fail:%v", err)
			//}
hujiebin's avatar
hujiebin committed
50 51 52 53 54 55 56
			if err := cp_m.UpdateCpAnniversaryReminded(model, v.ID); err != nil {
				model.Log.Errorf("UpdateCpAnniversaryReminded fail:%v", err)
			}
		}
	})
	c.Start()
}