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

97 lines
2.6 KiB
Go

package service
import (
"context"
"time"
"go-common/app/job/main/mcn/model"
"go-common/library/log"
"github.com/pkg/errors"
)
// UpMcnSignStateCron .
func (s *Service) UpMcnSignStateCron() {
defer func() {
if r := recover(); r != nil {
r = errors.WithStack(r.(error))
log.Error("recover panic error(%+v)", r)
}
}()
var (
err error
c = context.TODO()
now = time.Now()
nowDate = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, time.Local).Unix()
mss []*model.MCNSignInfo
)
if mss, err = s.dao.McnSigns(c); err != nil {
log.Error("s.dao.McnSigns error(%+v)", err)
return
}
if len(mss) == 0 {
log.Warn("mcn sign data is empty!")
return
}
for _, v := range mss {
var state int8
switch {
case v.State.NotDealState():
continue
case nowDate > v.EndDate.Time().Unix() && nowDate-v.EndDate.Time().Unix() <= model.ThirtyDayUnixTime && v.State != model.MCNSignStateOnCooling:
state = int8(model.MCNSignStateOnCooling)
case nowDate > v.EndDate.Time().Unix() && nowDate-v.EndDate.Time().Unix() > model.ThirtyDayUnixTime:
state = int8(model.MCNSignStateOnExpire)
case nowDate < v.BeginDate.Time().Unix() && v.State != model.MCNSignStateOnPreOpen:
state = int8(model.MCNSignStateOnPreOpen)
case v.BeginDate.Time().Unix() <= nowDate && nowDate <= v.EndDate.Time().Unix() && v.State != model.MCNSignStateOnSign && v.State == model.MCNSignStateOnPreOpen:
state = int8(model.MCNSignStateOnSign)
default:
continue
}
if _, err = s.dao.UpMcnSignStateOP(c, v.SignID, state); err != nil {
log.Error("s.dao.UpMcnSignStateOP(%d,%d) error(%+v)", v.SignID, state, err)
continue
}
if err = s.dao.DelMcnSignCache(c, v.McnMid); err != nil {
log.Error("s.dao.DelMcnSignCache(%d) error(%+v)", v.McnMid, err)
continue
}
log.Info("signID(%d) change old state(%d) to new state(%d)", v.SignID, v.State, state)
}
}
// UpExpirePayCron .
func (s *Service) UpExpirePayCron() {
defer func() {
if r := recover(); r != nil {
r = errors.WithStack(r.(error))
log.Error("recover panic error(%+v)", r)
}
}()
var (
err error
c = context.TODO()
sps []*model.SignPayInfo
)
if sps, err = s.dao.McnSignPayWarns(c); err != nil {
log.Error("s.dao.McnSignPayWarns error(%+v)", err)
return
}
if len(sps) == 0 {
log.Warn("mcn sign pay date is empty!")
return
}
ms := make(map[int64]struct{})
for _, v := range sps {
ms[v.SignID] = struct{}{}
}
for signID := range ms {
if _, err = s.dao.UpMcnSignPayExpOP(c, signID); err != nil {
log.Error("s.dao.UpMcnSignPayExpOP(%d) error(%+v)", signID, err)
continue
}
log.Info("sign_id(%d) change pay data warn state to 2", signID)
}
}