edb_monitor.go 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530
  1. package edbmonitor
  2. import (
  3. "eta/eta_api/models/data_manage"
  4. edbmonitor "eta/eta_api/models/edb_monitor"
  5. "eta/eta_api/models/edb_monitor/request"
  6. "eta/eta_api/models/edb_monitor/response"
  7. "eta/eta_api/models/system"
  8. "eta/eta_api/utils"
  9. "fmt"
  10. "strconv"
  11. "strings"
  12. "time"
  13. "github.com/rdlucklib/rdluck_tools/paging"
  14. )
  15. // 预警触发状态
  16. const (
  17. EDB_MONITOR_STATE_CLOSE = iota
  18. EDB_MONITOR_STATE_NO_TRIGGER
  19. EDB_MONITOR_STATE_TRIGGER_SUCCESS
  20. )
  21. // 预警突破方式
  22. const (
  23. EDB_MONITOR_TYPE_UP = iota
  24. EDB_MONITOR_TYPE_DOWN
  25. )
  26. func GetMonitorList(classifyId, level, state, userId string, pageSize, currentIndex int) (resp response.EdbMonitorInfoListResp, msg string, err error) {
  27. if pageSize <= 0 {
  28. pageSize = utils.PageSize20
  29. }
  30. if currentIndex <= 0 {
  31. currentIndex = 1
  32. }
  33. startSize := utils.StartIndex(currentIndex, pageSize)
  34. var classifyIdList []int
  35. if classifyId != "" {
  36. tmp := strings.Split(classifyId, ",")
  37. for _, v := range tmp {
  38. cv, _ := strconv.Atoi(v)
  39. classifyIdList = append(classifyIdList, cv)
  40. }
  41. }
  42. var levelList []string
  43. if level != "" {
  44. levelList = strings.Split(level, ",")
  45. }
  46. var stateList []int
  47. if state != "" {
  48. tmp := strings.Split(state, ",")
  49. for _, v := range tmp {
  50. st, _ := strconv.Atoi(v)
  51. stateList = append(stateList, st)
  52. }
  53. }
  54. var userIdList []int
  55. if userId != "" {
  56. tmp := strings.Split(userId, ",")
  57. for _, v := range tmp {
  58. ui, _ := strconv.Atoi(v)
  59. userIdList = append(userIdList, ui)
  60. }
  61. }
  62. var conditon string
  63. var pars []interface{}
  64. if len(classifyIdList) != 0 {
  65. conditon += ` AND edb_monitor_classify_id IN (` + utils.GetOrmInReplace(len(classifyIdList)) + ` )`
  66. pars = append(pars, classifyIdList)
  67. }
  68. if len(levelList) != 0 {
  69. conditon += ` AND monitor_level IN (` + utils.GetOrmInReplace(len(levelList)) + ` )`
  70. pars = append(pars, levelList)
  71. }
  72. if len(stateList) != 0 {
  73. conditon += ` AND state IN (` + utils.GetOrmInReplace(len(stateList)) + ` )`
  74. pars = append(pars, stateList)
  75. }
  76. if len(userIdList) != 0 {
  77. conditon += ` AND create_user_id IN (` + utils.GetOrmInReplace(len(userIdList)) + ` )`
  78. pars = append(pars, userIdList)
  79. }
  80. total, err := edbmonitor.GetEdbMonitorInfoCountByCondition(conditon, pars)
  81. if err != nil {
  82. msg = "获取监控列表失败"
  83. err = fmt.Errorf("GetEdbMonitorInfoCountByCondition err:%w", err)
  84. return
  85. }
  86. edbMonitorList, err := edbmonitor.GetEdbMonitorInfoPageByCondition(conditon, pars, startSize, pageSize)
  87. if err != nil {
  88. msg = "获取监控列表失败"
  89. err = fmt.Errorf("GetEdbMonitorInfoPageByCondition err:%w", err)
  90. return
  91. }
  92. var edbInfoId, edbUserId []int
  93. for _, v := range edbMonitorList {
  94. edbUserId = append(edbUserId, v.CreateUserId)
  95. edbInfoId = append(edbInfoId, v.EdbInfoId)
  96. }
  97. edbInfoList, err := data_manage.GetEdbInfoByIdList(edbInfoId)
  98. if err != nil {
  99. msg = "获取监控列表失败"
  100. err = fmt.Errorf("GetEdbInfoByIdList err:%w", err)
  101. return
  102. }
  103. infoMap := make(map[int]string)
  104. for _, v := range edbInfoList {
  105. infoMap[v.EdbInfoId] = v.EdbName
  106. }
  107. userInfoList, err := system.GetSysAdminByIdList(edbUserId)
  108. if err != nil {
  109. msg = "获取监控列表失败"
  110. err = fmt.Errorf("GetSysAdminByIdList err:%w", err)
  111. return
  112. }
  113. userMap := make(map[int]string)
  114. for _, v := range userInfoList {
  115. userMap[v.AdminId] = v.RealName
  116. }
  117. classifyList, err := edbmonitor.GetEdbMonitorClassifyList()
  118. if err != nil {
  119. msg = "获取监控列表失败"
  120. err = fmt.Errorf("GetEdbMonitorClassifyList err:%w", err)
  121. return
  122. }
  123. classifyMap := make(map[int]string)
  124. for _, v := range classifyList {
  125. classifyMap[v.ClassifyId] = v.ClassifyName
  126. }
  127. classifyPathMap := make(map[int]string)
  128. for _, v := range classifyList {
  129. var path []string
  130. if v.ParentId != 0 {
  131. parentName := classifyMap[v.ParentId]
  132. if v.RootId != 0 && v.RootId != v.ParentId {
  133. rootName := classifyMap[v.RootId]
  134. path = append(path, rootName)
  135. }
  136. curName := v.ClassifyName
  137. path = append(path, parentName, curName)
  138. } else {
  139. path = append(path, v.ClassifyName)
  140. }
  141. classifyPathMap[v.ClassifyId] = strings.Join(path, "/")
  142. }
  143. edbMonitorItems := toEdbMonitorInfoItems(edbMonitorList, userMap, classifyPathMap, infoMap)
  144. page := paging.GetPaging(currentIndex, pageSize, total)
  145. resp.List = edbMonitorItems
  146. resp.Paging = page
  147. return
  148. }
  149. func SaveEdbMonitorInfo(req request.EdbMonitorInfoSaveReq, adminId int) (msg string, err error) {
  150. edb, er := data_manage.GetEdbInfoById(req.EdbInfoId)
  151. if er != nil {
  152. if er.Error() == utils.ErrNoRow() {
  153. msg = "指标不存在,请刷新重试"
  154. err = er
  155. return
  156. }
  157. msg = "添加指标预警失败"
  158. err = er
  159. return
  160. }
  161. var edbMonitorInfo *edbmonitor.EdbMonitorInfo
  162. if req.EdbMonitorId > 0 {
  163. ok, msg1, er := OperatePermissionCheck(req.EdbMonitorId, adminId)
  164. if !ok {
  165. if msg1 == "" {
  166. msg1 = "编辑失败"
  167. }
  168. msg = msg1
  169. if er == nil {
  170. err = fmt.Errorf("权限校验失败")
  171. }
  172. return
  173. }
  174. edbMonitorInfo, er = edbmonitor.GetEdbMonitorInfoById(req.EdbMonitorId)
  175. if er != nil {
  176. if er.Error() == utils.ErrNoRow() {
  177. msg = "指标预警不存在,请刷新重试"
  178. err = er
  179. return
  180. }
  181. msg = "编辑指标预警失败"
  182. err = fmt.Errorf("GetEdbMonitorInfoById err:%w", er)
  183. return
  184. }
  185. var updateCols []string
  186. if edbMonitorInfo.EdbInfoId != req.EdbInfoId {
  187. updateCols = append(updateCols, []string{"edb_info_id", "edb_info_type", "edb_code", "edb_classify_id", "edb_unique_code", "source", "sub_source", "edb_latest_date", "edb_latest_value"}...)
  188. edbMonitorInfo.EdbInfoId = req.EdbInfoId
  189. edbMonitorInfo.EdbInfoType = edb.EdbInfoType
  190. edbMonitorInfo.EdbCode = edb.EdbCode
  191. edbMonitorInfo.EdbClassifyId = edb.ClassifyId
  192. edbMonitorInfo.EdbUniqueCode = edb.UniqueCode
  193. edbMonitorInfo.Source = edb.Source
  194. edbMonitorInfo.SubSource = edb.SubSource
  195. edbMonitorInfo.EdbLatestDate = edb.LatestDate
  196. edbMonitorInfo.EdbLatestValue = edb.LatestValue
  197. }
  198. if edbMonitorInfo.EdbMonitorName != req.EdbMonitorName {
  199. updateCols = append(updateCols, "edb_monitor_name")
  200. edbMonitorInfo.EdbMonitorName = req.EdbMonitorName
  201. }
  202. if edbMonitorInfo.EdbMonitorClassifyId != req.ClassifyId {
  203. updateCols = append(updateCols, "edb_monitor_classify_id")
  204. edbMonitorInfo.EdbMonitorClassifyId = req.ClassifyId
  205. }
  206. if edbMonitorInfo.MonitorType != req.MonitorType {
  207. updateCols = append(updateCols, "monitor_type")
  208. edbMonitorInfo.MonitorType = req.MonitorType
  209. }
  210. monitorData, _ := strconv.ParseFloat(req.MonitorData, 64)
  211. if edbMonitorInfo.MonitorData != monitorData {
  212. updateCols = append(updateCols, "monitor_data")
  213. edbMonitorInfo.MonitorData = monitorData
  214. }
  215. if edbMonitorInfo.MonitorLevel != req.MonitorLevel {
  216. updateCols = append(updateCols, "monitor_level")
  217. edbMonitorInfo.MonitorLevel = req.MonitorLevel
  218. }
  219. if len(updateCols) > 0 {
  220. updateCols = append(updateCols, "modify_time")
  221. edbMonitorInfo.ModifyTime = time.Now()
  222. er := edbMonitorInfo.Update(updateCols)
  223. if er != nil {
  224. msg = "编辑指标预警失败"
  225. err = fmt.Errorf("UpdateEdbMonitorInfoById err:%w", er)
  226. return
  227. }
  228. }
  229. } else {
  230. edbMonitorInfo = new(edbmonitor.EdbMonitorInfo)
  231. edbMonitorInfo.EdbMonitorClassifyId = req.ClassifyId
  232. edbMonitorInfo.EdbMonitorName = req.EdbMonitorName
  233. edbMonitorInfo.EdbInfoId = req.EdbInfoId
  234. edbMonitorInfo.EdbInfoType = edb.EdbInfoType
  235. edbMonitorInfo.EdbUniqueCode = edb.UniqueCode
  236. edbMonitorInfo.EdbClassifyId = edb.ClassifyId
  237. edbMonitorInfo.EdbCode = edb.EdbCode
  238. edbMonitorInfo.Source = edb.Source
  239. edbMonitorInfo.SubSource = edb.SubSource
  240. edbMonitorInfo.EdbLatestDate = edb.LatestDate
  241. edbMonitorInfo.EdbLatestValue = edb.LatestValue
  242. edbMonitorInfo.MonitorType = req.MonitorType
  243. monitorData, _ := strconv.ParseFloat(req.MonitorData, 64)
  244. edbMonitorInfo.MonitorData = monitorData
  245. edbMonitorInfo.MonitorLevel = req.MonitorLevel
  246. edbMonitorInfo.CreateUserId = adminId
  247. edbMonitorInfo.CreateTime = time.Now()
  248. edbMonitorInfo.ModifyTime = time.Now()
  249. insertId, er := edbMonitorInfo.Insert()
  250. if er != nil {
  251. msg = "添加指标预警失败"
  252. err = fmt.Errorf("insert err:%w", er)
  253. return
  254. }
  255. edbMonitorInfo.EdbMonitorId = int(insertId)
  256. }
  257. err = ModifyEdbMonitorState(edbMonitorInfo, edb.EdbCode, edb.Source, edb.SubSource)
  258. if err != nil {
  259. msg = "更新指标预警失败"
  260. err = fmt.Errorf("ModifyEdbMonitorState err:%w", err)
  261. return
  262. }
  263. return
  264. }
  265. func ModifyEdbMonitorState(edbMonitorInfo *edbmonitor.EdbMonitorInfo, edbCode string, source, subSource int) (err error) {
  266. cond := ` AND edb_code = ? `
  267. pars := []interface{}{edbCode}
  268. latestTwoData, er := data_manage.GetEdbDataListByCondition(cond, pars, source, subSource, 2, 0)
  269. if er != nil {
  270. err = fmt.Errorf("GetEdbDataListByCondition err:%w", er)
  271. return
  272. }
  273. var updateCols []string
  274. edbMonitorInfo.EdbLatestDate = latestTwoData[0].DataTime
  275. edbMonitorInfo.EdbLatestValue = latestTwoData[0].Value
  276. updateCols = append(updateCols, []string{"edb_latest_date", "edb_latest_value"}...)
  277. triggerState := cmpEdbMonitorState(latestTwoData, edbMonitorInfo.MonitorType, edbMonitorInfo.MonitorData)
  278. if triggerState == EDB_MONITOR_STATE_TRIGGER_SUCCESS {
  279. tmpTime, _ := time.Parse(utils.FormatDate, latestTwoData[0].DataTime)
  280. edbMonitorInfo.EdbTriggerDate = tmpTime
  281. edbMonitorInfo.MonitorTriggerTime = time.Now()
  282. updateCols = append(updateCols, []string{"edb_trigger_date", "monitor_trigger_time"}...)
  283. }
  284. if edbMonitorInfo.State == EDB_MONITOR_STATE_NO_TRIGGER || edbMonitorInfo.State == EDB_MONITOR_STATE_CLOSE {
  285. edbMonitorInfo.State = triggerState
  286. updateCols = append(updateCols, "state")
  287. }
  288. err = edbMonitorInfo.Update(updateCols)
  289. if err != nil {
  290. return
  291. }
  292. if triggerState == EDB_MONITOR_STATE_TRIGGER_SUCCESS {
  293. triggerTime := edbMonitorInfo.MonitorTriggerTime.Format(utils.FormatDateTime)
  294. err = SendMessages(edbMonitorInfo.CreateUserId, edbMonitorInfo.EdbInfoId, edbMonitorInfo.EdbInfoType, edbMonitorInfo.EdbMonitorClassifyId, edbMonitorInfo.EdbUniqueCode, edbMonitorInfo.EdbMonitorName, triggerTime)
  295. isRead := 1
  296. if err != nil {
  297. isRead = 0
  298. }
  299. err = LogMessage(edbMonitorInfo.EdbMonitorName, edbMonitorInfo.EdbUniqueCode, edbMonitorInfo.MonitorTriggerTime, edbMonitorInfo.EdbInfoId, edbMonitorInfo.EdbInfoType, edbMonitorInfo.CreateUserId, isRead, edbMonitorInfo.EdbClassifyId)
  300. }
  301. return
  302. }
  303. func cmpEdbMonitorState(twoData []*data_manage.EdbData, monitorType int, monitorData float64) int {
  304. if len(twoData) < 2 {
  305. return EDB_MONITOR_STATE_NO_TRIGGER
  306. }
  307. switch monitorType {
  308. case EDB_MONITOR_TYPE_UP:
  309. if twoData[0].Value >= monitorData && twoData[1].Value < monitorData {
  310. return EDB_MONITOR_STATE_TRIGGER_SUCCESS
  311. } else {
  312. return EDB_MONITOR_STATE_NO_TRIGGER
  313. }
  314. case EDB_MONITOR_TYPE_DOWN:
  315. if twoData[0].Value <= monitorData && twoData[1].Value > monitorData {
  316. return EDB_MONITOR_STATE_TRIGGER_SUCCESS
  317. } else {
  318. return EDB_MONITOR_STATE_NO_TRIGGER
  319. }
  320. default:
  321. return EDB_MONITOR_STATE_NO_TRIGGER
  322. }
  323. }
  324. func OperatePermissionCheck(edbMonitorId int, adminId int) (ok bool, msg string, err error) {
  325. monitorInfo, err := edbmonitor.GetEdbMonitorInfoById(edbMonitorId)
  326. if err != nil {
  327. if err.Error() == utils.ErrNoRow() {
  328. msg = "指标预警不存在,请刷新重试"
  329. return
  330. }
  331. msg = "删除失败"
  332. err = fmt.Errorf("获取预警详情失败, err:%w", err)
  333. return
  334. }
  335. if monitorInfo.CreateUserId != adminId {
  336. userInfo, er := system.GetSysAdminById(adminId)
  337. if er != nil {
  338. msg = "删除失败"
  339. err = fmt.Errorf("查询用户信息失败 err:%w", er)
  340. return
  341. }
  342. if userInfo.Role != utils.ROLE_TYPE_CODE_ADMIN {
  343. msg = "无权限操作"
  344. err = fmt.Errorf("无权限操作")
  345. return
  346. }
  347. }
  348. ok = true
  349. return
  350. }
  351. func DeleteEdbMonitorInfo(req request.EdbMonitorInfoDeleteReq, adminId int) (msg string, err error) {
  352. ok, msg, err := OperatePermissionCheck(req.EdbMonitorId, adminId)
  353. if !ok {
  354. if msg == "" {
  355. msg = "删除失败"
  356. }
  357. if err == nil {
  358. err = fmt.Errorf("权限校验失败")
  359. }
  360. return
  361. }
  362. err = edbmonitor.DeleteEdbMonitorInfoById(req.EdbMonitorId)
  363. if err != nil {
  364. msg = "删除失败"
  365. err = fmt.Errorf("删除预警失败 err:%w", err)
  366. }
  367. return
  368. }
  369. func GetEdbMonitorLevelList() (list []string, msg string, err error) {
  370. list, err = edbmonitor.GetEdbMonitorLevelList()
  371. if err != nil {
  372. msg = "获取等级等级列表失败"
  373. err = fmt.Errorf("GetEdbMonitorLevelList err:%w", err)
  374. return
  375. }
  376. return
  377. }
  378. func CloseEdbMonitorInfo(req request.EdbMonitorInfoCloseReq, adminId int) (msg string, err error) {
  379. edbMonitor, er := edbmonitor.GetEdbMonitorInfoById(req.EdbMonitorId)
  380. if er != nil {
  381. if er.Error() == utils.ErrNoRow() {
  382. msg = "指标预警不存在,请刷新重试"
  383. err = er
  384. }
  385. msg = "关闭失败"
  386. err = fmt.Errorf("获取预警详情失败, err:%w", er)
  387. return
  388. }
  389. ok, msg, err := OperatePermissionCheck(req.EdbMonitorId, adminId)
  390. if !ok {
  391. if msg == "" {
  392. msg = "删除失败"
  393. }
  394. if err == nil {
  395. err = fmt.Errorf("权限校验失败")
  396. }
  397. return
  398. }
  399. if edbMonitor.State == EDB_MONITOR_STATE_CLOSE {
  400. msg = "预警已关闭"
  401. err = fmt.Errorf("预警已关闭")
  402. return
  403. }
  404. edbMonitor.State = EDB_MONITOR_STATE_CLOSE
  405. edbMonitor.ModifyTime = time.Now()
  406. er = edbMonitor.Update([]string{"state", "modify_time"})
  407. if er != nil {
  408. msg = "关闭失败"
  409. err = fmt.Errorf("修改预警状态失败, err:%w", er)
  410. return
  411. }
  412. return
  413. }
  414. func RestartEdbMonitorInfo(req request.EdbMonitorInfoRestartReq, adminId int) (msg string, err error) {
  415. edbMonitor, er := edbmonitor.GetEdbMonitorInfoById(req.EdbMonitorId)
  416. if er != nil {
  417. if er.Error() == utils.ErrNoRow() {
  418. msg = "指标预警不存在,请刷新重试"
  419. err = er
  420. }
  421. msg = "重启失败"
  422. err = fmt.Errorf("获取预警详情失败, err:%w", er)
  423. return
  424. }
  425. ok, msg, err := OperatePermissionCheck(req.EdbMonitorId, adminId)
  426. if !ok {
  427. if msg == "" {
  428. msg = "删除失败"
  429. }
  430. if err == nil {
  431. err = fmt.Errorf("权限校验失败")
  432. }
  433. return
  434. }
  435. if edbMonitor.State != EDB_MONITOR_STATE_CLOSE {
  436. msg = "预警未关闭,无需重启"
  437. err = fmt.Errorf("预警未关闭,无需重启")
  438. return
  439. }
  440. edbMonitor.EdbTriggerDate = time.Time{}
  441. edbMonitor.MonitorTriggerTime = time.Time{}
  442. edbMonitor.ModifyTime = time.Now()
  443. err = ModifyEdbMonitorState(edbMonitor, edbMonitor.EdbCode, edbMonitor.Source, edbMonitor.SubSource)
  444. if err != nil {
  445. msg = "重启失败"
  446. err = fmt.Errorf("修改预警状态失败, err:%w", err)
  447. return
  448. }
  449. return
  450. }
  451. func GetEdbMonitorInfoUserList() (resp response.EdbMonitorInfoCreateUserResp, msg string, err error) {
  452. userIdList, err := edbmonitor.GetEdbMonitorCreateUserId()
  453. if err != nil {
  454. msg = "获取用户列表失败"
  455. return
  456. }
  457. adminList, err := system.GetAdminItemByIdList(userIdList)
  458. if err != nil {
  459. msg = "获取用户列表失败"
  460. return
  461. }
  462. createUserItem := make([]*response.EdbMonitorCreateUserItem, 0)
  463. for _, v := range adminList {
  464. tmp := new(response.EdbMonitorCreateUserItem)
  465. tmp.AdminId = v.AdminId
  466. tmp.RealName = v.RealName
  467. createUserItem = append(createUserItem, tmp)
  468. }
  469. resp.List = createUserItem
  470. return
  471. }
  472. func toEdbMonitorInfoItems(edbmonitor []*edbmonitor.EdbMonitorInfo, userMap, classifyPathMap, infoMap map[int]string) []*response.EdbMonitorInfoItem {
  473. res := make([]*response.EdbMonitorInfoItem, 0, len(edbmonitor))
  474. for _, v := range edbmonitor {
  475. tmp := new(response.EdbMonitorInfoItem)
  476. tmp.EdbMonitorId = v.EdbMonitorId
  477. tmp.EdbMonitorName = v.EdbMonitorName
  478. tmp.EdbMonitorClassifyId = v.EdbMonitorClassifyId
  479. tmp.EdbMonitorClassifyName = classifyPathMap[v.EdbMonitorClassifyId]
  480. tmp.EdbInfoId = v.EdbInfoId
  481. tmp.EdbInfoName = infoMap[v.EdbInfoId]
  482. tmp.EdbUniqueCode = v.EdbUniqueCode
  483. tmp.EdbClassifyId = v.EdbClassifyId
  484. tmp.EdbInfoType = v.EdbInfoType
  485. tmp.EdbCode = v.EdbCode
  486. tmp.Source = v.Source
  487. tmp.SubSource = v.SubSource
  488. tmp.EdbLatestDate = v.EdbLatestDate
  489. tmp.EdbLatestValue = v.EdbLatestValue
  490. tmp.MonitorType = v.MonitorType
  491. tmp.MonitorData = v.MonitorData
  492. tmp.MonitorLevel = v.MonitorLevel
  493. tmp.State = v.State
  494. tmp.EdbTriggerDate = utils.TimeTransferString(utils.FormatDate, v.EdbTriggerDate)
  495. tmp.MonitorTriggerTime = utils.TimeTransferString(utils.FormatDateTime, v.MonitorTriggerTime)
  496. tmp.CreateUserId = v.CreateUserId
  497. tmp.CreateUserName = userMap[v.CreateUserId]
  498. tmp.CreateTime = utils.TimeTransferString(utils.FormatDateTime, v.CreateTime)
  499. tmp.ModifyTime = utils.TimeTransferString(utils.FormatDateTime, v.ModifyTime)
  500. res = append(res, tmp)
  501. }
  502. return res
  503. }