123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336 |
- package com.huaxu.controller;
- import com.baomidou.mybatisplus.core.metadata.IPage;
- import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
- import com.huaxu.dao.ReportWaterPumpStateMapper;
- import com.huaxu.dto.*;
- import com.huaxu.dto.watePump.ReprotWaterPumpDto;
- import com.huaxu.dto.watePump.ReprotWaterPumpQueryDto;
- import com.huaxu.entity.MonitorDataEntity;
- import com.huaxu.entity.MonitorDataValueEntity;
- import com.huaxu.model.AjaxMessage;
- import com.huaxu.model.Pagination;
- import com.huaxu.model.ResultStatus;
- import com.huaxu.service.*;
- import com.huaxu.util.ByteArrayUtils;
- import com.huaxu.util.DatesUtil;
- import com.huaxu.util.RedisUtil;
- import com.huaxu.util.UserUtil;
- import io.swagger.annotations.Api;
- import io.swagger.annotations.ApiOperation;
- import io.swagger.annotations.ApiParam;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.web.bind.annotation.*;
- import java.text.DecimalFormat;
- import java.util.*;
- import java.util.stream.Collectors;
- /**
- * 在线监测控制层
- *
- * @author yjy
- * @since 2020-12-2
- */
- @RestController
- @RequestMapping("/onlineMonitor")
- @Api(tags = "在线监测")
- public class OnlineMonitorController {
- /**
- * 服务对象
- */
- @Autowired
- private OnlineMonitorService onlineMonitorService;
- @Autowired
- private SceneService sceneService;
- @Autowired
- private RevenueService revenueService;
- @Autowired
- private ReportWaterPumpStateService reportWaterPumpStateService;
- @RequestMapping(value="selectAlarmDetails" , method = RequestMethod.GET)
- @ApiOperation(value = "查询实时报警信息")
- public AjaxMessage<List<AlarmDetailsDto>> selectAlarmDetails(
- @ApiParam(value = "一级场景类型名称", required = false) @RequestParam(required = false) String sceneTypeName,
- @ApiParam(value = "场景名称", required = false) @RequestParam(required = false) String sceneName,
- @ApiParam(value = "公司机构id", required = false)@RequestParam(required = false) Integer companyOrgId){
- AlarmDetailsDto alarmDetailsDto=new AlarmDetailsDto();
- alarmDetailsDto.setSceneTypeName(sceneTypeName);
- alarmDetailsDto.setSceneName(sceneName);
- alarmDetailsDto.setCompanyOrgId(companyOrgId);
- alarmDetailsDto.setSceneIds(sceneService.findByParentIdsLike(null));
- return new AjaxMessage<>(ResultStatus.OK, onlineMonitorService.selectAlarmDetails(alarmDetailsDto));
- }
- @RequestMapping(value="selectAlarmCount" , method = RequestMethod.GET)
- @ApiOperation(value = "查询实时报警数量")
- public AjaxMessage<List<Map<String, Object>>> selectAlarmCount(
- @ApiParam(value = "一级场景类型名称", required = true) @RequestParam String sceneTypeName,
- @ApiParam(value = "场景名称", required = false) @RequestParam(required = false) String sceneName){
- AlarmDetailsDto alarmDetailsDto=new AlarmDetailsDto();
- alarmDetailsDto.setSceneTypeName(sceneTypeName);
- alarmDetailsDto.setSceneName(sceneName);
- alarmDetailsDto.setSceneIds(sceneService.findByParentIdsLike(null));
- return new AjaxMessage<>(ResultStatus.OK, onlineMonitorService.selectAlarmCount(alarmDetailsDto));
- }
- @RequestMapping(value="selectMapSuspension" , method = RequestMethod.GET)
- @ApiOperation(value = "查询地图悬浮数据及用水量排行")
- public AjaxMessage<List<MonitorDataCollectDto>> selectMapSuspension(
- @ApiParam(value = "一级场景类型名称", required = false) @RequestParam(required = false) String sceneTypeName){
- MonitorDataCollectDto monitorDataCollectDto=new MonitorDataCollectDto();
- monitorDataCollectDto.setSceneTypeName(sceneTypeName);
- monitorDataCollectDto.setFlag(1);
- monitorDataCollectDto.setSceneIds(sceneService.findByParentIdsLike(null));
- List<MonitorDataCollectDto> result=onlineMonitorService.selectMapSuspension(monitorDataCollectDto);
- return new AjaxMessage<>(ResultStatus.OK, result);
- }
- @RequestMapping(value="selectMapParam" , method = RequestMethod.GET)
- @ApiOperation(value = "查询地图参数数据")
- public AjaxMessage<List<MonitorDataCollectDto>> selectMapParam(
- @ApiParam(value = "一级场景id", required = true) @RequestParam Long sceneId){
- MonitorDataCollectDto monitorDataCollectDto=new MonitorDataCollectDto();
- monitorDataCollectDto.setSceneId(sceneId);
- monitorDataCollectDto.setFlag(1);
- monitorDataCollectDto.setSceneIds(sceneService.findByParentIdsLike(null));
- List<MonitorDataCollectDto> result=onlineMonitorService.selectMapParam(monitorDataCollectDto);
- return new AjaxMessage<>(ResultStatus.OK, result);
- }
- @RequestMapping(value="selectPage" , method = RequestMethod.GET)
- @ApiOperation(value = "查询实时数据列表")
- public AjaxMessage<Pagination<OnlineDataDto>> selectPage(
- @ApiParam(value = "页数", required = true)@RequestParam Integer pageNum,
- @ApiParam(value = "条数", required = true)@RequestParam Integer pageSize,
- @ApiParam(value = "一级场景类型名称", required = true) @RequestParam String sceneTypeName,
- @ApiParam(value = "场景名称", required = false) @RequestParam(required = false) String sceneName){
- OnlineDataDto onlineDataDto=new OnlineDataDto();
- onlineDataDto.setSceneTypeName(sceneTypeName);
- onlineDataDto.setSceneName(sceneName);
- onlineDataDto.setSceneIds(sceneService.findByParentIdsLike(null));
- IPage<OnlineDataDto> iPage = new Page<>(pageNum, pageSize);
- iPage = onlineMonitorService.selectPage(iPage, onlineDataDto);
- Pagination<OnlineDataDto> pages = new Pagination<>(iPage);
- return new AjaxMessage<>(ResultStatus.OK, pages);
- }
- @RequestMapping(value="selectAlarmStats" , method = RequestMethod.GET)
- @ApiOperation(value = "查询设备报警分析")
- public AjaxMessage<List<Map<String, Object>>> selectAlarmStats(
- @ApiParam(value = "一级场景id", required = true) @RequestParam Long sceneId,
- @ApiParam(value = "查询天数 1、3、7", required = true) @RequestParam Integer days){
- AlarmDetailsDto alarmDetailsDto=new AlarmDetailsDto();
- alarmDetailsDto.setId(sceneId);
- alarmDetailsDto.setDays(days);
- alarmDetailsDto.setSceneIds(sceneService.findByParentIdsLike(null));
- return new AjaxMessage<>(ResultStatus.OK, onlineMonitorService.selectAlarmStats(alarmDetailsDto));
- }
- @RequestMapping(value="selectDeviceCount" , method = RequestMethod.GET)
- @ApiOperation(value = "按管网名称分类查询设备数量",notes = "sceneTypeName 为压力、水质、流量")
- public AjaxMessage<List<Map<String, Object>>> selectDeviceCount(
- @ApiParam(value = "场景类型名称", required = true) @RequestParam String sceneTypeName,
- @ApiParam(value = "场景id", required = false) @RequestParam(required = false) Long sceneId,
- @ApiParam(value = "设备名称", required = false) @RequestParam(required = false) String deviceName){
- OnlineDataDto onlineDataDto=new OnlineDataDto();
- onlineDataDto.setSceneTypeName(sceneTypeName);
- onlineDataDto.setSceneId(sceneId);
- onlineDataDto.setDeviceName(deviceName);
- onlineDataDto.setSceneIds(sceneService.findByParentIdsLike(null));
- return new AjaxMessage<>(ResultStatus.OK, onlineMonitorService.selectDeviceCount(onlineDataDto));
- }
- @RequestMapping(value="selectDeviceMapParam" , method = RequestMethod.GET)
- @ApiOperation(value = "查询设备地图参数数据")
- public AjaxMessage<List<MonitorDataCollectDto>> selectDeviceMapParam(
- @ApiParam(value = "一级场景id", required = true) @RequestParam Long deviceId){
- MonitorDataCollectDto monitorDataCollectDto=new MonitorDataCollectDto();
- monitorDataCollectDto.setDeviceId(deviceId);
- monitorDataCollectDto.setFlag(1);
- monitorDataCollectDto.setSceneIds(sceneService.findByParentIdsLike(null));
- List<MonitorDataCollectDto> result=onlineMonitorService.selectDeviceMapParam(monitorDataCollectDto);
- return new AjaxMessage<>(ResultStatus.OK, result);
- }
- @RequestMapping(value="statsDeviceQualified" , method = RequestMethod.GET)
- @ApiOperation(value = "统计设备合格数据",notes = "sceneTypeName 为压力、水质")
- public AjaxMessage<List<DeviceCountStatsDto>> statsDeviceQualified(
- @ApiParam(value = "场景类型名称", required = false) @RequestParam(required = false) String sceneTypeName,
- @ApiParam(value = "场景id", required = false) @RequestParam(required = false) Long sceneId,
- @ApiParam(value = "设备名称", required = false) @RequestParam(required = false) String deviceName){
- OnlineDataDto onlineDataDto=new OnlineDataDto();
- onlineDataDto.setSceneTypeName(sceneTypeName);
- onlineDataDto.setSceneId(sceneId);
- onlineDataDto.setDeviceName(deviceName);
- onlineDataDto.setSceneIds(sceneService.findByParentIdsLike(null));
- List<DeviceCountStatsDto> result=onlineMonitorService.statsDeviceQualified(onlineDataDto);
- return new AjaxMessage<>(ResultStatus.OK, result);
- }
- @RequestMapping(value="statsDeviceFlow" , method = RequestMethod.GET)
- @ApiOperation(value = "统计今日累计流量")
- public AjaxMessage<List<MonitorDataCollectDto>> statsDeviceFlow(
- @ApiParam(value = "场景id", required = false) @RequestParam(required = false) Long sceneId,
- @ApiParam(value = "设备名称", required = false) @RequestParam(required = false) String deviceName){
- OnlineDataDto onlineDataDto=new OnlineDataDto();
- onlineDataDto.setSceneTypeName("流量");
- onlineDataDto.setType(4);
- onlineDataDto.setSceneId(sceneId);
- onlineDataDto.setDeviceName(deviceName);
- onlineDataDto.setSceneIds(sceneService.findByParentIdsLike(null));
- List<MonitorDataCollectDto> result=onlineMonitorService.statsDeviceFlow(onlineDataDto);
- return new AjaxMessage<>(ResultStatus.OK, result);
- }
- @RequestMapping(value="statsDeviceParmCount" , method = RequestMethod.GET)
- @ApiOperation(value = "统计压力、瞬时流量的分布区间")
- public AjaxMessage<DistributeIntervalDto> statsDeviceParmCount(
- @ApiParam(value = "场景类型名称", required = true) @RequestParam String sceneTypeName,
- @ApiParam(value = "场景id", required = false) @RequestParam(required = false) Long sceneId,
- @ApiParam(value = "设备名称", required = false) @RequestParam(required = false) String deviceName){
- OnlineDataDto onlineDataDto=new OnlineDataDto();
- onlineDataDto.setSceneTypeName(sceneTypeName);
- if(sceneTypeName.equals("压力")){
- onlineDataDto.setType(1);
- }else if(sceneTypeName.equals("流量")){
- onlineDataDto.setType(5);
- }
- onlineDataDto.setSceneId(sceneId);
- onlineDataDto.setDeviceName(deviceName);
- onlineDataDto.setSceneIds(sceneService.findByParentIdsLike(null));
- DistributeIntervalDto result=onlineMonitorService.statsDeviceParmCount(onlineDataDto);
- return new AjaxMessage<>(ResultStatus.OK, result);
- }
- @RequestMapping(value="selectPipeNetPage" , method = RequestMethod.GET)
- @ApiOperation(value = "查询管网实时数据列表")
- public AjaxMessage<Pagination<OnlineDataDto>> selectPipeNetPage(
- @ApiParam(value = "页数", required = true)@RequestParam Integer pageNum,
- @ApiParam(value = "条数", required = true)@RequestParam Integer pageSize,
- @ApiParam(value = "场景类型名称(压力、流量、水质)", required = true) @RequestParam String sceneTypeName,
- @ApiParam(value = "场景id", required = false) @RequestParam(required = false) Long sceneId,
- @ApiParam(value = "设备名称", required = false) @RequestParam(required = false) String deviceName){
- OnlineDataDto onlineDataDto=new OnlineDataDto();
- onlineDataDto.setSceneTypeName(sceneTypeName);
- if(sceneTypeName.equals("压力")){
- onlineDataDto.setType(1);
- }else if(sceneTypeName.equals("流量")){
- onlineDataDto.setType(2);
- }else if(sceneTypeName.equals("水质")){
- onlineDataDto.setType(3);
- }
- onlineDataDto.setSceneId(sceneId);
- onlineDataDto.setDeviceName(deviceName);
- onlineDataDto.setSceneIds(sceneService.findByParentIdsLike(null));
- IPage<OnlineDataDto> iPage = new Page<>(pageNum, pageSize);
- iPage = onlineMonitorService.selectPipeNetPage(iPage, onlineDataDto);
- Pagination<OnlineDataDto> pages = new Pagination<>(iPage);
- return new AjaxMessage<>(ResultStatus.OK, pages);
- }
- @RequestMapping(value="selectPipeNetLayer" , method = RequestMethod.GET)
- @ApiOperation(value = "查询管网地图图层及设备")
- public AjaxMessage<List<PipeNetLayerDto>> selectPipeNetLayer(
- @ApiParam(value = "场景类型名称", required = false) @RequestParam(required = false) String sceneTypeName){
- OnlineDataDto onlineDataDto=new OnlineDataDto();
- onlineDataDto.setSceneTypeName(sceneTypeName);
- onlineDataDto.setFlag(1);
- onlineDataDto.setSceneIds(sceneService.findByParentIdsLike(null));
- List<PipeNetLayerDto> result=onlineMonitorService.selectPipeNetLayer(onlineDataDto);
- return new AjaxMessage<>(ResultStatus.OK, result);
- }
- @RequestMapping(value="statsDispatchSummary" , method = RequestMethod.GET)
- @ApiOperation(value = "统计从水源地到水龙头汇总数据")
- public AjaxMessage<DispatchSummaryDto> statsDispatchSummary(){
- MonitorDataCollectDto monitorDataCollectDto=new MonitorDataCollectDto();
- monitorDataCollectDto.setSceneIds(sceneService.findByParentIdsLike(null));
- DispatchSummaryDto result=onlineMonitorService.statsDispatchSummary(monitorDataCollectDto);
- return new AjaxMessage<>(ResultStatus.OK, result);
- }
- @RequestMapping(value="statsPipeNetQualified" , method = RequestMethod.GET)
- @ApiOperation(value = "App-统计管网设备合格数据",notes = "sceneTypeName 为压力、水质、流量")
- public AjaxMessage<List<DeviceCountStatsDto>> statsPipeNetQualified(
- @ApiParam(value = "场景类型名称", required = false) @RequestParam(required = false) String sceneTypeName){
- OnlineDataDto onlineDataDto=new OnlineDataDto();
- onlineDataDto.setSceneTypeName(sceneTypeName);
- onlineDataDto.setFlag(1);
- onlineDataDto.setSceneIds(sceneService.findByParentIdsLike(null));
- List<DeviceCountStatsDto> result=onlineMonitorService.statsDeviceQualified(onlineDataDto);
- for(DeviceCountStatsDto item : result){
- if(item.getType().equals("流量"))
- continue;
- onlineDataDto.setFlag(null);
- onlineDataDto.setSceneTypeName(item.getType());
- List<DeviceCountStatsDto> itemResult=onlineMonitorService.statsDeviceQualified(onlineDataDto);
- if(itemResult.size()>0){
- if(item.getType().equals("压力")){
- DeviceCountStatsDto pressQualified=itemResult.get(0).getParmQualified().size()>0?itemResult.get(0).getParmQualified().get(0):null;
- item.setQualifiedRate(pressQualified==null?100:(double)pressQualified.getNormalCount()/itemResult.get(0).getTotalCount()*100);
- }else if(item.getType().equals("水质")){
- item.setQualifiedRate((double)itemResult.get(0).getNormalCount()/itemResult.get(0).getTotalCount()*100);
- }
- }
- }
- return new AjaxMessage<>(ResultStatus.OK, result);
- }
- @RequestMapping(value="selectList" , method = RequestMethod.GET)
- @ApiOperation(value = "App-查询场景实时数据列表")
- public AjaxMessage<List<OnlineDataDto>> selectList(
- @ApiParam(value = "一级场景类型名称", required = true) @RequestParam String sceneTypeName,
- @ApiParam(value = "场景id", required = false) @RequestParam(required = false)Long sceneId,
- @ApiParam(value = "公司id", required = false) @RequestParam(required = false)Integer companyOrgId){
- OnlineDataDto onlineDataDto=new OnlineDataDto();
- onlineDataDto.setSceneTypeName(sceneTypeName);
- onlineDataDto.setSceneId(sceneId);
- onlineDataDto.setCompanyOrgId(companyOrgId);
- onlineDataDto.setSceneIds(sceneService.findByParentIdsLike(null));
- List<OnlineDataDto> result = onlineMonitorService.selectList(onlineDataDto);
- return new AjaxMessage<>(ResultStatus.OK, result);
- }
- @RequestMapping(value="selectPipeNetList" , method = RequestMethod.GET)
- @ApiOperation(value = "App-查询管网实时数据列表")
- public AjaxMessage<List<OnlineDataDto>> selectPipeNetList(
- @ApiParam(value = "场景类型名称(压力、流量、水质)", required = true) @RequestParam String sceneTypeName,
- @ApiParam(value = "设备id", required = false) @RequestParam(required = false)Long deviceId,
- @ApiParam(value = "公司id", required = false) @RequestParam(required = false)Integer companyOrgId){
- OnlineDataDto onlineDataDto=new OnlineDataDto();
- onlineDataDto.setSceneTypeName(sceneTypeName);
- if(sceneTypeName.equals("压力")){
- onlineDataDto.setType(1);
- }else if(sceneTypeName.equals("流量")){
- onlineDataDto.setType(2);
- }else if(sceneTypeName.equals("水质")){
- onlineDataDto.setType(3);
- }
- onlineDataDto.setDeviceId(deviceId);
- onlineDataDto.setCompanyOrgId(companyOrgId);
- onlineDataDto.setSceneIds(sceneService.findByParentIdsLike(null));
- List<OnlineDataDto> result = onlineMonitorService.selectPipeNetList(onlineDataDto);
- return new AjaxMessage<>(ResultStatus.OK, result);
- }
- @RequestMapping(value="selectStateCount" , method = RequestMethod.GET)
- @ApiOperation(value = "查询场景实时状态数量")
- public AjaxMessage<List<Map<String, Object>>> selectStatusCount(
- @ApiParam(value = "一级场景类型名称", required = true) @RequestParam String sceneTypeName){
- OnlineDataDto onlineDataDto=new OnlineDataDto();
- onlineDataDto.setSceneTypeName(sceneTypeName);
- onlineDataDto.setFlag(1);
- onlineDataDto.setSceneIds(sceneService.findByParentIdsLike(null));
- return new AjaxMessage<>(ResultStatus.OK, onlineMonitorService.selectStateCount(onlineDataDto));
- }
- @RequestMapping(value="selectWaterPumpSate" , method = RequestMethod.GET)
- @ApiOperation(value = "查询泵站状态数据")
- public AjaxMessage selectWaterPumpSate(
- @ApiParam(value = "一级场景id", required = true) @RequestParam Long sceneId,
- @ApiParam(value = "查询天数 1、3、7", required = true) @RequestParam Integer days){
- return new AjaxMessage<>(ResultStatus.OK, reportWaterPumpStateService.findReportWaterPumpStateList(sceneService.findByParentIdsLike(sceneId),days));
- }
- }
|