12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250 |
- package data
- import (
- "context"
- "errors"
- "eta/eta_task/models/data_manage"
- "eta/eta_task/services/alarm_msg"
- "eta/eta_task/utils"
- "fmt"
- "strconv"
- "strings"
- "sync"
- "time"
- )
- // RefreshDataFromThs 刷新同花顺数据
- func RefreshDataFromThs(wg *sync.WaitGroup) (err error) {
- errMsgList := make([]string, 0)
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromThs Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromThs ErrMsg:"+err.Error(), 3)
- }
- if len(errMsgList) > 0 {
- errMsg := "RefreshDataFromThs Err:" + strings.Join(errMsgList, "\n")
- fmt.Println(errMsg)
- go alarm_msg.SendAlarmMsg(errMsg, 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_THS)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- err = errors.New("GetEdbInfoByCondition:" + err.Error())
- return
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- errMsgList = append(errMsgList, v.EdbCode+"RefreshEdbData Err:"+err.Error())
- continue
- }
- if resp.Ret != 200 {
- errMsgList = append(errMsgList, v.EdbCode+";RefreshEdbData Err:"+resp.Msg+";ErrMsg:"+resp.ErrMsg)
- continue
- }
- }
- return err
- }
- // RefreshDataFromWind 刷新万得数据
- func RefreshDataFromWind(wg *sync.WaitGroup) (err error) {
- errMsgList := make([]string, 0)
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromWind Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromWind ErrMsg:"+err.Error(), 3)
- }
- if len(errMsgList) > 0 {
- errMsg := "RefreshDataFromWind Err:" + strings.Join(errMsgList, "\n")
- fmt.Println(errMsg)
- go alarm_msg.SendAlarmMsg(errMsg, 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += ` AND source=? AND no_update = 0 `
- pars = append(pars, utils.DATA_SOURCE_WIND)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return err
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- errMsgList = append(errMsgList, v.EdbCode+"RefreshEdbData Err:"+err.Error())
- continue
- }
- if resp.Ret != 200 {
- errMsgList = append(errMsgList, v.EdbCode+";RefreshEdbData Err:"+resp.Msg+";ErrMsg:"+resp.ErrMsg)
- continue
- }
- }
- fmt.Println("wind刷新结束")
- return err
- }
- // RefreshDataFromPb 刷新彭博数据
- func RefreshDataFromPb(wg *sync.WaitGroup) (err error) {
- errMsgList := make([]string, 0)
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromPb Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromPb ErrMsg:"+err.Error(), 3)
- }
- if len(errMsgList) > 0 {
- errMsg := "RefreshDataFromPb Err:" + strings.Join(errMsgList, "\n")
- fmt.Println(errMsg)
- go alarm_msg.SendAlarmMsg(errMsg, 3)
- }
- wg.Done()
- }()
- if utils.PbRefreshOpen == "0" {
- return
- }
- var condition string
- var pars []interface{}
- var frequencyStr string
- if utils.PbRefreshFrequency == "" {
- frequencyStr = "'日度','周度'"
- } else {
- frequencyStr = utils.PbRefreshFrequency
- }
- condition += " AND source=? AND frequency in (" + frequencyStr + ") "
- pars = append(pars, utils.DATA_SOURCE_PB)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- errMsgList = append(errMsgList, v.EdbCode+"RefreshEdbData Err:"+err.Error())
- continue
- }
- if resp.Ret != 200 {
- errMsgList = append(errMsgList, v.EdbCode+";RefreshEdbData Err:"+resp.Msg+";ErrMsg:"+resp.ErrMsg)
- continue
- }
- }
- return err
- }
- // RefreshDataFromPbFinance 刷新彭博财务指标数据
- func RefreshDataFromPbFinance(wg *sync.WaitGroup) (err error) {
- errMsgList := make([]string, 0)
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromPb Err:" + err.Error())
- //go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromPb ErrMsg:"+err.Error(), utils.EmailSendToUsers)
- go alarm_msg.SendAlarmMsg("RefreshDataFromPb ErrMsg:"+err.Error(), 3)
- }
- if len(errMsgList) > 0 {
- errMsg := "RefreshDataFromPbFinance Err:" + strings.Join(errMsgList, "\n")
- fmt.Println(errMsg)
- go alarm_msg.SendAlarmMsg(errMsg, 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_PB_FINANCE)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- errMsgList = append(errMsgList, v.EdbCode+"RefreshEdbData Err:"+err.Error())
- continue
- }
- if resp.Ret != 200 {
- errMsgList = append(errMsgList, v.EdbCode+";RefreshEdbData Err:"+resp.Msg+";ErrMsg:"+resp.ErrMsg)
- continue
- }
- }
- return err
- }
- // RefreshDataFromCalculateAll 刷新所有计算指标
- func RefreshDataFromCalculateAll() (err error) {
- var errmsg string
- defer func() {
- if err != nil {
- utils.FileLog.Info("RefreshDataFromCalculateAll Err:" + err.Error())
- //go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromCalculateAll ErrMsg:"+err.Error(), utils.EmailSendToUsers)
- go alarm_msg.SendAlarmMsg("RefreshDataFromCalculateAll ErrMsg:"+err.Error(), 3)
- }
- }()
- var condition string
- var pars []interface{}
- // 查询 普通指标的计算指标
- condition += " AND edb_type=? AND edb_info_type=? "
- pars = append(pars, 2, 0)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return err
- }
- for _, v := range items {
- source := v.Source
- startDate := v.StartDate.Format(utils.FormatDate)
- if startDate == "0001-01-01" {
- continue
- }
- fmt.Println(v.EdbInfoId, v.EdbCode, v.EdbName, v.SourceName, source)
- fmt.Println("RefreshEdbCalculateData", v.EdbInfoId, v.EdbCode, startDate)
- result, err := RefreshEdbCalculateData(v.EdbInfoId, v.EdbCode, startDate)
- if err != nil {
- errmsg += v.EdbCode + ","
- err = errors.New("RefreshEdbCalculateData Err:" + err.Error())
- //return err
- continue
- }
- if result.Ret != 200 {
- errmsg += v.EdbCode + ","
- err = errors.New("RefreshEdbCalculateData err;msg:" + result.Msg + ";errMsg:" + result.ErrMsg)
- //return err
- continue
- }
- }
- return err
- }
- // RefreshPredictDataFromCalculateAll 刷新所有预测计算指标
- func RefreshPredictDataFromCalculateAll() (err error) {
- defer func() {
- if err != nil {
- utils.FileLog.Info("RefreshDataFromCalculateAll Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromCalculateAll ErrMsg:"+err.Error(), 3)
- }
- }()
- var condition string
- var pars []interface{}
- // 查询 普通指标的计算指标
- condition += " AND edb_type=? AND edb_info_type=? "
- pars = append(pars, 2, 1)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return err
- }
- for _, v := range items {
- source := v.Source
- startDate := v.StartDate.Format(utils.FormatDate)
- if startDate == "0001-01-01" {
- continue
- }
- fmt.Println(v.EdbInfoId, v.EdbCode, v.EdbName, v.SourceName, source, "======RefreshPredictEdbCalculateData:", startDate)
- result, err := RefreshPredictEdbCalculateData(v.EdbInfoId, v.EdbCode, startDate)
- if err != nil {
- err = errors.New("RefreshPredictEdbCalculateData Err:" + err.Error())
- return err
- }
- if result.Ret != 200 {
- err = errors.New("RefreshPredictEdbCalculateData err;msg:" + result.Msg + ";errMsg:" + result.ErrMsg)
- return err
- }
- }
- return err
- }
- // RefreshDataFromManual 刷新手工指标数据
- func RefreshDataFromManual(wg *sync.WaitGroup) (err error) {
- errMsgList := make([]string, 0)
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromManual Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromManual ErrMsg:"+err.Error(), 3)
- }
- if len(errMsgList) > 0 {
- errMsg := "RefreshDataFromManual Err:" + strings.Join(errMsgList, "\n")
- fmt.Println(errMsg)
- go alarm_msg.SendAlarmMsg(errMsg, 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_MANUAL)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := v.StartDate.Format(utils.FormatDate)
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- errMsgList = append(errMsgList, v.EdbCode+"RefreshEdbData Err:"+err.Error())
- continue
- }
- if resp.Ret != 200 {
- errMsgList = append(errMsgList, v.EdbCode+";RefreshEdbData Err:"+resp.Msg+";ErrMsg:"+resp.ErrMsg)
- continue
- }
- }
- return err
- }
- func ResetEdbInfoIsUpdate(cont context.Context) (err error) {
- go data_manage.ResetEdbInfoIsUpdate()
- return nil
- }
- // RefreshDataFromGoogleTravel RefreshDataFromEic 刷新谷歌出行数据
- func RefreshDataFromGoogleTravel(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromGoogleTravel Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromGoogleTravel ErrMsg:"+err.Error(), 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_GOOGLE_TRAVEL)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- return errors.New("RefreshEdbData Err:" + err.Error())
- }
- if resp.Ret != 200 {
- return errors.New("RefreshEdbData Err:" + resp.Msg + ";ErrMsg:" + resp.ErrMsg)
- }
- }
- return err
- }
- // RefreshDataFromEiaSteo 刷新eia steo 报告数据
- func RefreshDataFromEiaSteo(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromEiaSteo Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromEiaSteo ErrMsg:"+err.Error(), 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_EIA_STEO)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- return errors.New("RefreshDataFromEiaSteoData Err:" + err.Error())
- }
- if resp.Ret != 200 {
- return errors.New("RefreshDataFromEiaSteoData Err:" + resp.Msg + ";ErrMsg:" + resp.ErrMsg)
- }
- }
- return err
- }
- // RefreshDataFromZz 刷新郑商所数据
- func RefreshDataFromZz(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromZz Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromZz ErrMsg:"+err.Error(), 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_ZZ)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- return errors.New("RefreshEdbData Err:" + err.Error())
- }
- if resp.Ret != 200 {
- return errors.New("RefreshEdbData Err:" + resp.Msg + ";ErrMsg:" + resp.ErrMsg)
- }
- }
- return err
- }
- // RefreshDataFromSh 刷新上期所数据
- func RefreshDataFromSh(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromSh Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromSh ErrMsg:"+err.Error(), 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_SH)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- return errors.New("RefreshEdbData Err:" + err.Error())
- }
- if resp.Ret != 200 {
- return errors.New("RefreshEdbData Err:" + resp.Msg + ";ErrMsg:" + resp.ErrMsg)
- }
- }
- return err
- }
- // RefreshDataFromShfe 刷新上期能源数据
- func RefreshDataFromShfe(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromShfe Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromShfe ErrMsg:"+err.Error(), 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_SHFE)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- return errors.New("RefreshEdbData Err:" + err.Error())
- }
- if resp.Ret != 200 {
- return errors.New("RefreshEdbData Err:" + resp.Msg + ";ErrMsg:" + resp.ErrMsg)
- }
- }
- return err
- }
- // RefreshDataFromCffex 刷新中金所数据
- func RefreshDataFromCffex(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromCffex Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromCffex ErrMsg:"+err.Error(), 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_CFFEX)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- return errors.New("RefreshEdbData Err:" + err.Error())
- }
- if resp.Ret != 200 {
- return errors.New("RefreshEdbData Err:" + resp.Msg + ";ErrMsg:" + resp.ErrMsg)
- }
- }
- return err
- }
- // RefreshDataFromDl 刷新大商所数据
- func RefreshDataFromDl(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromDl Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromDl ErrMsg:"+err.Error(), 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_DL)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- return errors.New("RefreshEdbData Err:" + err.Error())
- }
- if resp.Ret != 200 {
- return errors.New("RefreshEdbData Err:" + resp.Msg + ";ErrMsg:" + resp.ErrMsg)
- }
- }
- return err
- }
- // RefreshDataFromYs 刷新有色数据
- func RefreshDataFromYs(wg *sync.WaitGroup) (err error) {
- errMsgList := make([]string, 0)
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromYs Err:" + err.Error())
- //go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "RefreshDataFromYs ErrMsg:"+err.Error(), utils.EmailSendToUsers)
- go alarm_msg.SendAlarmMsg("RefreshDataFromYs ErrMsg:"+err.Error(), 3)
- }
- if len(errMsgList) > 0 {
- errMsg := "RefreshDataFromYs Err:" + strings.Join(errMsgList, "\n")
- fmt.Println(errMsg)
- go alarm_msg.SendAlarmMsg(errMsg, 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_YS)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- errMsgList = append(errMsgList, v.EdbCode+"RefreshEdbData Err:"+err.Error())
- continue
- }
- if resp.Ret != 200 {
- errMsgList = append(errMsgList, v.EdbCode+";RefreshEdbData Err:"+resp.Msg+";ErrMsg:"+resp.ErrMsg)
- continue
- }
- }
- return err
- }
- // 刷新钢联数据
- func RefreshDataFromGl(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromGl Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromGl ErrMsg:"+err.Error(), 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_GL)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- return errors.New("RefreshEdbData Err:" + err.Error())
- }
- if resp.Ret != 200 {
- return errors.New("RefreshEdbData Err:" + resp.Msg + ";ErrMsg:" + resp.ErrMsg)
- }
- }
- return err
- }
- // RefreshDataFromLt 刷新路透数据
- func RefreshDataFromLt(wg *sync.WaitGroup) (err error) {
- errMsgList := make([]string, 0)
- defer func() {
- if len(errMsgList) > 0 {
- fmt.Println("RefreshDataFromLt Err:", errMsgList)
- go alarm_msg.SendAlarmMsg("RefreshDataFromLt ErrMsg:"+strings.Join(errMsgList, `<br/>`), 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_LT)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- errMsgList = append(errMsgList, "GetEdbInfoByCondition:"+err.Error())
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- fmt.Println(v.EdbCode, v.Frequency, v.EndDate)
- startDate := v.StartDate.Format(utils.FormatDate)
- resp, err := RefreshEdbData(v.EdbInfoId, v.SubSource, v.Source, v.EdbCode, startDate)
- if err != nil {
- errMsgList = append(errMsgList, "RefreshEdbData Err:"+err.Error())
- continue
- }
- if resp.Ret != 200 {
- errMsgList = append(errMsgList, "RefreshEdbData Err:"+resp.Msg+";ErrMsg:"+resp.ErrMsg)
- continue
- }
- }
- return err
- }
- // RefreshDataFromCoal 刷新煤炭网数据
- func RefreshDataFromCoal(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromCoal Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromCoal ErrMsg:"+err.Error(), 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_COAL)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- return errors.New("RefreshEdbData Err:" + err.Error())
- }
- if resp.Ret != 200 {
- return errors.New("RefreshEdbData Err:" + resp.Msg + ";ErrMsg:" + resp.ErrMsg)
- }
- }
- return err
- }
- // RefreshDataFromMysteelChemical 刷新钢联化工数据
- func RefreshDataFromMysteelChemical(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromMysteelChemical Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromMysteelChemical ErrMsg:"+err.Error(), 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_MYSTEEL_CHEMICAL)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- return errors.New("RefreshEdbData Err:" + err.Error())
- }
- if resp.Ret != 200 {
- return errors.New("RefreshEdbData Err:" + resp.Msg + ";ErrMsg:" + resp.ErrMsg)
- }
- }
- return err
- }
- // RefreshDataFromComTrade 刷新 UN 数据
- func RefreshDataFromComTrade(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromComTrade Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromComTrade ErrMsg:"+err.Error(), 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_COM_TRADE)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- return errors.New("RefreshDataFromComTrade Err:" + err.Error())
- }
- if resp.Ret != 200 {
- return errors.New("RefreshDataFromComTrade Err:" + resp.Msg + ";ErrMsg:" + resp.ErrMsg)
- }
- }
- return err
- }
- // RefreshDataFromSci 刷新 卓创 数据
- func RefreshDataFromSci(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromSci Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromSci ErrMsg:"+err.Error(), 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_SCI)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- return errors.New("RefreshDataFromSci Err:" + err.Error())
- }
- if resp.Ret != 200 {
- return errors.New("RefreshDataFromSci Err:" + resp.Msg + ";ErrMsg:" + resp.ErrMsg)
- }
- }
- return err
- }
- // RefreshDataFromNationalStatistics 刷新统计局数据
- func RefreshDataFromNationalStatistics(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromNationalStatistics Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromNationalStatistics ErrMsg:"+err.Error(), 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += ` AND source = ? `
- pars = append(pars, utils.DATA_SOURCE_NATIONAL_STATISTICS)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- return errors.New("RefreshDataFromNationalStatistics Err:" + err.Error())
- }
- if resp.Ret != 200 {
- return errors.New("RefreshDataFromNationalStatistics Err:" + resp.Msg + ";ErrMsg:" + resp.ErrMsg)
- }
- }
- return err
- }
- // RefreshDataFromEic 刷欧洲天然气数据
- func RefreshDataFromEic(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromEic Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromEic ErrMsg:"+err.Error(), 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_GIE)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- return errors.New("RefreshEdbData Err:" + err.Error())
- }
- if resp.Ret != 200 {
- return errors.New("RefreshEdbData Err:" + resp.Msg + ";ErrMsg:" + resp.ErrMsg)
- }
- }
- return err
- }
- // RefreshJiaYueDataFromBridge 嘉悦物产-刷新数据宝指标
- func RefreshJiaYueDataFromBridge(cont context.Context) (err error) {
- utils.FileLog.Info(fmt.Sprintf("嘉悦-开始刷新数据宝指标: %s", time.Now().Format(utils.FormatDateTime)))
- defer func() {
- if err != nil {
- tips := fmt.Sprintf("RefreshJiaYueDataFromBridge ErrMsg: %s", err.Error())
- utils.FileLog.Info(tips)
- go alarm_msg.SendAlarmMsg(tips, 3)
- }
- utils.FileLog.Info(fmt.Sprintf("嘉悦-结束刷新数据宝指标: %s", time.Now().Format(utils.FormatDateTime)))
- }()
- // 获取来自桥接服务的指标来源
- cond := ` AND from_bridge = 1`
- pars := make([]interface{}, 0)
- sources, e := data_manage.GetEdbSourceItemsByCondition(cond, pars, []string{}, "")
- if e != nil {
- err = fmt.Errorf("获取来自桥接服务的数据源失败, err: %s", e.Error())
- return
- }
- sourceArr := make([]string, 0)
- for _, v := range sources {
- if v.EdbSourceId <= 0 {
- continue
- }
- sourceArr = append(sourceArr, strconv.Itoa(v.EdbSourceId))
- }
- if len(sourceArr) == 0 {
- utils.FileLog.Info("RefreshJiaYueDataFromBridge 无数据来源")
- return
- }
- // 获取指标
- edbCond := fmt.Sprintf(` AND source IN (%s)`, utils.GetOrmInReplace(len(sourceArr)))
- edbPars := make([]interface{}, 0)
- edbPars = append(edbPars, sourceArr)
- items, e := data_manage.GetEdbInfoByCondition(edbCond, edbPars, 0)
- if e != nil {
- err = fmt.Errorf("GetEdbInfoByCondition err: %s", e.Error())
- return
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, e := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if e != nil {
- utils.FileLog.Info(fmt.Sprintf("RefreshEdbData err: %s", e.Error()))
- //err = fmt.Errorf("RefreshEdbData err: %s", e.Error())
- continue
- }
- if resp.Ret != 200 {
- utils.FileLog.Info(fmt.Sprintf("RefreshEdbData indexCode: %s, err: %s, errMsg: %s", v.EdbCode, resp.Msg, resp.ErrMsg))
- //err = fmt.Errorf("RefreshEdbData Err: %s; ErrMsg: %s", resp.Msg, resp.ErrMsg)
- continue
- }
- }
- return
- }
- // RefreshDataFromFubao 刷新富宝数据
- func RefreshDataFromFubao(wg *sync.WaitGroup) (err error) {
- errMsgList := make([]string, 0)
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromFubao Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromFubao ErrMsg:"+err.Error(), 3)
- }
- if len(errMsgList) > 0 {
- errMsg := "RefreshDataFromFubao Err:" + strings.Join(errMsgList, "\n")
- fmt.Println(errMsg)
- go alarm_msg.SendAlarmMsg(errMsg, 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += ` AND source=? AND no_update = 0 `
- pars = append(pars, utils.DATA_SOURCE_FUBAO)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return err
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- errMsgList = append(errMsgList, v.EdbCode+"RefreshEdbData Err:"+err.Error())
- continue
- }
- if resp.Ret != 200 {
- errMsgList = append(errMsgList, v.EdbCode+";RefreshEdbData Err:"+resp.Msg+";ErrMsg:"+resp.ErrMsg)
- continue
- }
- }
- fmt.Println("Fubao刷新结束")
- return err
- }
- // RefreshDataFromDl 刷新广期所数据
- func RefreshDataFromGz(wg *sync.WaitGroup) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("RefreshDataFromGz Err:" + err.Error())
- go alarm_msg.SendAlarmMsg("RefreshDataFromGz ErrMsg:"+err.Error(), 3)
- }
- wg.Done()
- }()
- var condition string
- var pars []interface{}
- condition += " AND source=? "
- pars = append(pars, utils.DATA_SOURCE_GFEX)
- items, err := data_manage.GetEdbInfoByCondition(condition, pars, 0)
- if err != nil {
- return errors.New("GetEdbInfoByCondition:" + err.Error())
- }
- for _, v := range items {
- startDate := ""
- if v.Frequency == "日度" {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- } else if v.Frequency == "周度" {
- startDate = v.EndDate.AddDate(0, 0, -(utils.DATA_REFRESH * 7)).Format(utils.FormatDate)
- } else if v.Frequency == "月度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH, 0).Format(utils.FormatDate)
- } else if v.Frequency == "季度" {
- startDate = v.EndDate.AddDate(0, -utils.DATA_REFRESH*3, 0).Format(utils.FormatDate)
- } else if v.Frequency == "年度" {
- startDate = v.EndDate.AddDate(-utils.DATA_REFRESH, 0, 0).Format(utils.FormatDate)
- } else {
- startDate = v.EndDate.AddDate(0, 0, -utils.DATA_REFRESH).Format(utils.FormatDate)
- }
- resp, err := RefreshEdbData(v.EdbInfoId, v.Source, v.SubSource, v.EdbCode, startDate)
- if err != nil {
- return errors.New("RefreshEdbData Err:" + err.Error())
- }
- if resp.Ret != 200 {
- return errors.New("RefreshEdbData Err:" + resp.Msg + ";ErrMsg:" + resp.ErrMsg)
- }
- }
- return err
- }
|