edb_monitor.go 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531
  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. er = fmt.Errorf("权限校验失败")
  171. }
  172. err = er
  173. return
  174. }
  175. edbMonitorInfo, er = edbmonitor.GetEdbMonitorInfoById(req.EdbMonitorId)
  176. if er != nil {
  177. if er.Error() == utils.ErrNoRow() {
  178. msg = "指标预警不存在,请刷新重试"
  179. err = er
  180. return
  181. }
  182. msg = "编辑指标预警失败"
  183. err = fmt.Errorf("GetEdbMonitorInfoById err:%w", er)
  184. return
  185. }
  186. var updateCols []string
  187. if edbMonitorInfo.EdbInfoId != req.EdbInfoId {
  188. 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"}...)
  189. edbMonitorInfo.EdbInfoId = req.EdbInfoId
  190. edbMonitorInfo.EdbInfoType = edb.EdbInfoType
  191. edbMonitorInfo.EdbCode = edb.EdbCode
  192. edbMonitorInfo.EdbClassifyId = edb.ClassifyId
  193. edbMonitorInfo.EdbUniqueCode = edb.UniqueCode
  194. edbMonitorInfo.Source = edb.Source
  195. edbMonitorInfo.SubSource = edb.SubSource
  196. edbMonitorInfo.EdbLatestDate = edb.LatestDate
  197. edbMonitorInfo.EdbLatestValue = edb.LatestValue
  198. }
  199. if edbMonitorInfo.EdbMonitorName != req.EdbMonitorName {
  200. updateCols = append(updateCols, "edb_monitor_name")
  201. edbMonitorInfo.EdbMonitorName = req.EdbMonitorName
  202. }
  203. if edbMonitorInfo.EdbMonitorClassifyId != req.ClassifyId {
  204. updateCols = append(updateCols, "edb_monitor_classify_id")
  205. edbMonitorInfo.EdbMonitorClassifyId = req.ClassifyId
  206. }
  207. if edbMonitorInfo.MonitorType != req.MonitorType {
  208. updateCols = append(updateCols, "monitor_type")
  209. edbMonitorInfo.MonitorType = req.MonitorType
  210. }
  211. monitorData, _ := strconv.ParseFloat(req.MonitorData, 64)
  212. if edbMonitorInfo.MonitorData != monitorData {
  213. updateCols = append(updateCols, "monitor_data")
  214. edbMonitorInfo.MonitorData = monitorData
  215. }
  216. if edbMonitorInfo.MonitorLevel != req.MonitorLevel {
  217. updateCols = append(updateCols, "monitor_level")
  218. edbMonitorInfo.MonitorLevel = req.MonitorLevel
  219. }
  220. if len(updateCols) > 0 {
  221. updateCols = append(updateCols, "modify_time")
  222. edbMonitorInfo.ModifyTime = time.Now()
  223. er := edbMonitorInfo.Update(updateCols)
  224. if er != nil {
  225. msg = "编辑指标预警失败"
  226. err = fmt.Errorf("UpdateEdbMonitorInfoById err:%w", er)
  227. return
  228. }
  229. }
  230. } else {
  231. edbMonitorInfo = new(edbmonitor.EdbMonitorInfo)
  232. edbMonitorInfo.EdbMonitorClassifyId = req.ClassifyId
  233. edbMonitorInfo.EdbMonitorName = req.EdbMonitorName
  234. edbMonitorInfo.EdbInfoId = req.EdbInfoId
  235. edbMonitorInfo.EdbInfoType = edb.EdbInfoType
  236. edbMonitorInfo.EdbUniqueCode = edb.UniqueCode
  237. edbMonitorInfo.EdbClassifyId = edb.ClassifyId
  238. edbMonitorInfo.EdbCode = edb.EdbCode
  239. edbMonitorInfo.Source = edb.Source
  240. edbMonitorInfo.SubSource = edb.SubSource
  241. edbMonitorInfo.EdbLatestDate = edb.LatestDate
  242. edbMonitorInfo.EdbLatestValue = edb.LatestValue
  243. edbMonitorInfo.MonitorType = req.MonitorType
  244. monitorData, _ := strconv.ParseFloat(req.MonitorData, 64)
  245. edbMonitorInfo.MonitorData = monitorData
  246. edbMonitorInfo.MonitorLevel = req.MonitorLevel
  247. edbMonitorInfo.CreateUserId = adminId
  248. edbMonitorInfo.CreateTime = time.Now()
  249. edbMonitorInfo.ModifyTime = time.Now()
  250. insertId, er := edbMonitorInfo.Insert()
  251. if er != nil {
  252. msg = "添加指标预警失败"
  253. err = fmt.Errorf("insert err:%w", er)
  254. return
  255. }
  256. edbMonitorInfo.EdbMonitorId = int(insertId)
  257. }
  258. err = ModifyEdbMonitorState(edbMonitorInfo, edb.EdbCode, edb.Source, edb.SubSource)
  259. if err != nil {
  260. msg = "更新指标预警失败"
  261. err = fmt.Errorf("ModifyEdbMonitorState err:%w", err)
  262. return
  263. }
  264. return
  265. }
  266. func ModifyEdbMonitorState(edbMonitorInfo *edbmonitor.EdbMonitorInfo, edbCode string, source, subSource int) (err error) {
  267. cond := ` AND edb_code = ? `
  268. pars := []interface{}{edbCode}
  269. latestTwoData, er := data_manage.GetEdbDataListByCondition(cond, pars, source, subSource, 2, 0)
  270. if er != nil {
  271. err = fmt.Errorf("GetEdbDataListByCondition err:%w", er)
  272. return
  273. }
  274. var updateCols []string
  275. edbMonitorInfo.EdbLatestDate = latestTwoData[0].DataTime
  276. edbMonitorInfo.EdbLatestValue = latestTwoData[0].Value
  277. updateCols = append(updateCols, []string{"edb_latest_date", "edb_latest_value"}...)
  278. triggerState := cmpEdbMonitorState(latestTwoData, edbMonitorInfo.MonitorType, edbMonitorInfo.MonitorData)
  279. if triggerState == EDB_MONITOR_STATE_TRIGGER_SUCCESS {
  280. tmpTime, _ := time.Parse(utils.FormatDate, latestTwoData[0].DataTime)
  281. edbMonitorInfo.EdbTriggerDate = tmpTime
  282. edbMonitorInfo.MonitorTriggerTime = time.Now()
  283. updateCols = append(updateCols, []string{"edb_trigger_date", "monitor_trigger_time"}...)
  284. }
  285. if edbMonitorInfo.State == EDB_MONITOR_STATE_NO_TRIGGER || edbMonitorInfo.State == EDB_MONITOR_STATE_CLOSE {
  286. edbMonitorInfo.State = triggerState
  287. updateCols = append(updateCols, "state")
  288. }
  289. err = edbMonitorInfo.Update(updateCols)
  290. if err != nil {
  291. return
  292. }
  293. if triggerState == EDB_MONITOR_STATE_TRIGGER_SUCCESS {
  294. triggerTime := edbMonitorInfo.MonitorTriggerTime.Format(utils.FormatDateTime)
  295. err = SendMessages(edbMonitorInfo.CreateUserId, edbMonitorInfo.EdbInfoId, edbMonitorInfo.EdbInfoType, edbMonitorInfo.EdbMonitorClassifyId, edbMonitorInfo.EdbUniqueCode, edbMonitorInfo.EdbMonitorName, triggerTime)
  296. isRead := 1
  297. if err != nil {
  298. isRead = 0
  299. }
  300. err = LogMessage(edbMonitorInfo.EdbMonitorName, edbMonitorInfo.EdbUniqueCode, edbMonitorInfo.MonitorTriggerTime, edbMonitorInfo.EdbInfoId, edbMonitorInfo.EdbInfoType, edbMonitorInfo.CreateUserId, isRead, edbMonitorInfo.EdbClassifyId)
  301. }
  302. return
  303. }
  304. func cmpEdbMonitorState(twoData []*data_manage.EdbData, monitorType int, monitorData float64) int {
  305. if len(twoData) < 2 {
  306. return EDB_MONITOR_STATE_NO_TRIGGER
  307. }
  308. switch monitorType {
  309. case EDB_MONITOR_TYPE_UP:
  310. if twoData[0].Value >= monitorData && twoData[1].Value < monitorData {
  311. return EDB_MONITOR_STATE_TRIGGER_SUCCESS
  312. } else {
  313. return EDB_MONITOR_STATE_NO_TRIGGER
  314. }
  315. case EDB_MONITOR_TYPE_DOWN:
  316. if twoData[0].Value <= monitorData && twoData[1].Value > monitorData {
  317. return EDB_MONITOR_STATE_TRIGGER_SUCCESS
  318. } else {
  319. return EDB_MONITOR_STATE_NO_TRIGGER
  320. }
  321. default:
  322. return EDB_MONITOR_STATE_NO_TRIGGER
  323. }
  324. }
  325. func OperatePermissionCheck(edbMonitorId int, adminId int) (ok bool, msg string, err error) {
  326. monitorInfo, err := edbmonitor.GetEdbMonitorInfoById(edbMonitorId)
  327. if err != nil {
  328. if err.Error() == utils.ErrNoRow() {
  329. msg = "指标预警不存在,请刷新重试"
  330. return
  331. }
  332. msg = "删除失败"
  333. err = fmt.Errorf("获取预警详情失败, err:%w", err)
  334. return
  335. }
  336. if monitorInfo.CreateUserId != adminId {
  337. userInfo, er := system.GetSysAdminById(adminId)
  338. if er != nil {
  339. msg = "删除失败"
  340. err = fmt.Errorf("查询用户信息失败 err:%w", er)
  341. return
  342. }
  343. if userInfo.Role != utils.ROLE_TYPE_CODE_ADMIN {
  344. msg = "无权限操作"
  345. err = fmt.Errorf("无权限操作")
  346. return
  347. }
  348. }
  349. ok = true
  350. return
  351. }
  352. func DeleteEdbMonitorInfo(req request.EdbMonitorInfoDeleteReq, adminId int) (msg string, err error) {
  353. ok, msg, err := OperatePermissionCheck(req.EdbMonitorId, adminId)
  354. if !ok {
  355. if msg == "" {
  356. msg = "删除失败"
  357. }
  358. if err == nil {
  359. err = fmt.Errorf("权限校验失败")
  360. }
  361. return
  362. }
  363. err = edbmonitor.DeleteEdbMonitorInfoById(req.EdbMonitorId)
  364. if err != nil {
  365. msg = "删除失败"
  366. err = fmt.Errorf("删除预警失败 err:%w", err)
  367. }
  368. return
  369. }
  370. func GetEdbMonitorLevelList() (list []string, msg string, err error) {
  371. list, err = edbmonitor.GetEdbMonitorLevelList()
  372. if err != nil {
  373. msg = "获取等级等级列表失败"
  374. err = fmt.Errorf("GetEdbMonitorLevelList err:%w", err)
  375. return
  376. }
  377. return
  378. }
  379. func CloseEdbMonitorInfo(req request.EdbMonitorInfoCloseReq, adminId int) (msg string, err error) {
  380. edbMonitor, er := edbmonitor.GetEdbMonitorInfoById(req.EdbMonitorId)
  381. if er != nil {
  382. if er.Error() == utils.ErrNoRow() {
  383. msg = "指标预警不存在,请刷新重试"
  384. err = er
  385. }
  386. msg = "关闭失败"
  387. err = fmt.Errorf("获取预警详情失败, err:%w", er)
  388. return
  389. }
  390. ok, msg, err := OperatePermissionCheck(req.EdbMonitorId, adminId)
  391. if !ok {
  392. if msg == "" {
  393. msg = "删除失败"
  394. }
  395. if err == nil {
  396. err = fmt.Errorf("权限校验失败")
  397. }
  398. return
  399. }
  400. if edbMonitor.State == EDB_MONITOR_STATE_CLOSE {
  401. msg = "预警已关闭"
  402. err = fmt.Errorf("预警已关闭")
  403. return
  404. }
  405. edbMonitor.State = EDB_MONITOR_STATE_CLOSE
  406. edbMonitor.ModifyTime = time.Now()
  407. er = edbMonitor.Update([]string{"state", "modify_time"})
  408. if er != nil {
  409. msg = "关闭失败"
  410. err = fmt.Errorf("修改预警状态失败, err:%w", er)
  411. return
  412. }
  413. return
  414. }
  415. func RestartEdbMonitorInfo(req request.EdbMonitorInfoRestartReq, adminId int) (msg string, err error) {
  416. edbMonitor, er := edbmonitor.GetEdbMonitorInfoById(req.EdbMonitorId)
  417. if er != nil {
  418. if er.Error() == utils.ErrNoRow() {
  419. msg = "指标预警不存在,请刷新重试"
  420. err = er
  421. }
  422. msg = "重启失败"
  423. err = fmt.Errorf("获取预警详情失败, err:%w", er)
  424. return
  425. }
  426. ok, msg, err := OperatePermissionCheck(req.EdbMonitorId, adminId)
  427. if !ok {
  428. if msg == "" {
  429. msg = "删除失败"
  430. }
  431. if err == nil {
  432. err = fmt.Errorf("权限校验失败")
  433. }
  434. return
  435. }
  436. if edbMonitor.State != EDB_MONITOR_STATE_CLOSE {
  437. msg = "预警未关闭,无需重启"
  438. err = fmt.Errorf("预警未关闭,无需重启")
  439. return
  440. }
  441. edbMonitor.EdbTriggerDate = time.Time{}
  442. edbMonitor.MonitorTriggerTime = time.Time{}
  443. edbMonitor.ModifyTime = time.Now()
  444. err = ModifyEdbMonitorState(edbMonitor, edbMonitor.EdbCode, edbMonitor.Source, edbMonitor.SubSource)
  445. if err != nil {
  446. msg = "重启失败"
  447. err = fmt.Errorf("修改预警状态失败, err:%w", err)
  448. return
  449. }
  450. return
  451. }
  452. func GetEdbMonitorInfoUserList() (resp response.EdbMonitorInfoCreateUserResp, msg string, err error) {
  453. userIdList, err := edbmonitor.GetEdbMonitorCreateUserId()
  454. if err != nil {
  455. msg = "获取用户列表失败"
  456. return
  457. }
  458. adminList, err := system.GetAdminItemByIdList(userIdList)
  459. if err != nil {
  460. msg = "获取用户列表失败"
  461. return
  462. }
  463. createUserItem := make([]*response.EdbMonitorCreateUserItem, 0)
  464. for _, v := range adminList {
  465. tmp := new(response.EdbMonitorCreateUserItem)
  466. tmp.AdminId = v.AdminId
  467. tmp.RealName = v.RealName
  468. createUserItem = append(createUserItem, tmp)
  469. }
  470. resp.List = createUserItem
  471. return
  472. }
  473. func toEdbMonitorInfoItems(edbmonitor []*edbmonitor.EdbMonitorInfo, userMap, classifyPathMap, infoMap map[int]string) []*response.EdbMonitorInfoItem {
  474. res := make([]*response.EdbMonitorInfoItem, 0, len(edbmonitor))
  475. for _, v := range edbmonitor {
  476. tmp := new(response.EdbMonitorInfoItem)
  477. tmp.EdbMonitorId = v.EdbMonitorId
  478. tmp.EdbMonitorName = v.EdbMonitorName
  479. tmp.EdbMonitorClassifyId = v.EdbMonitorClassifyId
  480. tmp.EdbMonitorClassifyName = classifyPathMap[v.EdbMonitorClassifyId]
  481. tmp.EdbInfoId = v.EdbInfoId
  482. tmp.EdbInfoName = infoMap[v.EdbInfoId]
  483. tmp.EdbUniqueCode = v.EdbUniqueCode
  484. tmp.EdbClassifyId = v.EdbClassifyId
  485. tmp.EdbInfoType = v.EdbInfoType
  486. tmp.EdbCode = v.EdbCode
  487. tmp.Source = v.Source
  488. tmp.SubSource = v.SubSource
  489. tmp.EdbLatestDate = v.EdbLatestDate
  490. tmp.EdbLatestValue = v.EdbLatestValue
  491. tmp.MonitorType = v.MonitorType
  492. tmp.MonitorData = v.MonitorData
  493. tmp.MonitorLevel = v.MonitorLevel
  494. tmp.State = v.State
  495. tmp.EdbTriggerDate = utils.TimeTransferString(utils.FormatDate, v.EdbTriggerDate)
  496. tmp.MonitorTriggerTime = utils.TimeTransferString(utils.FormatDateTime, v.MonitorTriggerTime)
  497. tmp.CreateUserId = v.CreateUserId
  498. tmp.CreateUserName = userMap[v.CreateUserId]
  499. tmp.CreateTime = utils.TimeTransferString(utils.FormatDateTime, v.CreateTime)
  500. tmp.ModifyTime = utils.TimeTransferString(utils.FormatDateTime, v.ModifyTime)
  501. res = append(res, tmp)
  502. }
  503. return res
  504. }