task.go 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467
  1. package services
  2. import (
  3. "eta/eta_api/models"
  4. "eta/eta_api/services/alarm_msg"
  5. "eta/eta_api/services/data"
  6. "eta/eta_api/utils"
  7. "fmt"
  8. "strings"
  9. "time"
  10. )
  11. func Task() {
  12. fmt.Println("task start")
  13. {
  14. // 修复客户试用数据
  15. //FixCompanyUpdateData()
  16. //FixCompanyTryDay()
  17. //FixCompanyTryDay()
  18. //StaticCompanyTryDay()
  19. //return
  20. }
  21. UploadMinIo()
  22. //FixPermissionStatus()
  23. //GetCompanyInfo()
  24. //ReportCount()
  25. //windSourceUrl:=`http://47.100.166.55:7002/edbInfo/wind/?EdbCode=M0001427&StartDate=2020-11-01&EndDate=2021-03-01`
  26. //data.AddAllArticle()
  27. //data.GetSmmIndex()
  28. //data.GetSmmIndexData()
  29. go AutoInsertLogToDB()
  30. //手工数据表格导入后的指标库刷新
  31. go ImportManualDataRefresh()
  32. //修复用户关注标识
  33. //GetWxUsersSubscribe()
  34. go AutoInsertAdminOperateRecordToDB()
  35. // TODO:修复权限
  36. //FixEnCompanyPermission()
  37. fmt.Println("task end")
  38. }
  39. // 每日发布晨报
  40. func AutoPublishDayReport() {
  41. defer func() {
  42. if err := recover(); err != nil {
  43. fmt.Println("[AutoPublishDayReport]", err)
  44. }
  45. }()
  46. // 每日8:42发布晨报
  47. ticker := time.Tick(50 * time.Second)
  48. for range ticker {
  49. nowTime := time.Now()
  50. clock := nowTime.Format("1504")
  51. if clock == "0842" {
  52. if err := PublishTodayDayReport(); err != nil {
  53. go alarm_msg.SendAlarmMsg(fmt.Sprint("每日晨报自动发送 AutoPublishDayReport ERR:", err), 3)
  54. //utils.SendEmail(utils.APPNAME+" "+utils.RunMode+" 失败提醒", fmt.Sprint("AutoPublishDayReport ERR:", err), utils.EmailSendToUsers)
  55. }
  56. }
  57. }
  58. }
  59. // ImportManualDataRefresh 导入手工数据后的刷新
  60. func ImportManualDataRefresh() {
  61. defer func() {
  62. if err := recover(); err != nil {
  63. fmt.Println("[ImportManualDataRefresh]", err)
  64. }
  65. }()
  66. for {
  67. utils.Rc.Brpop(utils.CACHE_IMPORT_MANUAL_DATA, func(b []byte) {
  68. edbCode := string(b)
  69. edbCode = strings.TrimPrefix(edbCode, `"`)
  70. edbCode = strings.TrimSuffix(edbCode, `"`)
  71. data.RefreshManualData(edbCode)
  72. })
  73. }
  74. }
  75. //func init() {
  76. // fmt.Println("start task init")
  77. // UpdateEnglishEmailLogErrMsg()
  78. // fmt.Println("end task init")
  79. //}
  80. //
  81. //// UpdateEnglishEmailLogErrMsg 更新英文邮件日志的ErrMsg(研报后台4.2上线后执行, 仅一次)
  82. //func UpdateEnglishEmailLogErrMsg() {
  83. // var cond string
  84. // var pars []interface{}
  85. // list, e := models.GetEnglishReportEmailLogList(cond, pars)
  86. // if e != nil {
  87. // fmt.Println("获取日志列表失败")
  88. // return
  89. // }
  90. // for _, v := range list {
  91. // if v.SendStatus != 0 || v.Source != 1 || v.Result == "" || v.ErrMsg != "" {
  92. // continue
  93. // }
  94. // // 取出错误信息
  95. // fmt.Printf("正在更新%d\n", v.Id)
  96. // r := new(AliyunEmailResult)
  97. // if e = json.Unmarshal([]byte(v.Result), &r); e != nil {
  98. // fmt.Println("JSON解析报错了1" + e.Error())
  99. // continue
  100. // }
  101. // rd := new(AliyunEmailResultData)
  102. // res := strings.Replace(r.Data, `\`, ``, -1)
  103. // if e = json.Unmarshal([]byte(res), &rd); e != nil {
  104. // fmt.Println("JSON解析报错了2" + e.Error())
  105. // continue
  106. // }
  107. // v.ErrMsg = rd.Message
  108. // if e = v.Update([]string{"ErrMsg"}); e != nil {
  109. // fmt.Println("更新失败了" + e.Error())
  110. // continue
  111. // }
  112. // }
  113. // fmt.Println("更新成功")
  114. //}
  115. //func FixCompanyUpdateData1() {
  116. // list, err := company.GetCompanyProductUpdateLogList()
  117. // if err != nil {
  118. // fmt.Println("获取客户变更数据失败:", err)
  119. // return
  120. // }
  121. //
  122. // nowTime := time.Now()
  123. // for _, v := range list {
  124. // //item, tmpErr := company.GetCompanyProductLogItem(v.CompanyId, v.ProductId, v.CreateTime)
  125. // //if tmpErr != nil {
  126. // // fmt.Println(v.Id, "找数据,", tmpErr)
  127. // // continue
  128. // //}
  129. //
  130. // //permissionList := make([]*company.CompanyReportPermission, 0)
  131. // //switch v.Source {
  132. // //case "add", "receive", "thaw", "delay", "apply_receive":
  133. // //
  134. // //}
  135. // permissionList, err := company.GetCompanyReportPermission(v.CompanyId, v.ProductId)
  136. // if err != nil {
  137. // fmt.Println("err:", err)
  138. // continue
  139. // }
  140. //
  141. // startDate := v.CreateTime
  142. // endDate := v.CreateTime.AddDate(0, 2, 0)
  143. // isStop := 1
  144. // realEndDate := endDate
  145. // if realEndDate.After(nowTime) {
  146. // realEndDate = nowTime
  147. // isStop = 0
  148. // }
  149. // for _, permission := range permissionList {
  150. // permission.StartDate = startDate.Format(utils.FormatDate)
  151. // permission.EndDate = v.CreateTime.Format(utils.FormatDate)
  152. // }
  153. // companyProductTryOutUpdateLogItem := &company.CompanyProductTryOutUpdateLog{
  154. // Id: 0,
  155. // CompanyId: v.CompanyId,
  156. // ProductId: v.ProductId,
  157. // SellerId: v.SellerId,
  158. // SellerName: v.SellerName,
  159. // Source: v.Source,
  160. // StartDate: startDate,
  161. // EndDate: endDate,
  162. // RealEndDate: realEndDate,
  163. // IsStop: isStop,
  164. // CreateTime: v.CreateTime,
  165. // }
  166. // err = company.AddCompanyProductTryOutUpdateLog(companyProductTryOutUpdateLogItem, permissionList)
  167. // }
  168. // //fmt.Println("结束")
  169. //}
  170. //func FixCompanyUpdateData2() {
  171. // list, err := company.GetTryOutCompanyOperationRecordList()
  172. // if err != nil {
  173. // fmt.Println("获取客户变更数据失败:", err)
  174. // return
  175. // }
  176. //
  177. // nowTime := time.Now()
  178. // for _, v := range list {
  179. // //item, tmpErr := company.GetCompanyProductLogItem(v.CompanyId, v.ProductId, v.CreateTime)
  180. // //if tmpErr != nil {
  181. // // fmt.Println(v.Id, "找数据,", tmpErr)
  182. // // continue
  183. // //}
  184. //
  185. // //permissionList := make([]*company.CompanyReportPermission, 0)
  186. // //switch v.Source {
  187. // //case "add", "receive", "thaw", "delay", "apply_receive":
  188. // //
  189. // //}
  190. // permissionList, err := company.GetCompanyReportPermission(v.CompanyId, v.ProductId)
  191. // if err != nil {
  192. // fmt.Println("err:", err)
  193. // continue
  194. // }
  195. //
  196. // startDate := v.CreateTime
  197. // endDate := v.CreateTime.AddDate(0, 2, 0)
  198. // isStop := 1
  199. // realEndDate := endDate
  200. // if realEndDate.After(nowTime) {
  201. // realEndDate = nowTime
  202. // isStop = 0
  203. // }
  204. // for _, permission := range permissionList {
  205. // permission.StartDate = startDate.Format(utils.FormatDate)
  206. // permission.EndDate = v.CreateTime.Format(utils.FormatDate)
  207. // }
  208. // sellerName := ``
  209. // {
  210. // sysUser, _ := system.GetSysAdminById(v.SellerId)
  211. // if sysUser != nil {
  212. // sellerName = sysUser.RealName
  213. // }
  214. // }
  215. // companyProductTryOutUpdateLogItem := &company.CompanyProductTryOutUpdateLog{
  216. // Id: 0,
  217. // CompanyId: v.CompanyId,
  218. // ProductId: v.ProductId,
  219. // SellerId: v.SellerId,
  220. // SellerName: sellerName,
  221. // Source: "formal_to_try_out",
  222. // StartDate: startDate,
  223. // EndDate: endDate,
  224. // RealEndDate: realEndDate,
  225. // IsStop: isStop,
  226. // CreateTime: v.CreateTime,
  227. // }
  228. // err = company.AddCompanyProductTryOutUpdateLog(companyProductTryOutUpdateLogItem, permissionList)
  229. // }
  230. // fmt.Println("结束")
  231. //}
  232. // FixCompanyTryDay 修复试用天数
  233. //func FixCompanyTryDay() {
  234. // list, err := company.GetCompanyProductTryOutUpdateGroup()
  235. // if err != nil {
  236. // fmt.Println("获取客户变更数据失败:", err)
  237. // return
  238. // }
  239. //
  240. // lenList := len(list)
  241. // for k, v := range list {
  242. // fmt.Println("剩余", lenList-k-1, "条数据修复")
  243. // companyProduct, tmpErr := company.GetCompanyProductByCompanyIdAndProductId(v.CompanyId, v.ProductId)
  244. // if tmpErr != nil {
  245. // fmt.Println("company_id:", v.CompanyId, ";product_id:", v.ProductId, ";找不到对应的客户,Err:", tmpErr)
  246. // continue
  247. // }
  248. //
  249. // logList, err := company.GetCompanyProductTryOutUpdateList(v.CompanyId, v.ProductId)
  250. // if err != nil {
  251. // fmt.Println("查找客户日志失败,err:", err)
  252. // continue
  253. // }
  254. //
  255. // //lenLog := len(logList)
  256. // var day int //实际试用天数
  257. // var endDate time.Time
  258. // for _, log := range logList {
  259. // startDate := log.StartDate
  260. // if endDate.IsZero() {
  261. // endDate = log.RealEndDate
  262. // day = utils.GetTimeSubDay(startDate, log.RealEndDate) + 1
  263. // } else {
  264. // if log.RealEndDate.After(endDate) {
  265. // if endDate.After(startDate) {
  266. // startDate = endDate
  267. // }
  268. // if startDate.Equal(log.EndDate) {
  269. // day += utils.GetTimeSubDay(startDate, log.RealEndDate)
  270. // } else {
  271. // day += utils.GetTimeSubDay(startDate, log.RealEndDate) + 1
  272. // }
  273. // endDate = log.RealEndDate
  274. // }
  275. // }
  276. // }
  277. // companyProduct.TryOutDayTotal = day
  278. // companyProduct.Update([]string{"TryOutDayTotal"})
  279. // }
  280. // fmt.Println("结束")
  281. //}
  282. // StaticCompanyTryDay 定时任务每天更新试用天数
  283. //func StaticCompanyTryDay() {
  284. // list, err := company.GetCompanyProductTryOutUpdateNoStopGroup()
  285. // if err != nil {
  286. // fmt.Println("获取客户变更数据失败:", err)
  287. // return
  288. // }
  289. //
  290. // lenList := len(list)
  291. // for k, v := range list {
  292. // isAdd := false //是否要增加一天,默认不加
  293. // fmt.Println("剩余", lenList-k-1, "条数据修复")
  294. // permissionList, tmpErr := company.GetCompanyReportPermissionByStatus(v.CompanyId, v.ProductId, "试用")
  295. // if tmpErr == nil {
  296. // fmt.Println("company_id:", v.CompanyId, ";product_id:", v.ProductId, ";寻找对应的试用品种失败,Err:", tmpErr)
  297. // continue
  298. // }
  299. // currPermissionIdList := make([]int, 0) //当前试用的品种
  300. // for _, permission := range permissionList {
  301. // currPermissionIdList = append(currPermissionIdList, permission.ChartPermissionId)
  302. // }
  303. //
  304. // //获取所有未停止的记录列表
  305. // logList, err := company.GetCompanyProductTryOutUpdateNoStopListByEndDate(v.CompanyId, v.ProductId)
  306. // if err != nil {
  307. // fmt.Println("查找客户日志失败,err:", err)
  308. // continue
  309. // }
  310. //
  311. // logPermissionIdList := make([]int, 0) //当前日志中的试用的品种
  312. // for _, log := range logList {
  313. // //获取所有未停止的品种试用记录列表
  314. // logPermissionList, tmpErr := company.GetCompanyProductTryOutPermissionUpdateNoStopListByEndDate(log.Id)
  315. // if tmpErr != nil {
  316. // fmt.Println("查找客户品种变更日志失败,err:", tmpErr)
  317. // continue
  318. // }
  319. // lenLogPermissionList := len(logPermissionList) //当前日志存在试用的品种数量
  320. // stopPermission := 0 //当前日志需要停止的品种数量
  321. //
  322. // currTime := time.Now() //当前时间
  323. // for _, logPermission := range logPermissionList {
  324. // if utils.InArrayByInt(logPermissionIdList, logPermission.ChartPermissionId) {
  325. // // 如果已经被其他记录使用了,那么就将当前记录给标记停止
  326. // logPermission.IsStop = 1
  327. //
  328. // // 如果当前时间晚于结束日期,那么实际结束日期就是今天之前一天,否则就是当天
  329. // if currTime.After(logPermission.EndDate) {
  330. // logPermission.RealEndDate = currTime.AddDate(0, 0, -1)
  331. // } else {
  332. // logPermission.RealEndDate = time.Now()
  333. // }
  334. // logPermission.Update([]string{"IsStop", "RealEndDate"})
  335. // stopPermission++
  336. // continue
  337. // } else if !utils.InArrayByInt(currPermissionIdList, logPermission.ChartPermissionId) {
  338. // // 如果该品种不在当前客户的品种里面,那么也要将当前记录给标记停止
  339. // logPermission.IsStop = 1
  340. // // 如果当前时间晚于结束日期,那么实际结束日期就是今天之前一天,否则就是当天
  341. // if currTime.After(logPermission.EndDate) {
  342. // logPermission.RealEndDate = currTime.AddDate(0, 0, -1)
  343. // } else {
  344. // logPermission.RealEndDate = time.Now()
  345. // }
  346. // logPermission.Update([]string{"IsStop", "RealEndDate"})
  347. // stopPermission++
  348. // continue
  349. // }
  350. //
  351. // // 剩下的说明还处于试用状态,需要添加1天试用期,且需要把该品种加入到当前日志中的试用的品种列表
  352. // isAdd = true
  353. // logPermissionIdList = append(logPermissionIdList, logPermission.ChartPermissionId)
  354. // }
  355. //
  356. // //如果当前日志存在试用的品种数量 == 当前日志需要停止的品种数量
  357. // // 那么当前日志也是处于停用状态
  358. // if lenLogPermissionList == stopPermission {
  359. // log.IsStop = 1
  360. // // 如果当前时间晚于结束日期,那么实际结束日期就是今天之前一天,否则就是当天
  361. // if currTime.After(log.EndDate) {
  362. // log.RealEndDate = currTime.AddDate(0, 0, -1)
  363. // } else {
  364. // log.RealEndDate = time.Now()
  365. // }
  366. // log.Update([]string{"IsStop", "RealEndDate"})
  367. // }
  368. //
  369. // }
  370. //
  371. // // 如果需要添加,那么将该客户品种添加1天
  372. // if isAdd {
  373. //
  374. // }
  375. // // 更新客户产品的试用天数
  376. // tmpErr = company.AddCompanyProductTryOutDayTotal(v.CompanyId, v.ProductId)
  377. // if tmpErr != nil {
  378. // fmt.Println("company_id:", v.CompanyId, ";product_id:", v.ProductId, ";更新客户产品的试用天数,Err:", tmpErr)
  379. // continue
  380. // }
  381. // }
  382. // fmt.Println("结束")
  383. //}
  384. //func Task2() {
  385. // fmt.Println("task start")
  386. //
  387. // //_, _ = maycur.GetPublicOfferingSaleLeader()
  388. // //_ = maycur.TestSyncCompanyProfile()
  389. // //_ = maycur.SyncCompanyProfile()
  390. // //_ = maycur.ImportExcelEmployeeId()
  391. // //_ = maycur.ApiTest()
  392. // //_ = maycur.ApiTest2()
  393. // fmt.Println("task end")
  394. //}
  395. // FixEnCompanyPermission 英文权限上线时修复英文客户拥有所有权限(一次性)
  396. func FixEnCompanyPermission() {
  397. var err error
  398. defer func() {
  399. if err != nil {
  400. fmt.Println("FixEnCompanyPermission Err: ", err.Error())
  401. }
  402. }()
  403. // 获取正式客户
  404. companies := make([]*models.EnglishCompany, 0)
  405. {
  406. cond := ` AND status = ?`
  407. pars := make([]interface{}, 0)
  408. pars = append(pars, 1)
  409. list, e := models.GetEnglishCompanyList(cond, pars, "")
  410. if e != nil {
  411. err = fmt.Errorf("GetEnglishCompanyList err: %s", e.Error())
  412. return
  413. }
  414. companies = list
  415. }
  416. // 获取所有权限
  417. permissions := make([]*models.EnPermission, 0)
  418. {
  419. cond := ` AND parent_id > ?`
  420. pars := make([]interface{}, 0)
  421. pars = append(pars, 0)
  422. ob := new(models.EnPermission)
  423. list, e := ob.GetItemsByCondition(cond, pars, []string{}, "")
  424. if e != nil {
  425. err = fmt.Errorf("GetPermissionItemsByCondition err: %s", e.Error())
  426. return
  427. }
  428. permissions = list
  429. }
  430. for _, c := range companies {
  431. ps := make([]*models.EnCompanyPermission, 0)
  432. for _, p := range permissions {
  433. ps = append(ps, &models.EnCompanyPermission{
  434. EnCompanyId: c.CompanyId,
  435. EnPermissionId: p.EnPermissionId,
  436. CreateTime: time.Now().Local(),
  437. })
  438. }
  439. if e := models.ClearAndCreateEnCompanyPermissions(c.CompanyId, ps); e != nil {
  440. err = fmt.Errorf("ClearAndCreateEnCompanyPermissions err: %s", e.Error())
  441. return
  442. }
  443. }
  444. fmt.Println("修复完成")
  445. }