|  |  |  | 
|---|
|  |  |  | import com.dy.common.multiDataSource.DataSourceContext; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.Command; | 
|---|
|  |  |  | import com.dy.common.webUtil.BaseResponse; | 
|---|
|  |  |  | import com.dy.common.webUtil.BaseResponseUtils; | 
|---|
|  |  |  | import com.dy.common.webUtil.QueryResultVo; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.daoPr.PrIntakeMapper; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.daoRm.RmOpenCloseValveHistoryMapper; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoPr.PrIntake; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.voPr.VoAllIntake; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.voPr.VoOnLineIntake; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.voRm.VoOpenClostWechat; | 
|---|
|  |  |  | import com.dy.pipIrrWechat.intake.qo.OnLineIntakesQO; | 
|---|
|  |  |  | 
|---|
|  |  |  | import org.springframework.web.client.RestTemplate; | 
|---|
|  |  |  | import org.springframework.web.util.UriComponentsBuilder; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.HashMap; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.Map; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public VoOnLineIntake selectOneIntake(OnLineIntakesQO qo) { | 
|---|
|  |  |  | Command com = new Command() ; | 
|---|
|  |  |  | com.id = Command.defaultId; | 
|---|
|  |  |  | com.code = "LCD0001"; | 
|---|
|  |  |  | com.type = "innerCommand"; | 
|---|
|  |  |  | comSendUrl = env.getProperty(pro_mw + "." + DataSourceContext.get() + "." + key_mw); | 
|---|
|  |  |  | //Command com = new Command() ; | 
|---|
|  |  |  | //com.id = Command.defaultId; | 
|---|
|  |  |  | //com.code = "LCD0001"; | 
|---|
|  |  |  | //com.type = "innerCommand"; | 
|---|
|  |  |  | //comSendUrl = env.getProperty(pro_mw + "." + DataSourceContext.get() + "." + key_mw); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //JSONObject response = (JSONObject) JSON.toJSON(sendCom2Mw(com)); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //JSONArray jsonArray = new JSONArray(); | 
|---|
|  |  |  | //if(response != null && response.getString("code").equals("0001")) { | 
|---|
|  |  |  | //    JSONObject attachment = response.getJSONObject("content").getJSONObject("attachment"); | 
|---|
|  |  |  | //    if(attachment != null) { | 
|---|
|  |  |  | //        attachment.forEach((key, value) -> { | 
|---|
|  |  |  | //            JSONObject jsonObject = new JSONObject(); | 
|---|
|  |  |  | //            jsonObject.put("rtuAddr", key); | 
|---|
|  |  |  | //            jsonObject.put("isOnLine", value); | 
|---|
|  |  |  | //            jsonArray.add(jsonObject); | 
|---|
|  |  |  | //        }); | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | //qo.setOnLineMap(jsonArray.toJSONString()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONObject response = (JSONObject) JSON.toJSON(sendCom2Mw(com)); | 
|---|
|  |  |  | if(response != null && response.getString("code").equals("0001")) { | 
|---|
|  |  |  | JSONObject attachment = response.getJSONObject("content").getJSONObject("attachment").getJSONObject("onLineMap"); | 
|---|
|  |  |  | HashMap<String, Boolean> onLineMap = JSON.parseObject(attachment.toJSONString(), HashMap.class); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONArray jsonArray = new JSONArray(); | 
|---|
|  |  |  | for (Map.Entry<String, Boolean> entry : onLineMap.entrySet()) { | 
|---|
|  |  |  | JSONObject jsonObject = new JSONObject(); | 
|---|
|  |  |  | jsonObject.put("rtuAddr", entry.getKey()); | 
|---|
|  |  |  | jsonObject.put("isOnLine", entry.getValue()); | 
|---|
|  |  |  | jsonArray.add(jsonObject); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | qo.setOnLineMap(jsonArray.toJSONString()); | 
|---|
|  |  |  | // 如果 intakeNum 不为空,则转为小写再写入qo对象 | 
|---|
|  |  |  | String intakeNum = qo.getIntakeNum(); | 
|---|
|  |  |  | if(intakeNum != null) { | 
|---|
|  |  |  | qo.setIntakeNum(intakeNum.toLowerCase()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(qo) ; | 
|---|
|  |  |  | return prIntakeMapper.getIntakeByName(params); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | return new VoOnLineIntake(); | 
|---|
|  |  |  | // 如果 intakeNum 不为空,则转为小写再写入qo对象 | 
|---|
|  |  |  | String intakeNum = qo.getIntakeNum(); | 
|---|
|  |  |  | if(intakeNum != null) { | 
|---|
|  |  |  | qo.setIntakeNum(intakeNum.toLowerCase()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(qo) ; | 
|---|
|  |  |  | return prIntakeMapper.getIntakeByName(params); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public QueryResultVo<List<VoOnLineIntake>> selectAllIntakes(OnLineIntakesQO qo) { | 
|---|
|  |  |  | Command com = new Command() ; | 
|---|
|  |  |  | com.id = Command.defaultId; | 
|---|
|  |  |  | com.code = "LCD0001"; | 
|---|
|  |  |  | com.type = "innerCommand"; | 
|---|
|  |  |  | comSendUrl = env.getProperty(pro_mw + "." + DataSourceContext.get() + "." + key_mw); | 
|---|
|  |  |  | //Command com = new Command() ; | 
|---|
|  |  |  | //com.id = Command.defaultId; | 
|---|
|  |  |  | //com.code = "LCD0001"; | 
|---|
|  |  |  | //com.type = "innerCommand"; | 
|---|
|  |  |  | //comSendUrl = env.getProperty(pro_mw + "." + DataSourceContext.get() + "." + key_mw); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //JSONObject response = (JSONObject) JSON.toJSON(sendCom2Mw(com)); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //JSONArray jsonArray = new JSONArray(); | 
|---|
|  |  |  | //if(response != null && response.getString("code").equals("0001")) { | 
|---|
|  |  |  | //    JSONObject attachment = response.getJSONObject("content").getJSONObject("attachment"); | 
|---|
|  |  |  | //    if(attachment != null) { | 
|---|
|  |  |  | //        attachment.forEach((key, value) -> { | 
|---|
|  |  |  | //            JSONObject jsonObject = new JSONObject(); | 
|---|
|  |  |  | //            jsonObject.put("rtuAddr", key); | 
|---|
|  |  |  | //            jsonObject.put("isOnLine", value); | 
|---|
|  |  |  | //            jsonArray.add(jsonObject); | 
|---|
|  |  |  | //        }); | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | //qo.setOnLineMap(jsonArray.toJSONString()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONObject response = (JSONObject) JSON.toJSON(sendCom2Mw(com)); | 
|---|
|  |  |  | if(response != null && response.getString("code").equals("0001")) { | 
|---|
|  |  |  | JSONObject attachment = response.getJSONObject("content").getJSONObject("attachment").getJSONObject("onLineMap"); | 
|---|
|  |  |  | HashMap<String, Boolean> onLineMap = JSON.parseObject(attachment.toJSONString(), HashMap.class); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONArray jsonArray = new JSONArray(); | 
|---|
|  |  |  | for (Map.Entry<String, Boolean> entry : onLineMap.entrySet()) { | 
|---|
|  |  |  | JSONObject jsonObject = new JSONObject(); | 
|---|
|  |  |  | jsonObject.put("rtuAddr", entry.getKey()); | 
|---|
|  |  |  | jsonObject.put("isOnLine", entry.getValue()); | 
|---|
|  |  |  | jsonArray.add(jsonObject); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | qo.setOnLineMap(jsonArray.toJSONString()); | 
|---|
|  |  |  | // 如果 intakeNum 不为空,则转为小写再写入qo对象 | 
|---|
|  |  |  | String intakeNum = qo.getIntakeNum(); | 
|---|
|  |  |  | if(intakeNum != null) { | 
|---|
|  |  |  | qo.setIntakeNum(intakeNum.toLowerCase()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(qo) ; | 
|---|
|  |  |  | Long itemTotal = prIntakeMapper.getOnLineIntakesCount(params); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | QueryResultVo<List<VoOnLineIntake>> rsVo = new QueryResultVo<>() ; | 
|---|
|  |  |  | rsVo.pageSize = qo.pageSize ; | 
|---|
|  |  |  | rsVo.pageCurr = qo.pageCurr ; | 
|---|
|  |  |  | rsVo.calculateAndSet(itemTotal, params); | 
|---|
|  |  |  | rsVo.obj = prIntakeMapper.getOnLineIntakes(params); | 
|---|
|  |  |  | return rsVo; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | QueryResultVo<List<VoOnLineIntake>> rsVo = new QueryResultVo<>(); | 
|---|
|  |  |  | return rsVo; | 
|---|
|  |  |  | // 如果 intakeNum 不为空,则转为小写再写入qo对象 | 
|---|
|  |  |  | String intakeNum = qo.getIntakeNum(); | 
|---|
|  |  |  | if(intakeNum != null) { | 
|---|
|  |  |  | qo.setIntakeNum(intakeNum.toLowerCase()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(qo) ; | 
|---|
|  |  |  | Long itemTotal = prIntakeMapper.getOnLineIntakesCount(params); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | QueryResultVo<List<VoOnLineIntake>> rsVo = new QueryResultVo<>() ; | 
|---|
|  |  |  | rsVo.pageSize = qo.pageSize ; | 
|---|
|  |  |  | rsVo.pageCurr = qo.pageCurr ; | 
|---|
|  |  |  | rsVo.calculateAndSet(itemTotal, params); | 
|---|
|  |  |  | rsVo.obj = prIntakeMapper.getOnLineIntakes(params); | 
|---|
|  |  |  | return rsVo; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 根据操作员获取常用取水口 | 
|---|
|  |  |  | * @param operator | 
|---|
|  |  |  | * @param operatorId | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public List<VoOnLineIntake> getUsedIntakes(Long operator) { | 
|---|
|  |  |  | public List<VoOnLineIntake> getUsedIntakes(Long operatorId) { | 
|---|
|  |  |  | Command com = new Command() ; | 
|---|
|  |  |  | com.id = Command.defaultId; | 
|---|
|  |  |  | com.code = "LCD0001"; | 
|---|
|  |  |  | com.type = "innerCommand"; | 
|---|
|  |  |  | comSendUrl = env.getProperty(pro_mw + "." + DataSourceContext.get() + "." + key_mw); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONObject response = (JSONObject) JSON.toJSON(sendCom2Mw(com)); | 
|---|
|  |  |  | //String response_Str = "{\"code\": \"0001\",\"content\": {\"attachment\": {\"530115059980\": true,\"620201000030\": true},\"code\": \"LCD0001\",\"id\": \"999999999\",\"param\": {\"message\": \"查询所有RTU在线情况结果\",\"success\": true},\"protocol\": \"\",\"rtuAddr\": \"\",\"rtuResultSendWebUrl\": \"\",\"type\": \"resultCommand\"},\"msg\": \"请求成功\",\"success\": true}"; | 
|---|
|  |  |  | //JSONObject response = JSON.parseObject(response_Str); | 
|---|
|  |  |  | //String test = response.toJSONString(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONArray jsonArray = new JSONArray(); | 
|---|
|  |  |  | if(response != null && response.getString("code").equals("0001")) { | 
|---|
|  |  |  | JSONObject attachment = response.getJSONObject("content").getJSONObject("attachment").getJSONObject("onLineMap"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONArray jsonArray = new JSONArray(); | 
|---|
|  |  |  | JSONObject attachment = response.getJSONObject("content").getJSONObject("attachment"); | 
|---|
|  |  |  | if(attachment != null) { | 
|---|
|  |  |  | HashMap<String, Boolean> onLineMap = JSON.parseObject(attachment.toJSONString(), HashMap.class); | 
|---|
|  |  |  | for (Map.Entry<String, Boolean> entry : onLineMap.entrySet()) { | 
|---|
|  |  |  | attachment.forEach((key, value) -> { | 
|---|
|  |  |  | JSONObject jsonObject = new JSONObject(); | 
|---|
|  |  |  | jsonObject.put("rtuAddr", entry.getKey()); | 
|---|
|  |  |  | jsonObject.put("isOnLine", entry.getValue()); | 
|---|
|  |  |  | jsonObject.put("rtuAddr", key); | 
|---|
|  |  |  | jsonObject.put("isOnLine", value); | 
|---|
|  |  |  | jsonArray.add(jsonObject); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return prIntakeMapper.getUsedIntakes(jsonArray.toJSONString(), operator); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | return new ArrayList<>(); | 
|---|
|  |  |  | System.out.println(jsonArray.toJSONString()); | 
|---|
|  |  |  | //return prIntakeMapper.getUsedIntakes(jsonArray.toJSONString(), operatorId); | 
|---|
|  |  |  | //} else { | 
|---|
|  |  |  | //    return new ArrayList<>(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return prIntakeMapper.getUsedIntakes(jsonArray.toJSONString(), operatorId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if(response == null) { | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg("中间件调用失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return response.getBody(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | rsVo.obj = rmOpenCloseValveHistoryMapper.getVcCardOpenClose(params); | 
|---|
|  |  |  | return rsVo; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 得到所有取水口 | 
|---|
|  |  |  | * | 
|---|
|  |  |  | * @return 所有取水口集合 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public QueryResultVo<List<VoAllIntake>> selectAll() { | 
|---|
|  |  |  | QueryResultVo<List<VoAllIntake>> rsVo = new QueryResultVo<>(); | 
|---|
|  |  |  | rsVo.obj = this.prIntakeMapper.selectAll(); | 
|---|
|  |  |  | return rsVo; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|