go-common/app/job/main/relation/dao/stat.go

112 lines
3.7 KiB
Go
Raw Normal View History

2019-04-22 10:49:16 +00:00
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
}