123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909 |
- package services
- import (
- "context"
- "errors"
- "fmt"
- "github.com/beego/beego/v2/task"
- "hongze/hongze_task/models"
- "hongze/hongze_task/services/alarm_msg"
- "hongze/hongze_task/services/comein"
- "hongze/hongze_task/services/company"
- "hongze/hongze_task/services/company_contract"
- "hongze/hongze_task/services/data"
- "hongze/hongze_task/services/data/future_good"
- "hongze/hongze_task/services/maycur"
- "hongze/hongze_task/services/overseas_custom"
- "hongze/hongze_task/services/roadshow"
- "hongze/hongze_task/utils"
- "runtime"
- "strconv"
- "strings"
- "sync"
- "time"
- )
- func InitTask() {
- defer func() {
- if err := recover(); err != nil {
- fmt.Println("进来了定时任务的异常处理")
- stack := fmt.Sprintf("Handler crashed with error: %v", err) + "\n</br>"
- for i := 1; ; i++ {
- _, file, line, ok := runtime.Caller(i)
- if !ok {
- break
- }
- stack += fmt.Sprintln(fmt.Sprintf("%s:%d</br>", file, line))
- }
-
- go alarm_msg.SendAlarmMsg(utils.APPNAME+"崩了"+time.Now().Format("2006-01-02 15:04:05")+"\n"+stack, 3)
- }
- }()
- comein.SyncWhiteList(nil)
-
- Task()
- }
- func Task() {
- fmt.Println("task start")
-
- if utils.RunMode == "release" {
- releaseTask()
- }
-
- handleCompanyContract := task.NewTask("handleCompanyContract", "0 1 2 * * *", company_contract.HandleCompanyContract)
- task.AddTask("每日定时合同处理", handleCompanyContract)
-
- companyTryOut := task.NewTask("companyTryOut", "0 5 2 * * *", CompanyTryOut)
- task.AddTask("正式->试用", companyTryOut)
-
- handleCompanyRenewalRecord := task.NewTask("handleCompanyContract", "0 10 2 * * *", company_contract.HandleCompanyRenewalRecordV2)
- task.AddTask("每日续约异常客户信息处理", handleCompanyRenewalRecord)
-
- companyFreeze := task.NewTask("companyFreeze", "0 10 2 * * *", CompanyFreeze)
- task.AddTask("试用->冻结", companyFreeze)
-
- companyLoss := task.NewTask("companyLoss", "0 20 2 * * *", CompanyLoss)
- task.AddTask("冻结->流失", companyLoss)
-
-
-
-
- companyFreezeXClassRai := task.NewTask("companyFreezeXClassRai", "0 30 2 * * *", CompanyFreezeXClassRai)
- task.AddTask("权益X类试用(永续)->冻结", companyFreezeXClassRai)
-
- companyReportPermissionTryOut := task.NewTask("companyReportPermissionTryOut", "0 30 2 * * *", CompanyReportPermissionTryOut)
- task.AddTask("用户产品权限正式-->试用", companyReportPermissionTryOut)
-
- companyReportPermissionClose := task.NewTask("companyReportPermissionClose", "0 35 2 * * *", CompanyReportPermissionClose)
- task.AddTask("用户产品权限试用-->关闭", companyReportPermissionClose)
-
- staticCompanyTryDay := task.NewTask("StaticCompanyTryDay", "0 40 2 * * *", StaticCompanyTryDay)
- task.AddTask("定时任务每天更新客户试用总天数", staticCompanyTryDay)
-
- stackCompanyStatistic := task.NewTask("stackCompanyStatistic", "0 40 2 * * *", StackCompanyStatistic)
- task.AddTask("存量客户数据统计", stackCompanyStatistic)
-
-
-
-
- ybTelRemind := task.NewTask("YbTelRemind", "0 */1 * * * * ", YbTelRemind)
- task.AddTask("研报电话会提醒", ybTelRemind)
-
- ybSalonRemind := task.NewTask("ybSalonRemind", "0 */1 * * * * ", YbSalonRemind)
- task.AddTask("研报沙龙提醒", ybSalonRemind)
-
-
-
-
-
-
- statisticsUserView := task.NewTask("statisticsUserView", "0 5 2 * * *", StatisticsUserView)
- task.AddTask("每日用户阅读数据统计", statisticsUserView)
-
- modifyRsCalendarStatus := task.NewTask("modifyRsCalendarStatus", "0 */1 * * * * ", roadshow.ModifyRsCalendarResearcherStatus)
- task.AddTask("modifyRsCalendarStatus", modifyRsCalendarStatus)
- addReportRecord := task.NewTask("addReportRecord", "0 0 */1 * * *", roadshow.AddReportRecord)
- task.AddTask("addReportRecord", addReportRecord)
-
- addCompanyReportRecord := task.NewTask("addCompanyReportRecord", "0 0 */1 * * *", company.AddCompanyReportRecord)
- task.AddTask("addCompanyReportRecord", addCompanyReportRecord)
-
- addRaiCompanyReportRecord := task.NewTask("addRaiCompanyReportRecord", "0 0 */1 * * *", company.AddRaiCompanyReportRecord)
- task.AddTask("addRaiCompanyReportRecord", addRaiCompanyReportRecord)
-
- roadShowTotal := task.NewTask("roadShowTotal", "0 */30 * * * *", roadshow.RoadShow)
- task.AddTask("roadShowTotal", roadShowTotal)
-
- statisticsUserView1Hour := task.NewTask("statisticsUserView1Hour", "0 */30 * * * *", StatisticsUserView1Hour)
- task.AddTask("每半个小时用户阅读数据统计", statisticsUserView1Hour)
-
- setPublicMeetingUnionCode := task.NewTask("setPublicMeetingUnionCode", "0 */10 * * * *", roadshow.SetPublicMeetingUnionCode)
- task.AddTask("setPublicMeetingUnionCode", setPublicMeetingUnionCode)
-
- syncComeinMeeting := task.NewTask("SyncComeinMeeting", "0 1 */1 * * * ", SyncComeinMeeting)
- task.AddTask("SyncComeinMeeting", syncComeinMeeting)
-
- syncSubStatus := task.NewTask("syncSubStatus", "0 0 2 * * *", SyncSubStatus)
- task.AddTask("syncSubStatus", syncSubStatus)
-
-
-
-
- publishVoiceBroadcast := task.NewTask("publishVoiceBroadcast", "0 */1 * * * *", PublishVoiceBroadcast)
- task.AddTask("定时发布研报语音播报", publishVoiceBroadcast)
-
-
-
-
-
-
-
-
- cygxResearchSummary := task.NewTask("cygxResearchSummary", "0 0 13 * * 5", CygxResearchSummary)
- task.AddTask("定时生成本周研究汇总", cygxResearchSummary)
-
- cygxLastWeekSummary := task.NewTask("CygxLastWeekSummary", "0 0 10 * * 2", CygxLastWeekSummary)
- task.AddTask("定时生成上周纪要汇总", cygxLastWeekSummary)
-
- eTATrialDisabled := task.NewTask("eTATrialDisabled", "0 15 2 * * *", ETATrialDisabled)
- task.AddTask("ETA试用客户 启用->禁用", eTATrialDisabled)
-
- englishReportEmailTermination := task.NewTask("englishReportEmailTermination", "0 30 2 * * *", EnglishReportEmailTermination)
- task.AddTask("英文研报客户 临时->终止", englishReportEmailTermination)
-
- etaBusinessUpdateStatus := task.NewTask("etaBusinessUpdateStatus", "0 5 5 * * *", EtaBusinessUpdateStatus)
- task.AddTask("etaBusinessUpdateStatus", etaBusinessUpdateStatus)
-
- fixEnglishCompanyRoadShowTotal := task.NewTask("fixEnglishCompanyRoadShowTotal", "0 */10 6-23 * * *", overseas_custom.FixEnglishCompanyRoadShowTotal)
- task.AddTask("英文客户路演统计", fixEnglishCompanyRoadShowTotal)
-
- fixEnglishCompanyLastViewTime := task.NewTask("fixEnglishCompanyLastViewTime", "0 */30 6-23 * * *", overseas_custom.FixEnglishCompanyLastViewTime)
- task.AddTask("英文客户最后一次阅读时间", fixEnglishCompanyLastViewTime)
-
- fixCompanyOverseasStatus := task.NewTask("fixCompanyOverseasStatus", "0 */5 * * * *", overseas_custom.FixCompanyOverseasStatus)
- task.AddTask("同步客户状态", fixCompanyOverseasStatus)
- task.StartTask()
- fmt.Println("task end")
- }
- func releaseTask() {
-
-
-
-
-
-
-
- sendEmail := task.NewTask("sendEmail", "0 0 12 * * 0 ", SendEmail)
- task.AddTask("sendEmail", sendEmail)
-
- companyRemind := task.NewTask("companyRemind", "0 30 08 * * *", CompanyRemind)
- task.AddTask("companyRemind", companyRemind)
-
- freeViewerDetail := task.NewTask("freeViewerDetail", "0 0 9 * * 1 ", FreeViewerDetail)
- task.AddTask("潜在客户", freeViewerDetail)
-
- incrementCompany := task.NewTask("incrementCompany", "0 0 9 * * 1 ", IncrementCompany)
- task.AddTask("上周增量客户列表", incrementCompany)
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- syncMaycurCompanyProfile := task.NewTask("syncMaycurCompanyProfile", "0 1 4 * * * ", maycur.DailyUpdateCompanyProfile)
- task.AddTask("每日更新每刻报销-客户档案", syncMaycurCompanyProfile)
-
- etaBusinessRemind := task.NewTask("etaBusinessRemind", "0 20 8 * * *", EtaBusinessExpiredRemind)
- task.AddTask("etaBusinessRemind", etaBusinessRemind)
-
- syncWhiteList := task.NewTask("syncWhiteList", "0 */10 * * * *", comein.SyncWhiteList)
- task.AddTask("syncWhiteList", syncWhiteList)
-
- notifyNeedAnswerQuestionToResearch := task.NewTask("notifyNeedAnswerQuestionToResearch", "0 0 10 * * *", NotifyNeedAnswerQuestionToResearch)
- task.AddTask("问答社区定时发送模版消息给研究员", notifyNeedAnswerQuestionToResearch)
- }
- func SendEmail(cont context.Context) (err error) {
-
- go ReportViewTimes()
-
- go ReportViewDetail()
-
- go HongzeUsers()
- return
- }
- func OneMinute(cont context.Context) (err error) {
-
-
-
- FrequencyByWeek()
-
- FrequencyByMonth()
- return
- }
- func RefreshData(cont context.Context) (err error) {
- wg := sync.WaitGroup{}
- wg.Add(16)
-
-
-
- go data.RefreshDataFromWind(&wg)
-
- go data.RefreshDataFromThs(&wg)
-
- go data.RefreshDataFromPb(&wg)
-
- go data.RefreshDataFromPbFinance(&wg)
-
- go data.RefreshDataFromManual(&wg)
-
- go data.RefreshDataFromLz(&wg)
-
- go data.RefreshDataFromYs(&wg)
-
- go data.RefreshDataFromGl(&wg)
-
- go data.RefreshDataFromLt(&wg)
-
- go data.RefreshDataFromCoal(&wg)
-
- go data.RefreshDataFromGoogleTravel(&wg)
-
- go data.RefreshDataFromMysteelChemical(&wg)
-
- go data.RefreshDataFromEiaSteo(&wg)
-
- go data.RefreshDataFromComTrade(&wg)
-
- go data.RefreshDataFromSci(&wg)
-
- go data.RefreshDataFromNationalStatistics(&wg)
- wg.Wait()
-
- data.RefreshDataFromCalculateAll()
-
- data.RefreshPredictDataFromCalculateAll()
- time.Sleep(5 * time.Second)
- data.RefreshNotice()
- fmt.Println("Refresh End")
- return
- }
- func RefreshFutureGoodData(cont context.Context) (err error) {
- future_good.RefreshFutureGoodDataFromThs()
- fmt.Println("Refresh End")
- return
- }
- func RefreshTradeData(cont context.Context) (err error) {
- wg := sync.WaitGroup{}
- wg.Add(5)
-
- go data.RefreshDataFromZz(&wg)
-
- go data.RefreshDataFromSh(&wg)
-
- go data.RefreshDataFromShfe(&wg)
-
- go data.RefreshDataFromCffex(&wg)
-
- go data.RefreshDataFromDl(&wg)
- wg.Wait()
-
- data.RefreshDataFromCalculateAll()
-
- data.RefreshPredictDataFromCalculateAll()
- return
- }
- func RefreshEicData(cont context.Context) (err error) {
- wg := sync.WaitGroup{}
- wg.Add(1)
-
- go data.RefreshDataFromEic(&wg)
- wg.Wait()
-
- data.RefreshDataFromCalculateAll()
-
- data.RefreshPredictDataFromCalculateAll()
- return
- }
- func RefreshBaseData(cont context.Context) (err error) {
- now := time.Now()
- if now.Hour() == 0 || now.Hour() == 19 {
- return nil
- }
-
- go data.SyncSmmIndexDataBase()
- return
- }
- func SyncBaseData(cont context.Context) (err error) {
- now := time.Now()
- if now.Hour() == 0 || now.Hour() == 19 {
- return nil
- }
-
- go data.SyncGlDataBase()
- return
- }
- func SyncBaseDataExt(cont context.Context) (err error) {
- now := time.Now()
- if now.Hour() == 0 || now.Hour() == 19 {
- return nil
- }
-
- go data.SyncLzDataBase()
-
- go data.SyncManualDataBase()
-
- go data.SyncSmmDataBase()
-
- go data.SetChartEdbEndDate()
- return
- }
- 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 tmpErr.Error() != utils.ErrNoRow() {
- failList = append(failList, fmt.Sprint(tmpEdb.TradeCode, "失败,Err:", tmpErr.Error()))
- continue
- }
- }
-
- if edbData != nil {
- 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 tmpErr.Error() != utils.ErrNoRow() {
- funcErr = tmpErr
- return
- }
- }
- if utils.RunMode == "debug" && debugNoticeUserId > 0 {
- tmpEdb.UserId = debugNoticeUserId
- }
-
- var funcDataDtTime time.Time
-
- if edbData != nil {
- 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 err.Error() == utils.ErrNoRow() {
- funcErr = errors.New("openId 列表为空" + strconv.Itoa(tmpEdb.UserId))
- return
- } else {
- return err
- }
- }
- if admin == nil {
- 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
- }
- }
- }
- func checkDataServer(cont context.Context) (err error) {
-
- go data.CheckWindDataInterface(cont)
-
-
-
- go data.CheckLtDataInterface(cont)
-
- go data.CheckPbDataInterface(cont)
- return
- }
|