go-common/app/job/main/growup/service/blacklist.go
2019-04-22 18:49:16 +08:00

269 lines
6.1 KiB
Go

package service
import (
"context"
"encoding/json"
"math"
"strconv"
"time"
"go-common/app/job/main/growup/model"
"go-common/library/log"
"go-common/library/xstr"
)
// add to blacklist reason
const (
// _all = 0
// _stopIncome = 1
// _breachRecord = 2
_porder = 3
_executeOrder = 4
)
// InitBlacklistMID init av_black_list mid
func (s *Service) InitBlacklistMID(c context.Context) (err error) {
blacklist, err := s.listBlacklist(c, "mid = 0")
if err != nil {
log.Error("s.listBlacklist error(%v)", err)
return
}
avIDs := make([]int64, 0)
for _, b := range blacklist {
if b.MID == 0 {
avIDs = append(avIDs, b.AvID)
}
}
if len(avIDs) == 0 {
return
}
m, err := s.GetAvsMID(c, avIDs)
if err != nil {
log.Error("GetAvsMID error(%v)", err)
return
}
for i := 0; i < len(blacklist); i++ {
blacklist[i].MID = m[blacklist[i].AvID]
}
_, err = s.updateBlacklistBatch(c, blacklist)
return
}
func (s *Service) listBlacklist(c context.Context, query string) (list []*model.Blacklist, err error) {
from, limit := 0, 2000
var b []*model.Blacklist
for {
b, err = s.dao.ListBlacklist(c, query, from, limit)
if err != nil {
return
}
list = append(list, b...)
if len(b) < limit {
break
}
from += len(b)
}
return
}
// UpdateBlacklist update blacklist
func (s *Service) UpdateBlacklist(c context.Context) (err error) {
defer func() {
GetTaskService().SetTaskStatus(c, TaskBlacklist, time.Now().AddDate(0, 0, -1).Format(_layout), err)
}()
blacklist := make([]*model.Blacklist, 0)
porders, err := s.getNewPorder(c)
if err != nil {
log.Error("s.getNewPorder error(%v)", err)
return
}
log.Info("Get new porder %d", len(porders))
blacklist = append(blacklist, porders...)
executeOrders, err := s.getNewExecuteOrder(c)
if err != nil {
log.Error("s.getNewExecuteOrder error(%v)", err)
return
}
log.Info("Get new execute order %d", len(executeOrders))
blacklist = append(blacklist, executeOrders...)
count, err := s.updateBlacklistBatch(c, blacklist)
if err != nil {
log.Error("s.updateBlacklistBatch error(%v)", err)
return
}
log.Info("Add %d list into blacklist", count)
return
}
func (s *Service) updateBlacklistBatch(c context.Context, blacklist []*model.Blacklist) (count int64, err error) {
ups, err := s.getHasSignUpInfo(c)
if err != nil {
log.Error("s.dao.GetHasSignUpInfo error(%v)", err)
return
}
for i := 0; i < len(blacklist); i++ {
if nickname, ok := ups[blacklist[i].MID]; ok {
blacklist[i].HasSigned = 1
blacklist[i].Nickname = nickname
}
}
return s.dao.AddBlacklistBatch(c, blacklist)
}
func (s *Service) getHasSignUpInfo(c context.Context) (m map[int64]string, err error) {
m = make(map[int64]string)
offset, limit := 0, 2000
for {
err = s.dao.GetHasSignUpInfo(c, offset, limit, m)
if err != nil {
log.Error("s.dao.GetHasSignUpInfo error(%v)", err)
return
}
offset += limit
if len(m) < offset {
break
}
}
return
}
func (s *Service) getNewPorder(c context.Context) (blacklist []*model.Blacklist, err error) {
beginTime, err := s.dao.GetLastCtime(c, _porder)
if err != nil {
log.Error("s.dao.GetLastCtime error(%v)", err)
return
}
if beginTime != 0 {
beginTime -= 10 * 60 // pre 10min
}
endTime := time.Now().Unix()
porders, err := s.getPorder(beginTime, endTime)
if err != nil {
log.Error("get Porder error(%v)", err)
return
}
// get porder mid
avIds := []int64{}
for _, b := range porders {
avIds = append(avIds, b.AID)
}
m, err := s.GetAvsMID(c, avIds)
if err != nil {
log.Error("s.dao.GetAvsMID error(%v)", err)
return
}
blacklist = make([]*model.Blacklist, len(porders))
for i := 0; i < len(porders); i++ {
blacklist[i] = &model.Blacklist{
AvID: porders[i].AID,
MID: m[porders[i].AID],
Reason: _porder,
}
}
return
}
// GetAvsMID get avs mid from api
func (s *Service) GetAvsMID(c context.Context, avs []int64) (avsMap map[int64]int64, err error) {
avsMap = make(map[int64]int64)
if len(avs) == 0 {
return
}
start, limit := 0, 10
if limit > len(avs) {
limit = len(avs)
}
for start+limit <= len(avs) {
if err = s.getAvsMID(c, avs[start:start+limit], avsMap); err != nil {
return
}
start += limit
if start < len(avs) && start+limit > len(avs) {
limit = len(avs) - start
}
}
log.Info("Get avs(%d) from archiveURL", len(avsMap))
return
}
func (s *Service) getAvsMID(c context.Context, avs []int64, avsMap map[int64]int64) (err error) {
params := map[string]string{"aids": xstr.JoinInts(avs)}
body, err := s.HTTPClient("GET", s.conf.Host.Archives, params, time.Now().Unix())
if err != nil {
log.Error("s.HTTPClient error(%v)", err)
return
}
res := model.ArchiveRes{}
err = json.Unmarshal(body, &res)
if err != nil {
log.Error("json.Unmarshal body %s error(%v)", string(body), err)
return
}
for _, archive := range res.Data {
avsMap[archive.AID] = archive.Owner.MID
}
return
}
func (s *Service) getPorder(begin, end int64) (porders []*model.Porder, err error) {
params := map[string]string{
"begin": strconv.FormatInt(begin, 10),
"end": strconv.FormatInt(end, 10),
}
body, err := s.HTTPClient("GET", s.conf.Host.Porder, params, time.Now().UnixNano()/int64(math.Pow(10, 6)))
if err != nil {
log.Error("s.HTTPClient error(%v)", err)
return
}
res := model.PorderRes{}
err = json.Unmarshal(body, &res)
if err != nil {
log.Error("json.Unmarshal body %s error(%v)", string(body), err)
return
}
porders = res.Data
return
}
func (s *Service) getNewExecuteOrder(c context.Context) (blacklist []*model.Blacklist, err error) {
beginTime, err := s.dao.GetLastCtime(c, _executeOrder)
if err != nil {
log.Error("s.dao.GetLastCtime error(%v)", err)
return
}
if beginTime != 0 {
beginTime -= 10 * 60 // pre 10min
}
executeOrders, err := s.dao.GetExecuteOrder(c, time.Unix(beginTime, 0), time.Now())
if err != nil {
log.Error("s.dao.GetExecuteOrder error(%v)", err)
return
}
blacklist = make([]*model.Blacklist, len(executeOrders))
for i := 0; i < len(executeOrders); i++ {
blacklist[i] = &model.Blacklist{
AvID: executeOrders[i].AvID,
MID: executeOrders[i].MID,
Reason: _executeOrder,
}
}
return
}