|
@@ -20,12 +20,26 @@ import com.java110.core.annotation.Java110Cmd;
|
|
|
import com.java110.core.context.ICmdDataFlowContext;
|
|
import com.java110.core.context.ICmdDataFlowContext;
|
|
|
import com.java110.core.event.cmd.Cmd;
|
|
import com.java110.core.event.cmd.Cmd;
|
|
|
import com.java110.core.event.cmd.CmdEvent;
|
|
import com.java110.core.event.cmd.CmdEvent;
|
|
|
|
|
+import com.java110.dto.RoomDto;
|
|
|
|
|
+import com.java110.dto.community.CommunityDto;
|
|
|
|
|
+import com.java110.dto.community.CommunityLocationDto;
|
|
|
|
|
+import com.java110.dto.unit.FloorAndUnitDto;
|
|
|
|
|
+import com.java110.intf.common.IMachineInnerServiceSMO;
|
|
|
import com.java110.intf.common.IMachineV1InnerServiceSMO;
|
|
import com.java110.intf.common.IMachineV1InnerServiceSMO;
|
|
|
|
|
+import com.java110.intf.community.*;
|
|
|
import com.java110.utils.exception.CmdException;
|
|
import com.java110.utils.exception.CmdException;
|
|
|
|
|
+import com.java110.utils.util.Assert;
|
|
|
import com.java110.utils.util.BeanConvertUtil;
|
|
import com.java110.utils.util.BeanConvertUtil;
|
|
|
|
|
+import com.java110.utils.util.DateUtil;
|
|
|
|
|
+import com.java110.utils.util.StringUtil;
|
|
|
import com.java110.vo.ResultVo;
|
|
import com.java110.vo.ResultVo;
|
|
|
|
|
+import com.java110.vo.api.machine.ApiMachineDataVo;
|
|
|
|
|
+import com.java110.vo.api.machine.ApiMachineVo;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import com.java110.dto.machine.MachineDto;
|
|
import com.java110.dto.machine.MachineDto;
|
|
|
|
|
+
|
|
|
|
|
+import java.text.ParseException;
|
|
|
|
|
+import java.util.Calendar;
|
|
|
import java.util.List;
|
|
import java.util.List;
|
|
|
import java.util.ArrayList;
|
|
import java.util.ArrayList;
|
|
|
import org.springframework.http.ResponseEntity;
|
|
import org.springframework.http.ResponseEntity;
|
|
@@ -44,37 +58,253 @@ import com.java110.core.log.LoggerFactory;
|
|
|
* 温馨提示:如果您对此文件进行修改 请不要删除原有作者及注释信息,请补充您的 修改的原因以及联系邮箱如下
|
|
* 温馨提示:如果您对此文件进行修改 请不要删除原有作者及注释信息,请补充您的 修改的原因以及联系邮箱如下
|
|
|
* // modify by 张三 at 2021-09-12 第10行在某种场景下存在某种bug 需要修复,注释10至20行 加入 20行至30行
|
|
* // modify by 张三 at 2021-09-12 第10行在某种场景下存在某种bug 需要修复,注释10至20行 加入 20行至30行
|
|
|
*/
|
|
*/
|
|
|
-@Java110Cmd(serviceCode = "machine.listMachine")
|
|
|
|
|
|
|
+@Java110Cmd(serviceCode = "machine.listMachines")
|
|
|
public class ListMachineCmd extends Cmd {
|
|
public class ListMachineCmd extends Cmd {
|
|
|
|
|
|
|
|
private static Logger logger = LoggerFactory.getLogger(ListMachineCmd.class);
|
|
private static Logger logger = LoggerFactory.getLogger(ListMachineCmd.class);
|
|
|
@Autowired
|
|
@Autowired
|
|
|
- private IMachineV1InnerServiceSMO machineV1InnerServiceSMOImpl;
|
|
|
|
|
|
|
+ private IMachineInnerServiceSMO machineInnerServiceSMOImpl;
|
|
|
|
|
+
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private ICommunityInnerServiceSMO communityInnerServiceSMOImpl;
|
|
|
|
|
+
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private IFloorInnerServiceSMO floorInnerServiceSMOImpl;
|
|
|
|
|
+
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private IUnitInnerServiceSMO unitInnerServiceSMOImpl;
|
|
|
|
|
+
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private IRoomInnerServiceSMO roomInnerServiceSMOImpl;
|
|
|
|
|
+
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private ICommunityLocationInnerServiceSMO communityLocationInnerServiceSMOImpl;
|
|
|
|
|
|
|
|
@Override
|
|
@Override
|
|
|
public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
|
|
public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
|
|
|
super.validatePageInfo(reqJson);
|
|
super.validatePageInfo(reqJson);
|
|
|
|
|
+
|
|
|
|
|
+ Assert.jsonObjectHaveKey(reqJson, "communityId", "请求报文中未包含小区信息");
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
@Override
|
|
|
public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
|
|
public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
|
|
|
|
|
|
|
|
- MachineDto machineDto = BeanConvertUtil.covertBean(reqJson, MachineDto.class);
|
|
|
|
|
|
|
+ MachineDto machineDto = BeanConvertUtil.covertBean(reqJson, MachineDto.class);
|
|
|
|
|
+
|
|
|
|
|
+ int count = machineInnerServiceSMOImpl.queryMachinesCount(machineDto);
|
|
|
|
|
+
|
|
|
|
|
+ List<ApiMachineDataVo> machines = null;
|
|
|
|
|
+
|
|
|
|
|
+ if (count > 0) {
|
|
|
|
|
+ List<MachineDto> machineDtos = machineInnerServiceSMOImpl.queryMachines(machineDto);
|
|
|
|
|
+ // 刷新 位置信息
|
|
|
|
|
+ //refreshMachines(machineDtos);
|
|
|
|
|
+ refreshMachineLocation(machineDtos);
|
|
|
|
|
+ machines = BeanConvertUtil.covertBeanList(machineDtos, ApiMachineDataVo.class);
|
|
|
|
|
+ } else {
|
|
|
|
|
+ machines = new ArrayList<>();
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ ApiMachineVo apiMachineVo = new ApiMachineVo();
|
|
|
|
|
+
|
|
|
|
|
+ apiMachineVo.setTotal(count);
|
|
|
|
|
+ apiMachineVo.setRecords((int) Math.ceil((double) count / (double) reqJson.getInteger("row")));
|
|
|
|
|
+ apiMachineVo.setMachines(machines);
|
|
|
|
|
+
|
|
|
|
|
+ ResponseEntity<String> responseEntity = new ResponseEntity<String>(JSONObject.toJSONString(apiMachineVo), HttpStatus.OK);
|
|
|
|
|
+
|
|
|
|
|
+ cmdDataFlowContext.setResponseEntity(responseEntity);
|
|
|
|
|
+
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ private void refreshMachineLocation(List<MachineDto> machines) {
|
|
|
|
|
+ for (MachineDto machineDto : machines) {
|
|
|
|
|
+ freshMachineStateName(machineDto);
|
|
|
|
|
+ getMachineLocation(machineDto);
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ private void freshMachineStateName(MachineDto machineDto) {
|
|
|
|
|
+ String heartbeatTime = machineDto.getHeartbeatTime();
|
|
|
|
|
+ try {
|
|
|
|
|
+ if (StringUtil.isEmpty(heartbeatTime)) {
|
|
|
|
|
+ machineDto.setStateName(machineDto.getStateName() + ";设备离线");
|
|
|
|
|
+ } else {
|
|
|
|
|
+ Calendar calendar = Calendar.getInstance();
|
|
|
|
|
+ calendar.setTime(DateUtil.getDateFromString(heartbeatTime, DateUtil.DATE_FORMATE_STRING_A));
|
|
|
|
|
+ calendar.add(Calendar.MINUTE, 2);
|
|
|
|
|
+ if (calendar.getTime().getTime() <= DateUtil.getCurrentDate().getTime()) {
|
|
|
|
|
+ machineDto.setStateName(machineDto.getStateName() + ";设备离线");
|
|
|
|
|
+ } else {
|
|
|
|
|
+ machineDto.setStateName(machineDto.getStateName() + ";设备在线");
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ } catch (ParseException e) {
|
|
|
|
|
+ e.printStackTrace();
|
|
|
|
|
+ machineDto.setStateName(machineDto.getStateName() + ";设备离线");
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- int count = machineV1InnerServiceSMOImpl.queryMachinesCount(machineDto);
|
|
|
|
|
|
|
+ private void refreshMachines(List<MachineDto> machines) {
|
|
|
|
|
|
|
|
- List<MachineDto> machineDtos = null;
|
|
|
|
|
|
|
+ //批量处理 小区
|
|
|
|
|
+ refreshCommunitys(machines);
|
|
|
|
|
|
|
|
- if (count > 0) {
|
|
|
|
|
- machineDtos = machineV1InnerServiceSMOImpl.queryMachines(machineDto);
|
|
|
|
|
- } else {
|
|
|
|
|
- machineDtos = new ArrayList<>();
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ //批量处理单元信息
|
|
|
|
|
+ refreshUnits(machines);
|
|
|
|
|
+
|
|
|
|
|
+ //批量处理 房屋信息
|
|
|
|
|
+ refreshRooms(machines);
|
|
|
|
|
+
|
|
|
|
|
+ //位置未分配时
|
|
|
|
|
+ refreshOther(machines);
|
|
|
|
|
+
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ private void getMachineLocation(MachineDto machineDto) {
|
|
|
|
|
+
|
|
|
|
|
+ CommunityLocationDto communityLocationDto = new CommunityLocationDto();
|
|
|
|
|
+ communityLocationDto.setCommunityId(machineDto.getCommunityId());
|
|
|
|
|
+ communityLocationDto.setLocationId(machineDto.getLocationTypeCd());
|
|
|
|
|
+ List<CommunityLocationDto> communityLocationDtos = communityLocationInnerServiceSMOImpl.queryCommunityLocations(communityLocationDto);
|
|
|
|
|
+
|
|
|
|
|
+ if (communityLocationDtos == null || communityLocationDtos.size() < 1) {
|
|
|
|
|
+ machineDto.setLocationType(machineDto.getLocationTypeCd());
|
|
|
|
|
+ return;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ machineDto.setLocationType(communityLocationDtos.get(0).getLocationType());
|
|
|
|
|
+ machineDto.setLocationObjName(communityLocationDtos.get(0).getLocationName());
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ /**
|
|
|
|
|
+ * 获取批量小区
|
|
|
|
|
+ *
|
|
|
|
|
+ * @param machines 设备信息
|
|
|
|
|
+ * @return 批量userIds 信息
|
|
|
|
|
+ */
|
|
|
|
|
+ private void refreshCommunitys(List<MachineDto> machines) {
|
|
|
|
|
+ List<String> communityIds = new ArrayList<String>();
|
|
|
|
|
+ List<MachineDto> tmpMachineDtos = new ArrayList<>();
|
|
|
|
|
+ for (MachineDto machineDto : machines) {
|
|
|
|
|
+ getMachineLocation(machineDto);
|
|
|
|
|
+ if (!"2000".equals(machineDto.getLocationType())
|
|
|
|
|
+ && !"3000".equals(machineDto.getLocationType())
|
|
|
|
|
+ && !"4000".equals(machineDto.getLocationType())
|
|
|
|
|
+ ) {
|
|
|
|
|
+ communityIds.add(machineDto.getLocationObjId());
|
|
|
|
|
+ tmpMachineDtos.add(machineDto);
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ if (communityIds.size() < 1) {
|
|
|
|
|
+ return;
|
|
|
|
|
+ }
|
|
|
|
|
+ String[] tmpCommunityIds = communityIds.toArray(new String[communityIds.size()]);
|
|
|
|
|
+
|
|
|
|
|
+ CommunityDto communityDto = new CommunityDto();
|
|
|
|
|
+ communityDto.setCommunityIds(tmpCommunityIds);
|
|
|
|
|
+ //根据 userId 查询用户信息
|
|
|
|
|
+ List<CommunityDto> communityDtos = communityInnerServiceSMOImpl.queryCommunitys(communityDto);
|
|
|
|
|
+
|
|
|
|
|
+ for (MachineDto machineDto : tmpMachineDtos) {
|
|
|
|
|
+ for (CommunityDto tmpCommunityDto : communityDtos) {
|
|
|
|
|
+ if (machineDto.getLocationObjId().equals(tmpCommunityDto.getCommunityId())) {
|
|
|
|
|
+ machineDto.setLocationObjName(tmpCommunityDto.getName() + " " + machineDto.getLocationTypeName());
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ /**
|
|
|
|
|
+ * 获取批量单元
|
|
|
|
|
+ *
|
|
|
|
|
+ * @param machines 设备信息
|
|
|
|
|
+ * @return 批量userIds 信息
|
|
|
|
|
+ */
|
|
|
|
|
+ private void refreshUnits(List<MachineDto> machines) {
|
|
|
|
|
+ List<String> unitIds = new ArrayList<String>();
|
|
|
|
|
+ List<MachineDto> tmpMachineDtos = new ArrayList<>();
|
|
|
|
|
+ for (MachineDto machineDto : machines) {
|
|
|
|
|
+ getMachineLocation(machineDto);
|
|
|
|
|
+ if ("2000".equals(machineDto.getLocationType())) {
|
|
|
|
|
+ unitIds.add(machineDto.getLocationObjId());
|
|
|
|
|
+ tmpMachineDtos.add(machineDto);
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ if (unitIds.size() < 1) {
|
|
|
|
|
+ return;
|
|
|
|
|
+ }
|
|
|
|
|
+ String[] tmpUnitIds = unitIds.toArray(new String[unitIds.size()]);
|
|
|
|
|
+
|
|
|
|
|
+ FloorAndUnitDto floorAndUnitDto = new FloorAndUnitDto();
|
|
|
|
|
+ floorAndUnitDto.setUnitIds(tmpUnitIds);
|
|
|
|
|
+ //根据 userId 查询用户信息
|
|
|
|
|
+ List<FloorAndUnitDto> unitDtos = unitInnerServiceSMOImpl.getFloorAndUnitInfo(floorAndUnitDto);
|
|
|
|
|
+
|
|
|
|
|
+ for (MachineDto machineDto : tmpMachineDtos) {
|
|
|
|
|
+ for (FloorAndUnitDto tmpUnitDto : unitDtos) {
|
|
|
|
|
+ if (machineDto.getLocationObjId().equals(tmpUnitDto.getUnitId())) {
|
|
|
|
|
+ machineDto.setLocationObjName(tmpUnitDto.getFloorNum() + "栋" + tmpUnitDto.getUnitNum() + "单元");
|
|
|
|
|
+ BeanConvertUtil.covertBean(tmpUnitDto, machineDto);
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ /**
|
|
|
|
|
+ * 获取批量单元
|
|
|
|
|
+ *
|
|
|
|
|
+ * @param machines 设备信息
|
|
|
|
|
+ * @return 批量userIds 信息
|
|
|
|
|
+ */
|
|
|
|
|
+ private void refreshRooms(List<MachineDto> machines) {
|
|
|
|
|
+ List<String> roomIds = new ArrayList<String>();
|
|
|
|
|
+ List<MachineDto> tmpMachineDtos = new ArrayList<>();
|
|
|
|
|
+ for (MachineDto machineDto : machines) {
|
|
|
|
|
+ getMachineLocation(machineDto);
|
|
|
|
|
+ if ("3000".equals(machineDto.getLocationType())) {
|
|
|
|
|
+ roomIds.add(machineDto.getLocationObjId());
|
|
|
|
|
+ tmpMachineDtos.add(machineDto);
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ if (roomIds.size() < 1) {
|
|
|
|
|
+ return;
|
|
|
|
|
+ }
|
|
|
|
|
+ String[] tmpRoomIds = roomIds.toArray(new String[roomIds.size()]);
|
|
|
|
|
+
|
|
|
|
|
+ RoomDto roomDto = new RoomDto();
|
|
|
|
|
+ roomDto.setRoomIds(tmpRoomIds);
|
|
|
|
|
+ roomDto.setCommunityId(machines.get(0).getCommunityId());
|
|
|
|
|
+ //根据 userId 查询用户信息
|
|
|
|
|
+ List<RoomDto> roomDtos = roomInnerServiceSMOImpl.queryRooms(roomDto);
|
|
|
|
|
+
|
|
|
|
|
+ for (MachineDto machineDto : tmpMachineDtos) {
|
|
|
|
|
+ for (RoomDto tmpRoomDto : roomDtos) {
|
|
|
|
|
+ if (machineDto.getLocationObjId().equals(tmpRoomDto.getRoomId())) {
|
|
|
|
|
+ machineDto.setLocationObjName(tmpRoomDto.getFloorNum() + "栋" + tmpRoomDto.getUnitNum() + "单元" + tmpRoomDto.getRoomNum() + "室");
|
|
|
|
|
+ BeanConvertUtil.covertBean(tmpRoomDto, machineDto);
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- ResultVo resultVo = new ResultVo((int) Math.ceil((double) count / (double) reqJson.getInteger("row")), count, machineDtos);
|
|
|
|
|
|
|
+ /**
|
|
|
|
|
+ * 获取批量单元
|
|
|
|
|
+ *
|
|
|
|
|
+ * @param machines 设备信息
|
|
|
|
|
+ * @return 批量userIds 信息
|
|
|
|
|
+ */
|
|
|
|
|
+ private void refreshOther(List<MachineDto> machines) {
|
|
|
|
|
+ for (MachineDto machineDto : machines) {
|
|
|
|
|
|
|
|
- ResponseEntity<String> responseEntity = new ResponseEntity<String>(resultVo.toString(), HttpStatus.OK);
|
|
|
|
|
|
|
+ if ("4000".equals(machineDto.getLocationTypeCd())) {
|
|
|
|
|
+ machineDto.setLocationObjName("未分配");
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- cmdDataFlowContext.setResponseEntity(responseEntity);
|
|
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|