From 9c7e5bc10f242b71f3d94e2c700cb7de79feda17 Mon Sep 17 00:00:00 2001 From: yxFwq <1> Date: 星期二, 25 二月 2025 08:45:14 +0800 Subject: [PATCH] * --- src/main/java/com/zy/asrs/controller/OpenController.java | 472 ++++++++++++++++++++++++++++++++++++++++++++++------------ 1 files changed, 371 insertions(+), 101 deletions(-) diff --git a/src/main/java/com/zy/asrs/controller/OpenController.java b/src/main/java/com/zy/asrs/controller/OpenController.java index 925fa41..797ae7d 100644 --- a/src/main/java/com/zy/asrs/controller/OpenController.java +++ b/src/main/java/com/zy/asrs/controller/OpenController.java @@ -1,21 +1,27 @@ package com.zy.asrs.controller; +import com.alibaba.fastjson.JSON; +import com.baomidou.mybatisplus.mapper.EntityWrapper; +import com.core.annotations.AppAuth; import com.core.common.*; import com.core.exception.CoolException; -import com.zy.asrs.entity.DocType; -import com.zy.asrs.entity.Mat; -import com.zy.asrs.entity.Order; -import com.zy.asrs.entity.OrderDetl; -import com.zy.asrs.entity.param.OpenOrderPakinParam; +import com.zy.asrs.entity.BasCrnp; +import com.zy.asrs.entity.BasDevp; +import com.zy.asrs.entity.BasJar; +import com.zy.asrs.entity.RgvOneSign; +import com.zy.asrs.entity.param.*; +import com.zy.asrs.entity.result.LocDetlMesVo; +import com.zy.asrs.entity.vo.JarStateTableVo; import com.zy.asrs.service.*; import com.zy.common.model.DetlDto; +import com.zy.common.model.enums.JarStatusType; +import com.zy.common.web.BaseController; +import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.transaction.annotation.Transactional; -import org.springframework.web.bind.annotation.PostMapping; -import org.springframework.web.bind.annotation.RequestBody; -import org.springframework.web.bind.annotation.RequestMapping; -import org.springframework.web.bind.annotation.RestController; +import org.springframework.web.bind.annotation.*; +import javax.servlet.http.HttpServletRequest; import java.util.ArrayList; import java.util.Date; import java.util.List; @@ -23,29 +29,51 @@ /** * Created by vincent on 2022/4/8 */ +@Slf4j @RestController @RequestMapping("open/asrs") -public class OpenController { +public class OpenController extends BaseController { + + private static final boolean auth = true; + public static final ArrayList<String> APP_KEY_LIST = new ArrayList<String>() {{ + add("ea1f0459efc02a79f046f982767939ae"); + }}; @Autowired - private OrderService orderService; + private OpenService openService; @Autowired - private OrderDetlService orderDetlService; + private BasDevpService basDevpService; @Autowired - private SnowflakeIdWorker snowflakeIdWorker; + private BasCrnpService basCrnpService; @Autowired - private DocTypeService docTypeService; - @Autowired - private MatService matService; + private BasJarService basJarService; @Autowired private LocDetlService locDetlService; + @Autowired + private RgvOneSignService rgvOneSignService; + + @PostMapping("/order/matSync/default/v1") + @AppAuth(memo = "鍟嗗搧淇℃伅鍚屾鎺ュ彛") + public synchronized R syncMatInfo(@RequestHeader(required = false) String appkey, + @RequestBody(required = false) MatSyncParam param, + HttpServletRequest request){ + auth(appkey, param, request); + if (Cools.isEmpty(param)) { + return R.parse(BaseRes.PARAM); + } + openService.syncMat(param); + return R.ok(); + } /** * 娣诲姞鍏ュ簱鍗� */ - @PostMapping("/order/pakin/default/v1") - @Transactional - public synchronized R orderCreate(@RequestBody OpenOrderPakinParam param) { + /*@PostMapping("/order/pakin/default/v1") + @AppAuth(memo = "娣诲姞璁㈠崟鍏ュ簱") + public synchronized R pakinOrderCreate(@RequestHeader(required = false) String appkey, + @RequestBody OpenOrderPakinParam param, + HttpServletRequest request) { + auth(appkey, param, request); if (Cools.isEmpty(param)) { return R.parse(BaseRes.PARAM); } @@ -58,94 +86,336 @@ if (Cools.isEmpty(param.getOrderDetails())) { return R.error("鍗曟嵁鏄庣粏[orderDetails]涓嶈兘涓虹┖"); } - Order order = orderService.selectByNo(param.getOrderNo()); - if (!Cools.isEmpty(order)) { - return R.error(param.getOrderNo() + "鍗曟嵁宸插瓨鍦紝璇峰嬁閲嶅鎻愪氦"); - } - DocType docType = docTypeService.selectOrAdd(param.getOrderType()); - Date now = new Date(); - // 鍗曟嵁涓绘。 - order = new Order( - String.valueOf(snowflakeIdWorker.nextId()), // 缂栧彿[闈炵┖] - param.getOrderNo(), // 璁㈠崟缂栧彿 - DateUtils.convert(now), // 鍗曟嵁鏃ユ湡 - docType.getDocId(), // 鍗曟嵁绫诲瀷 - null, // 椤圭洰缂栧彿 - null, // - null, // 璋冩嫧椤圭洰缂栧彿 - null, // 鍒濆绁ㄦ嵁鍙� - null, // 绁ㄦ嵁鍙� - null, // 瀹㈡埛缂栧彿 - null, // 瀹㈡埛 - null, // 鑱旂郴鏂瑰紡 - null, // 鎿嶄綔浜哄憳 - null, // 鍚堣閲戦 - null, // 浼樻儬鐜� - null, // 浼樻儬閲戦 - null, // 閿�鍞垨閲囪喘璐圭敤鍚堣 - null, // 瀹炰粯閲戦 - null, // 浠樻绫诲瀷 - null, // 涓氬姟鍛� - null, // 缁撶畻澶╂暟 - null, // 閭垂鏀粯绫诲瀷 - null, // 閭垂 - null, // 浠樻鏃堕棿 - null, // 鍙戣揣鏃堕棿 - null, // 鐗╂祦鍚嶇О - null, // 鐗╂祦鍗曞彿 - 1L, // 璁㈠崟鐘舵�� - 1, // 鐘舵�� - 9527L, // 娣诲姞浜哄憳 - now, // 娣诲姞鏃堕棿 - 9527L, // 淇敼浜哄憳 - now, // 淇敼鏃堕棿 - null // 澶囨敞 - ); - if (!orderService.insert(order)) { - throw new CoolException("鐢熸垚鍗曟嵁涓绘。澶辫触锛岃鑱旂郴绠$悊鍛�"); - } - // 鍗曟嵁鏄庣粏妗� - List<DetlDto> list = new ArrayList<>(); - List<DetlDto> orderDetails = param.getOrderDetails(); - for (DetlDto detail : orderDetails) { - DetlDto dto = new DetlDto(detail.getMatnr(), detail.getBatch(), detail.getAnfme()); - if (DetlDto.has(list, dto)) { - DetlDto detlDto = DetlDto.find(list, dto.getMatnr(), dto.getBatch()); - assert detlDto != null; - detlDto.setAnfme(detlDto.getAnfme() + detail.getAnfme()); - } else { - list.add(dto); - } - } - for (DetlDto detlDto : list) { - Mat mat = matService.selectByMatnr(detlDto.getMatnr()); - if (Cools.isEmpty(mat)) { - throw new CoolException(detlDto.getMatnr() + "缂栧彿鍟嗗搧妫�绱㈠け璐ワ紝璇峰厛娣诲姞鍟嗗搧"); - } - OrderDetl orderDetl = new OrderDetl(); - orderDetl.sync(mat); - orderDetl.setOrderId(order.getId()); - orderDetl.setOrderNo(order.getOrderNo()); - orderDetl.setCreateBy(9527L); - orderDetl.setCreateTime(now); - orderDetl.setUpdateBy(9527L); - orderDetl.setUpdateTime(now); - orderDetl.setStatus(1); - orderDetl.setQty(0.0D); - if (!orderDetlService.insert(orderDetl)) { - throw new CoolException("鐢熸垚鍗曟嵁鏄庣粏澶辫触锛岃鑱旂郴绠$悊鍛�"); - } - } + openService.pakinOrderCreate(param); return R.ok(); - } + }*/ + + /** + * 鍏ュ簱鍗曞洖鍐� + */ + /*@PostMapping("/order/pakin/complete/default/v1") + public synchronized R orderPakinComplete(@RequestHeader(required = false) String appkey, + @RequestBody(required = false) OpenOrderCompleteParam param, + HttpServletRequest request) { + auth(appkey, param, request); + return R.ok().add(openService.pakinOrderComplete(param)); + }*/ + + /** + * 娣诲姞鍑哄簱鍗� + */ + /*@PostMapping("/order/pakout/default/v1") + @AppAuth(memo = "娣诲姞璁㈠崟鍑哄簱") + public synchronized R pakoutOrderCreate(@RequestHeader(required = false) String appkey, + @RequestBody OpenOrderPakoutParam param, + HttpServletRequest request) { + auth(appkey, param, request); + if (Cools.isEmpty(param)) { + return R.parse(BaseRes.PARAM); + } + if (Cools.isEmpty(param.getLgort())) { + return R.error("鍗曟嵁缂栧彿[lgort]涓嶈兘涓虹┖"); + } + if (!param.getLgort().equals("5006")) { + return R.ok(); + } + if (Cools.isEmpty(param.getOrderNo())) { + return R.error("鍗曟嵁缂栧彿[orderNo]涓嶈兘涓虹┖"); + } + if (Cools.isEmpty(param.getOrderType())) { + return R.error("鍗曟嵁绫诲瀷[orderType]涓嶈兘涓虹┖"); + } + if (Cools.isEmpty(param.getOrderDetails())) { + return R.error("鍗曟嵁鏄庣粏[orderDetails]涓嶈兘涓虹┖"); + } + openService.pakoutOrderCreate(param); + return R.ok(); + }*/ + + /** + * 鍑哄簱鍗曞洖鍐� + */ + /*@PostMapping("/order/pakout/complete/default/v1") + public synchronized R orderPakoutComplete(@RequestHeader(required = false) String appkey, + @RequestBody(required = false) OpenOrderCompleteParam param, + HttpServletRequest request) { + auth(appkey, param, request); + return R.ok().add(openService.pakoutOrderComplete(param)); + }*/ /** * 搴撳瓨缁熻 */ - @RequestMapping("/stock/default/v1") - public R queryStock() { - return R.ok(locDetlService.queryStockTotal()); + /*@RequestMapping("/stock/default/v1") + public R queryStock(@RequestHeader(required = false) String appkey, + HttpServletRequest request) { + auth(appkey, null, request); + return R.ok().add(openService.queryStock()); + }*/ + + private void auth(String appkey, Object obj, HttpServletRequest request) { + log.info("{}鎺ュ彛琚闂紱appkey:{}锛涜姹傛暟鎹細{}", "open/sensorType/list/auth/v1", appkey, JSON.toJSONString(obj)); + request.setAttribute("cache", obj); + if (!auth) { + return; + } + if (Cools.isEmpty(appkey)) { + throw new CoolException("璁よ瘉澶辫触锛岃纭appkey鏃犺锛�"); + } + if (!APP_KEY_LIST.contains(appkey)) { + throw new CoolException("璁よ瘉澶辫触锛岃纭appkey鏃犺锛�"); + } } + /*public static void main(String[] args) { + // 1 + System.out.println("======================================"); + OpenOrderPakinParam param = new OpenOrderPakinParam(); + param.setOrderNo(String.valueOf(new SnowflakeIdWorker().nextId())); + param.setOrderType("鎵撳寘涓婄嚎鍗�"); + param.setOrderTime(DateUtils.convert(new Date())); + List<DetlDto> orderDetails = new ArrayList<>(); + param.setOrderDetails(orderDetails); + for (int i = 0; i < 3; i++) { + DetlDto detlDto = new DetlDto(); + switch (i) { + case 0: + detlDto.setMatnr("MDH020030530"); + detlDto.setBatch("500"); + detlDto.setAnfme(18.0); + break; + case 1: + detlDto.setMatnr("MDH020016416"); + detlDto.setBatch("500"); + detlDto.setAnfme(32.0); + break; + case 2: + detlDto.setMatnr("LSH90152025"); + detlDto.setAnfme(50.0); + break; + default: + break; + } + orderDetails.add(detlDto); + } + System.out.println(JSON.toJSONString(param)); + // 2 + System.out.println("======================================"); + OpenOrderCompleteParam param1 = new OpenOrderCompleteParam(); + param1.setOrderNo("963001846497017856"); + System.out.println(JSON.toJSONString(param1)); + }*/ + + + + /*...........................寰愬伐姹変簯..............浠ヤ笅.............涓婇ザ姹熼摐...........................*/ + /*............................Created by Monkey D. Luffy on 2023.07.19.............................*/ + + /** + * 璐存爣鏈虹敵璇疯幏鍙栬揣鐗╀俊鎭� + */ + @PostMapping("/labeller/mat/auth/v1") + @AppAuth(memo = "璐存爣鏈虹敵璇疯幏鍙栬揣鐗╀俊鎭�") //old闇�瑕佷慨鏀� + public synchronized R labellerMat(@RequestHeader(required = false) String appkey, + @RequestBody LabellerMatParam param, + HttpServletRequest request) { + auth(appkey, param, request); + return R.ok(openService.labellerMat(param)); + } + + /** + * 璐存爣鏈鸿创鏍囧畬鎴� + */ + @PostMapping("/labeller/complete/auth/v1") + @AppAuth(memo = "璐存爣鏈鸿创鏍囧畬鎴�") //old闇�瑕佷慨鏀� + public synchronized R labellerComplete(@RequestHeader(required = false) String appkey, + @RequestBody LabellerCompleteParam param, + HttpServletRequest request) { + auth(appkey, param, request); + openService.labellerComplete(param); + return R.ok(); + } + +// /** +// * 涓帶(2妤�)锛氱爜鍨涘畬鎴愪笅鍙戝叆搴撲俊鎭� +// */ +// @PostMapping("/palletizing/complete/auth/v1") +// @AppAuth(memo = "涓帶(2妤�)锛氱爜鍨涘畬鎴愪笅鍙戝叆搴撲俊鎭�") +// public synchronized R PalletizingCompleteTwoFloorParam(@RequestHeader(required = false) String appkey, +// @RequestBody PalletizingCompleteTwoFloorParam param, +// HttpServletRequest request) { +// auth(appkey, param, request); +// openService.PalletizingCompleteTwoFloorParam(param); +// return R.ok(param); +// } + + /** + * 鏉剧洓(1妤�)锛氱爜鍨涘畬鎴愪笅鍙戝叆搴撲俊鎭� + */ + @PostMapping("/palletizing/complete/auth/v2") + @AppAuth(memo = "鏉剧洓(1妤�)锛氱爜鍨涘畬鎴愪笅鍙戠‘璁や俊鍙�") + public synchronized R palletizingCompleteS(@RequestHeader(required = false) String appkey, + @RequestBody PalletizingCompleteParam param, + HttpServletRequest request) { + auth(appkey, param, request); + openService.palletizingCompleteS(param); + return R.ok(); + } + + /** + * 涓帶锛氬嚭搴撳畬鎴愭湀鍙扮浉鍏� + */ + @PostMapping("/balcony/complete/auth/v1") + @AppAuth(memo = "涓帶锛氬嚭搴撳畬鎴愭湀鍙扮浉鍏�") //old闇�瑕佷慨鏀� + public synchronized R balconyComplete(@RequestHeader(required = false) String appkey, + @RequestBody LabellerMatParam param, + HttpServletRequest request) { + auth(appkey, param, request); + openService.balconyComplete(param); + return R.ok(param); + } + + + /** + * 妗佹灦涓婁綅杞欢锛氬崟娆℃媶鍨涘畬鎴愰�氱煡 + */ + @PostMapping("/single/unstacking/complete/auth/v1") + @AppAuth(memo = "妗佹灦涓婁綅杞欢锛氬崟娆℃媶鍨涘畬鎴愰�氱煡") + public synchronized R singleUnstackingComplete(@RequestHeader(required = false) String appkey, + @RequestBody SingleUnstackingCompleteParam param, + HttpServletRequest request) { + auth(appkey, param, request); + openService.singleUnstackingComplete(param); + return R.ok(param); + } + + /** + * 妗佹灦涓婁綅杞欢锛氬崟鎵樻媶鍨涘畬鎴愰�氱煡 + */ + @PostMapping("/single/mount/unstacking/complete/auth/v1") + @AppAuth(memo = "妗佹灦涓婁綅杞欢锛氬崟鎵樻媶鍨涘畬鎴愰�氱煡") + public synchronized R singleMountUnstackingComplete(@RequestHeader(required = false) String appkey, + @RequestBody SingleMountUnstackingCompleteParam param, + HttpServletRequest request) { + auth(appkey, param, request); + openService.singleMountUnstackingComplete(param); + return R.ok(param); + } + + /*...........................涓婇ザ姹熼摐..............浠ヤ笂.............寰愬伐姹変簯...........................*/ + /*...........................浜冲窞鐓滄槦..............浠ヤ笂.............浜冲窞鐓滄槦...........................*/ + + /** + * 浜冲窞鐓滄槦浠诲姟涓嬪彂 // 灏忔枡绠辨姇鏂欏畬鎴愮粍鎵� + */ + @PostMapping("/small/containers/auth/v1") + @AppAuth(memo = "MES浠诲姟涓嬪彂") + public synchronized R smallContainers(@RequestHeader(required = false) String appkey, + @RequestBody SmallCompleteParam param, + HttpServletRequest request) { + auth(appkey, param, request); + openService.smallContainers(param); + return R.ok().add("鎴愬姛"); + } +// +// /** +// * 浜冲窞鐓滄槦浠诲姟涓嬪彂 +// */ +// @PostMapping("/small/containers/auth/v1") +// @AppAuth(memo = "璐存爣鏈鸿创鏍囧畬鎴�") //old闇�瑕佷慨鏀� +// public synchronized R smallContainers(@RequestHeader(required = false) String appkey, +// @RequestBody LabellerCompleteParam param, +// HttpServletRequest request) { +// auth(appkey, param, request); +// openService.labellerComplete(param); +// return R.ok(); +// } +// +// /** +// * 浜冲窞鐓滄槦浠诲姟涓嬪彂 +// */ +// @PostMapping("/small/containers/auth/v1") +// @AppAuth(memo = "璐存爣鏈鸿创鏍囧畬鎴�") //old闇�瑕佷慨鏀� +// public synchronized R smallContainers(@RequestHeader(required = false) String appkey, +// @RequestBody LabellerCompleteParam param, +// HttpServletRequest request) { +// auth(appkey, param, request); +// openService.labellerComplete(param); +// return R.ok(); +// } + + //璁惧鐘舵�佹煡璇㈡帴鍙� + @PostMapping("/deviceStatus") + @AppAuth(memo = "璁惧鐘舵�佹煡璇㈡帴鍙�") + @Transactional + public R deviceStatus(@RequestHeader String appkey, + HttpServletRequest request) { + auth(appkey, "璁惧鐘舵�佹煡璇㈡帴鍙�", request); + List<BasDevp> basDevps = basDevpService.selectList(new EntityWrapper<>()); + List<Object> list = new ArrayList<>(); + for (BasDevp basDevp:basDevps){ + list.add(basDevp); + } + List<BasCrnp> basCrnps = basCrnpService.selectList(new EntityWrapper<>()); + for (BasCrnp basCrnp:basCrnps){ + list.add(basCrnp); + } + return R.ok(list); + } + + //璁惧鐘舵�佹煡璇㈡帴鍙� + @PostMapping("/jarStatus") + @AppAuth(memo = "纭寲缃愮姸鎬佹煡璇㈡帴鍙�") + @Transactional + public R jarStatus(@RequestHeader String appkey, + HttpServletRequest request) { + auth(appkey, "纭寲缃愮姸鎬佹煡璇㈡帴鍙�", request); + List<JarStateTableVo> list = new ArrayList<>(); + List<BasJar> jars = basJarService.selectList(new EntityWrapper<BasJar>().orderBy("jar_no")); + for (BasJar basJar : jars) { + // 琛ㄦ牸琛� + JarStateTableVo vo = new JarStateTableVo(); + vo.setJarNo(basJar.getJarNo()); // JAR鍙� + list.add(vo); + + vo.setJarMode(basJar.getJarMode$()); // 妯″紡鐘舵�� + vo.setJarStatus(JarStatusType.get(basJar.getJarStatus()).desc); // 鐘舵�� + vo.setJarNo(basJar.getJarNo()); // 宸ヤ綅1浠诲姟鍙� + vo.setRegion(basJar.getRegion()); + vo.setJarCode(basJar.getJarCode()); + vo.setJarErr(basJar.getJarErr$()); + vo.setJarMastTableVoList(openService.getJatIdList(vo.getJarNo())); + } + return R.ok().add(list); + } + + //璁惧鐘舵�佹煡璇㈡帴鍙� + @PostMapping("/mesLocStatus") + @AppAuth(memo = "搴撳瓨淇℃伅鏌ヨ鎺ュ彛") + @Transactional + public R mesLocStatus(@RequestHeader String appkey, + HttpServletRequest request) { + auth(appkey, "搴撳瓨淇℃伅鏌ヨ鎺ュ彛", request); + List<LocDetlMesVo> list = locDetlService.selectLocDetlMesAll(); + return R.ok().add(list); + } + + @PostMapping("/overturn/empty") + @AppAuth(memo = "缈昏浆鍚庡厑璁稿洖搴撴帴鍙�") + @Transactional + public R mesOverturnEmpty(@RequestHeader String appkey, + @RequestParam Integer devNo, + HttpServletRequest request) { + auth(appkey, "绔欑偣鍙�"+devNo, request); + RgvOneSign sign = rgvOneSignService.selectOne(new EntityWrapper<RgvOneSign>().eq("rgv_one_type","sign"+devNo)); + if (Cools.isEmpty(sign)) { + return R.error().add("缈昏浆绔欎俊鎭湁璇�"); + } + sign.setRgvOneSign(1); + rgvOneSignService.updateById(sign); + return R.ok(); + } + /*...........................浜冲窞鐓滄槦..............浠ヤ笂.............浜冲窞鐓滄槦...........................*/ + } -- Gitblit v1.9.1