edb_inspection.go 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358
  1. package data_manage
  2. import (
  3. "encoding/json"
  4. "eta/eta_api/controllers"
  5. "eta/eta_api/models"
  6. "eta/eta_api/models/data_manage/edb_inspection"
  7. "eta/eta_api/services/data"
  8. "eta/eta_api/utils"
  9. "time"
  10. "github.com/rdlucklib/rdluck_tools/paging"
  11. )
  12. type EdbInspectionController struct {
  13. controllers.BaseAuthController
  14. }
  15. // InspectionSourceList
  16. // @Title 获取巡检配置的来源接口
  17. // @Description 获取巡检配置的来源接口
  18. // @Success Ret=200 获取成功
  19. // @router /edb_inspection/source_list [get]
  20. func (c *EdbInspectionController) InspectionSourceList() {
  21. br := new(models.BaseResponse).Init()
  22. defer func() {
  23. c.Data["json"] = br
  24. c.ServeJSON()
  25. }()
  26. // 这里可以添加获取巡检来源的逻辑
  27. // 目前暂时返回空列表
  28. list := make([]interface{}, 0)
  29. br.Ret = 200
  30. br.Success = true
  31. br.Msg = "获取成功"
  32. br.Data = list
  33. }
  34. // InspectionConfigList
  35. // @Title 获取巡检配置列表接口
  36. // @Description 获取巡检配置列表接口
  37. // @Param Source query int true "来源"
  38. // @Param TerminalCode query string false "终端编码"
  39. // @Success Ret=200 获取成功
  40. // @router /edb_inspection/config/list [get]
  41. func (c *EdbInspectionController) InspectionConfigList() {
  42. br := new(models.BaseResponse).Init()
  43. defer func() {
  44. c.Data["json"] = br
  45. c.ServeJSON()
  46. }()
  47. source, _ := c.GetInt("Source")
  48. terminalCode := c.GetString("TerminalCode")
  49. list, err, errMsg, isSendEmail := data.GetConfigList(source, terminalCode)
  50. if err != nil {
  51. br.Msg = errMsg
  52. br.ErrMsg = "获取失败,Err:" + err.Error()
  53. br.IsSendEmail = isSendEmail
  54. return
  55. }
  56. br.Ret = 200
  57. br.Success = true
  58. br.Msg = "获取成功"
  59. br.Data = list
  60. }
  61. // SaveInspectionConfig
  62. // @Title 设置巡检配置接口
  63. // @Description 设置巡检配置接口
  64. // @Param request body edb_inspection.EdbInspectionConfigAddReq true "type json string"
  65. // @Success Ret=200 保存成功
  66. // @router /edb_inspection/config/save [post]
  67. func (c *EdbInspectionController) SaveInspectionConfig() {
  68. br := new(models.BaseResponse).Init()
  69. defer func() {
  70. c.Data["json"] = br
  71. c.ServeJSON()
  72. }()
  73. var req edb_inspection.EdbInspectionConfigAddReq
  74. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  75. if err != nil {
  76. br.Msg = "参数解析异常!"
  77. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  78. return
  79. }
  80. // 保存
  81. err, errMsg, isSendEmail := data.SaveEdbInspectionConfig(&req)
  82. if err != nil {
  83. br.Msg = errMsg
  84. br.ErrMsg = "保存失败,Err:" + err.Error()
  85. br.IsSendEmail = isSendEmail
  86. return
  87. }
  88. br.Ret = 200
  89. br.Success = true
  90. br.Msg = "保存成功"
  91. }
  92. // UpdateInspectionConfigStatus
  93. // @Title 更新巡检配置状态接口
  94. // @Description 更新巡检配置状态接口
  95. // @Param ConfigId query int64 true "配置ID"
  96. // @Param Status query int8 true "状态"
  97. // @Success Ret=200 更新成功
  98. // @router /edb_inspection/config/status/update [post]
  99. func (c *EdbInspectionController) UpdateInspectionConfigStatus() {
  100. br := new(models.BaseResponse).Init()
  101. defer func() {
  102. c.Data["json"] = br
  103. c.ServeJSON()
  104. }()
  105. var req edb_inspection.EdbInspectionConfigStatusReq
  106. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  107. if err != nil {
  108. br.Msg = "参数解析异常!"
  109. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  110. return
  111. }
  112. configId := req.ConfigId
  113. status := req.Status
  114. if status != 1 && status != 0 {
  115. br.Msg = "状态错误"
  116. br.ErrMsg = "状态错误,请输入1或0"
  117. br.IsSendEmail = false
  118. return
  119. }
  120. if configId <= 0 {
  121. br.Msg = "配置ID不能为空"
  122. br.IsSendEmail = false
  123. return
  124. }
  125. config := &edb_inspection.EdbInspectionConfig{
  126. ConfigId: configId,
  127. }
  128. err = config.UpdateStatus(status)
  129. if err != nil {
  130. br.Msg = "更新失败"
  131. br.ErrMsg = "更新失败,Err:" + err.Error()
  132. return
  133. }
  134. br.Ret = 200
  135. br.Success = true
  136. br.Msg = "更新成功"
  137. }
  138. // DeleteInspectionConfig
  139. // @Title 删除巡检配置接口
  140. // @Description 删除巡检配置接口
  141. // @Param ConfigId query int64 true "配置ID"
  142. // @Success Ret=200 删除成功
  143. // @router /edb_inspection/config/delete [post]
  144. func (c *EdbInspectionController) DeleteInspectionConfig() {
  145. br := new(models.BaseResponse).Init()
  146. defer func() {
  147. c.Data["json"] = br
  148. c.ServeJSON()
  149. }()
  150. var req edb_inspection.EdbInspectionConfigDeleteReq
  151. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  152. if err != nil {
  153. br.Msg = "参数解析异常!"
  154. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  155. return
  156. }
  157. configId := req.ConfigId
  158. if configId <= 0 {
  159. br.Msg = "配置ID不能为空"
  160. br.IsSendEmail = false
  161. return
  162. }
  163. config := &edb_inspection.EdbInspectionConfig{
  164. ConfigId: configId,
  165. }
  166. err = config.Delete()
  167. if err != nil {
  168. br.Msg = "删除失败"
  169. br.ErrMsg = "删除失败,Err:" + err.Error()
  170. return
  171. }
  172. _ = edb_inspection.DeleteEdbInspectionDateConfigByConfigId(configId)
  173. br.Ret = 200
  174. br.Success = true
  175. br.Msg = "删除成功"
  176. }
  177. // GetInspectionConfigDetail
  178. // @Title 获取巡检配置详情接口
  179. // @Description 获取巡检配置详情接口
  180. // @Param ConfigId query int64 true "配置ID"
  181. // @Success Ret=200 获取成功
  182. // @router /edb_inspection/config/detail [get]
  183. func (c *EdbInspectionController) GetInspectionConfigDetail() {
  184. br := new(models.BaseResponse).Init()
  185. defer func() {
  186. c.Data["json"] = br
  187. c.ServeJSON()
  188. }()
  189. configId, _ := c.GetInt64("ConfigId")
  190. if configId <= 0 {
  191. br.Msg = "配置ID不能为空"
  192. br.IsSendEmail = false
  193. return
  194. }
  195. detail, err := data.GetConfigDetail(configId)
  196. if err != nil {
  197. br.Msg = "获取失败"
  198. br.ErrMsg = "获取失败,Err:" + err.Error()
  199. return
  200. }
  201. br.Ret = 200
  202. br.Success = true
  203. br.Msg = "获取成功"
  204. br.Data = detail
  205. }
  206. // 查询看板列表
  207. // @Title 查询看板列表接口
  208. // @Description 查询看板列表接口
  209. // @Success Ret=200 获取成功
  210. // @router /edb_inspection/dashboard [get]
  211. func (c *EdbInspectionController) GetDashboardList() {
  212. br := new(models.BaseResponse).Init()
  213. defer func() {
  214. c.Data["json"] = br
  215. c.ServeJSON()
  216. }()
  217. list, err := edb_inspection.GetDashboardList()
  218. if err != nil {
  219. br.Msg = "获取失败"
  220. br.ErrMsg = "获取失败,Err:" + err.Error()
  221. return
  222. }
  223. br.Ret = 200
  224. br.Success = true
  225. br.Msg = "获取成功"
  226. br.Data = list
  227. }
  228. // 查询看板详情
  229. // @Title 查询看板详情接口
  230. // @Description 查询看板详情接口
  231. // @Success Ret=200 获取成功
  232. // @router /edb_inspection/record [get]
  233. func (c *EdbInspectionController) GetInspectionRecordDetail() {
  234. br := new(models.BaseResponse).Init()
  235. defer func() {
  236. c.Data["json"] = br
  237. c.ServeJSON()
  238. }()
  239. // 根据source和terminalCode查询巡检记录
  240. source, _ := c.GetInt("Source")
  241. terminalCode := c.GetString("TerminalCode")
  242. startDate := c.GetString("StartDate")
  243. endDate := c.GetString("EndDate")
  244. pageSize, _ := c.GetInt("PageSize")
  245. currentIndex, _ := c.GetInt("CurrentIndex")
  246. if pageSize <= 0 {
  247. pageSize = utils.PageSize20
  248. }
  249. if currentIndex <= 0 {
  250. currentIndex = 1
  251. }
  252. condition := ``
  253. var pars []interface{}
  254. if source > 0 {
  255. condition += " AND r.source = ?"
  256. pars = append(pars, source)
  257. }
  258. if terminalCode != "" {
  259. condition += " AND r.terminal_code = ?"
  260. pars = append(pars, terminalCode)
  261. }
  262. if startDate != "" {
  263. // 检查是否是时间格式
  264. _, err := time.Parse(utils.FormatDate, startDate)
  265. if err != nil {
  266. br.Msg = "开始时间格式错误"
  267. br.ErrMsg = "开始时间格式错误,请输入正确的时间格式"
  268. return
  269. }
  270. condition += " AND r.inspection_time >= ?"
  271. pars = append(pars, startDate)
  272. }
  273. if endDate != "" {
  274. // 检查是否是时间格式
  275. _, err := time.Parse(utils.FormatDate, endDate)
  276. if err != nil {
  277. br.Msg = "结束时间格式错误"
  278. br.ErrMsg = "结束时间格式错误,请输入正确的时间格式"
  279. return
  280. }
  281. endTime := endDate + " 23:59:59"
  282. condition += " AND r.inspection_time <= ?"
  283. pars = append(pars, endTime)
  284. }
  285. list, err := edb_inspection.GetInspectionRecordListByCondition(condition, pars, currentIndex, pageSize)
  286. if err != nil {
  287. br.Msg = "获取失败"
  288. br.ErrMsg = "获取失败,Err:" + err.Error()
  289. return
  290. }
  291. // 查询总数
  292. count, err := edb_inspection.GetInspectionRecordCountByCondition(condition, pars)
  293. if err != nil {
  294. br.Msg = "获取失败"
  295. br.ErrMsg = "获取失败,Err:" + err.Error()
  296. return
  297. }
  298. page := paging.GetPaging(currentIndex, pageSize, int(count))
  299. br.Ret = 200
  300. br.Success = true
  301. br.Msg = "获取成功"
  302. br.Data = map[string]interface{}{
  303. "List": list,
  304. "Paging": page,
  305. }
  306. }