So2Controller.java 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324
  1. package com.ruoyi.web.controller.gas;
  2. import cn.hutool.core.convert.Convert;
  3. import cn.hutool.core.date.DateUtil;
  4. import cn.hutool.core.util.NumberUtil;
  5. import cn.hutool.core.util.ObjectUtil;
  6. import cn.hutool.core.util.StrUtil;
  7. import com.ruoyi.common.constant.CacheConstants;
  8. import com.ruoyi.common.constant.ElasticConstants;
  9. import com.ruoyi.common.constant.HttpStatus;
  10. import com.ruoyi.common.core.controller.BaseController;
  11. import com.ruoyi.common.core.domain.AjaxResult;
  12. import com.ruoyi.common.core.domain.entity.SysDictData;
  13. import com.ruoyi.common.core.page.PageDomain;
  14. import com.ruoyi.common.core.page.TableDataInfo;
  15. import com.ruoyi.common.core.page.TableSupport;
  16. import com.ruoyi.common.core.redis.RedisCache;
  17. import com.ruoyi.common.enums.AggsType;
  18. import com.ruoyi.framework.config.ElasticSearchClient;
  19. import com.ruoyi.system.domain.GuapAlert;
  20. import com.ruoyi.system.domain.GuapMonitorPoint;
  21. import com.ruoyi.system.domain.IllegalShip;
  22. import com.ruoyi.system.domain.XiuTanIllegalShip;
  23. import com.ruoyi.system.domain.XiuTanSemInstrument;
  24. import com.ruoyi.system.service.IAisDatabase;
  25. import com.ruoyi.system.service.IHeiYanService;
  26. import com.ruoyi.system.service.ISo2Service;
  27. import com.ruoyi.system.service.ISysDictTypeService;
  28. import io.swagger.annotations.Api;
  29. import io.swagger.annotations.ApiOperation;
  30. import org.elasticsearch.search.aggregations.bucket.histogram.DateHistogramInterval;
  31. import org.springframework.beans.factory.annotation.Autowired;
  32. import org.springframework.web.bind.annotation.GetMapping;
  33. import org.springframework.web.bind.annotation.RequestMapping;
  34. import org.springframework.web.bind.annotation.RequestParam;
  35. import org.springframework.web.bind.annotation.RestController;
  36. import java.util.ArrayList;
  37. import java.util.Date;
  38. import java.util.HashMap;
  39. import java.util.List;
  40. import java.util.Map;
  41. /**
  42. * @Description: 硫含量
  43. * @Author: huangcheng
  44. * @Date: 2021/8/26
  45. * @Version V1.0
  46. */
  47. @RestController
  48. @RequestMapping("/so2")
  49. @Api(tags = "硫含量接口")
  50. public class So2Controller extends BaseController {
  51. @Autowired
  52. private ElasticSearchClient client;
  53. @Autowired
  54. private IAisDatabase aisDatabase;
  55. @Autowired
  56. private ISo2Service so2Service;
  57. @Autowired
  58. private IHeiYanService heiYanService;
  59. @Autowired
  60. private RedisCache redisCache;
  61. @Autowired
  62. private ISysDictTypeService dictTypeService;
  63. @GetMapping("/guangpu/list")
  64. @ApiOperation("光谱-硫嫌疑船舶列表数据")
  65. public TableDataInfo GpList(GuapAlert guapAlert) {
  66. // 传来的参数
  67. Map<String, Object> params = guapAlert.getParams();
  68. Map<String, Object> equalsCondition = new HashMap<>();
  69. // 组装查询条件
  70. equalsCondition.put("mmsi", ObjectUtil.isEmpty(guapAlert.getMmsi()) ? null : StrUtil.concat(true, "*", Convert.toStr(guapAlert.getMmsi()), "*"));
  71. equalsCondition.put("shipName", StrUtil.isBlank(guapAlert.getShipName()) ? null : StrUtil.concat(true, "*", guapAlert.getShipName(), "*"));
  72. equalsCondition.put("shipRegionType", guapAlert.getShipRegionType());
  73. equalsCondition.put("destination", StrUtil.isBlank(guapAlert.getDestination()) ? null : StrUtil.concat(true, "*", guapAlert.getDestination(), "*"));
  74. equalsCondition.put("orgName", guapAlert.getOrgName());
  75. equalsCondition.put("illegalStatus", guapAlert.getIllegalStatus());
  76. equalsCondition.put("dealResult", guapAlert.getDealResult());
  77. equalsCondition.put("fastResult", guapAlert.getFastResult());
  78. equalsCondition.put("uploadResult", guapAlert.getUploadResult());
  79. equalsCondition.put("monitorPointName", guapAlert.getMonitorPointName());
  80. // 组装范围查询条件
  81. Map<String, Object> rangeCondition = new HashMap<>();
  82. if (ObjectUtil.isNotEmpty(params.get("beginTime"))) {
  83. params.put("beginTime", params.get("beginTime") + " 00:00:00");
  84. }
  85. if (ObjectUtil.isNotEmpty(params.get("endTime"))) {
  86. params.put("endTime", params.get("endTime") + " 23:59:59");
  87. }
  88. rangeCondition.put("createTime", StrUtil.concat(true, "[", Convert.toStr(params.get("beginTime")), ",", Convert.toStr(params.get("endTime")), "]"));
  89. List<String> orderBy = new ArrayList<>();
  90. orderBy.add("-createTime");
  91. PageDomain pageDomain = TableSupport.buildPageRequest();
  92. Map<String, Object> maps = client.searchDocument(equalsCondition, rangeCondition, orderBy, pageDomain.getPageNum(), pageDomain.getPageSize(), ElasticConstants.SO2_ALERT);
  93. TableDataInfo rspData = new TableDataInfo();
  94. rspData.setCode(HttpStatus.SUCCESS);
  95. rspData.setMsg("查询成功");
  96. rspData.setRows(Convert.toList(GuapAlert.class, maps.get("pageList")));
  97. rspData.setTotal(Convert.toLong(maps.get("totalNum")));
  98. return rspData;
  99. }
  100. @GetMapping("/xiutan/list")
  101. @ApiOperation("嗅探-硫嫌疑船舶列表数据")
  102. public TableDataInfo XtList(XiuTanIllegalShip illegalShip) {
  103. // 传来的参数
  104. Map<String, Object> params = illegalShip.getParams();
  105. Map<String, Object> equalsCondition = new HashMap<>();
  106. // 组装查询条件
  107. equalsCondition.put("mmsi", ObjectUtil.isEmpty(illegalShip.getMmsi()) ? null : StrUtil.concat(true, "*", Convert.toStr(illegalShip.getMmsi()), "*"));
  108. equalsCondition.put("shipName", StrUtil.isBlank(illegalShip.getShipName()) ? null : StrUtil.concat(true, "*", illegalShip.getShipName(), "*"));
  109. equalsCondition.put("shipRegionType", illegalShip.getShipRegionType());
  110. equalsCondition.put("destination", StrUtil.isBlank(illegalShip.getDestination()) ? null : StrUtil.concat(true, "*", illegalShip.getDestination(), "*"));
  111. equalsCondition.put("orgName", illegalShip.getOrgName());
  112. equalsCondition.put("illegalStatus", illegalShip.getIllegalStatus());
  113. equalsCondition.put("dealResult", illegalShip.getDealResult());
  114. equalsCondition.put("fastResult", illegalShip.getFastResult());
  115. equalsCondition.put("uploadResult", illegalShip.getUploadResult());
  116. equalsCondition.put("monitorPointName", illegalShip.getMonitorPointName());
  117. // 组装范围查询条件
  118. Map<String, Object> rangeCondition = new HashMap<>();
  119. if (ObjectUtil.isNotEmpty(params.get("beginTime"))) {
  120. params.put("beginTime", params.get("beginTime") + " 00:00:00");
  121. }
  122. if (ObjectUtil.isNotEmpty(params.get("endTime"))) {
  123. params.put("endTime", params.get("endTime") + " 23:59:59");
  124. }
  125. rangeCondition.put("peakTime", StrUtil.concat(true, "[", Convert.toStr(params.get("beginTime")), ",", Convert.toStr(params.get("endTime")), "]"));
  126. List<String> orderBy = new ArrayList<>();
  127. orderBy.add("-peakTime");
  128. PageDomain pageDomain = TableSupport.buildPageRequest();
  129. Map<String, Object> maps = client.searchDocument(equalsCondition, rangeCondition, orderBy, pageDomain.getPageNum(), pageDomain.getPageSize(), ElasticConstants.AIS_ILLEGAL_SHIP);
  130. TableDataInfo rspData = new TableDataInfo();
  131. rspData.setCode(HttpStatus.SUCCESS);
  132. rspData.setMsg("查询成功");
  133. rspData.setRows(Convert.toList(GuapAlert.class, maps.get("pageList")));
  134. rspData.setTotal(Convert.toLong(maps.get("totalNum")));
  135. return rspData;
  136. }
  137. @GetMapping("/list")
  138. @ApiOperation("硫嫌疑船舶列表数据")
  139. public TableDataInfo list(IllegalShip illegalShip) {
  140. // 传来的参数
  141. Map<String, Object> params = illegalShip.getParams();
  142. Map<String, Object> equalsCondition = new HashMap<>();
  143. // 组装查询条件
  144. equalsCondition.put("mmsi", ObjectUtil.isEmpty(illegalShip.getMmsi()) ? null : StrUtil.concat(true, "*", Convert.toStr(illegalShip.getMmsi()), "*"));
  145. equalsCondition.put("shipName", StrUtil.isBlank(illegalShip.getShipName()) ? null : StrUtil.concat(true, "*", illegalShip.getShipName(), "*"));
  146. equalsCondition.put("shipRegionType", illegalShip.getShipRegionType());
  147. equalsCondition.put("destination", StrUtil.isBlank(illegalShip.getDestination()) ? null : StrUtil.concat(true, "*", illegalShip.getDestination(), "*"));
  148. equalsCondition.put("orgName", illegalShip.getOrgName());
  149. equalsCondition.put("illegalStatus", illegalShip.getIllegalStatus());
  150. equalsCondition.put("dealResult", illegalShip.getDealResult());
  151. equalsCondition.put("fastResult", illegalShip.getFastResult());
  152. equalsCondition.put("uploadResult", illegalShip.getUploadResult());
  153. equalsCondition.put("illegalType", illegalShip.getIllegalType());
  154. equalsCondition.put("monitorPointName", illegalShip.getMonitorPointName());
  155. // 组装范围查询条件
  156. Map<String, Object> rangeCondition = new HashMap<>();
  157. if (ObjectUtil.isNotEmpty(params.get("beginTime"))) {
  158. params.put("beginTime", params.get("beginTime") + " 00:00:00");
  159. }
  160. if (ObjectUtil.isNotEmpty(params.get("endTime"))) {
  161. params.put("endTime", params.get("endTime") + " 23:59:59");
  162. }
  163. rangeCondition.put("createTime", StrUtil.concat(true, "[", Convert.toStr(params.get("beginTime")), ",", Convert.toStr(params.get("endTime")), "]"));
  164. List<String> orderBy = new ArrayList<>();
  165. orderBy.add("-createTime");
  166. PageDomain pageDomain = TableSupport.buildPageRequest();
  167. Map<String, Object> maps = client.searchDocument(equalsCondition, rangeCondition, orderBy, pageDomain.getPageNum(), pageDomain.getPageSize(), ElasticConstants.SO2_ALERT, ElasticConstants.AIS_ILLEGAL_SHIP);
  168. TableDataInfo rspData = new TableDataInfo();
  169. rspData.setCode(HttpStatus.SUCCESS);
  170. rspData.setMsg("查询成功");
  171. rspData.setRows(Convert.toList(IllegalShip.class, maps.get("pageList")));
  172. rspData.setTotal(Convert.toLong(maps.get("totalNum")));
  173. return rspData;
  174. }
  175. @GetMapping("/guangpu/monitorPoint")
  176. @ApiOperation("光谱-检测点数据")
  177. public AjaxResult monitorPoint(GuapMonitorPoint monitorPoint) {
  178. // 传来的参数
  179. Map<String, Object> equalsCondition = new HashMap<>();
  180. // 组装查询条件
  181. equalsCondition.put("name", StrUtil.isBlank(monitorPoint.getName()) ? null : StrUtil.concat(true, "*", monitorPoint.getName(), "*"));
  182. Map<String, Object> maps = client.searchDocument(equalsCondition, null, null, 1, 10000, ElasticConstants.SO2_MONITOR_POINT);
  183. return AjaxResult.success(Convert.toList(GuapMonitorPoint.class, maps.get("pageList")));
  184. }
  185. @GetMapping("/xiutan/semInstrument")
  186. @ApiOperation("嗅探-设备数据")
  187. public AjaxResult semInstrument(XiuTanSemInstrument semInstrument) {
  188. // 传来的参数
  189. Map<String, Object> equalsCondition = new HashMap<>();
  190. // 组装查询条件
  191. equalsCondition.put("name", StrUtil.isBlank(semInstrument.getName()) ? null : StrUtil.concat(true, "*", semInstrument.getName(), "*"));
  192. Map<String, Object> maps = client.searchDocument(equalsCondition, null, null, 1, 10000, ElasticConstants.AIS_SEM_INSTRUMENT);
  193. return AjaxResult.success(Convert.toList(XiuTanSemInstrument.class, maps.get("pageList")));
  194. }
  195. @GetMapping("/static/device")
  196. @ApiOperation("设备安装位置统计")
  197. public AjaxResult deviceStatic() {
  198. if (redisCache.hasKey(CacheConstants.DEVICE_STATIC)) {
  199. return AjaxResult.success(redisCache.getCacheMap(CacheConstants.DEVICE_STATIC));
  200. }
  201. List<Map<String, Object>> aisDevice = aisDatabase.queryDeviceStatic();
  202. List<Map<String, Object>> so2Device = so2Service.queryDeviceStatic();
  203. List<Map<String, Object>> heiyanDevice = heiYanService.queryDeviceStatic();
  204. // 两个结果合并
  205. Map<String, Integer> result = new HashMap<>(8);
  206. for (Map<String, Object> stringIntegerMap : aisDevice) {
  207. result.put(Convert.toStr(stringIntegerMap.get("point")), Convert.toInt(stringIntegerMap.get("count")));
  208. }
  209. for (Map<String, Object> stringIntegerMap : so2Device) {
  210. result.put(Convert.toStr(stringIntegerMap.get("point")), Convert.toInt(NumberUtil.add(result.get(Convert.toStr(stringIntegerMap.get("point"))), Convert.toInt(stringIntegerMap.get("count")))));
  211. }
  212. for (Map<String, Object> stringObjectMap : heiyanDevice) {
  213. result.put(Convert.toStr(stringObjectMap.get("point")), Convert.toInt(NumberUtil.add(result.get(Convert.toStr(stringObjectMap.get("point"))), Convert.toInt(stringObjectMap.get("count")))));
  214. }
  215. redisCache.setCacheMap(CacheConstants.DEVICE_STATIC, result);
  216. return AjaxResult.success(result);
  217. }
  218. @GetMapping("/static/deviceType")
  219. @ApiOperation("设备类型统计")
  220. public AjaxResult deviceTypeStatic() {
  221. if (redisCache.hasKey(CacheConstants.DEVICE_TYPE_STATIC)) {
  222. return AjaxResult.success(redisCache.getCacheMap(CacheConstants.DEVICE_TYPE_STATIC));
  223. }
  224. int aisDevice = aisDatabase.queryDeviceCount();
  225. int so2Device = so2Service.queryDeviceCount();
  226. int heiyanDevice = heiYanService.queryDeviceCount();
  227. // 两个结果合并
  228. Map<String, Integer> result = new HashMap<>(4);
  229. result.put("光谱", so2Device);
  230. result.put("嗅探", aisDevice);
  231. result.put("黑烟", heiyanDevice);
  232. redisCache.setCacheMap(CacheConstants.DEVICE_TYPE_STATIC, result);
  233. return AjaxResult.success(result);
  234. }
  235. @GetMapping("/snapPos/static")
  236. @ApiOperation("硫含量超标船舶分布统计")
  237. public AjaxResult so2SnapPosStatic(@RequestParam(required = false) String month) {
  238. String beginTime = "";
  239. String endTime = "";
  240. if (StrUtil.isBlank(month)) {
  241. beginTime = DateUtil.formatDate(DateUtil.beginOfMonth(new Date())) + " 00:00:00";
  242. endTime = DateUtil.formatDate(DateUtil.endOfMonth(new Date())) + " 23:59:59";
  243. } else {
  244. beginTime = month + "-01 00:00:00";
  245. endTime = DateUtil.formatDate(DateUtil.endOfMonth(DateUtil.parseDate(beginTime))) + " 23:59:59";
  246. }
  247. Map<String, Object> equalsCondition = new HashMap<>();
  248. equalsCondition.put("illegalStatus", 2);
  249. Map<String, Object> so2RangeCondition = new HashMap<>();
  250. so2RangeCondition.put("createTime", StrUtil.concat(true, "[", beginTime, ",", endTime, "]"));
  251. Map<Object, Object> so2Aggs = client.aggs(AggsType.count, "monitorPointName", "id", equalsCondition, so2RangeCondition, ElasticConstants.AIS_ILLEGAL_SHIP, ElasticConstants.SO2_ALERT);
  252. // 构造硫的数据
  253. List<SysDictData> so2_snap_pos = dictTypeService.selectDictDataByType("so2_snap_pos");
  254. Map<String, Object> result = new HashMap<>();
  255. for (SysDictData so2_snap_po : so2_snap_pos) {
  256. result.put(so2_snap_po.getDictLabel(),
  257. (ObjectUtil.isEmpty(so2Aggs.get(so2_snap_po.getDictLabel())) ? 0 : Convert.toInt(so2Aggs.get(so2_snap_po.getDictLabel()))));
  258. }
  259. return AjaxResult.success(result);
  260. }
  261. @GetMapping("/timeStatic")
  262. @ApiOperation("超标船舶统计-按时间")
  263. public AjaxResult monthStatic(@RequestParam(required = false) String interval, @RequestParam(required = false) String startMonth, @RequestParam(required = false) String endMonth) {
  264. if (StrUtil.isBlank(interval)) {
  265. // 默认值为1个月
  266. interval = "1M";
  267. }
  268. Map<String, Object> rangeCondition = new HashMap<>();
  269. if (!StrUtil.isAllBlank(startMonth, endMonth)) {
  270. if (StrUtil.isNotBlank(startMonth)) {
  271. startMonth = startMonth + "-01 00:00:00";
  272. }
  273. if (StrUtil.isNotBlank(endMonth)) {
  274. endMonth = DateUtil.formatDate(DateUtil.endOfMonth(DateUtil.parseDate(endMonth + "-01 00:00:00"))) + " 23:59:59";
  275. }
  276. rangeCondition.put("createTime", StrUtil.concat(true, "[", startMonth, ",", endMonth, "]"));
  277. }
  278. Map<String, Object> equalsCondition = new HashMap<>();
  279. equalsCondition.put("illegalStatus", 2);
  280. Map<Object, Object> aisAggs = client.dateHistogramAggs(ElasticConstants.AIS_ILLEGAL_SHIP, AggsType.count, "createTime", "id", equalsCondition, rangeCondition, new DateHistogramInterval(interval));
  281. Map<Object, Object> so2Aggs = client.dateHistogramAggs(ElasticConstants.SO2_ALERT, AggsType.count, "createTime", "id", equalsCondition, rangeCondition, new DateHistogramInterval(interval));
  282. equalsCondition.put("illegalStatus", 3);
  283. Map<Object, Object> heiyanAggs = client.dateHistogramAggs(ElasticConstants.HEIYAN_SHIP_RECOGNITION, AggsType.count, "createTime", "id", equalsCondition, rangeCondition, new DateHistogramInterval(interval));
  284. Map<String, Map<Object, Object>> result = new HashMap<>();
  285. result.put("ais", aisAggs);
  286. result.put("so2", so2Aggs);
  287. result.put("black", heiyanAggs);
  288. return AjaxResult.success(result);
  289. }
  290. /*@DeleteMapping("/del")
  291. @ApiOperation("删除数据")
  292. public AjaxResult del() {
  293. if (StrUtil.isBlank(interval)) {
  294. // 默认值为1个月
  295. interval = "1M";
  296. }
  297. Map<Object, Object> aisAggs = client.dateHistogramAggs(ElasticConstants.AIS_ILLEGAL_SHIP, AggsType.count, "peakTime", "id", null, null, new DateHistogramInterval(interval));
  298. Map<Object, Object> so2Aggs = client.dateHistogramAggs(ElasticConstants.SO2_ALERT, AggsType.count, "createTime", "id", null, null, new DateHistogramInterval(interval));
  299. Map<Object, Object> heiyanAggs = client.dateHistogramAggs(ElasticConstants.HEIYAN_SHIP_RECOGNITION, AggsType.count, "snapTimeFmt", "id", null, null, new DateHistogramInterval(interval));
  300. Map<String, Map<Object, Object>> result = new HashMap<>();
  301. result.put("ais", aisAggs);
  302. result.put("so2", so2Aggs);
  303. result.put("black", heiyanAggs);
  304. return AjaxResult.success(result);
  305. }*/
  306. }