123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- package dao
- import (
- "context"
- "fmt"
- "math"
- "net/url"
- "strconv"
- "go-common/app/job/main/relation/model"
- "go-common/library/log"
- )
- // DelStatCache is
- func (d *Dao) DelStatCache(mid int64) (err error) {
- params := url.Values{}
- params.Set("mid", strconv.FormatInt(mid, 10))
- var res struct {
- Code int `json:"code"`
- }
- if err = d.client.Post(context.TODO(), d.clearStatPath, "", params, &res); err != nil {
- log.Error("d.client.Post error(%v)", err)
- return
- }
- if res.Code != 0 {
- log.Error("url(%s) res code(%d) or res.result(%v)", d.clearStatPath+"?"+params.Encode(), res.Code)
- }
- return
- }
- // FollowerAchieve is
- func (d *Dao) FollowerAchieve(c context.Context, mid, follower int64) {
- // 不为 0 结尾的就不检查了
- if follower%10 != 0 {
- return
- }
- flag := model.AchieveFromFollower(follower)
- if flag <= 0 {
- log.Warn("No achieve flag achieved with mid: %d, follower: %d", mid, follower)
- return
- }
- effected, err := d.UserSetAchieveFlag(c, mid, uint64(flag))
- if err != nil {
- log.Error("Failed to set user achieve flag: mid: %d, flag: %d: %+v", mid, flag, err)
- return
- }
- if effected <= 0 {
- log.Info("Already achieved with mid: %d, flag: %d", mid, flag)
- return
- }
- msg := func() string {
- switch flag {
- case model.FollowerAchieve1k:
- return `恭喜您,您的粉丝已经达到1000粉!`
- case model.FollowerAchieve5k:
- return `恭喜您,您的粉丝已经达到5000粉!`
- case model.FollowerAchieve10k:
- return `恭喜您,您的粉丝已经达到1万粉!您将有机会获得UP主粉丝成就奖“一万粉丝成就奖励”, #{戳我领取吧!}{"https://www.bilibili.com/blackboard/activity-zxIQ8otdK.html#/"}`
- case model.FollowerAchieve100k:
- return `恭喜您,您的粉丝已经达到10万粉!您将有机会获得UP主粉丝成就奖“十万粉丝成就奖励”, #{戳我领取吧!}{"https://www.bilibili.com/blackboard/activity-zxIQ8otdK.html#/"}`
- case model.FollowerAchieve1000k:
- return `恭喜您,您的粉丝已经达到100万粉!您将有机会获得UP主粉丝成就奖“百万粉丝成就奖励”, #{戳我领取吧!}{"https://www.bilibili.com/blackboard/activity-zxIQ8otdK.html#/"}`
- }
- if flag >= model.FollowerAchieve100k {
- return fmt.Sprintf(`恭喜您,您的粉丝已达%d万粉!`, int64((math.Log2(float64(flag))-2)*100000/10000))
- }
- return ""
- }()
- if msg != "" {
- log.Info("Follower achieve send message to mid: %d: %s", mid, msg)
- d.SendMsg(c, mid, "粉丝增长通知", msg)
- }
- d.ensureAllFollowerAchieve(c, mid, follower)
- }
- func (d *Dao) ensureAllFollowerAchieve(c context.Context, mid int64, follower int64) {
- flags := model.AllAchieveFromFollower(follower)
- v := model.AchieveFlag(0)
- for _, f := range flags {
- v |= f
- }
- effected, err := d.UserSetAchieveFlag(c, mid, uint64(v))
- if err != nil {
- log.Error("Failed to ensure user achieve flag: mid: %d, flags: %+v, follower: %d: %+v", mid, flags, follower, err)
- return
- }
- if effected >= 0 {
- log.Warn("Achieve missed on mid: %d, follower: %d, flags: %+v", mid, follower, flags)
- return
- }
- }
- // SendMsg send message.
- func (d *Dao) SendMsg(c context.Context, mid int64, title string, context string) (err error) {
- params := url.Values{}
- params.Set("mc", "2_5_1")
- params.Set("title", title)
- params.Set("data_type", "4")
- params.Set("context", context)
- params.Set("mid_list", fmt.Sprintf("%d", mid))
- var res struct {
- Code int `json:"code"`
- }
- if err = d.client.Post(c, d.followersNotify, "", params, &res); err != nil || res.Code != 0 {
- log.Error("sendMsgURL(%s) code(%d) error(%v)", d.followersNotify+"?"+params.Encode(), res.Code, err)
- return
- }
- log.Info("d.sendMsgURL url(%s) res(%d)", d.followersNotify+"?"+params.Encode(), res.Code)
- return
- }
|