From 38ab8fbd4355070def9e3b39f362731dd4dea6d1 Mon Sep 17 00:00:00 2001 From: CZT <czt18638530771@163.com> Date: 星期三, 30 八月 2023 20:54:12 +0800 Subject: [PATCH] 优化设备状态解析 --- igds-inout/src/main/java/com/ld/igds/inout/manager/InoutEventControlManager.java | 308 ++++++++++++++++++++++++++++++++------------------ 1 files changed, 195 insertions(+), 113 deletions(-) diff --git a/igds-inout/src/main/java/com/ld/igds/inout/manager/InoutEventControlManager.java b/igds-inout/src/main/java/com/ld/igds/inout/manager/InoutEventControlManager.java index 8539d8b..7732e83 100644 --- a/igds-inout/src/main/java/com/ld/igds/inout/manager/InoutEventControlManager.java +++ b/igds-inout/src/main/java/com/ld/igds/inout/manager/InoutEventControlManager.java @@ -29,7 +29,6 @@ import org.springframework.stereotype.Component; import javax.annotation.Resource; -import java.util.ArrayList; import java.util.Date; import java.util.List; @@ -69,20 +68,16 @@ //濡傛灉浣跨敤鐨勬槸鍦扮鎻掍欢鑾峰彇锛屽垯闇�瑕佽皟鏁磋澶囦负鍦扮鎻掍欢淇℃伅 if (ProtocolEnum.TCP_FZZY_WEIGHT.getCode().equals(param.getProtocol())) { - InoutConf conf = this.getInoutConf(param.getCompanyId(), param.getDeptId(), param.getSort(), InoutConstant.CONF_TYPE_70); if (null == conf) { param.setErrorMsg("娌℃湁鑾峰彇鍒板綋鍓嶅崗璁彃浠堕厤缃厤缃俊鎭紝鑾峰彇澶辫触"); return param; } - - param.setIp(conf.getIp()); param.setPort(conf.getPort()); param.setProtocol(conf.getProtocol()); return apiInoutManager.getApiService(param.getProtocol()).getPlateNum(param); - } return apiInoutManager.getApiService(param.getProtocol()).getPlateNum(param); @@ -96,6 +91,20 @@ * @return */ public ApiInoutData getIcCardNum(ApiInoutData param) { + + //濡傛灉浣跨敤鐨勬槸鍦扮鎻掍欢鑾峰彇锛屽垯闇�瑕佽皟鏁磋澶囦负鍦扮鎻掍欢淇℃伅 + if (ProtocolEnum.TCP_FZZY_WEIGHT.getCode().equals(param.getProtocol())) { + InoutConf conf = this.getInoutConf(param.getCompanyId(), param.getDeptId(), param.getSort(), InoutConstant.CONF_TYPE_70); + if (null == conf) { + param.setErrorMsg("娌℃湁鑾峰彇鍒板綋鍓嶅崗璁彃浠堕厤缃厤缃俊鎭紝鑾峰彇澶辫触"); + return param; + } + param.setIp(conf.getIp()); + param.setPort(conf.getPort()); + param.setProtocol(conf.getProtocol()); + + return apiInoutManager.getApiService(param.getProtocol()).getIcCardNum(param); + } return apiInoutManager.getApiService(param.getProtocol()).getIcCardNum(param); } @@ -121,23 +130,23 @@ * @param param * @return */ - public String noticeWeightDone(ApiInoutData param) { - //鑾峰彇绉伴噸涓绘帶鍣ㄩ厤缃� - InoutConf conf = getWeightGateway(param.getCompanyId(), param.getDeptId(), param.getSort()); - - if (null == conf) { - return "绉伴噸涓绘帶鏈厤缃紝鏀寔澶辫触"; - } - - ApiInoutData apiData = new ApiInoutData(conf); - apiData.setPlateNum(param.getPlateNum()); - apiData.setTime(new Date()); - - ApiInoutService inoutApiService = apiInoutManager.getApiService(conf.getProtocol()); - - // return inoutApiService.noticeWeightDone(apiData); TODO - return null; - } +// public String noticeWeightDone(ApiInoutData param) { +// //鑾峰彇绉伴噸涓绘帶鍣ㄩ厤缃� +// InoutConf conf = getWeightGateway(param.getCompanyId(), param.getDeptId(), param.getSort()); +// +// if (null == conf) { +// return "绉伴噸涓绘帶鏈厤缃紝鏀寔澶辫触"; +// } +// +// ApiInoutData apiData = new ApiInoutData(conf); +// apiData.setPlateNum(param.getPlateNum()); +// apiData.setTime(new Date()); +// +// ApiInoutService inoutApiService = apiInoutManager.getApiService(conf.getProtocol()); +// +// // return inoutApiService.noticeWeightDone(apiData); TODO +// return null; +// } /** * 鍑哄叆搴撴姄鎷� @@ -175,73 +184,73 @@ * * @param snapImgDto */ - private void noticeGatewayWeightInfo(SnapImgDto snapImgDto) { - - log.debug("-------------鐢ㄦ埛纭绉伴噸----閫氱煡绉伴噸缃戝叧----{}", snapImgDto.getWeight()); - InoutConf conf = this.getWeightGateway(snapImgDto.getCompanyId(), snapImgDto.getDeptId(), snapImgDto.getSort()); - - if (null == conf) { - log.info("-------------鐢ㄦ埛纭绉伴噸----閫氱煡绉伴噸缃戝叧---鏈厤缃綉鍏�----"); - return; - } - - ApiInoutData apiData = new ApiInoutData(conf); - apiData.setTime(new Date()); - apiData.setRepeat(2); - apiData.setWeight(snapImgDto.getWeight()); - apiData.setPlateNum(snapImgDto.getPlateNum()); - //绉伴噸淇℃伅鏆傛椂鍙栨秷鎾斁 -// apiData.setMsg("褰撳墠绉伴噸锛�" + apiData.getWeight() + "鍗冨厠"); - apiData.setMsg("绉伴噸宸插畬鎴�"); - -// apiInoutManager.getApiService(apiData.getProtocol()).noticeWeightDone(apiData); - // apiInoutManager.getApiService(apiData.getProtocol()).noticeRadio(apiData); - } +// private void noticeGatewayWeightInfo(SnapImgDto snapImgDto) { +// +// log.debug("-------------鐢ㄦ埛纭绉伴噸----閫氱煡绉伴噸缃戝叧----{}", snapImgDto.getWeight()); +// InoutConf conf = this.getWeightGateway(snapImgDto.getCompanyId(), snapImgDto.getDeptId(), snapImgDto.getSort()); +// +// if (null == conf) { +// log.info("-------------鐢ㄦ埛纭绉伴噸----閫氱煡绉伴噸缃戝叧---鏈厤缃綉鍏�----"); +// return; +// } +// +// ApiInoutData apiData = new ApiInoutData(conf); +// apiData.setTime(new Date()); +// apiData.setRepeat(2); +// apiData.setWeight(snapImgDto.getWeight()); +// apiData.setPlateNum(snapImgDto.getPlateNum()); +// //绉伴噸淇℃伅鏆傛椂鍙栨秷鎾斁 +//// apiData.setMsg("褰撳墠绉伴噸锛�" + apiData.getWeight() + "鍗冨厠"); +// apiData.setMsg("绉伴噸宸插畬鎴�"); +// +//// apiInoutManager.getApiService(apiData.getProtocol()).noticeWeightDone(apiData); +// // apiInoutManager.getApiService(apiData.getProtocol()).noticeRadio(apiData); +// } /** * 鏂板鐧藉悕鍗曠粰浣忔帶鍒跺櫒锛岄渶瑕佹敞鎰忕殑鏄紝鐧昏鏃跺�欎笉纭浣跨敤鍝釜鍦扮绯荤粺锛屽鏋滅郴缁熼厤缃涓富鎺у櫒锛岄渶瑕佸悓姝ュ叏閮ㄦ帹閫� * * @param imgDto */ - private void noticeGatewayAddWhitePlate(SnapImgDto imgDto) { +// private void noticeGatewayAddWhitePlate(SnapImgDto imgDto) { +// +// List<InoutConf> list = this.getWeightGateway(imgDto.getCompanyId(), imgDto.getDeptId()); +// +// if (null == list || list.isEmpty()) { +// log.info("-------------绉伴噸缃戝叧澧炲姞鐧藉悕鍗�----娌℃湁鑾峰彇鍒扮綉鍏抽厤缃�-----鍙栨秷鎵ц---"); +// return; +// } +// +// log.debug("-------------鐧昏瀹屾垚锛屽鍔犺溅鐗岀櫧鍚嶅崟-----------{}", imgDto.getPlateNum()); +// +// ApiInoutService inoutApiService = apiInoutManager.getApiService(list.get(0).getProtocol()); +// +// ApiInoutData apiData; +// for (InoutConf conf : list) { +// apiData = new ApiInoutData(conf); +// apiData.setPlateNum(imgDto.getPlateNum()); +// // inoutApiService.addWhitePlate(apiData); +// } +// } - List<InoutConf> list = this.getWeightGateway(imgDto.getCompanyId(), imgDto.getDeptId()); - - if (null == list || list.isEmpty()) { - log.info("-------------绉伴噸缃戝叧澧炲姞鐧藉悕鍗�----娌℃湁鑾峰彇鍒扮綉鍏抽厤缃�-----鍙栨秷鎵ц---"); - return; - } - - log.debug("-------------鐧昏瀹屾垚锛屽鍔犺溅鐗岀櫧鍚嶅崟-----------{}", imgDto.getPlateNum()); - - ApiInoutService inoutApiService = apiInoutManager.getApiService(list.get(0).getProtocol()); - - ApiInoutData apiData; - for (InoutConf conf : list) { - apiData = new ApiInoutData(conf); - apiData.setPlateNum(imgDto.getPlateNum()); - // inoutApiService.addWhitePlate(apiData); - } - } - - public void noticeProgressComplete(InoutData data) { - log.debug("-----------------閫氱煡绉伴噸涓绘帶--------娴佺▼缁撴潫鍒犻櫎鐧藉悕鍗�"); - List<InoutConf> list = this.getWeightGateway(data.getCompanyId(), data.getDeptId()); - - if (null == list || list.isEmpty()) { - return; - } - - ApiInoutService inoutApiService = apiInoutManager.getApiService(list.get(0).getProtocol()); - - ApiInoutData apiData; - for (InoutConf conf : list) { - apiData = new ApiInoutData(conf); - apiData.setPlateNum(data.getPlateNum()); - - // inoutApiService.delWhitePlate(apiData); TODO - } - } +// public void noticeProgressComplete(InoutData data) { +// log.debug("-----------------閫氱煡绉伴噸涓绘帶--------娴佺▼缁撴潫鍒犻櫎鐧藉悕鍗�"); +// List<InoutConf> list = this.getWeightGateway(data.getCompanyId(), data.getDeptId()); +// +// if (null == list || list.isEmpty()) { +// return; +// } +// +// ApiInoutService inoutApiService = apiInoutManager.getApiService(list.get(0).getProtocol()); +// +// ApiInoutData apiData; +// for (InoutConf conf : list) { +// apiData = new ApiInoutData(conf); +// apiData.setPlateNum(data.getPlateNum()); +// +// // inoutApiService.delWhitePlate(apiData); TODO +// } +// } /** * 璋冪敤鎺ュ彛杩涜鎶撴媿 @@ -362,26 +371,6 @@ return inoutCommonService.getCacheInoutConf(ContextUtil.getCompanyId(), ContextUtil.subDeptId(null), id); } - - /** - * @Desc: 鑾峰彇绉伴噸缃戝叧璁惧 - * @author: Andy - * @update-time: 2022/11/26 - */ - public List<InoutConf> getWeightGateway(String companyId, String deptId) { - List<InoutConf> list = inoutCommonService.getCacheInoutConf(companyId, deptId); - if (null == list || list.isEmpty()) return null; - - List<InoutConf> result = new ArrayList<>(); - - for (InoutConf conf : list) { - if (InoutConstant.CONF_TYPE_70.equals(conf.getType())) { - result.add(conf); - } - } - return result; - } - /** * @Desc: 鑾峰彇绉伴噸缃戝叧璁惧 * @author: Andy @@ -399,6 +388,80 @@ } return null; } + + + /** + * 琚姩鏀跺埌杞︾墝璇嗗埆缁撴灉锛屼簨浠� + * + * @param data + */ + @Async + public void onReceivePlateNum(ApiInoutData data) { + + InoutConf conf = this.getInoutConfBySn(data.getCompanyId(), data.getDeptId(), data.getSn()); + if (null == conf) { + log.error("娌℃湁鑾峰彇鍒板嚭鍏ュ簱閰嶇疆CONF锛�"+data.toString()); + return; + } + log.info(conf.toString()); + if (0 == conf.getInOrder()) return; + + data = new ApiInoutData(conf); + log.info(data.toString()); + ApiInoutService inoutApiService = null; + InoutConf gateconf = null; + //鑾峰彇杞︾墝淇℃伅锛屽紑闂告満 + if (InoutApiConstant.DEVICE_CODE_1002 == data.getDeviceCode()) { + gateconf = this.getWeightGateway(data.getCompanyId(), data.getDeptId(), null); + if (null == gateconf) { + log.info("----------娌℃湁鑾峰彇鍒扮О閲嶆帶鍒跺櫒--------------"); + } + data = new ApiInoutData(gateconf); + //寮�鍏ュ彛澶勯亾闂� + inoutApiService = apiInoutManager.getApiService(gateconf.getProtocol()); + data.setDeviceCode(InoutApiConstant.DEVICE_CODE_2002); + data.setActionCode(InoutApiConstant.ACTION_CODE_1); + inoutApiService.gateControl(data); + } + + if (InoutApiConstant.DEVICE_CODE_1003 == data.getDeviceCode()) { + gateconf = this.getWeightGateway(data.getCompanyId(), data.getDeptId(), null); + if (null == gateconf) { + log.info("----------娌℃湁鑾峰彇鍒扮О閲嶆帶鍒跺櫒--------------"); + } + //寮�鍏ュ彛澶勯亾闂� + data = new ApiInoutData(gateconf); + inoutApiService = apiInoutManager.getApiService(gateconf.getProtocol()); + data.setDeviceCode(InoutApiConstant.DEVICE_CODE_2003); + data.setActionCode(InoutApiConstant.ACTION_CODE_1); + inoutApiService.gateControl(data); + } + + } + + /** + * 鍑哄叆搴撶О閲嶉〉闈㈠垵濮嬪寲锛屽鏋滄湁SDK杞︾墝璇嗗埆锛岄渶瑕佽繘琛屽垵濮嬪寲鎿嶄綔 + * + * @param listInoutConf + * @param sort + */ + @Async + public void initInoutWeight(List<InoutConf> listInoutConf, String sort) { + + //鑾峰彇杞︾墝閰嶇疆淇℃伅 + if (null == listInoutConf) return; + + ApiInoutData apiInoutData; + ApiInoutService inoutApiService; + for (InoutConf conf : listInoutConf) { + if (InoutConstant.PROGRESS_WEIGHT_TAG.equals(conf.getInoutProgress())&&InoutConstant.CONF_TYPE_10.equals(conf.getType()) && sort.equals(conf.getSort())) { + apiInoutData = new ApiInoutData(conf); + inoutApiService = apiInoutManager.getApiService(conf.getProtocol()); + inoutApiService.initLpr(apiInoutData); + } + } + } + /** * 鍑哄叆搴撶櫥璁板畬鎴愯Е鍙戜簨浠讹紝榛樿涓哄紓姝ュ鐞� @@ -430,21 +493,21 @@ //1銆侀�氱煡绉伴噸鏄剧ず灞忥紝璁惧缂栧彿6001 ApiInoutData apiData = new ApiInoutData(conf); apiData.setTime(new Date()); - apiData.setDeviceId(InoutApiConstant.DEVICE_CODE_6001); + apiData.setDeviceCode(InoutApiConstant.DEVICE_CODE_6001); ApiInoutService inoutApiService = apiInoutManager.getApiService(conf.getProtocol()); inoutApiService.noticeLed(apiData, data); //2銆佽闊抽�氱煡 - apiData.setDeviceId(InoutApiConstant.DEVICE_CODE_8001); + apiData.setDeviceCode(InoutApiConstant.DEVICE_CODE_8001); inoutApiService.noticeRadio(apiData, data); //3銆佸紑闂告満 if (InoutConstant.TYPE_IN.equals(data.getType())) { //缁撶畻閲嶉噺澶т簬0琛ㄧず浜屾绉伴噸 if (data.getNetWeight() > 0) { - apiData.setDeviceId(InoutApiConstant.DEVICE_CODE_1002); + apiData.setDeviceCode(InoutApiConstant.DEVICE_CODE_2002); } else { - apiData.setDeviceId(InoutApiConstant.DEVICE_CODE_1003); + apiData.setDeviceCode(InoutApiConstant.DEVICE_CODE_2003); } apiData.setActionCode(InoutApiConstant.ACTION_CODE_1); @@ -452,9 +515,9 @@ } else { //缁撶畻閲嶉噺澶т簬0琛ㄧず浜屾绉伴噸 if (data.getNetWeight() > 0) { - apiData.setDeviceId(InoutApiConstant.DEVICE_CODE_1003); + apiData.setDeviceCode(InoutApiConstant.DEVICE_CODE_2002); } else { - apiData.setDeviceId(InoutApiConstant.DEVICE_CODE_1002); + apiData.setDeviceCode(InoutApiConstant.DEVICE_CODE_2003); } apiData.setActionCode(InoutApiConstant.ACTION_CODE_1); inoutApiService.gateControl(apiData); @@ -464,9 +527,9 @@ if (InoutConstant.TYPE_IN.equals(data.getType())) { //缁撶畻閲嶉噺澶т簬0琛ㄧず浜屾绉伴噸 if (data.getNetWeight() > 0) { - apiData.setDeviceId(InoutApiConstant.DEVICE_CODE_7001); + apiData.setDeviceCode(InoutApiConstant.DEVICE_CODE_7001); } else { - apiData.setDeviceId(InoutApiConstant.DEVICE_CODE_7002); + apiData.setDeviceCode(InoutApiConstant.DEVICE_CODE_7002); } apiData.setActionCode(InoutApiConstant.ACTION_CODE_1); @@ -474,14 +537,14 @@ } else { //缁撶畻閲嶉噺澶т簬0琛ㄧず浜屾绉伴噸 if (data.getNetWeight() > 0) { - apiData.setDeviceId(InoutApiConstant.DEVICE_CODE_7002); + apiData.setDeviceCode(InoutApiConstant.DEVICE_CODE_7002); } else { - apiData.setDeviceId(InoutApiConstant.DEVICE_CODE_7001); + apiData.setDeviceCode(InoutApiConstant.DEVICE_CODE_7001); } apiData.setActionCode(InoutApiConstant.ACTION_CODE_1); inoutApiService.lightControl(apiData); } - + } @@ -671,5 +734,24 @@ return result; } + private InoutConf getInoutConfBySn(String companyId, String deptId, String sn) { + + if (null == sn) return null; + + // 鑾峰彇鍑哄叆搴撻厤缃俊鎭� + List<InoutConf> listInoutConf = inoutCommonService.getCacheInoutConf(companyId, deptId); + + if (null == listInoutConf) return null; + + for (InoutConf conf : listInoutConf) { + + if (null == conf.getSn()) continue; + + if (sn.equals(conf.getSn())) return conf; + } + + return null; + } + } -- Gitblit v1.9.3