edb_monitor.go 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437
  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 []int
  43. if level != "" {
  44. tmp := strings.Split(level, ",")
  45. for _, v := range tmp {
  46. lv, _ := strconv.Atoi(v)
  47. levelList = append(levelList, lv)
  48. }
  49. }
  50. var stateList []int
  51. if state != "" {
  52. tmp := strings.Split(state, ",")
  53. for _, v := range tmp {
  54. st, _ := strconv.Atoi(v)
  55. stateList = append(stateList, st)
  56. }
  57. }
  58. var userIdList []int
  59. if userId != "" {
  60. tmp := strings.Split(userId, ",")
  61. for _, v := range tmp {
  62. ui, _ := strconv.Atoi(v)
  63. userIdList = append(userIdList, ui)
  64. }
  65. }
  66. var conditon string
  67. var pars []interface{}
  68. if len(classifyIdList) != 0 {
  69. conditon += ` AND edb_monitor_classify_id IN (` + utils.GetOrmInReplace(len(classifyIdList)) + ` )`
  70. pars = append(pars, classifyIdList)
  71. }
  72. if len(levelList) != 0 {
  73. conditon += ` AND monitor_level IN (` + utils.GetOrmInReplace(len(levelList)) + ` )`
  74. pars = append(pars, levelList)
  75. }
  76. if len(stateList) != 0 {
  77. conditon += ` AND state IN (` + utils.GetOrmInReplace(len(stateList)) + ` )`
  78. pars = append(pars, stateList)
  79. }
  80. if len(userIdList) != 0 {
  81. conditon += ` AND create_user_id IN (` + utils.GetOrmInReplace(len(userIdList)) + ` )`
  82. pars = append(pars, userIdList)
  83. }
  84. total, err := edbmonitor.GetEdbMonitorInfoCountByCondition(conditon, pars)
  85. if err != nil {
  86. msg = "获取监控列表失败"
  87. err = fmt.Errorf("GetEdbMonitorInfoCountByCondition err:%w", err)
  88. return
  89. }
  90. edbMonitorList, err := edbmonitor.GetEdbMonitorInfoPageByCondition(conditon, pars, startSize, pageSize)
  91. if err != nil {
  92. msg = "获取监控列表失败"
  93. err = fmt.Errorf("GetEdbMonitorInfoPageByCondition err:%w", err)
  94. return
  95. }
  96. edbUserId := make([]int, 0)
  97. for _, v := range edbMonitorList {
  98. edbUserId = append(edbUserId, v.CreateUserId)
  99. }
  100. userInfoList, err := system.GetSysAdminByIdList(edbUserId)
  101. if err != nil {
  102. msg = "获取监控列表失败"
  103. err = fmt.Errorf("GetSysAdminByIdList err:%w", err)
  104. return
  105. }
  106. userMap := make(map[int]string)
  107. for _, v := range userInfoList {
  108. userMap[v.AdminId] = v.RealName
  109. }
  110. classifyList, err := edbmonitor.GetEdbMonitorClassifyList()
  111. if err != nil {
  112. msg = "获取监控列表失败"
  113. err = fmt.Errorf("GetEdbMonitorClassifyList err:%w", err)
  114. return
  115. }
  116. classifyMap := make(map[int]string)
  117. for _, v := range classifyList {
  118. classifyMap[v.ClassifyId] = v.ClassifyName
  119. }
  120. classifyPathMap := make(map[int]string)
  121. for _, v := range classifyList {
  122. var path []string
  123. if v.ParentId != 0 {
  124. parentName := classifyMap[v.ParentId]
  125. if v.RootId != 0 && v.RootId != v.ParentId {
  126. rootName := classifyMap[v.RootId]
  127. path = append(path, rootName)
  128. }
  129. curName := v.ClassifyName
  130. path = append(path, parentName, curName)
  131. } else {
  132. path = append(path, v.ClassifyName)
  133. }
  134. classifyPathMap[v.ClassifyId] = strings.Join(path, "/")
  135. }
  136. edbMonitorItems := toEdbMonitorInfoItems(edbMonitorList, userMap, classifyPathMap)
  137. page := paging.GetPaging(currentIndex, pageSize, total)
  138. resp.List = edbMonitorItems
  139. resp.Paging = page
  140. return
  141. }
  142. func SaveEdbMonitorInfo(req request.EdbMonitorInfoSaveReq, adminId int) (msg string, err error) {
  143. edb, er := data_manage.GetEdbInfoById(req.EdbInfoId)
  144. if er != nil {
  145. if er.Error() == utils.ErrNoRow() {
  146. msg = "指标不存在,请刷新重试"
  147. err = er
  148. return
  149. }
  150. msg = "添加指标预警失败"
  151. err = er
  152. return
  153. }
  154. var edbMonitorInfo *edbmonitor.EdbMonitorInfo
  155. if req.EdbMonitorId > 0 {
  156. edbMonitorInfo, er = edbmonitor.GetEdbMonitorInfoById(req.EdbMonitorId)
  157. if er != nil {
  158. if er.Error() == utils.ErrNoRow() {
  159. msg = "指标预警不存在,请刷新重试"
  160. err = er
  161. return
  162. }
  163. msg = "编辑指标预警失败"
  164. err = fmt.Errorf("GetEdbMonitorInfoById err:%w", er)
  165. return
  166. }
  167. var updateCols []string
  168. if edbMonitorInfo.EdbInfoId != req.EdbInfoId {
  169. updateCols = append(updateCols, []string{"edb_info_id", "edb_info_type", "edb_code", "source", "sub_source", "edb_latest_date", "edb_latest_value"}...)
  170. edbMonitorInfo.EdbInfoId = req.EdbInfoId
  171. edbMonitorInfo.EdbInfoType = edb.EdbInfoType
  172. edbMonitorInfo.EdbCode = edb.EdbCode
  173. edbMonitorInfo.Source = edb.Source
  174. edbMonitorInfo.SubSource = edb.SubSource
  175. edbMonitorInfo.EdbLatestDate = edb.LatestDate
  176. edbMonitorInfo.EdbLatestValue = edb.LatestValue
  177. }
  178. if edbMonitorInfo.EdbMonitorName != req.EdbMonitorName {
  179. updateCols = append(updateCols, "edb_monitor_name")
  180. edbMonitorInfo.EdbMonitorName = req.EdbMonitorName
  181. }
  182. if edbMonitorInfo.EdbMonitorClassifyId != req.ClassifyId {
  183. updateCols = append(updateCols, "edb_monitor_classify_id")
  184. edbMonitorInfo.EdbMonitorClassifyId = req.ClassifyId
  185. }
  186. if edbMonitorInfo.MonitorType != req.MonitorType {
  187. updateCols = append(updateCols, "monitor_type")
  188. edbMonitorInfo.MonitorType = req.MonitorType
  189. }
  190. monitorData, _ := strconv.ParseFloat(req.MonitorData, 64)
  191. if edbMonitorInfo.MonitorData != monitorData {
  192. updateCols = append(updateCols, "monitor_data")
  193. edbMonitorInfo.MonitorData = monitorData
  194. }
  195. if edbMonitorInfo.MonitorLevel != req.MonitorLevel {
  196. updateCols = append(updateCols, "monitor_level")
  197. edbMonitorInfo.MonitorLevel = req.MonitorLevel
  198. }
  199. if len(updateCols) > 0 {
  200. updateCols = append(updateCols, "modify_time")
  201. edbMonitorInfo.ModifyTime = time.Now()
  202. er := edbMonitorInfo.Update(updateCols)
  203. if er != nil {
  204. msg = "编辑指标预警失败"
  205. err = fmt.Errorf("UpdateEdbMonitorInfoById err:%w", er)
  206. return
  207. }
  208. }
  209. } else {
  210. edbMonitorInfo = new(edbmonitor.EdbMonitorInfo)
  211. edbMonitorInfo.EdbMonitorClassifyId = req.ClassifyId
  212. edbMonitorInfo.EdbMonitorName = req.EdbMonitorName
  213. edbMonitorInfo.EdbInfoId = req.EdbInfoId
  214. edbMonitorInfo.EdbInfoType = edb.EdbInfoType
  215. edbMonitorInfo.EdbCode = edb.EdbCode
  216. edbMonitorInfo.Source = edb.Source
  217. edbMonitorInfo.SubSource = edb.SubSource
  218. edbMonitorInfo.EdbLatestDate = edb.LatestDate
  219. edbMonitorInfo.EdbLatestValue = edb.LatestValue
  220. edbMonitorInfo.MonitorType = req.MonitorType
  221. monitorData, _ := strconv.ParseFloat(req.MonitorData, 64)
  222. edbMonitorInfo.MonitorData = monitorData
  223. edbMonitorInfo.MonitorLevel = req.MonitorLevel
  224. edbMonitorInfo.CreateUserId = adminId
  225. edbMonitorInfo.CreateTime = time.Now()
  226. edbMonitorInfo.ModifyTime = time.Now()
  227. insertId, er := edbMonitorInfo.Insert()
  228. if er != nil {
  229. msg = "添加指标预警失败"
  230. err = fmt.Errorf("insert err:%w", er)
  231. return
  232. }
  233. edbMonitorInfo.EdbMonitorId = int(insertId)
  234. }
  235. err = ModifyEdbMonitorState(edbMonitorInfo, edb.EdbCode, edb.Source, edb.SubSource)
  236. if err != nil {
  237. msg = "更新指标预警失败"
  238. err = fmt.Errorf("ModifyEdbMonitorState err:%w", err)
  239. return
  240. }
  241. return
  242. }
  243. func ModifyEdbMonitorState(edbMonitorInfo *edbmonitor.EdbMonitorInfo, edbCode string, source, subSource int) (err error) {
  244. cond := ` AND edb_code = ? `
  245. pars := []interface{}{edbCode}
  246. latestTwoData, er := data_manage.GetEdbDataListByCondition(cond, pars, source, subSource, 0, 2)
  247. if er != nil {
  248. err = fmt.Errorf("GetEdbDataListByCondition err:%w", er)
  249. return
  250. }
  251. triggerState := cmpEdbMonitorState(latestTwoData, edbMonitorInfo.MonitorType, edbMonitorInfo.MonitorData)
  252. var updateCols []string
  253. if edbMonitorInfo.State != EDB_MONITOR_STATE_TRIGGER_SUCCESS {
  254. edbMonitorInfo.State = triggerState
  255. updateCols = append(updateCols, "state")
  256. } else {
  257. tmpTime, _ := time.Parse(utils.FormatDate, latestTwoData[0].DataTime)
  258. edbMonitorInfo.EdbTriggerDate = tmpTime
  259. edbMonitorInfo.MonitorTriggerTime = time.Now()
  260. updateCols = append(updateCols, []string{"edb_trigger_date", "monitor_trigger_time"}...)
  261. }
  262. err = edbMonitorInfo.Update(updateCols)
  263. if err != nil {
  264. return
  265. }
  266. return
  267. }
  268. func cmpEdbMonitorState(twoData []*data_manage.EdbData, monitorType int, monitorData float64) int {
  269. if len(twoData) < 2 {
  270. return EDB_MONITOR_STATE_NO_TRIGGER
  271. }
  272. switch monitorType {
  273. case EDB_MONITOR_TYPE_UP:
  274. if twoData[0].Value >= monitorData && twoData[1].Value < monitorData {
  275. return EDB_MONITOR_STATE_TRIGGER_SUCCESS
  276. } else {
  277. return EDB_MONITOR_STATE_NO_TRIGGER
  278. }
  279. case EDB_MONITOR_TYPE_DOWN:
  280. if twoData[0].Value <= monitorData && twoData[1].Value > monitorData {
  281. return EDB_MONITOR_STATE_TRIGGER_SUCCESS
  282. } else {
  283. return EDB_MONITOR_STATE_NO_TRIGGER
  284. }
  285. default:
  286. return EDB_MONITOR_STATE_NO_TRIGGER
  287. }
  288. }
  289. func DeleteEdbMonitorInfo(req request.EdbMonitorInfoDeleteReq) (msg string, err error) {
  290. err = edbmonitor.DeleteEdbMonitorInfoById(req.EdbMonitorId)
  291. if err != nil {
  292. msg = "删除失败"
  293. err = fmt.Errorf("DeleteEdbMonitorInfoById err:%w", err)
  294. }
  295. return
  296. }
  297. func GetEdbMonitorLevelList() (list []string, msg string, err error) {
  298. list, err = edbmonitor.GetEdbMonitorLevelList()
  299. if err != nil {
  300. msg = "获取等级等级列表失败"
  301. err = fmt.Errorf("GetEdbMonitorLevelList err:%w", err)
  302. return
  303. }
  304. return
  305. }
  306. func CloseEdbMonitorInfo(req request.EdbMonitorInfoCloseReq, adminId int) (msg string, err error) {
  307. edbMonitor, er := edbmonitor.GetEdbMonitorInfoById(req.EdbMonitorId)
  308. if er != nil {
  309. if er.Error() == utils.ErrNoRow() {
  310. msg = "指标预警不存在,请刷新重试"
  311. err = er
  312. }
  313. msg = "关闭失败"
  314. err = fmt.Errorf("获取预警详情失败, err:%w", er)
  315. return
  316. }
  317. if edbMonitor.CreateUserId != adminId {
  318. msg = "无权限操作"
  319. err = fmt.Errorf("无权限操作")
  320. return
  321. }
  322. if edbMonitor.State == EDB_MONITOR_STATE_CLOSE {
  323. msg = "预警已关闭"
  324. err = fmt.Errorf("预警已关闭")
  325. return
  326. }
  327. edbMonitor.State = EDB_MONITOR_STATE_CLOSE
  328. edbMonitor.ModifyTime = time.Now()
  329. er = edbMonitor.Update([]string{"state", "modify_time"})
  330. if er != nil {
  331. msg = "关闭失败"
  332. err = fmt.Errorf("修改预警状态失败, err:%w", er)
  333. return
  334. }
  335. return
  336. }
  337. func RestartEdbMonitorInfo(req request.EdbMonitorInfoRestartReq, adminId int) (msg string, err error) {
  338. edbMonitor, er := edbmonitor.GetEdbMonitorInfoById(req.EdbMonitorId)
  339. if er != nil {
  340. if er.Error() == utils.ErrNoRow() {
  341. msg = "指标预警不存在,请刷新重试"
  342. err = er
  343. }
  344. msg = "重启失败"
  345. err = fmt.Errorf("获取预警详情失败, err:%w", er)
  346. return
  347. }
  348. if edbMonitor.CreateUserId != adminId {
  349. msg = "无权限操作"
  350. err = fmt.Errorf("无权限操作")
  351. return
  352. }
  353. if edbMonitor.State != EDB_MONITOR_STATE_CLOSE {
  354. msg = "预警未关闭,无需重启"
  355. err = fmt.Errorf("预警未关闭,无需重启")
  356. return
  357. }
  358. err = ModifyEdbMonitorState(edbMonitor, edbMonitor.EdbCode, edbMonitor.Source, edbMonitor.SubSource)
  359. if err != nil {
  360. msg = "重启失败"
  361. err = fmt.Errorf("修改预警状态失败, err:%w", err)
  362. return
  363. }
  364. return
  365. }
  366. func GetEdbMonitorInfoUserList() (resp response.EdbMonitorInfoCreateUserResp, msg string, err error) {
  367. userIdList, err := edbmonitor.GetEdbMonitorCreateUserId()
  368. if err != nil {
  369. msg = "获取用户列表失败"
  370. return
  371. }
  372. adminList, err := system.GetAdminItemByIdList(userIdList)
  373. if err != nil {
  374. msg = "获取用户列表失败"
  375. return
  376. }
  377. createUserItem := make([]*response.EdbMonitorCreateUserItem, 0)
  378. for _, v := range adminList {
  379. tmp := new(response.EdbMonitorCreateUserItem)
  380. tmp.AdminId = v.AdminId
  381. tmp.RealName = v.RealName
  382. createUserItem = append(createUserItem, tmp)
  383. }
  384. resp.List = createUserItem
  385. return
  386. }
  387. func toEdbMonitorInfoItems(edbmonitor []*edbmonitor.EdbMonitorInfo, userMap map[int]string, classifyPathMap map[int]string) []*response.EdbMonitorInfoItem {
  388. res := make([]*response.EdbMonitorInfoItem, 0, len(edbmonitor))
  389. for _, v := range edbmonitor {
  390. tmp := new(response.EdbMonitorInfoItem)
  391. tmp.EdbMonitorId = v.EdbMonitorId
  392. tmp.EdbMonitorName = v.EdbMonitorName
  393. tmp.EdbMonitorClassifyId = v.EdbMonitorClassifyId
  394. tmp.EdbMonitorClassifyName = classifyPathMap[v.EdbMonitorClassifyId]
  395. tmp.EdbInfoId = v.EdbInfoId
  396. tmp.EdbInfoType = v.EdbInfoType
  397. tmp.EdbCode = v.EdbCode
  398. tmp.Source = v.Source
  399. tmp.SubSource = v.SubSource
  400. tmp.EdbLatestDate = v.EdbLatestDate
  401. tmp.EdbLatestValue = v.EdbLatestValue
  402. tmp.MonitorType = v.MonitorType
  403. tmp.MonitorData = v.MonitorData
  404. tmp.MonitorLevel = v.MonitorLevel
  405. tmp.State = v.State
  406. tmp.EdbTriggerDate = utils.TimeTransferString(utils.FormatDate, v.EdbTriggerDate)
  407. tmp.MonitorTriggerTime = utils.TimeTransferString(utils.FormatDateTime, v.MonitorTriggerTime)
  408. tmp.CreateUserId = v.CreateUserId
  409. tmp.CreateUserName = userMap[v.CreateUserId]
  410. tmp.CreateTime = utils.TimeTransferString(utils.FormatDateTime, v.CreateTime)
  411. tmp.ModifyTime = utils.TimeTransferString(utils.FormatDateTime, v.ModifyTime)
  412. res = append(res, tmp)
  413. }
  414. return res
  415. }