123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440 |
- package services
- import (
- "context"
- "errors"
- "eta/eta_task/models"
- "eta/eta_task/utils"
- "fmt"
- "github.com/beego/beego/v2/task"
- "strconv"
- "strings"
- "time"
- )
- var EdbTaskNameMap map[string]map[string]bool
- var EdbTaskNameChannel chan string
- var EdbTaskStopChannel chan string
- var EdbTaskRunNum int
- func AddEdbTask(cont context.Context) (err error) {
-
- failList := make([]string, 0)
- defer func() {
- if len(failList) > 0 {
- fmt.Println("提醒失败:")
- for _, v := range failList {
- fmt.Println(v)
- }
- }
- }()
- list, err := models.GetEdbInfoByFrequencyNotDay()
- if err != nil {
- fmt.Println("查询获取频度非日度 且 提醒时间不为空 的指标数据失败,Err:", err.Error())
- }
-
- if EdbTaskNameMap == nil {
- EdbTaskNameMap = make(map[string]map[string]bool)
- }
- tmpEdbTaskNameMap := make(map[string]bool)
-
- todayStr := time.Now().Format(utils.FormatDate)
-
- nowWeekFirstDay := utils.GetNowWeekMonday()
- nowWeekLastDay := utils.GetNowWeekLastDay()
-
- nowMonthFirstDay := utils.GetNowMonthFirstDay()
- nowMonthLastDay := utils.GetNowMonthLastDay()
-
- nowQuarterFirstDay := utils.GetNowQuarterFirstDay()
- nowQuarterLastDay := utils.GetNowQuarterLastDay()
-
- nowHalfYearFirstDay := utils.GetNowHalfYearFirstDay()
- nowHalfYearLastDay := utils.GetNowHalfYearLastDay()
-
- nowYearFirstDay := utils.GetNowYearFirstDay()
- nowYearLastDay := utils.GetNowYearLastDay()
- debugNoticeUserId := 0
-
-
-
-
-
-
-
-
-
- for _, edb := range list {
- if edb.UserId <= 0 {
- continue
- }
- tmpEdb := edb
- isNotice := false
- noticeTime := "12:00:00"
- var dataDtTime time.Time
- edbData, tmpErr := models.GetLastEdbdataInfo(tmpEdb.TradeCode)
- if tmpErr != nil {
- if !utils.IsErrNoRow(tmpErr) {
- failList = append(failList, fmt.Sprint(tmpEdb.TradeCode, "失败,Err:", tmpErr.Error()))
- continue
- }
- }
-
- if edbData != nil && edbData.TradeCode != "" {
- tmpDataDtTime, _ := time.ParseInLocation(utils.FormatDate, edbData.Dt, time.Now().Location())
- dataDtTime = tmpDataDtTime
- }
- switch tmpEdb.Frequency {
- case "周度":
- modifyDate := nowWeekLastDay
- if tmpEdb.NoticeTime != "" {
- addDay := 7
- noticeArr := strings.Split(tmpEdb.NoticeTime, " ")
- if len(noticeArr) >= 2 {
- noticeTime = noticeArr[1]
- }
- noticeWeek := noticeArr[0]
- switch noticeWeek {
- case "周一":
- addDay = 1
- case "周二":
- addDay = 2
- case "周三":
- addDay = 3
- case "周四":
- addDay = 4
- case "周五":
- addDay = 5
- case "周六":
- addDay = 6
- case "周日":
- addDay = 7
- }
- modifyDate = modifyDate.AddDate(0, 0, addDay-7)
- }
-
- if todayStr == modifyDate.Format(utils.FormatDate) && !nowWeekFirstDay.Before(dataDtTime) {
- isNotice = true
- }
- case "月度":
- addDay := 0
- modifyDate := nowMonthLastDay
- if tmpEdb.NoticeTime != "" {
- strArr := strings.Split(tmpEdb.NoticeTime, "日")
- if len(strArr) >= 2 {
- noticeTime = strArr[1]
- }
- tmpAddDay, tmpErr := strconv.Atoi(strArr[0])
- if tmpErr != nil {
- continue
- }
- addDay = tmpAddDay - 1
- modifyDate = nowMonthFirstDay.AddDate(0, 0, addDay)
- }
-
- if todayStr == modifyDate.Format(utils.FormatDate) && !nowMonthFirstDay.Before(dataDtTime) {
- isNotice = true
- }
- case "季度":
-
- if tmpEdb.NoticeTime != "" {
- noticeArr := strings.Split(tmpEdb.NoticeTime, " ")
- if len(noticeArr) >= 2 {
- noticeTime = noticeArr[1]
- }
- }
-
-
- if todayStr == nowQuarterLastDay.Format(utils.FormatDate) && !nowQuarterFirstDay.Before(dataDtTime) {
- isNotice = true
- }
- case "半年度":
-
- if tmpEdb.NoticeTime != "" {
- noticeArr := strings.Split(tmpEdb.NoticeTime, " ")
- if len(noticeArr) >= 2 {
- noticeTime = noticeArr[1]
- }
- }
-
-
- if todayStr == nowHalfYearLastDay.Format(utils.FormatDate) && !nowHalfYearFirstDay.Before(dataDtTime) {
- isNotice = true
- }
- case "年度":
-
- if tmpEdb.NoticeTime != "" {
- noticeArr := strings.Split(tmpEdb.NoticeTime, " ")
- if len(noticeArr) >= 2 {
- noticeTime = noticeArr[1]
- }
- }
-
-
- if todayStr == nowYearLastDay.Format(utils.FormatDate) && !nowYearFirstDay.Before(dataDtTime) {
- isNotice = true
- }
- }
- if isNotice {
- taskName := "edb_task_" + todayStr + ":" + fmt.Sprint(tmpEdb.TradeCode)
-
-
- tmpTaskFunc := func(ctx context.Context) (funcErr error) {
-
- defer func() {
- EdbTaskNameChannel <- taskName
- }()
-
- funcIsNotice := false
-
- edbData, tmpErr := models.GetLastEdbdataInfo(tmpEdb.TradeCode)
- if tmpErr != nil {
- if !utils.IsErrNoRow(tmpErr) {
- funcErr = tmpErr
- return
- }
- }
- if utils.RunMode == "debug" && debugNoticeUserId > 0 {
- tmpEdb.UserId = debugNoticeUserId
- }
-
- var funcDataDtTime time.Time
-
- if edbData != nil && edbData.TradeCode != "" {
- tmpDataDtTime, _ := time.ParseInLocation(utils.FormatDate, edbData.Dt, time.Now().Location())
- funcDataDtTime = tmpDataDtTime
- }
-
- notifyFrequency := "每日"
- switch tmpEdb.Frequency {
- case "周度":
- notifyFrequency = "每周"
- modifyDate := nowWeekLastDay
- if tmpEdb.NoticeTime != "" {
- addDay := 7
- noticeArr := strings.Split(tmpEdb.NoticeTime, " ")
- if len(noticeArr) >= 2 {
- noticeTime = noticeArr[1]
- }
- noticeWeek := noticeArr[0]
- switch noticeWeek {
- case "周一":
- addDay = 1
- case "周二":
- addDay = 2
- case "周三":
- addDay = 3
- case "周四":
- addDay = 4
- case "周五":
- addDay = 5
- case "周六":
- addDay = 6
- case "周日":
- addDay = 7
- }
- modifyDate = modifyDate.AddDate(0, 0, addDay-7)
- }
-
- if todayStr == modifyDate.Format(utils.FormatDate) && !nowWeekFirstDay.Before(funcDataDtTime) {
- funcIsNotice = true
- }
- case "月度":
- notifyFrequency = "每月"
- addDay := 0
- modifyDate := nowMonthLastDay
- if tmpEdb.NoticeTime != "" {
- strArr := strings.Split(tmpEdb.NoticeTime, "日")
- if len(strArr) >= 2 {
- noticeTime = strArr[1]
- }
- tmpAddDay, tmpErr := strconv.Atoi(strArr[0])
- if tmpErr != nil {
- funcErr = tmpErr
- }
- addDay = tmpAddDay - 1
- modifyDate = nowMonthFirstDay.AddDate(0, 0, addDay)
- }
-
- if todayStr == modifyDate.Format(utils.FormatDate) && !nowMonthFirstDay.Before(funcDataDtTime) {
- funcIsNotice = true
- }
- case "季度":
- notifyFrequency = "每季度"
-
- if tmpEdb.NoticeTime != "" {
- noticeArr := strings.Split(tmpEdb.NoticeTime, " ")
- if len(noticeArr) >= 2 {
- noticeTime = noticeArr[1]
- }
- }
-
-
- if todayStr == nowQuarterLastDay.Format(utils.FormatDate) && !nowQuarterFirstDay.Before(funcDataDtTime) {
- funcIsNotice = true
- }
- case "半年度":
- notifyFrequency = "每半年度"
-
- if tmpEdb.NoticeTime != "" {
- noticeArr := strings.Split(tmpEdb.NoticeTime, " ")
- if len(noticeArr) >= 2 {
- noticeTime = noticeArr[1]
- }
- }
-
-
- if todayStr == nowHalfYearLastDay.Format(utils.FormatDate) && !nowHalfYearFirstDay.Before(funcDataDtTime) {
- funcIsNotice = true
- }
- case "年度":
- notifyFrequency = "每年"
-
- if tmpEdb.NoticeTime != "" {
- noticeArr := strings.Split(tmpEdb.NoticeTime, " ")
- if len(noticeArr) >= 2 {
- noticeTime = noticeArr[1]
- }
- }
-
-
- if todayStr == nowYearLastDay.Format(utils.FormatDate) && !nowYearFirstDay.Before(funcDataDtTime) {
- funcIsNotice = true
- }
- }
-
-
- if funcIsNotice {
-
- openIdList := make([]*models.OpenIdList, 0)
-
- admin, err := models.GetAdminByAdminId(tmpEdb.UserId)
- if err != nil {
- if utils.IsErrNoRow(err) {
- funcErr = errors.New("openId 列表为空" + strconv.Itoa(tmpEdb.UserId))
- return
- } else {
- return err
- }
- }
- if admin == nil || (admin != nil && admin.AdminId <= 0) {
- funcErr = errors.New("openId 列表为空" + strconv.Itoa(tmpEdb.UserId))
- return
- }
-
- if admin.OpenId == "" {
- funcErr = errors.New("openId 列表为空" + strconv.Itoa(tmpEdb.UserId))
- return
- }
- openIdTemp := new(models.OpenIdList)
- openIdTemp.OpenId = admin.OpenId
- openIdList = append(openIdList, openIdTemp)
- first := "数据录入提醒"
- keyword1 := tmpEdb.SecName + "该更新了"
- keyword2 := notifyFrequency + " " + tmpEdb.NoticeTime
- remark := tmpEdb.SecName + "该更新了"
- err = SendWxMsgWithFrequency(first, keyword1, keyword2, remark, openIdList)
- if err != nil {
- return err
- }
-
- {
- sendRecord := new(models.EdbinfoSendMsgRecord)
- sendRecord.UserId = tmpEdb.UserId
- sendRecord.TradeCode = tmpEdb.TradeCode
- sendRecord.CreateTime = time.Now()
- err = models.AddEdbinfoSendMsgRecord(sendRecord)
- if err != nil {
- return err
- }
- }
- }
- return
- }
-
- spec := ``
- if noticeTime != "" {
- noticeArr := strings.Split(noticeTime, ":")
- if len(noticeArr) == 3 {
-
- spec = fmt.Sprintf(` %s %s %s * * * `, noticeArr[2], noticeArr[1], noticeArr[0])
-
- tmpTask := task.NewTask(taskName, spec, tmpTaskFunc)
- task.AddTask(taskName, tmpTask)
- tmpEdbTaskNameMap[taskName] = true
- }
- }
- }
- }
-
- EdbTaskNameMap[todayStr] = tmpEdbTaskNameMap
-
- go deleteTask()
-
- if EdbTaskRunNum > 0 {
-
- EdbTaskStopChannel <- time.Now().AddDate(0, 0, -1).Format(utils.FormatDate)
- }
-
- EdbTaskRunNum++
- return
-
- }
- func deleteTask() {
- for {
- select {
- case taskName := <-EdbTaskNameChannel:
- task.DeleteTask(taskName)
- delete(EdbTaskNameMap, taskName)
- case dayStr := <-EdbTaskStopChannel:
- for taskName := range EdbTaskNameMap[dayStr] {
- task.DeleteTask(taskName)
- delete(EdbTaskNameMap, taskName)
- }
- break
- }
- }
- }
|