|  |  | 
 |  |  | package com.zy.asrs.controller; | 
 |  |  |  | 
 |  |  | import com.alibaba.fastjson.JSON; | 
 |  |  | import com.core.common.*; | 
 |  |  | import com.alibaba.fastjson.JSONObject; | 
 |  |  | import com.core.annotations.AppAuth; | 
 |  |  | import com.core.common.BaseRes; | 
 |  |  | import com.core.common.Cools; | 
 |  |  | import com.core.common.R; | 
 |  |  | import com.core.exception.CoolException; | 
 |  |  | import com.zy.asrs.entity.param.OpenOrderCompleteParam; | 
 |  |  | import com.zy.asrs.entity.param.OpenOrderPakinParam; | 
 |  |  | import com.zy.asrs.entity.param.OpenOrderPakoutParam; | 
 |  |  | import com.zy.asrs.service.ApiLogService; | 
 |  |  | import com.zy.asrs.entity.param.*; | 
 |  |  | import com.zy.asrs.service.OpenService; | 
 |  |  | import com.zy.common.model.DetlDto; | 
 |  |  | import com.zy.common.utils.IpTools; | 
 |  |  | import com.zy.common.web.BaseController; | 
 |  |  | import lombok.extern.slf4j.Slf4j; | 
 |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
 |  |  | 
 |  |  |  | 
 |  |  | import javax.servlet.http.HttpServletRequest; | 
 |  |  | import java.util.ArrayList; | 
 |  |  | import java.util.Date; | 
 |  |  | import java.util.List; | 
 |  |  | import java.util.Map; | 
 |  |  |  | 
 |  |  | /** | 
 |  |  |  * Created by vincent on 2022/4/8 | 
 |  |  | 
 |  |  |  | 
 |  |  |     @Autowired | 
 |  |  |     private OpenService openService; | 
 |  |  |     @Autowired | 
 |  |  |     private ApiLogService apiLogService; | 
 |  |  |  | 
 |  |  |  | 
 |  |  |  | 
 |  |  | 
 |  |  |  | 
 |  |  |  | 
 |  |  |     @PostMapping("/order/pakin/new/package/v1") | 
 |  |  |     @AppAuth(memo = "打包上线接口") | 
 |  |  |     public synchronized R pakinOrderPackage(@RequestHeader(required = false) String appkey, | 
 |  |  |                                             @RequestParam(required = false) String barcode, | 
 |  |  |                                             @RequestBody(required = false) PackParam param, | 
 |  |  |                                             HttpServletRequest request) { | 
 |  |  |         auth(appkey, barcode); | 
 |  |  |         if (Cools.isEmpty(barcode)) { | 
 |  |  |         auth(appkey, param, request); | 
 |  |  |         if (Cools.isEmpty(param)) { | 
 |  |  |             return R.parse(BaseRes.PARAM); | 
 |  |  |         } | 
 |  |  |         openService.packageUp(barcode); | 
 |  |  |         // 保存接口日志 | 
 |  |  |         apiLogService.save( | 
 |  |  |                 "打包上线接口", | 
 |  |  |                 request.getRequestURI(), | 
 |  |  |                 appkey, | 
 |  |  |                 IpTools.gainRealIp(request), | 
 |  |  |                 barcode, | 
 |  |  |                 JSON.toJSONString(R.ok()), | 
 |  |  |                 Boolean.TRUE | 
 |  |  |         ); | 
 |  |  |         openService.packageUp(param); | 
 |  |  |         return R.ok(); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  | 
 |  |  |      */ | 
 |  |  |     @PostMapping("/order/pakin/new/default/v1") | 
 |  |  |     public synchronized R pakinOrderCreate(@RequestHeader(required = false) String appkey, | 
 |  |  |                                            @RequestBody OpenOrderPakinParam param) { | 
 |  |  |         auth(appkey, param); | 
 |  |  |                                            @RequestBody OpenOrderPakinParam param, | 
 |  |  |                                            HttpServletRequest request) { | 
 |  |  |         auth(appkey, param, request); | 
 |  |  |         if (Cools.isEmpty(param)) { | 
 |  |  |             return R.parse(BaseRes.PARAM); | 
 |  |  |         } | 
 |  |  | 
 |  |  |      */ | 
 |  |  |     @PostMapping("/order/pakin/complete/default/v1") | 
 |  |  |     public synchronized R orderPakinComplete(@RequestHeader(required = false) String appkey, | 
 |  |  |                                         @RequestBody(required = false) OpenOrderCompleteParam param) { | 
 |  |  |         auth(appkey, param); | 
 |  |  |                                              @RequestBody(required = false) OpenOrderCompleteParam param, | 
 |  |  |                                              HttpServletRequest request) { | 
 |  |  |         auth(appkey, param, request); | 
 |  |  |         return R.ok().add(openService.pakinOrderComplete(param)); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  | 
 |  |  |      * 添加出库单 | 
 |  |  |      */ | 
 |  |  |     @PostMapping("/order/pakout/new/default/v1") | 
 |  |  |     @AppAuth(memo = "添加订单出库") | 
 |  |  |     public synchronized R pakoutOrderCreate(@RequestHeader(required = false) String appkey, | 
 |  |  |                                            @RequestBody OpenOrderPakoutParam param) { | 
 |  |  |         auth(appkey, param); | 
 |  |  |                                             @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]不能为空"); | 
 |  |  | 
 |  |  |      */ | 
 |  |  |     @PostMapping("/order/pakout/complete/default/v1") | 
 |  |  |     public synchronized R orderPakoutComplete(@RequestHeader(required = false) String appkey, | 
 |  |  |                                         @RequestBody(required = false) OpenOrderCompleteParam param) { | 
 |  |  |         auth(appkey, param); | 
 |  |  |                                               @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(@RequestHeader(required = false) String appkey) { | 
 |  |  |         auth(appkey, null); | 
 |  |  |     public R queryStock(@RequestHeader(required = false) String appkey, | 
 |  |  |                         HttpServletRequest request) { | 
 |  |  |         auth(appkey, null, request); | 
 |  |  |         return R.ok().add(openService.queryStock()); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 商品信息同步接口 | 
 |  |  |      */ | 
 |  |  |     @PostMapping("/mat/v1") | 
 |  |  |     public synchronized R syncMatInfoErp(@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); | 
 |  |  |         } | 
 |  |  |         MatSyncParam matSyncParam = openService.syncMat(param); | 
 |  |  |         if (Cools.isEmpty(matSyncParam.getMats()) || matSyncParam.getMats().size() <=0 ) { | 
 |  |  |             return R.error("数据异常"); | 
 |  |  |         } | 
 |  |  |         StringBuilder Msg= new StringBuilder("原因:"); | 
 |  |  |         int MsgT=0,MsgF=0; | 
 |  |  |         for (MatSyncParam.Mats matParam:matSyncParam.getMats()){ | 
 |  |  |             if (matParam.isType()){ | 
 |  |  |                 MsgT++; | 
 |  |  |             }else { | 
 |  |  |                 MsgF++; | 
 |  |  |                 Msg.append(matParam.getMatnr()).append(":").append(matParam.getMemo()).append(";"); | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |         if (MsgF==0){ | 
 |  |  |             return R.ok("成功接收物料:"+MsgT+"个"); | 
 |  |  |         }else if (MsgT==0){ | 
 |  |  |             return R.ok("接收物料失败:"+MsgF+"个;"+Msg); | 
 |  |  |         }else { | 
 |  |  |             return R.ok("成功接收物料:"+MsgT+"个;"+"接收物料失败:"+MsgF+"个;"+Msg); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |     private void auth(String appkey, Object obj) { | 
 |  |  |         log.info("{}接口被访问!appkey:{},请求数据:{}", "open/sensorType/list/auth/v1", appkey, JSON.toJSONString(obj)); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 入库通知档生成 | 
 |  |  |      */ | 
 |  |  |     @PostMapping("/comb/v1") | 
 |  |  |     public synchronized R combMES(@RequestHeader(required = false) String appkey, | 
 |  |  |                                       @RequestBody(required = false) CombParam param, | 
 |  |  |                                       HttpServletRequest request){ | 
 |  |  |         auth(appkey, param, request); | 
 |  |  |         if (Cools.isEmpty(param)) { | 
 |  |  |             return R.parse(BaseRes.PARAM); | 
 |  |  |         } | 
 |  |  |         openService.combMes(param); | 
 |  |  |         return R.ok("组托成功"); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 入库记录获取 | 
 |  |  |      */ | 
 |  |  |     @PostMapping("/inlog/v1") | 
 |  |  |     public synchronized R inlogERP(@RequestHeader(required = false) String appkey, | 
 |  |  |                                   HttpServletRequest request){ | 
 |  |  |         auth(appkey,null, request); | 
 |  |  |         if (Cools.isEmpty()) { | 
 |  |  |             return R.parse(BaseRes.PARAM); | 
 |  |  |         } | 
 |  |  |         return R.ok().add(openService.inlogERP()); | 
 |  |  |     } | 
 |  |  |     /** | 
 |  |  |      * 出库记录获取 | 
 |  |  |      */ | 
 |  |  |     @PostMapping("/outlog/v1") | 
 |  |  |     public synchronized R outlogERP(@RequestHeader(required = false) String appkey, | 
 |  |  |                                    HttpServletRequest request){ | 
 |  |  |         auth(appkey,null, request); | 
 |  |  |         if (Cools.isEmpty()) { | 
 |  |  |             return R.parse(BaseRes.PARAM); | 
 |  |  |         } | 
 |  |  |         return R.ok().add(openService.outlogERP()); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |  | 
 |  |  |     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; | 
 |  |  |         } | 
 |  |  | 
 |  |  |         } | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     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); | 
 |  |  |     @PostMapping("/order/matSync/default/v1") | 
 |  |  |     public synchronized R syncMatInfoU8(@RequestHeader(required = false) String appkey, | 
 |  |  |                                          @RequestBody(required = false) Map<String, Object> param, | 
 |  |  |                                          HttpServletRequest request){ | 
 |  |  |         auth(appkey, param, request); | 
 |  |  |         if (Cools.isEmpty(param)) { | 
 |  |  |             return R.parse(BaseRes.PARAM); | 
 |  |  |         } | 
 |  |  |         System.out.println(JSON.toJSONString(param)); | 
 |  |  |         // 2 | 
 |  |  |         System.out.println("======================================"); | 
 |  |  |         OpenOrderCompleteParam param1 = new OpenOrderCompleteParam(); | 
 |  |  |         param1.setOrderNo("963001846497017856"); | 
 |  |  |         System.out.println(JSON.toJSONString(param1)); | 
 |  |  |  | 
 |  |  |         int msgU = 0; | 
 |  |  |         int msgT = 0; | 
 |  |  |         int msgF = 0; | 
 |  |  |         StringBuilder msg= new StringBuilder("原因:"); | 
 |  |  |  | 
 |  |  |         List<MatInfoParam> matDetails = (List<MatInfoParam>) param.get("matDetails"); | 
 |  |  |  | 
 |  |  |         for (Object matDetail : matDetails){ | 
 |  |  |             MatInfoParam matInfoParam = JSONObject.parseObject(JSON.toJSONString(matDetail),MatInfoParam.class); | 
 |  |  |             if (Cools.isEmpty(matDetails)) { | 
 |  |  |                 msgF++; | 
 |  |  |                 continue; | 
 |  |  |             } | 
 |  |  |             openService.syncMat(matInfoParam); | 
 |  |  |             if(matInfoParam.isUpdate()){ | 
 |  |  |                 msgU++; | 
 |  |  |             }else if(matInfoParam.isInsert()){ | 
 |  |  |                 msgT++; | 
 |  |  |             } else if(matInfoParam.isError()){ | 
 |  |  |                 msgF++; | 
 |  |  |                 msg.append(matInfoParam.getCinvcode()).append(":").append(matInfoParam.getMemo()).append(";"); | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |         String message = ""; | 
 |  |  |         boolean success = false; | 
 |  |  |         if(msgT != 0){ | 
 |  |  |             message += "成功接收物料:"+msgT+"个"; | 
 |  |  |             success = true; | 
 |  |  |         } | 
 |  |  |         if(msgU != 0){ | 
 |  |  |             message += "成功修改物料:"+msgU+"个"; | 
 |  |  |             success = true; | 
 |  |  |         } | 
 |  |  |         if(msgF != 0){ | 
 |  |  |             message += "接收物料失败:"+msgF+"个;"+msg; | 
 |  |  |         } | 
 |  |  |         if(success){ | 
 |  |  |             return R.ok(message); | 
 |  |  |         }else { | 
 |  |  |             return R.error(message); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  | //        if (MsgF==0){ | 
 |  |  | //            return R.ok("成功接收物料:"+MsgT+"个"); | 
 |  |  | //        }else if (MsgT==0){ | 
 |  |  | //            return R.error("接收物料失败:"+MsgF+"个;"+Msg); | 
 |  |  | //        }else { | 
 |  |  | //            return R.ok("成功接收物料:"+MsgT+"个;"+"接收物料失败:"+MsgF+"个;"+Msg); | 
 |  |  | //        } | 
 |  |  |  | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     @PostMapping("/order/pakin/default/v1") | 
 |  |  |     @AppAuth(memo = "生成入库单据") | 
 |  |  |     public synchronized R orderPakin(@RequestHeader(required = false) String appkey, | 
 |  |  |                                         @RequestBody(required = false) Map<String, Object> param, | 
 |  |  |                                         HttpServletRequest request){ | 
 |  |  |         auth(appkey, param, request); | 
 |  |  |         if (Cools.isEmpty(param)) { | 
 |  |  |             return R.parse(BaseRes.PARAM); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         openService.syncOrder(param,true); | 
 |  |  |  | 
 |  |  |         return R.ok("入库单据接受成功"); | 
 |  |  |  | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     @PostMapping("/order/pakout/default/v1") | 
 |  |  |     @AppAuth(memo = "生成出库单据") | 
 |  |  |     public synchronized R orderPakout(@RequestHeader(required = false) String appkey, | 
 |  |  |                                      @RequestBody(required = false) Map<String, Object> param, | 
 |  |  |                                      HttpServletRequest request){ | 
 |  |  |  | 
 |  |  |         auth(appkey, param, request); | 
 |  |  |         if (Cools.isEmpty(param)) { | 
 |  |  |             return R.parse(BaseRes.PARAM); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         openService.syncOrder(param,false); | 
 |  |  |  | 
 |  |  |         return R.ok("出库单据接受成功"); | 
 |  |  |  | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     @PostMapping("/order/delete/default/v1") | 
 |  |  |     @AppAuth(memo = "单据删除审核") | 
 |  |  |     public synchronized R orderDelete(@RequestHeader(required = false) String appkey, | 
 |  |  |                                       @RequestBody(required = false) Map<String, Object> param, | 
 |  |  |                                       HttpServletRequest request){ | 
 |  |  |         auth(appkey, param, request); | 
 |  |  |         if (Cools.isEmpty(param)) { | 
 |  |  |             return R.parse(BaseRes.PARAM); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         boolean success = openService.orderDelete(param.get("id").toString()); | 
 |  |  |  | 
 |  |  |         if(success){ | 
 |  |  |             return R.ok("单据删除成功"); | 
 |  |  |         }else { | 
 |  |  |             return R.error("单据正在执行,删除失败"); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |     } | 
 |  |  |  | 
 |  |  | } |